annotate .cms/lib/codemirror/addon/display/placeholder.js @ 1:1d486627aa1e draft default tip

24.10
author Coffee CMS <info@coffee-cms.ru>
date Sat, 12 Oct 2024 02:51:39 +0000
parents 78edf6b517a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
1 // CodeMirror, copyright (c) by Marijn Haverbeke and others
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
2 // Distributed under an MIT license: https://codemirror.net/5/LICENSE
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
3
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
4 (function(mod) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
5 if (typeof exports == "object" && typeof module == "object") // CommonJS
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
6 mod(require("../../lib/codemirror"));
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
7 else if (typeof define == "function" && define.amd) // AMD
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
8 define(["../../lib/codemirror"], mod);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
9 else // Plain browser env
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
10 mod(CodeMirror);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
11 })(function(CodeMirror) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
12 CodeMirror.defineOption("placeholder", "", function(cm, val, old) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
13 var prev = old && old != CodeMirror.Init;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
14 if (val && !prev) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
15 cm.on("blur", onBlur);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
16 cm.on("change", onChange);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
17 cm.on("swapDoc", onChange);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
18 CodeMirror.on(cm.getInputField(), "compositionupdate", cm.state.placeholderCompose = function() { onComposition(cm) })
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
19 onChange(cm);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
20 } else if (!val && prev) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
21 cm.off("blur", onBlur);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
22 cm.off("change", onChange);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
23 cm.off("swapDoc", onChange);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
24 CodeMirror.off(cm.getInputField(), "compositionupdate", cm.state.placeholderCompose)
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
25 clearPlaceholder(cm);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
26 var wrapper = cm.getWrapperElement();
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
27 wrapper.className = wrapper.className.replace(" CodeMirror-empty", "");
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
28 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
29
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
30 if (val && !cm.hasFocus()) onBlur(cm);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
31 });
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
32
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
33 function clearPlaceholder(cm) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
34 if (cm.state.placeholder) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
35 cm.state.placeholder.parentNode.removeChild(cm.state.placeholder);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
36 cm.state.placeholder = null;
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
37 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
38 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
39 function setPlaceholder(cm) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
40 clearPlaceholder(cm);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
41 var elt = cm.state.placeholder = document.createElement("pre");
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
42 elt.style.cssText = "height: 0; overflow: visible";
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
43 elt.style.direction = cm.getOption("direction");
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
44 elt.className = "CodeMirror-placeholder CodeMirror-line-like";
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
45 var placeHolder = cm.getOption("placeholder")
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
46 if (typeof placeHolder == "string") placeHolder = document.createTextNode(placeHolder)
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
47 elt.appendChild(placeHolder)
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
48 cm.display.lineSpace.insertBefore(elt, cm.display.lineSpace.firstChild);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
49 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
50
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
51 function onComposition(cm) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
52 setTimeout(function() {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
53 var empty = false
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
54 if (cm.lineCount() == 1) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
55 var input = cm.getInputField()
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
56 empty = input.nodeName == "TEXTAREA" ? !cm.getLine(0).length
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
57 : !/[^\u200b]/.test(input.querySelector(".CodeMirror-line").textContent)
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
58 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
59 if (empty) setPlaceholder(cm)
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
60 else clearPlaceholder(cm)
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
61 }, 20)
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
62 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
63
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
64 function onBlur(cm) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
65 if (isEmpty(cm)) setPlaceholder(cm);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
66 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
67 function onChange(cm) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
68 var wrapper = cm.getWrapperElement(), empty = isEmpty(cm);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
69 wrapper.className = wrapper.className.replace(" CodeMirror-empty", "") + (empty ? " CodeMirror-empty" : "");
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
70
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
71 if (empty) setPlaceholder(cm);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
72 else clearPlaceholder(cm);
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
73 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
74
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
75 function isEmpty(cm) {
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
76 return (cm.lineCount() === 1) && (cm.getLine(0) === "");
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
77 }
Coffee CMS <info@coffee-cms.ru>
parents:
diff changeset
78 });