polotno 0.38.3 → 0.38.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -10,4 +10,4 @@
10
10
  line-height: auto;
11
11
  margin: 0;
12
12
  }
13
- `,RichEditor=({html:e,onBlur:t,onChange:r,element:a})=>{const i=react_1.default.useRef(null);return react_1.default.useEffect((()=>{if(!i.current)return;const e=new quill_1.default(i.current,{toolbar:!1,keyboard:!1,clipboard:{matchVisual:!1}});return exports.quillRef.editor.instance=e,window.__polotnoQuill=e,e.on("text-change",(()=>{var t;e.getSelection()&&(exports.quillRef.currentFormat=e.getFormat()),r(null===(t=i.current)||void 0===t?void 0:t.childNodes[0].innerHTML)})),e.setSelection(0,0,"api"),e.on("selection-change",(r=>{r||t(),r&&(exports.quillRef.currentFormat=e.getFormat())})),i.current.childNodes[0].addEventListener("blur",(e=>{var r;(null===(r=e.relatedTarget)||void 0===r?void 0:r.classList.contains("ql-clipboard"))||t()})),()=>{exports.quillRef.editor.instance=null,exports.quillRef.currentFormat={},delete window.__polotnoQuill}}),[]),react_1.default.useEffect((()=>{var t;const r=exports.quillRef.editor.instance,n=r.getSelection();if(!((null===(t=i.current)||void 0===t?void 0:t.childNodes[0].innerHTML)===a.text)){var l=r.clipboard.convert("<div class='ql-editor' style='outline: none;'>"+e+"<p><br></p></div>");r.setContents(l),r.history.clear(),n&&(r.setSelection(n.index,n.length),exports.quillRef.currentFormat=r.getFormat())}}),[a.text]),react_1.default.createElement(RichTextContainer,{ref:i,style:{fontSize:a.fontSize,color:a.fill,width:a.width,fontFamily:a.fontFamily,lineHeight:a.lineHeight,letterSpacing:a.letterSpacing,textAlign:a.align}})};function useHtmlSize(e,t,r){return react_1.default.useMemo((()=>(0,html2canvas_1.detectSize)(e)),[e,t.width,r])}exports.HTMLElement=(0,mobx_react_lite_1.observer)((({element:e,store:t})=>{const r=react_1.default.useRef(null),[a,i]=react_1.default.useState(),[n,l]=react_1.default.useState(!1),[o,u]=react_1.default.useState(!0),[c,s]=react_1.default.useState(!1),[d,f]=react_1.default.useState(!1),_=t.selectedElements.indexOf(e)>=0,[m]=(0,text_element_1.useFontLoader)(t,e.fontFamily);(0,use_fadein_1.useFadeIn)(r);const h=m?e.fontFamily:"Arial",g=`<div style="width: ${e.width||100}px; color: ${e.fill}; font-size: ${e.fontSize}px; font-family: '${h}'; text-decoration: ${e.textDecoration}; text-align: ${e.align}; line-height: ${e.lineHeight}; letter-spacing: ${e.letterSpacing}; font-style: ${e.fontStyle}; font-weight: ${e.fontWeight}; -webkit-text-stroke: ${e.strokeWidth}px ${e.stroke}" contentEditable>${e.text}</div>`,{width:p,height:v}=useHtmlSize(g,e,m);react_1.default.useEffect((()=>{e.set({height:v})}),[v]),react_1.default.useLayoutEffect((()=>{if(n||c)return;const t=(0,loader_1.incrementLoader)();u(!0),async function(){await new Promise((e=>setTimeout(e)));const r=await(0,html2canvas_1.htmlToCanvas)({html:g,width:e.width||1,height:v||1,fontFamily:h});i(r),u(!1),konva_1.default.Util.requestAnimFrame(t)}()}),[g,n,v,c,h]),react_1.default.useLayoutEffect((()=>mobx.autorun((()=>{const t=r.current;(0,apply_filters_1.applyFilter)(t,e)}))),[a]);const x=n||o;return react_1.default.createElement(react_1.default.Fragment,null,react_1.default.createElement(react_konva_1.Image,{ref:r,name:"element",image:a,x:e.x,y:e.y,rotation:e.rotation,width:e.width,height:e.height,visible:!x,draggable:!e.locked,opacity:c?0:e.opacity,shadowEnabled:e.shadowEnabled,shadowBlur:e.shadowBlur,onMouseEnter:()=>{f(!0)},onMouseLeave:()=>{f(!1)},onDragStart:()=>{t.history.startTransaction()},onDragMove:t=>{setTimeout((()=>{e.set({x:t.target.x(),y:t.target.y()})}))},onDragEnd:r=>{e.set({x:r.target.x(),y:r.target.y()}),t.history.endTransaction()},id:e.id,onDblClick:()=>{e.locked||s(!0)},onDblTap:()=>{e.locked||s(!0)},onTransformStart:e=>{var t;const r=(null===(t=e.target.getStage())||void 0===t?void 0:t.findOne("Transformer")).getActiveAnchor();("middle-left"===r||"middle-right"===r)&&l(!0)},onTransform:t=>{var r;const a=(null===(r=t.target.getStage())||void 0===r?void 0:r.findOne("Transformer")).getActiveAnchor();if("middle-left"===a||"middle-right"===a){const r=t.target.scaleX(),a=Math.max(t.target.width()*r,e.fontSize);t.target.width(a),t.target.scaleX(1),e.set({width:a})}e.set({x:t.target.x(),y:t.target.y(),rotation:t.target.rotation()})},onTransformEnd:t=>{l(!1),u(!0);const r=t.target.scaleX();t.target.scaleX(1),t.target.scaleY(1),e.set({fontSize:e.fontSize*r,width:t.target.width()*r,x:t.target.x(),y:t.target.y(),rotation:t.target.rotation()})}}),x&&react_1.default.createElement(react_konva_1.Group,{x:e.x,y:e.y,rotation:e.rotation},react_1.default.createElement(react_konva_utils_1.Html,{divProps:{style:{pointerEvents:"none"}}},react_1.default.createElement(RichTextContainer,{dangerouslySetInnerHTML:{__html:g},style:{pointerEvents:"none",display:"inline-block"}}))),c&&react_1.default.createElement(react_konva_1.Group,{x:e.x,y:e.y,rotation:e.rotation},react_1.default.createElement(react_konva_utils_1.Html,null,react_1.default.createElement(RichEditor,{html:g,element:e,onChange:t=>{e.set({text:t})},onBlur:e=>{s(!1)}}))),(_||d)&&react_1.default.createElement(highlighter_1.Highlighter,{element:e}))}));
13
+ `,RichEditor=({html:e,onBlur:t,onChange:r,element:a})=>{const i=react_1.default.useRef(null);return react_1.default.useEffect((()=>{if(!i.current)return;const e=new quill_1.default(i.current,{toolbar:!1,keyboard:!1,clipboard:{matchVisual:!1}});return exports.quillRef.editor.instance=e,window.__polotnoQuill=e,e.on("text-change",(()=>{var t;e.getSelection()&&(exports.quillRef.currentFormat=e.getFormat()),r(null===(t=i.current)||void 0===t?void 0:t.childNodes[0].innerHTML)})),e.setSelection(0,0,"api"),e.on("selection-change",(r=>{r||t(),r&&(exports.quillRef.currentFormat=e.getFormat())})),i.current.childNodes[0].addEventListener("blur",(e=>{var r;(null===(r=e.relatedTarget)||void 0===r?void 0:r.classList.contains("ql-clipboard"))||t()})),()=>{exports.quillRef.editor.instance=null,exports.quillRef.currentFormat={},delete window.__polotnoQuill}}),[]),react_1.default.useEffect((()=>{var t;const r=exports.quillRef.editor.instance,n=r.getSelection();if(!((null===(t=i.current)||void 0===t?void 0:t.childNodes[0].innerHTML)===a.text)){var l=r.clipboard.convert("<div class='ql-editor' style='outline: none;'>"+e+"<p><br></p></div>");r.setContents(l),r.history.clear(),n&&(r.setSelection(n.index,n.length),exports.quillRef.currentFormat=r.getFormat())}}),[a.text]),react_1.default.createElement(RichTextContainer,{ref:i,style:{fontSize:a.fontSize,color:a.fill,width:a.width,fontFamily:a.fontFamily,lineHeight:a.lineHeight,letterSpacing:a.letterSpacing,textAlign:a.align}})};function useHtmlSize(e,t,r){return react_1.default.useMemo((()=>(0,html2canvas_1.detectSize)(e)),[e,t.width,r])}exports.HTMLElement=(0,mobx_react_lite_1.observer)((({element:e,store:t})=>{const r=react_1.default.useRef(null),[a,i]=react_1.default.useState(),[n,l]=react_1.default.useState(!1),[o,u]=react_1.default.useState(!0),[c,s]=react_1.default.useState(!1),[d,f]=react_1.default.useState(!1),_=t.selectedElements.indexOf(e)>=0,[m]=(0,text_element_1.useFontLoader)(t,e.fontFamily);(0,use_fadein_1.useFadeIn)(r);const h=m?e.fontFamily:"Arial",g=`<div style="width: ${e.width||100}px; color: ${e.fill}; font-size: ${e.fontSize}px; font-family: '${h}'; text-decoration: ${e.textDecoration}; text-align: ${e.align}; line-height: ${e.lineHeight}; letter-spacing: ${e.letterSpacing}; font-style: ${e.fontStyle}; font-weight: ${e.fontWeight}; -webkit-text-stroke: ${e.strokeWidth}px ${e.stroke}" contentEditable>${e.text}</div>`,{width:p,height:v}=useHtmlSize(g,e,m);react_1.default.useEffect((()=>{e.set({height:v})}),[v]),react_1.default.useLayoutEffect((()=>{if(n||c)return;const t=(0,loader_1.incrementLoader)();u(!0),async function(){await new Promise((e=>setTimeout(e)));const r=await(0,html2canvas_1.htmlToCanvas)({html:g,width:e.width||1,height:v||1,fontFamily:h});i(r),u(!1),konva_1.default.Util.requestAnimFrame(t)}()}),[g,n,v,c,h]);const x=n||o;return react_1.default.useLayoutEffect((()=>mobx.autorun((()=>{const t=r.current;(0,apply_filters_1.applyFilter)(t,e)}))),[a,x]),react_1.default.createElement(react_1.default.Fragment,null,react_1.default.createElement(react_konva_1.Image,{ref:r,name:"element",image:a,x:e.x,y:e.y,rotation:e.rotation,width:e.width,height:e.height,visible:!x,draggable:!e.locked,opacity:c?0:e.opacity,shadowEnabled:e.shadowEnabled,shadowBlur:e.shadowBlur,onMouseEnter:()=>{f(!0)},onMouseLeave:()=>{f(!1)},onDragStart:()=>{t.history.startTransaction()},onDragMove:t=>{setTimeout((()=>{e.set({x:t.target.x(),y:t.target.y()})}))},onDragEnd:r=>{e.set({x:r.target.x(),y:r.target.y()}),t.history.endTransaction()},id:e.id,onDblClick:()=>{e.locked||s(!0)},onDblTap:()=>{e.locked||s(!0)},onTransformStart:e=>{var t;const r=(null===(t=e.target.getStage())||void 0===t?void 0:t.findOne("Transformer")).getActiveAnchor();("middle-left"===r||"middle-right"===r)&&l(!0)},onTransform:t=>{var r;const a=(null===(r=t.target.getStage())||void 0===r?void 0:r.findOne("Transformer")).getActiveAnchor();if("middle-left"===a||"middle-right"===a){const r=t.target.scaleX(),a=Math.max(t.target.width()*r,e.fontSize);t.target.width(a),t.target.scaleX(1),e.set({width:a})}e.set({x:t.target.x(),y:t.target.y(),rotation:t.target.rotation()})},onTransformEnd:t=>{l(!1),u(!0);const r=t.target.scaleX();t.target.scaleX(1),t.target.scaleY(1),e.set({fontSize:e.fontSize*r,width:t.target.width()*r,x:t.target.x(),y:t.target.y(),rotation:t.target.rotation()})}}),x&&react_1.default.createElement(react_konva_1.Group,{x:e.x,y:e.y,rotation:e.rotation},react_1.default.createElement(react_konva_utils_1.Html,{divProps:{style:{pointerEvents:"none"}}},react_1.default.createElement(RichTextContainer,{dangerouslySetInnerHTML:{__html:g},style:{pointerEvents:"none",display:"inline-block"}}))),c&&react_1.default.createElement(react_konva_1.Group,{x:e.x,y:e.y,rotation:e.rotation},react_1.default.createElement(react_konva_utils_1.Html,null,react_1.default.createElement(RichEditor,{html:g,element:e,onChange:t=>{e.set({text:t})},onBlur:e=>{s(!1)}}))),(_||d)&&react_1.default.createElement(highlighter_1.Highlighter,{element:e}))}));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "polotno",
3
- "version": "0.38.3",
3
+ "version": "0.38.5",
4
4
  "description": "Design Editor Framework",
5
5
  "author": "Anton Lavrenov",
6
6
  "keywords": [