- Timestamp:
- 05/15/2019 11:44:37 PM (5 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/js/_enqueues/vendor/tinymce/plugins/lists/plugin.js
r44713 r45316 1 1 (function () { 2 var lists = (function ( ) {2 var lists = (function (domGlobals) { 3 3 'use strict'; 4 4 … … 210 210 }; 211 211 }; 212 function curry(fn) {213 var initialArgs = [];214 for (var _i = 1; _i < arguments.length; _i++) {215 initialArgs[_i - 1] = arguments[_i];216 }217 return function () {218 var restArgs = [];219 for (var _i = 0; _i < arguments.length; _i++) {220 restArgs[_i] = arguments[_i];221 }222 var all = initialArgs.concat(restArgs);223 return fn.apply(null, all);224 };225 }226 212 var not = function (f) { 227 213 return function () { … … 245 231 return o.isNone(); 246 232 }; 247 var call $$1= function (thunk) {233 var call = function (thunk) { 248 234 return thunk(); 249 235 }; … … 251 237 return n; 252 238 }; 253 var noop $$1= function () {239 var noop = function () { 254 240 }; 255 241 var nul = function () { … … 267 253 isNone: always$1, 268 254 getOr: id, 269 getOrThunk: call $$1,255 getOrThunk: call, 270 256 getOrDie: function (msg) { 271 257 throw new Error(msg || 'error: getOrDie called on none.'); … … 274 260 getOrUndefined: undef, 275 261 or: id, 276 orThunk: call $$1,262 orThunk: call, 277 263 map: none, 278 264 ap: none, 279 each: noop $$1,265 each: noop, 280 266 bind: none, 281 267 flatten: none, … … 478 464 }; 479 465 480 var Global = typeof window !== 'undefined' ?window : Function('return this;')();466 var Global = typeof domGlobals.window !== 'undefined' ? domGlobals.window : Function('return this;')(); 481 467 482 468 var path = function (parts, scope) { … … 590 576 }; 591 577 578 var fromHtml = function (html, scope) { 579 var doc = scope || domGlobals.document; 580 var div = doc.createElement('div'); 581 div.innerHTML = html; 582 if (!div.hasChildNodes() || div.childNodes.length > 1) { 583 domGlobals.console.error('HTML does not have a single root node', html); 584 throw new Error('HTML must have a single root node'); 585 } 586 return fromDom(div.childNodes[0]); 587 }; 588 var fromTag = function (tag, scope) { 589 var doc = scope || domGlobals.document; 590 var node = doc.createElement(tag); 591 return fromDom(node); 592 }; 593 var fromText = function (text, scope) { 594 var doc = scope || domGlobals.document; 595 var node = doc.createTextNode(text); 596 return fromDom(node); 597 }; 598 var fromDom = function (node) { 599 if (node === null || node === undefined) { 600 throw new Error('Node cannot be null or undefined'); 601 } 602 return { dom: constant(node) }; 603 }; 604 var fromPoint = function (docElm, x, y) { 605 var doc = docElm.dom(); 606 return Option.from(doc.elementFromPoint(x, y)).map(fromDom); 607 }; 608 var Element = { 609 fromHtml: fromHtml, 610 fromTag: fromTag, 611 fromText: fromText, 612 fromDom: fromDom, 613 fromPoint: fromPoint 614 }; 615 616 var liftN = function (arr, f) { 617 var r = []; 618 for (var i = 0; i < arr.length; i++) { 619 var x = arr[i]; 620 if (x.isSome()) { 621 r.push(x.getOrDie()); 622 } else { 623 return Option.none(); 624 } 625 } 626 return Option.some(f.apply(null, r)); 627 }; 628 629 var fromElements = function (elements, scope) { 630 var doc = scope || domGlobals.document; 631 var fragment = doc.createDocumentFragment(); 632 each(elements, function (element) { 633 fragment.appendChild(element.dom()); 634 }); 635 return Element.fromDom(fragment); 636 }; 637 638 var Immutable = function () { 639 var fields = []; 640 for (var _i = 0; _i < arguments.length; _i++) { 641 fields[_i] = arguments[_i]; 642 } 643 return function () { 644 var values = []; 645 for (var _i = 0; _i < arguments.length; _i++) { 646 values[_i] = arguments[_i]; 647 } 648 if (fields.length !== values.length) { 649 throw new Error('Wrong number of arguments to struct. Expected "[' + fields.length + ']", got ' + values.length + ' arguments'); 650 } 651 var struct = {}; 652 each(fields, function (name, i) { 653 struct[name] = constant(values[i]); 654 }); 655 return struct; 656 }; 657 }; 658 659 var keys = Object.keys; 660 var each$1 = function (obj, f) { 661 var props = keys(obj); 662 for (var k = 0, len = props.length; k < len; k++) { 663 var i = props[k]; 664 var x = obj[i]; 665 f(x, i, obj); 666 } 667 }; 668 592 669 var node = function () { 593 670 var f = Global$1.getOrDie('Node'); … … 603 680 return compareDocumentPosition(a, b, node().DOCUMENT_POSITION_CONTAINED_BY); 604 681 }; 605 var Node $1= {682 var Node = { 606 683 documentPositionPreceding: documentPositionPreceding, 607 684 documentPositionContainedBy: documentPositionContainedBy … … 802 879 }; 803 880 804 var contains $1= function (str, substr) {881 var contains = function (str, substr) { 805 882 return str.indexOf(substr) !== -1; 806 883 }; … … 809 886 var checkContains = function (target) { 810 887 return function (uastring) { 811 return contains $1(uastring, target);888 return contains(uastring, target); 812 889 }; 813 890 }; … … 817 894 versionRegexes: [/.*?edge\/ ?([0-9]+)\.([0-9]+)$/], 818 895 search: function (uastring) { 819 var monstrosity = contains $1(uastring, 'edge/') && contains$1(uastring, 'chrome') && contains$1(uastring, 'safari') && contains$1(uastring, 'applewebkit');896 var monstrosity = contains(uastring, 'edge/') && contains(uastring, 'chrome') && contains(uastring, 'safari') && contains(uastring, 'applewebkit'); 820 897 return monstrosity; 821 898 } … … 828 905 ], 829 906 search: function (uastring) { 830 return contains $1(uastring, 'chrome') && !contains$1(uastring, 'chromeframe');907 return contains(uastring, 'chrome') && !contains(uastring, 'chromeframe'); 831 908 } 832 909 }, … … 838 915 ], 839 916 search: function (uastring) { 840 return contains $1(uastring, 'msie') || contains$1(uastring, 'trident');917 return contains(uastring, 'msie') || contains(uastring, 'trident'); 841 918 } 842 919 }, … … 861 938 ], 862 939 search: function (uastring) { 863 return (contains $1(uastring, 'safari') || contains$1(uastring, 'mobile/')) && contains$1(uastring, 'applewebkit');940 return (contains(uastring, 'safari') || contains(uastring, 'mobile/')) && contains(uastring, 'applewebkit'); 864 941 } 865 942 } … … 874 951 name: 'iOS', 875 952 search: function (uastring) { 876 return contains $1(uastring, 'iphone') || contains$1(uastring, 'ipad');953 return contains(uastring, 'iphone') || contains(uastring, 'ipad'); 877 954 }, 878 955 versionRegexes: [ … … 928 1005 929 1006 var detect$3 = cached(function () { 930 var userAgent = navigator.userAgent;1007 var userAgent = domGlobals.navigator.userAgent; 931 1008 return PlatformDetection.detect(userAgent); 932 1009 }); 933 1010 var PlatformDetection$1 = { detect: detect$3 }; 934 1011 935 var fromHtml = function (html, scope) { 936 var doc = scope || document; 937 var div = doc.createElement('div'); 938 div.innerHTML = html; 939 if (!div.hasChildNodes() || div.childNodes.length > 1) { 940 console.error('HTML does not have a single root node', html); 941 throw 'HTML must have a single root node'; 942 } 943 return fromDom(div.childNodes[0]); 944 }; 945 var fromTag = function (tag, scope) { 946 var doc = scope || document; 947 var node = doc.createElement(tag); 948 return fromDom(node); 949 }; 950 var fromText = function (text, scope) { 951 var doc = scope || document; 952 var node = doc.createTextNode(text); 953 return fromDom(node); 954 }; 955 var fromDom = function (node) { 956 if (node === null || node === undefined) 957 throw new Error('Node cannot be null or undefined'); 958 return { dom: constant(node) }; 959 }; 960 var fromPoint = function (docElm, x, y) { 961 var doc = docElm.dom(); 962 return Option.from(doc.elementFromPoint(x, y)).map(fromDom); 963 }; 964 var Element$$1 = { 965 fromHtml: fromHtml, 966 fromTag: fromTag, 967 fromText: fromText, 968 fromDom: fromDom, 969 fromPoint: fromPoint 970 }; 971 972 var ATTRIBUTE = Node.ATTRIBUTE_NODE; 973 var CDATA_SECTION = Node.CDATA_SECTION_NODE; 974 var COMMENT = Node.COMMENT_NODE; 975 var DOCUMENT = Node.DOCUMENT_NODE; 976 var DOCUMENT_TYPE = Node.DOCUMENT_TYPE_NODE; 977 var DOCUMENT_FRAGMENT = Node.DOCUMENT_FRAGMENT_NODE; 978 var ELEMENT = Node.ELEMENT_NODE; 979 var TEXT = Node.TEXT_NODE; 980 var PROCESSING_INSTRUCTION = Node.PROCESSING_INSTRUCTION_NODE; 981 var ENTITY_REFERENCE = Node.ENTITY_REFERENCE_NODE; 982 var ENTITY = Node.ENTITY_NODE; 983 var NOTATION = Node.NOTATION_NODE; 1012 var ATTRIBUTE = domGlobals.Node.ATTRIBUTE_NODE; 1013 var CDATA_SECTION = domGlobals.Node.CDATA_SECTION_NODE; 1014 var COMMENT = domGlobals.Node.COMMENT_NODE; 1015 var DOCUMENT = domGlobals.Node.DOCUMENT_NODE; 1016 var DOCUMENT_TYPE = domGlobals.Node.DOCUMENT_TYPE_NODE; 1017 var DOCUMENT_FRAGMENT = domGlobals.Node.DOCUMENT_FRAGMENT_NODE; 1018 var ELEMENT = domGlobals.Node.ELEMENT_NODE; 1019 var TEXT = domGlobals.Node.TEXT_NODE; 1020 var PROCESSING_INSTRUCTION = domGlobals.Node.PROCESSING_INSTRUCTION_NODE; 1021 var ENTITY_REFERENCE = domGlobals.Node.ENTITY_REFERENCE_NODE; 1022 var ENTITY = domGlobals.Node.ENTITY_NODE; 1023 var NOTATION = domGlobals.Node.NOTATION_NODE; 984 1024 985 1025 var ELEMENT$1 = ELEMENT; 986 1026 var is = function (element, selector) { 987 1027 var elem = element.dom(); 988 if (elem.nodeType !== ELEMENT$1) 1028 if (elem.nodeType !== ELEMENT$1) { 989 1029 return false; 990 else if (elem.matches !== undefined)1030 } else if (elem.matches !== undefined) { 991 1031 return elem.matches(selector); 992 else if (elem.msMatchesSelector !== undefined)1032 } else if (elem.msMatchesSelector !== undefined) { 993 1033 return elem.msMatchesSelector(selector); 994 else if (elem.webkitMatchesSelector !== undefined)1034 } else if (elem.webkitMatchesSelector !== undefined) { 995 1035 return elem.webkitMatchesSelector(selector); 996 else if (elem.mozMatchesSelector !== undefined)1036 } else if (elem.mozMatchesSelector !== undefined) { 997 1037 return elem.mozMatchesSelector(selector); 998 else1038 } else { 999 1039 throw new Error('Browser lacks native selectors'); 1040 } 1000 1041 }; 1001 1042 … … 1004 1045 }; 1005 1046 var regularContains = function (e1, e2) { 1006 var d1 = e1.dom(), d2 = e2.dom(); 1047 var d1 = e1.dom(); 1048 var d2 = e2.dom(); 1007 1049 return d1 === d2 ? false : d1.contains(d2); 1008 1050 }; 1009 1051 var ieContains = function (e1, e2) { 1010 return Node $1.documentPositionContainedBy(e1.dom(), e2.dom());1052 return Node.documentPositionContainedBy(e1.dom(), e2.dom()); 1011 1053 }; 1012 1054 var browser = PlatformDetection$1.detect().browser; 1013 var contains$ 2= browser.isIE() ? ieContains : regularContains;1055 var contains$1 = browser.isIE() ? ieContains : regularContains; 1014 1056 var is$1 = is; 1015 1057 1016 var keys = Object.keys; 1017 var each$1 = function (obj, f) { 1018 var props = keys(obj); 1019 for (var k = 0, len = props.length; k < len; k++) { 1020 var i = props[k]; 1021 var x = obj[i]; 1022 f(x, i, obj); 1058 var parent = function (element) { 1059 var dom = element.dom(); 1060 return Option.from(dom.parentNode).map(Element.fromDom); 1061 }; 1062 var children = function (element) { 1063 var dom = element.dom(); 1064 return map(dom.childNodes, Element.fromDom); 1065 }; 1066 var child = function (element, index) { 1067 var cs = element.dom().childNodes; 1068 return Option.from(cs[index]).map(Element.fromDom); 1069 }; 1070 var firstChild = function (element) { 1071 return child(element, 0); 1072 }; 1073 var lastChild = function (element) { 1074 return child(element, element.dom().childNodes.length - 1); 1075 }; 1076 var spot = Immutable('element', 'offset'); 1077 1078 var before = function (marker, element) { 1079 var parent$1 = parent(marker); 1080 parent$1.each(function (v) { 1081 v.dom().insertBefore(element.dom(), marker.dom()); 1082 }); 1083 }; 1084 var append = function (parent, element) { 1085 parent.dom().appendChild(element.dom()); 1086 }; 1087 1088 var before$1 = function (marker, elements) { 1089 each(elements, function (x) { 1090 before(marker, x); 1091 }); 1092 }; 1093 var append$1 = function (parent, elements) { 1094 each(elements, function (x) { 1095 append(parent, x); 1096 }); 1097 }; 1098 1099 var remove = function (element) { 1100 var dom = element.dom(); 1101 if (dom.parentNode !== null) { 1102 dom.parentNode.removeChild(dom); 1023 1103 } 1024 1104 }; … … 1029 1109 }; 1030 1110 1031 var rawSet = function (dom, key, value $$1) {1032 if (isString(value $$1) || isBoolean(value$$1) || isNumber(value$$1)) {1033 dom.setAttribute(key, value $$1+ '');1111 var rawSet = function (dom, key, value) { 1112 if (isString(value) || isBoolean(value) || isNumber(value)) { 1113 dom.setAttribute(key, value + ''); 1034 1114 } else { 1035 console.error('Invalid call to Attr.set. Key ', key, ':: Value ', value$$1, ':: Element ', dom);1115 domGlobals.console.error('Invalid call to Attr.set. Key ', key, ':: Value ', value, ':: Element ', dom); 1036 1116 throw new Error('Attribute value was not simple'); 1037 1117 } … … 1050 1130 }; 1051 1131 1052 var Immutable = function () { 1053 var fields = []; 1054 for (var _i = 0; _i < arguments.length; _i++) { 1055 fields[_i] = arguments[_i]; 1056 } 1057 return function () { 1058 var values = []; 1059 for (var _i = 0; _i < arguments.length; _i++) { 1060 values[_i] = arguments[_i]; 1061 } 1062 if (fields.length !== values.length) { 1063 throw new Error('Wrong number of arguments to struct. Expected "[' + fields.length + ']", got ' + values.length + ' arguments'); 1064 } 1065 var struct = {}; 1066 each(fields, function (name, i) { 1067 struct[name] = constant(values[i]); 1068 }); 1069 return struct; 1070 }; 1071 }; 1072 1073 var parent = function (element) { 1132 var isSupported = function (dom) { 1133 return dom.style !== undefined; 1134 }; 1135 1136 var internalSet = function (dom, property, value) { 1137 if (!isString(value)) { 1138 domGlobals.console.error('Invalid call to CSS.set. Property ', property, ':: Value ', value, ':: Element ', dom); 1139 throw new Error('CSS value must be a string: ' + value); 1140 } 1141 if (isSupported(dom)) { 1142 dom.style.setProperty(property, value); 1143 } 1144 }; 1145 var set = function (element, property, value) { 1074 1146 var dom = element.dom(); 1075 return Option.from(dom.parentNode).map(Element$$1.fromDom); 1076 }; 1077 var children = function (element) { 1078 var dom = element.dom(); 1079 return map(dom.childNodes, Element$$1.fromDom); 1080 }; 1081 var child = function (element, index) { 1082 var children = element.dom().childNodes; 1083 return Option.from(children[index]).map(Element$$1.fromDom); 1084 }; 1085 var firstChild = function (element) { 1086 return child(element, 0); 1087 }; 1088 var lastChild = function (element) { 1089 return child(element, element.dom().childNodes.length - 1); 1090 }; 1091 var spot = Immutable('element', 'offset'); 1092 1093 var before = function (marker, element) { 1094 var parent$$1 = parent(marker); 1095 parent$$1.each(function (v) { 1096 v.dom().insertBefore(element.dom(), marker.dom()); 1097 }); 1098 }; 1099 var append = function (parent$$1, element) { 1100 parent$$1.dom().appendChild(element.dom()); 1101 }; 1102 1103 var before$1 = function (marker, elements) { 1104 each(elements, function (x) { 1105 before(marker, x); 1106 }); 1107 }; 1108 var append$1 = function (parent, elements) { 1109 each(elements, function (x) { 1110 append(parent, x); 1111 }); 1112 }; 1113 1114 var remove$1 = function (element) { 1115 var dom = element.dom(); 1116 if (dom.parentNode !== null) 1117 dom.parentNode.removeChild(dom); 1118 }; 1119 1120 var clone$1 = function (original, deep) { 1121 return Element$$1.fromDom(original.dom().cloneNode(deep)); 1147 internalSet(dom, property, value); 1148 }; 1149 1150 var clone$1 = function (original, isDeep) { 1151 return Element.fromDom(original.dom().cloneNode(isDeep)); 1122 1152 }; 1123 1153 var deep = function (original) { … … 1125 1155 }; 1126 1156 var shallowAs = function (original, tag) { 1127 var nu = Element $$1.fromTag(tag);1157 var nu = Element.fromTag(tag); 1128 1158 var attributes = clone(original); 1129 1159 setAll(nu, attributes); … … 1133 1163 var nu = shallowAs(original, tag); 1134 1164 before(original, nu); 1135 var children$ $1 = children(original);1136 append$1(nu, children$ $1);1137 remove $1(original);1165 var children$1 = children(original); 1166 append$1(nu, children$1); 1167 remove(original); 1138 1168 return nu; 1139 1169 }; 1140 1170 1171 var joinSegment = function (parent, child) { 1172 append(parent.item, child.list); 1173 }; 1174 var joinSegments = function (segments) { 1175 for (var i = 1; i < segments.length; i++) { 1176 joinSegment(segments[i - 1], segments[i]); 1177 } 1178 }; 1179 var appendSegments = function (head$1, tail) { 1180 liftN([ 1181 last(head$1), 1182 head(tail) 1183 ], joinSegment); 1184 }; 1185 var createSegment = function (scope, listType) { 1186 var segment = { 1187 list: Element.fromTag(listType, scope), 1188 item: Element.fromTag('li', scope) 1189 }; 1190 append(segment.list, segment.item); 1191 return segment; 1192 }; 1193 var createSegments = function (scope, entry, size) { 1194 var segments = []; 1195 for (var i = 0; i < size; i++) { 1196 segments.push(createSegment(scope, entry.listType)); 1197 } 1198 return segments; 1199 }; 1200 var populateSegments = function (segments, entry) { 1201 for (var i = 0; i < segments.length - 1; i++) { 1202 set(segments[i].item, 'list-style-type', 'none'); 1203 } 1204 last(segments).each(function (segment) { 1205 setAll(segment.list, entry.listAttributes); 1206 setAll(segment.item, entry.itemAttributes); 1207 append$1(segment.item, entry.content); 1208 }); 1209 }; 1210 var normalizeSegment = function (segment, entry) { 1211 if (name(segment.list) !== entry.listType) { 1212 segment.list = mutate(segment.list, entry.listType); 1213 } 1214 setAll(segment.list, entry.listAttributes); 1215 }; 1216 var createItem = function (scope, attr, content) { 1217 var item = Element.fromTag('li', scope); 1218 setAll(item, attr); 1219 append$1(item, content); 1220 return item; 1221 }; 1222 var appendItem = function (segment, item) { 1223 append(segment.list, item); 1224 segment.item = item; 1225 }; 1226 var writeShallow = function (scope, cast, entry) { 1227 var newCast = cast.slice(0, entry.depth); 1228 last(newCast).each(function (segment) { 1229 var item = createItem(scope, entry.itemAttributes, entry.content); 1230 appendItem(segment, item); 1231 normalizeSegment(segment, entry); 1232 }); 1233 return newCast; 1234 }; 1235 var writeDeep = function (scope, cast, entry) { 1236 var segments = createSegments(scope, entry, entry.depth - cast.length); 1237 joinSegments(segments); 1238 populateSegments(segments, entry); 1239 appendSegments(cast, segments); 1240 return cast.concat(segments); 1241 }; 1242 var composeList = function (scope, entries) { 1243 var cast = foldl(entries, function (cast, entry) { 1244 return entry.depth > cast.length ? writeDeep(scope, cast, entry) : writeShallow(scope, cast, entry); 1245 }, []); 1246 return head(cast).map(function (segment) { 1247 return segment.list; 1248 }); 1249 }; 1250 1251 var isList$1 = function (el) { 1252 return is$1(el, 'OL,UL'); 1253 }; 1254 var hasFirstChildList = function (el) { 1255 return firstChild(el).map(isList$1).getOr(false); 1256 }; 1257 var hasLastChildList = function (el) { 1258 return lastChild(el).map(isList$1).getOr(false); 1259 }; 1260 1261 var isIndented = function (entry) { 1262 return entry.depth > 0; 1263 }; 1264 var isSelected = function (entry) { 1265 return entry.isSelected; 1266 }; 1267 var cloneItemContent = function (li) { 1268 var children$1 = children(li); 1269 var content = hasLastChildList(li) ? children$1.slice(0, -1) : children$1; 1270 return map(content, deep); 1271 }; 1272 var createEntry = function (li, depth, isSelected) { 1273 return parent(li).map(function (list) { 1274 return { 1275 depth: depth, 1276 isSelected: isSelected, 1277 content: cloneItemContent(li), 1278 itemAttributes: clone(li), 1279 listAttributes: clone(list), 1280 listType: name(list) 1281 }; 1282 }); 1283 }; 1284 1285 var indentEntry = function (indentation, entry) { 1286 switch (indentation) { 1287 case 'Indent': 1288 entry.depth++; 1289 break; 1290 case 'Outdent': 1291 entry.depth--; 1292 break; 1293 case 'Flatten': 1294 entry.depth = 0; 1295 } 1296 }; 1297 1298 var hasOwnProperty = Object.prototype.hasOwnProperty; 1299 var shallow = function (old, nu) { 1300 return nu; 1301 }; 1302 var baseMerge = function (merger) { 1303 return function () { 1304 var objects = new Array(arguments.length); 1305 for (var i = 0; i < objects.length; i++) 1306 objects[i] = arguments[i]; 1307 if (objects.length === 0) 1308 throw new Error('Can\'t merge zero objects'); 1309 var ret = {}; 1310 for (var j = 0; j < objects.length; j++) { 1311 var curObject = objects[j]; 1312 for (var key in curObject) 1313 if (hasOwnProperty.call(curObject, key)) { 1314 ret[key] = merger(ret[key], curObject[key]); 1315 } 1316 } 1317 return ret; 1318 }; 1319 }; 1320 var merge = baseMerge(shallow); 1321 1322 var cloneListProperties = function (target, source) { 1323 target.listType = source.listType; 1324 target.listAttributes = merge({}, source.listAttributes); 1325 }; 1326 var previousSiblingEntry = function (entries, start) { 1327 var depth = entries[start].depth; 1328 for (var i = start - 1; i >= 0; i--) { 1329 if (entries[i].depth === depth) { 1330 return Option.some(entries[i]); 1331 } 1332 if (entries[i].depth < depth) { 1333 break; 1334 } 1335 } 1336 return Option.none(); 1337 }; 1338 var normalizeEntries = function (entries) { 1339 each(entries, function (entry, i) { 1340 previousSiblingEntry(entries, i).each(function (matchingEntry) { 1341 cloneListProperties(entry, matchingEntry); 1342 }); 1343 }); 1344 }; 1345 1346 var Cell = function (initial) { 1347 var value = initial; 1348 var get = function () { 1349 return value; 1350 }; 1351 var set = function (v) { 1352 value = v; 1353 }; 1354 var clone = function () { 1355 return Cell(get()); 1356 }; 1357 return { 1358 get: get, 1359 set: set, 1360 clone: clone 1361 }; 1362 }; 1363 1364 var parseItem = function (depth, itemSelection, selectionState, item) { 1365 return firstChild(item).filter(isList$1).fold(function () { 1366 itemSelection.each(function (selection) { 1367 if (eq(selection.start, item)) { 1368 selectionState.set(true); 1369 } 1370 }); 1371 var currentItemEntry = createEntry(item, depth, selectionState.get()); 1372 itemSelection.each(function (selection) { 1373 if (eq(selection.end, item)) { 1374 selectionState.set(false); 1375 } 1376 }); 1377 var childListEntries = lastChild(item).filter(isList$1).map(function (list) { 1378 return parseList(depth, itemSelection, selectionState, list); 1379 }).getOr([]); 1380 return currentItemEntry.toArray().concat(childListEntries); 1381 }, function (list) { 1382 return parseList(depth, itemSelection, selectionState, list); 1383 }); 1384 }; 1385 var parseList = function (depth, itemSelection, selectionState, list) { 1386 return bind(children(list), function (element) { 1387 var parser = isList$1(element) ? parseList : parseItem; 1388 var newDepth = depth + 1; 1389 return parser(newDepth, itemSelection, selectionState, element); 1390 }); 1391 }; 1392 var parseLists = function (lists, itemSelection) { 1393 var selectionState = Cell(false); 1394 var initialDepth = 0; 1395 return map(lists, function (list) { 1396 return { 1397 sourceList: list, 1398 entries: parseList(initialDepth, itemSelection, selectionState, list) 1399 }; 1400 }); 1401 }; 1402 1141 1403 var global$8 = tinymce.util.Tools.resolve('tinymce.Env'); 1142 1404 1143 var DOM$1 = global$6.DOM; 1144 var createNewTextBlock = function (editor, contentNode, blockName) { 1145 var node, textBlock; 1146 var fragment = DOM$1.createFragment(); 1147 var hasContentNode; 1405 var createTextBlock = function (editor, contentNode) { 1406 var dom = editor.dom; 1148 1407 var blockElements = editor.schema.getBlockElements(); 1408 var fragment = dom.createFragment(); 1409 var node, textBlock, blockName, hasContentNode; 1149 1410 if (editor.settings.forced_root_block) { 1150 blockName = blockName ||editor.settings.forced_root_block;1411 blockName = editor.settings.forced_root_block; 1151 1412 } 1152 1413 if (blockName) { 1153 textBlock = DOM$1.create(blockName);1414 textBlock = dom.create(blockName); 1154 1415 if (textBlock.tagName === editor.settings.forced_root_block) { 1155 DOM$1.setAttribs(textBlock, editor.settings.forced_root_block_attrs);1416 dom.setAttribs(textBlock, editor.settings.forced_root_block_attrs); 1156 1417 } 1157 1418 if (!NodeType.isBlock(contentNode.firstChild, blockElements)) { … … 1171 1432 if (blockName) { 1172 1433 if (!textBlock) { 1173 textBlock = DOM$1.create(blockName);1434 textBlock = dom.create(blockName); 1174 1435 fragment.appendChild(textBlock); 1175 1436 } … … 1182 1443 } 1183 1444 if (!editor.settings.forced_root_block) { 1184 fragment.appendChild( DOM$1.create('br'));1445 fragment.appendChild(dom.create('br')); 1185 1446 } else { 1186 1447 if (!hasContentNode && (!global$8.ie || global$8.ie > 10)) { 1187 textBlock.appendChild( DOM$1.create('br', { 'data-mce-bogus': '1' }));1448 textBlock.appendChild(dom.create('br', { 'data-mce-bogus': '1' })); 1188 1449 } 1189 1450 } 1190 1451 return fragment; 1191 };1192 var TextBlock = { createNewTextBlock: createNewTextBlock };1193 1194 var DOM$2 = global$6.DOM;1195 var splitList = function (editor, ul, li, newBlock) {1196 var tmpRng, fragment, bookmarks, node;1197 var removeAndKeepBookmarks = function (targetNode) {1198 global$5.each(bookmarks, function (node) {1199 targetNode.parentNode.insertBefore(node, li.parentNode);1200 });1201 DOM$2.remove(targetNode);1202 };1203 bookmarks = DOM$2.select('span[data-mce-type="bookmark"]', ul);1204 newBlock = newBlock || TextBlock.createNewTextBlock(editor, li);1205 tmpRng = DOM$2.createRng();1206 tmpRng.setStartAfter(li);1207 tmpRng.setEndAfter(ul);1208 fragment = tmpRng.extractContents();1209 for (node = fragment.firstChild; node; node = node.firstChild) {1210 if (node.nodeName === 'LI' && editor.dom.isEmpty(node)) {1211 DOM$2.remove(node);1212 break;1213 }1214 }1215 if (!editor.dom.isEmpty(fragment)) {1216 DOM$2.insertAfter(fragment, ul);1217 }1218 DOM$2.insertAfter(newBlock, ul);1219 if (NodeType.isEmpty(editor.dom, li.parentNode)) {1220 removeAndKeepBookmarks(li.parentNode);1221 }1222 DOM$2.remove(li);1223 if (NodeType.isEmpty(editor.dom, ul)) {1224 DOM$2.remove(ul);1225 }1226 };1227 var SplitList = { splitList: splitList };1228 1229 var liftN = function (arr, f) {1230 var r = [];1231 for (var i = 0; i < arr.length; i++) {1232 var x = arr[i];1233 if (x.isSome()) {1234 r.push(x.getOrDie());1235 } else {1236 return Option.none();1237 }1238 }1239 return Option.some(f.apply(null, r));1240 };1241 1242 var fromElements = function (elements, scope) {1243 var doc = scope || document;1244 var fragment = doc.createDocumentFragment();1245 each(elements, function (element) {1246 fragment.appendChild(element.dom());1247 });1248 return Element$$1.fromDom(fragment);1249 };1250 1251 var isSupported = function (dom) {1252 return dom.style !== undefined;1253 };1254 1255 var internalSet = function (dom, property, value$$1) {1256 if (!isString(value$$1)) {1257 console.error('Invalid call to CSS.set. Property ', property, ':: Value ', value$$1, ':: Element ', dom);1258 throw new Error('CSS value must be a string: ' + value$$1);1259 }1260 if (isSupported(dom))1261 dom.style.setProperty(property, value$$1);1262 };1263 var set$1 = function (element, property, value$$1) {1264 var dom = element.dom();1265 internalSet(dom, property, value$$1);1266 };1267 1268 var createSection = function (scope, listType) {1269 var section = {1270 list: Element$$1.fromTag(listType, scope),1271 item: Element$$1.fromTag('li', scope)1272 };1273 append(section.list, section.item);1274 return section;1275 };1276 var joinSections = function (parent, appendor) {1277 append(parent.item, appendor.list);1278 };1279 var createJoinedSections = function (scope, length, listType) {1280 var sections = [];1281 var _loop_1 = function (i) {1282 var newSection = createSection(scope, listType);1283 last(sections).each(function (lastSection) {1284 return joinSections(lastSection, newSection);1285 });1286 sections.push(newSection);1287 };1288 for (var i = 0; i < length; i++) {1289 _loop_1(i);1290 }1291 return sections;1292 };1293 var normalizeSection = function (section, entry) {1294 if (name(section.list).toUpperCase() !== entry.listType) {1295 section.list = mutate(section.list, entry.listType);1296 }1297 setAll(section.list, entry.listAttributes);1298 };1299 var createItem = function (scope, attr, content) {1300 var item = Element$$1.fromTag('li', scope);1301 setAll(item, attr);1302 append$1(item, content);1303 return item;1304 };1305 var setItem = function (section, item) {1306 append(section.list, item);1307 section.item = item;1308 };1309 var writeShallow = function (scope, outline, entry) {1310 var newOutline = outline.slice(0, entry.depth);1311 last(newOutline).each(function (section) {1312 setItem(section, createItem(scope, entry.itemAttributes, entry.content));1313 normalizeSection(section, entry);1314 });1315 return newOutline;1316 };1317 var populateSections = function (sections, entry) {1318 last(sections).each(function (section) {1319 setAll(section.list, entry.listAttributes);1320 setAll(section.item, entry.itemAttributes);1321 append$1(section.item, entry.content);1322 });1323 for (var i = 0; i < sections.length - 1; i++) {1324 set$1(sections[i].item, 'list-style-type', 'none');1325 }1326 };1327 var writeDeep = function (scope, outline, entry) {1328 var newSections = createJoinedSections(scope, entry.depth - outline.length, entry.listType);1329 populateSections(newSections, entry);1330 liftN([1331 last(outline),1332 head(newSections)1333 ], joinSections);1334 return outline.concat(newSections);1335 };1336 var composeList = function (scope, entries) {1337 var outline = foldl(entries, function (outline, entry) {1338 return entry.depth > outline.length ? writeDeep(scope, outline, entry) : writeShallow(scope, outline, entry);1339 }, []);1340 return head(outline).map(function (section) {1341 return section.list;1342 });1343 };1344 1345 var isIndented = function (entry) {1346 return entry.depth > 0;1347 };1348 var isSelected = function (entry) {1349 return entry.isSelected;1350 };1351 1352 var indentEntry = function (indentation, entry) {1353 switch (indentation) {1354 case 'Indent':1355 entry.depth++;1356 break;1357 case 'Outdent':1358 entry.depth--;1359 break;1360 case 'Flatten':1361 entry.depth = 0;1362 }1363 };1364 1365 var hasOwnProperty$1 = Object.prototype.hasOwnProperty;1366 var shallow$1 = function (old, nu) {1367 return nu;1368 };1369 var baseMerge = function (merger) {1370 return function () {1371 var objects = new Array(arguments.length);1372 for (var i = 0; i < objects.length; i++)1373 objects[i] = arguments[i];1374 if (objects.length === 0)1375 throw new Error('Can\'t merge zero objects');1376 var ret = {};1377 for (var j = 0; j < objects.length; j++) {1378 var curObject = objects[j];1379 for (var key in curObject)1380 if (hasOwnProperty$1.call(curObject, key)) {1381 ret[key] = merger(ret[key], curObject[key]);1382 }1383 }1384 return ret;1385 };1386 };1387 var merge = baseMerge(shallow$1);1388 1389 var assimilateEntry = function (adherent, source) {1390 adherent.listType = source.listType;1391 adherent.listAttributes = merge({}, source.listAttributes);1392 };1393 var normalizeShallow = function (outline, entry) {1394 var matchingEntryDepth = entry.depth - 1;1395 outline[matchingEntryDepth].each(function (matchingEntry) {1396 return assimilateEntry(entry, matchingEntry);1397 });1398 var newOutline = outline.slice(0, matchingEntryDepth);1399 newOutline.push(Option.some(entry));1400 return newOutline;1401 };1402 var normalizeDeep = function (outline, entry) {1403 var newOutline = outline.slice(0);1404 var diff = entry.depth - outline.length;1405 for (var i = 1; i < diff; i++) {1406 newOutline.push(Option.none());1407 }1408 newOutline.push(Option.some(entry));1409 return newOutline;1410 };1411 var normalizeEntries = function (entries) {1412 foldl(entries, function (outline, entry) {1413 return entry.depth > outline.length ? normalizeDeep(outline, entry) : normalizeShallow(outline, entry);1414 }, []);1415 };1416 1417 var Cell = function (initial) {1418 var value = initial;1419 var get = function () {1420 return value;1421 };1422 var set = function (v) {1423 value = v;1424 };1425 var clone = function () {1426 return Cell(get());1427 };1428 return {1429 get: get,1430 set: set,1431 clone: clone1432 };1433 };1434 1435 var ListType;1436 (function (ListType) {1437 ListType['OL'] = 'OL';1438 ListType['UL'] = 'UL';1439 ListType['DL'] = 'DL';1440 }(ListType || (ListType = {})));1441 var getListType = function (list) {1442 switch (name(list)) {1443 case 'ol':1444 return Option.some(ListType.OL);1445 case 'ul':1446 return Option.some(ListType.UL);1447 case 'dl':1448 return Option.some(ListType.DL);1449 default:1450 return Option.none();1451 }1452 };1453 var isList$1 = function (el) {1454 return is$1(el, 'OL,UL,DL');1455 };1456 1457 var hasFirstChildList = function (li) {1458 return firstChild(li).map(isList$1).getOr(false);1459 };1460 var hasLastChildList = function (li) {1461 return lastChild(li).map(isList$1).getOr(false);1462 };1463 1464 var getItemContent = function (li) {1465 var childNodes = children(li);1466 var contentLength = childNodes.length + (hasLastChildList(li) ? -1 : 0);1467 return map(childNodes.slice(0, contentLength), deep);1468 };1469 var createEntry = function (li, depth, isSelected) {1470 var list = parent(li);1471 return {1472 depth: depth,1473 isSelected: isSelected,1474 content: getItemContent(li),1475 listType: list.bind(getListType).getOr(ListType.OL),1476 listAttributes: list.map(clone).getOr({}),1477 itemAttributes: clone(li)1478 };1479 };1480 var parseItem = function (depth, itemSelection, selectionState, item) {1481 var curriedParseList = curry(parseList, depth, itemSelection, selectionState);1482 var updateSelectionState = function (itemRange) {1483 return itemSelection.each(function (selection) {1484 if (eq(itemRange === 'Start' ? selection.start : selection.end, item)) {1485 selectionState.set(itemRange === 'Start');1486 }1487 });1488 };1489 return firstChild(item).filter(isList$1).fold(function () {1490 updateSelectionState('Start');1491 var fromCurrentItem = createEntry(item, depth, selectionState.get());1492 updateSelectionState('End');1493 var fromChildList = lastChild(item).filter(isList$1).map(curriedParseList).getOr([]);1494 return [fromCurrentItem].concat(fromChildList);1495 }, curriedParseList);1496 };1497 var parseList = function (depth, itemSelection, selectionState, list) {1498 var newDepth = depth + 1;1499 return bind(children(list), function (child$$1) {1500 return isList$1(child$$1) ? parseList(newDepth, itemSelection, selectionState, child$$1) : parseItem(newDepth, itemSelection, selectionState, child$$1);1501 });1502 };1503 var parseLists = function (lists, itemSelection) {1504 var selectionState = Cell(false);1505 var initialDepth = 0;1506 return map(lists, function (list) {1507 return {1508 entries: parseList(initialDepth, itemSelection, selectionState, list),1509 sourceList: list1510 };1511 });1512 1452 }; 1513 1453 … … 1515 1455 return map(entries, function (entry) { 1516 1456 var content = fromElements(entry.content); 1517 return Element $$1.fromDom(TextBlock.createNewTextBlock(editor, content.dom()));1457 return Element.fromDom(createTextBlock(editor, content.dom())); 1518 1458 }); 1519 1459 }; … … 1534 1474 }; 1535 1475 var getItemSelection = function (editor) { 1536 var selectedListItems = map(Selection.getSelectedListItems(editor), Element $$1.fromDom);1476 var selectedListItems = map(Selection.getSelectedListItems(editor), Element.fromDom); 1537 1477 return liftN([ 1538 1478 find(selectedListItems, not(hasFirstChildList)), … … 1546 1486 }; 1547 1487 var listsIndentation = function (editor, lists, indentation) { 1548 var parsedLists = parseLists(lists, getItemSelection(editor));1549 each( parsedLists, function (entrySet) {1488 var entrySets = parseLists(lists, getItemSelection(editor)); 1489 each(entrySets, function (entrySet) { 1550 1490 indentSelectedEntries(entrySet.entries, indentation); 1551 1491 before$1(entrySet.sourceList, composeEntries(editor, entrySet.entries)); 1552 remove$1(entrySet.sourceList); 1553 }); 1554 }; 1492 remove(entrySet.sourceList); 1493 }); 1494 }; 1495 1496 var DOM$1 = global$6.DOM; 1497 var splitList = function (editor, ul, li) { 1498 var tmpRng, fragment, bookmarks, node, newBlock; 1499 var removeAndKeepBookmarks = function (targetNode) { 1500 global$5.each(bookmarks, function (node) { 1501 targetNode.parentNode.insertBefore(node, li.parentNode); 1502 }); 1503 DOM$1.remove(targetNode); 1504 }; 1505 bookmarks = DOM$1.select('span[data-mce-type="bookmark"]', ul); 1506 newBlock = createTextBlock(editor, li); 1507 tmpRng = DOM$1.createRng(); 1508 tmpRng.setStartAfter(li); 1509 tmpRng.setEndAfter(ul); 1510 fragment = tmpRng.extractContents(); 1511 for (node = fragment.firstChild; node; node = node.firstChild) { 1512 if (node.nodeName === 'LI' && editor.dom.isEmpty(node)) { 1513 DOM$1.remove(node); 1514 break; 1515 } 1516 } 1517 if (!editor.dom.isEmpty(fragment)) { 1518 DOM$1.insertAfter(fragment, ul); 1519 } 1520 DOM$1.insertAfter(newBlock, ul); 1521 if (NodeType.isEmpty(editor.dom, li.parentNode)) { 1522 removeAndKeepBookmarks(li.parentNode); 1523 } 1524 DOM$1.remove(li); 1525 if (NodeType.isEmpty(editor.dom, ul)) { 1526 DOM$1.remove(ul); 1527 } 1528 }; 1529 var SplitList = { splitList: splitList }; 1555 1530 1556 1531 var outdentDlItem = function (editor, item) { … … 1577 1552 } 1578 1553 }; 1554 1579 1555 var selectionIndentation = function (editor, indentation) { 1580 var dlItems = map(Selection.getSelectedDlItems(editor), Element$$1.fromDom); 1581 var lists = map(Selection.getSelectedListRoots(editor), Element$$1.fromDom); 1582 if (dlItems.length || lists.length) { 1556 var lists = map(Selection.getSelectedListRoots(editor), Element.fromDom); 1557 var dlItems = map(Selection.getSelectedDlItems(editor), Element.fromDom); 1558 var isHandled = false; 1559 if (lists.length || dlItems.length) { 1583 1560 var bookmark = editor.selection.getBookmark(); 1561 listsIndentation(editor, lists, indentation); 1584 1562 dlIndentation(editor, indentation, dlItems); 1585 listsIndentation(editor, lists, indentation);1586 1563 editor.selection.moveToBookmark(bookmark); 1587 1564 editor.selection.setRng(Range.normalizeRange(editor.selection.getRng())); 1588 1565 editor.nodeChanged(); 1589 } 1566 isHandled = true; 1567 } 1568 return isHandled; 1590 1569 }; 1591 1570 var indentListSelection = function (editor) { 1592 selectionIndentation(editor, 'Indent');1571 return selectionIndentation(editor, 'Indent'); 1593 1572 }; 1594 1573 var outdentListSelection = function (editor) { 1595 selectionIndentation(editor, 'Outdent');1574 return selectionIndentation(editor, 'Outdent'); 1596 1575 }; 1597 1576 var flattenListSelection = function (editor) { 1598 selectionIndentation(editor, 'Flatten');1577 return selectionIndentation(editor, 'Flatten'); 1599 1578 }; 1600 1579 … … 1824 1803 }; 1825 1804 1826 var DOM$ 3= global$6.DOM;1805 var DOM$2 = global$6.DOM; 1827 1806 var normalizeList = function (dom, ul) { 1828 1807 var sibling; … … 1833 1812 sibling.appendChild(ul); 1834 1813 if (NodeType.isEmpty(dom, parentNode)) { 1835 DOM$ 3.remove(parentNode);1814 DOM$2.remove(parentNode); 1836 1815 } 1837 1816 } else { 1838 DOM$ 3.setStyle(parentNode, 'listStyleType', 'none');1817 DOM$2.setStyle(parentNode, 'listStyleType', 'none'); 1839 1818 } 1840 1819 } … … 1929 1908 toElm.appendChild(listNode); 1930 1909 } 1910 var contains = contains$1(Element.fromDom(toElm), Element.fromDom(fromElm)); 1911 var nestedLists = contains ? dom.getParents(fromElm, NodeType.isListNode, toElm) : []; 1931 1912 dom.remove(fromElm); 1932 if (NodeType.isEmpty(dom, ul) && ul !== dom.getRoot()) { 1933 dom.remove(ul); 1934 } 1913 each(nestedLists, function (list) { 1914 if (NodeType.isEmpty(dom, list) && list !== dom.getRoot()) { 1915 dom.remove(list); 1916 } 1917 }); 1935 1918 }; 1936 1919 var mergeIntoEmptyLi = function (editor, fromLi, toLi) { … … 2048 2031 }; 2049 2032 2050 var get $3= function (editor) {2033 var get = function (editor) { 2051 2034 return { 2052 2035 backspaceDelete: function (isForward) { … … 2055 2038 }; 2056 2039 }; 2057 var Api = { get: get $3};2040 var Api = { get: get }; 2058 2041 2059 2042 var queryListCommandState = function (editor, listName) { … … 2100 2083 return; 2101 2084 } 2102 if (Selection.isList(editor)) { 2103 e.preventDefault(); 2104 editor.undoManager.transact(function () { 2105 if (e.shiftKey) { 2106 outdentListSelection(editor); 2107 } else { 2108 indentListSelection(editor); 2109 } 2110 }); 2111 } 2085 editor.undoManager.transact(function () { 2086 if (e.shiftKey ? outdentListSelection(editor) : indentListSelection(editor)) { 2087 e.preventDefault(); 2088 } 2089 }); 2112 2090 }); 2113 2091 }; … … 2120 2098 var Keyboard = { setup: setup$1 }; 2121 2099 2122 var findIndex $2= function (list, predicate) {2100 var findIndex = function (list, predicate) { 2123 2101 for (var index = 0; index < list.length; index++) { 2124 2102 var element = list[index]; … … 2133 2111 var ctrl = e.control; 2134 2112 editor.on('NodeChange', function (e) { 2135 var tableCellIndex = findIndex $2(e.parents, NodeType.isTableCellNode);2113 var tableCellIndex = findIndex(e.parents, NodeType.isTableCellNode); 2136 2114 var parents = tableCellIndex !== -1 ? e.parents.slice(0, tableCellIndex) : e.parents; 2137 2115 var lists = global$5.grep(parents, NodeType.isListNode); … … 2178 2156 return Plugin; 2179 2157 2180 }( ));2158 }(window)); 2181 2159 })();
Note: See TracChangeset
for help on using the changeset viewer.