From b3d495f796e3f3a04a561a2fab8a9d5c0abe89dd Mon Sep 17 00:00:00 2001 From: Peter Savchenko Date: Wed, 3 Jul 2024 20:33:05 +0300 Subject: [PATCH 1/2] placeholder actvie --- dist/paragraph.mjs | 4 ++-- dist/paragraph.umd.js | 4 ++-- package.json | 2 +- src/index.css | 24 +++++++++--------------- src/index.ts | 2 +- 5 files changed, 15 insertions(+), 21 deletions(-) diff --git a/dist/paragraph.mjs b/dist/paragraph.mjs index 9706c75..46154d6 100644 --- a/dist/paragraph.mjs +++ b/dist/paragraph.mjs @@ -1,4 +1,4 @@ -(function(){"use strict";try{if(typeof document<"u"){var e=document.createElement("style");e.appendChild(document.createTextNode(".ce-paragraph{line-height:1.6em;outline:none}.ce-paragraph[data-placeholder]:empty:before{content:attr(data-placeholder);color:#707684;font-weight:400;opacity:0}.codex-editor--empty .ce-block:first-child .ce-paragraph[data-placeholder]:empty:before{opacity:1}.codex-editor--toolbox-opened .ce-block:first-child .ce-paragraph[data-placeholder]:empty:before,.codex-editor--empty .ce-block:first-child .ce-paragraph[data-placeholder]:empty:focus:before{opacity:0}.ce-paragraph p:first-of-type{margin-top:0}.ce-paragraph p:last-of-type{margin-bottom:0}")),document.head.appendChild(e)}}catch(t){console.error("vite-plugin-css-injected-by-js",t)}})(); +(function(){"use strict";try{if(typeof document<"u"){var e=document.createElement("style");e.appendChild(document.createTextNode(".ce-paragraph{line-height:1.6em;outline:none}.ce-block:only-of-type .ce-paragraph[data-placeholder-active]:empty:before,.ce-block:only-of-type .ce-paragraph[data-placeholder-active][data-empty=true]:before{content:attr(data-placeholder-active)}.ce-paragraph p:first-of-type{margin-top:0}.ce-paragraph p:last-of-type{margin-bottom:0}")),document.head.appendChild(e)}}catch(a){console.error("vite-plugin-css-injected-by-js",a)}})(); const a = ''; function l(r) { const t = document.createElement("div"); @@ -59,7 +59,7 @@ class n { */ drawView() { const t = document.createElement("DIV"); - return t.classList.add(this._CSS.wrapper, this._CSS.block), t.contentEditable = "false", t.dataset.placeholder = this.api.i18n.t(this._placeholder), this._data.text && (t.innerHTML = this._data.text), this.readOnly || (t.contentEditable = "true", t.addEventListener("keyup", this.onKeyUp)), t; + return t.classList.add(this._CSS.wrapper, this._CSS.block), t.contentEditable = "false", t.dataset.placeholderActive = this.api.i18n.t(this._placeholder), this._data.text && (t.innerHTML = this._data.text), this.readOnly || (t.contentEditable = "true", t.addEventListener("keyup", this.onKeyUp)), t; } /** * Return Tool's view diff --git a/dist/paragraph.umd.js b/dist/paragraph.umd.js index e4db866..f85304a 100644 --- a/dist/paragraph.umd.js +++ b/dist/paragraph.umd.js @@ -1,4 +1,4 @@ -(function(){"use strict";try{if(typeof document<"u"){var e=document.createElement("style");e.appendChild(document.createTextNode(".ce-paragraph{line-height:1.6em;outline:none}.ce-paragraph[data-placeholder]:empty:before{content:attr(data-placeholder);color:#707684;font-weight:400;opacity:0}.codex-editor--empty .ce-block:first-child .ce-paragraph[data-placeholder]:empty:before{opacity:1}.codex-editor--toolbox-opened .ce-block:first-child .ce-paragraph[data-placeholder]:empty:before,.codex-editor--empty .ce-block:first-child .ce-paragraph[data-placeholder]:empty:focus:before{opacity:0}.ce-paragraph p:first-of-type{margin-top:0}.ce-paragraph p:last-of-type{margin-bottom:0}")),document.head.appendChild(e)}}catch(t){console.error("vite-plugin-css-injected-by-js",t)}})(); +(function(){"use strict";try{if(typeof document<"u"){var e=document.createElement("style");e.appendChild(document.createTextNode(".ce-paragraph{line-height:1.6em;outline:none}.ce-block:only-of-type .ce-paragraph[data-placeholder-active]:empty:before,.ce-block:only-of-type .ce-paragraph[data-placeholder-active][data-empty=true]:before{content:attr(data-placeholder-active)}.ce-paragraph p:first-of-type{margin-top:0}.ce-paragraph p:last-of-type{margin-bottom:0}")),document.head.appendChild(e)}}catch(a){console.error("vite-plugin-css-injected-by-js",a)}})(); (function(i,n){typeof exports=="object"&&typeof module<"u"?module.exports=n():typeof define=="function"&&define.amd?define(n):(i=typeof globalThis<"u"?globalThis:i||self,i.Paragraph=n())})(this,function(){"use strict";const i="",n='';function s(a){const e=document.createElement("div");e.innerHTML=a.trim();const t=document.createDocumentFragment();return t.append(...Array.from(e.childNodes)),t}/** * Base Paragraph Block for the Editor.js. * Represents a regular text block @@ -6,4 +6,4 @@ * @author CodeX (team@codex.so) * @copyright CodeX 2018 * @license The MIT License (MIT) - */class r{static get DEFAULT_PLACEHOLDER(){return""}constructor({data:e,config:t,api:o,readOnly:l}){this.api=o,this.readOnly=l,this._CSS={block:this.api.styles.block,wrapper:"ce-paragraph"},this.readOnly||(this.onKeyUp=this.onKeyUp.bind(this)),this._placeholder=t.placeholder?t.placeholder:r.DEFAULT_PLACEHOLDER,this._data=e??{},this._element=null,this._preserveBlank=t.preserveBlank??!1}onKeyUp(e){if(e.code!=="Backspace"&&e.code!=="Delete"||!this._element)return;const{textContent:t}=this._element;t===""&&(this._element.innerHTML="")}drawView(){const e=document.createElement("DIV");return e.classList.add(this._CSS.wrapper,this._CSS.block),e.contentEditable="false",e.dataset.placeholder=this.api.i18n.t(this._placeholder),this._data.text&&(e.innerHTML=this._data.text),this.readOnly||(e.contentEditable="true",e.addEventListener("keyup",this.onKeyUp)),e}render(){return this._element=this.drawView(),this._element}merge(e){if(!this._element)return;this._data.text+=e.text;const t=s(e.text);this._element.appendChild(t),this._element.normalize()}validate(e){return!(e.text.trim()===""&&!this._preserveBlank)}save(e){return{text:e.innerHTML}}onPaste(e){const t={text:e.detail.data.innerHTML};this._data=t,window.requestAnimationFrame(()=>{this._element&&(this._element.innerHTML=this._data.text||"")})}static get conversionConfig(){return{export:"text",import:"text"}}static get sanitize(){return{text:{br:!0}}}static get isReadOnlySupported(){return!0}static get pasteConfig(){return{tags:["P"]}}static get toolbox(){return{icon:n,title:"Text"}}}return r}); + */class r{static get DEFAULT_PLACEHOLDER(){return""}constructor({data:e,config:t,api:o,readOnly:l}){this.api=o,this.readOnly=l,this._CSS={block:this.api.styles.block,wrapper:"ce-paragraph"},this.readOnly||(this.onKeyUp=this.onKeyUp.bind(this)),this._placeholder=t.placeholder?t.placeholder:r.DEFAULT_PLACEHOLDER,this._data=e??{},this._element=null,this._preserveBlank=t.preserveBlank??!1}onKeyUp(e){if(e.code!=="Backspace"&&e.code!=="Delete"||!this._element)return;const{textContent:t}=this._element;t===""&&(this._element.innerHTML="")}drawView(){const e=document.createElement("DIV");return e.classList.add(this._CSS.wrapper,this._CSS.block),e.contentEditable="false",e.dataset.placeholderActive=this.api.i18n.t(this._placeholder),this._data.text&&(e.innerHTML=this._data.text),this.readOnly||(e.contentEditable="true",e.addEventListener("keyup",this.onKeyUp)),e}render(){return this._element=this.drawView(),this._element}merge(e){if(!this._element)return;this._data.text+=e.text;const t=s(e.text);this._element.appendChild(t),this._element.normalize()}validate(e){return!(e.text.trim()===""&&!this._preserveBlank)}save(e){return{text:e.innerHTML}}onPaste(e){const t={text:e.detail.data.innerHTML};this._data=t,window.requestAnimationFrame(()=>{this._element&&(this._element.innerHTML=this._data.text||"")})}static get conversionConfig(){return{export:"text",import:"text"}}static get sanitize(){return{text:{br:!0}}}static get isReadOnlySupported(){return!0}static get pasteConfig(){return{tags:["P"]}}static get toolbox(){return{icon:n,title:"Text"}}}return r}); diff --git a/package.json b/package.json index 9445d89..1305350 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@editorjs/paragraph", - "version": "2.11.5", + "version": "2.11.6", "keywords": [ "codex editor", "paragraph", diff --git a/src/index.css b/src/index.css index f635210..bdd3c63 100644 --- a/src/index.css +++ b/src/index.css @@ -3,21 +3,15 @@ outline: none; } -.ce-paragraph[data-placeholder]:empty::before{ - content: attr(data-placeholder); - color: #707684; - font-weight: normal; - opacity: 0; -} - -/** Show placeholder at the first paragraph if Editor is empty */ -.codex-editor--empty .ce-block:first-child .ce-paragraph[data-placeholder]:empty::before { - opacity: 1; -} - -.codex-editor--toolbox-opened .ce-block:first-child .ce-paragraph[data-placeholder]:empty::before, -.codex-editor--empty .ce-block:first-child .ce-paragraph[data-placeholder]:empty:focus::before { - opacity: 0; +/** + * Normally paragraph placeholder is shown only for the current block (thanks to "data-placeholder-active"). + * + * But there is a special case when the paragraph is the only block in the empty editor. + * When editor autofocus=false, there be no current block. We need to show the placeholder anyway. + */ +.ce-block:only-of-type .ce-paragraph[data-placeholder-active]:empty::before, +.ce-block:only-of-type .ce-paragraph[data-placeholder-active][data-empty="true"]::before { + content: attr(data-placeholder-active); } .ce-paragraph p:first-of-type{ diff --git a/src/index.ts b/src/index.ts index ff9e115..8179b63 100644 --- a/src/index.ts +++ b/src/index.ts @@ -212,7 +212,7 @@ export default class Paragraph { div.classList.add(this._CSS.wrapper, this._CSS.block); div.contentEditable = 'false'; - div.dataset.placeholder = this.api.i18n.t(this._placeholder); + div.dataset.placeholderActive = this.api.i18n.t(this._placeholder); if (this._data.text) { div.innerHTML = this._data.text; From ee9a685031b612c5f7f59203cb38d6a07cd857f3 Mon Sep 17 00:00:00 2001 From: Peter Savchenko Date: Thu, 4 Jul 2024 00:10:37 +0300 Subject: [PATCH 2/2] Update index.css --- src/index.css | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/index.css b/src/index.css index bdd3c63..0cd106e 100644 --- a/src/index.css +++ b/src/index.css @@ -4,10 +4,10 @@ } /** - * Normally paragraph placeholder is shown only for the current block (thanks to "data-placeholder-active"). + * Normally paragraph placeholder is shown only for the focused block (thanks to "data-placeholder-active"). * * But there is a special case when the paragraph is the only block in the empty editor. - * When editor autofocus=false, there be no current block. We need to show the placeholder anyway. + * When editor autofocus=false, there will be no focus. We need to show the placeholder anyway. */ .ce-block:only-of-type .ce-paragraph[data-placeholder-active]:empty::before, .ce-block:only-of-type .ce-paragraph[data-placeholder-active][data-empty="true"]::before {