@pie-lib/editable-html 9.5.13 → 10.0.0-beta.1
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.
- package/CHANGELOG.md +0 -302
- package/lib/components.js +116 -0
- package/lib/components.js.map +1 -0
- package/lib/editor.js +418 -103
- package/lib/editor.js.map +1 -1
- package/lib/index.js +101 -155
- package/lib/index.js.map +1 -1
- package/lib/new-serialization.js +320 -0
- package/lib/new-serialization.js.map +1 -0
- package/lib/old-serialization.js +330 -0
- package/lib/parse-html.js +1 -1
- package/lib/parse-html.js.map +1 -1
- package/lib/plugins/characters/custom-popper.js +1 -1
- package/lib/plugins/characters/custom-popper.js.map +1 -1
- package/lib/plugins/characters/index.js +21 -19
- package/lib/plugins/characters/index.js.map +1 -1
- package/lib/plugins/characters/utils.js +1 -1
- package/lib/plugins/characters/utils.js.map +1 -1
- package/lib/plugins/hotKeys/index.js +67 -0
- package/lib/plugins/hotKeys/index.js.map +1 -0
- package/lib/plugins/image/alt-dialog.js +1 -6
- package/lib/plugins/image/alt-dialog.js.map +1 -1
- package/lib/plugins/image/component.js +70 -53
- package/lib/plugins/image/component.js.map +1 -1
- package/lib/plugins/image/image-toolbar.js +7 -9
- package/lib/plugins/image/image-toolbar.js.map +1 -1
- package/lib/plugins/image/index.js +83 -27
- package/lib/plugins/image/index.js.map +1 -1
- package/lib/plugins/image/insert-image-handler.js +72 -33
- package/lib/plugins/image/insert-image-handler.js.map +1 -1
- package/lib/plugins/index.js +23 -41
- package/lib/plugins/index.js.map +1 -1
- package/lib/plugins/list/index.js +64 -100
- package/lib/plugins/list/index.js.map +1 -1
- package/lib/plugins/math/index.js +86 -60
- package/lib/plugins/math/index.js.map +1 -1
- package/lib/plugins/media/index.js +202 -132
- package/lib/plugins/media/index.js.map +1 -1
- package/lib/plugins/media/media-dialog.js +17 -16
- package/lib/plugins/media/media-dialog.js.map +1 -1
- package/lib/plugins/media/media-toolbar.js +3 -3
- package/lib/plugins/media/media-toolbar.js.map +1 -1
- package/lib/plugins/media/media-wrapper.js +21 -58
- package/lib/plugins/media/media-wrapper.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/choice.js +3 -3
- package/lib/plugins/respArea/drag-in-the-blank/choice.js.map +1 -1
- package/lib/plugins/respArea/drag-in-the-blank/index.js +3 -2
- package/lib/plugins/respArea/drag-in-the-blank/index.js.map +1 -1
- package/lib/plugins/respArea/explicit-constructed-response/index.js +3 -2
- package/lib/plugins/respArea/explicit-constructed-response/index.js.map +1 -1
- package/lib/plugins/respArea/icons/index.js +13 -15
- package/lib/plugins/respArea/icons/index.js.map +1 -1
- package/lib/plugins/respArea/index.js +87 -53
- package/lib/plugins/respArea/index.js.map +1 -1
- package/lib/plugins/respArea/inline-dropdown/index.js +4 -3
- package/lib/plugins/respArea/inline-dropdown/index.js.map +1 -1
- package/lib/plugins/respArea/utils.js +17 -20
- package/lib/plugins/respArea/utils.js.map +1 -1
- package/lib/plugins/table/icons/index.js +1 -1
- package/lib/plugins/table/icons/index.js.map +1 -1
- package/lib/plugins/table/index.js +381 -212
- package/lib/plugins/table/index.js.map +1 -1
- package/lib/plugins/table/table-toolbar.js +5 -6
- package/lib/plugins/table/table-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/default-toolbar.js +55 -11
- package/lib/plugins/toolbar/default-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/done-button.js +1 -1
- package/lib/plugins/toolbar/done-button.js.map +1 -1
- package/lib/plugins/toolbar/editor-and-toolbar.js +186 -232
- package/lib/plugins/toolbar/editor-and-toolbar.js.map +1 -1
- package/lib/plugins/toolbar/index.js +1 -2
- package/lib/plugins/toolbar/index.js.map +1 -1
- package/lib/plugins/toolbar/toolbar-buttons.js +1 -1
- package/lib/plugins/toolbar/toolbar-buttons.js.map +1 -1
- package/lib/plugins/toolbar/toolbar.js +253 -239
- package/lib/plugins/toolbar/toolbar.js.map +1 -1
- package/lib/plugins/utils.js +27 -2
- package/lib/plugins/utils.js.map +1 -1
- package/lib/serialization.js +1 -1
- package/lib/serialization.js.map +1 -1
- package/lib/slate-editor.js +302 -0
- package/lib/test-serializer.js +189 -0
- package/lib/test-serializer.js.map +1 -0
- package/lib/theme.js +1 -1
- package/lib/theme.js.map +1 -1
- package/package.json +18 -14
- package/playground/image/data.js +20 -20
- package/playground/image/index.html +22 -20
- package/playground/image/index.jsx +12 -10
- package/playground/index.html +25 -23
- package/playground/mathquill/index.html +23 -20
- package/playground/mathquill/index.jsx +18 -22
- package/playground/prod-test/index.html +24 -20
- package/playground/prod-test/index.jsx +5 -3
- package/playground/schema-override/data.js +10 -10
- package/playground/schema-override/image-plugin.jsx +3 -4
- package/playground/schema-override/index.html +21 -19
- package/playground/schema-override/index.jsx +13 -14
- package/playground/serialization/data.js +10 -10
- package/playground/serialization/image-plugin.jsx +3 -4
- package/playground/serialization/index.html +22 -20
- package/playground/table-examples.html +5 -8
- package/playground/webpack.config.js +10 -10
- package/src/components.js +135 -0
- package/src/editor.jsx +478 -141
- package/src/index.jsx +71 -95
- package/src/new-serialization.jsx +291 -0
- package/src/parse-html.js +1 -1
- package/src/plugins/characters/custom-popper.js +7 -7
- package/src/plugins/characters/index.jsx +33 -34
- package/src/plugins/characters/utils.js +81 -81
- package/src/plugins/hotKeys/index.js +54 -0
- package/src/plugins/image/alt-dialog.jsx +4 -5
- package/src/plugins/image/component.jsx +106 -89
- package/src/plugins/image/image-toolbar.jsx +27 -19
- package/src/plugins/image/index.jsx +75 -43
- package/src/plugins/image/insert-image-handler.js +62 -27
- package/src/plugins/index.jsx +23 -41
- package/src/plugins/list/index.jsx +70 -95
- package/src/plugins/math/index.jsx +102 -82
- package/src/plugins/media/index.jsx +159 -124
- package/src/plugins/media/media-dialog.js +98 -71
- package/src/plugins/media/media-toolbar.jsx +8 -8
- package/src/plugins/media/media-wrapper.jsx +29 -30
- package/src/plugins/respArea/drag-in-the-blank/choice.jsx +21 -19
- package/src/plugins/respArea/drag-in-the-blank/index.jsx +14 -11
- package/src/plugins/respArea/explicit-constructed-response/index.jsx +7 -6
- package/src/plugins/respArea/icons/index.jsx +11 -14
- package/src/plugins/respArea/index.jsx +92 -52
- package/src/plugins/respArea/inline-dropdown/index.jsx +9 -8
- package/src/plugins/respArea/utils.jsx +26 -35
- package/src/plugins/table/icons/index.jsx +17 -11
- package/src/plugins/table/index.jsx +288 -231
- package/src/plugins/table/table-toolbar.jsx +15 -11
- package/src/plugins/toolbar/default-toolbar.jsx +65 -19
- package/src/plugins/toolbar/done-button.jsx +4 -4
- package/src/plugins/toolbar/editor-and-toolbar.jsx +150 -145
- package/src/plugins/toolbar/index.jsx +2 -3
- package/src/plugins/toolbar/toolbar-buttons.jsx +11 -11
- package/src/plugins/toolbar/toolbar.jsx +244 -221
- package/src/plugins/utils.js +21 -4
- package/src/serialization.jsx +32 -32
- package/src/test-serializer.js +139 -0
- package/src/test-serializer.js.rej +20 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/plugins/math/index.jsx"],"names":["log","TEXT_NODE","generateAdditionalKeys","keyData","map","key","name","latex","write","label","CustomToolbarComp","React","memo","props","node","value","onFocus","onBlur","onClick","pluginProps","math","keypadMode","customKeys","controlledKeypadMode","onDone","update","data","toObject","change","setNodeByKey","nextText","document","getNextText","moveFocusTo","moveAnchorTo","onToolbarDone","onChange","onDataChange","get","prev","next","nodeNext","keypadModeNext","controlledKeypadModeNext","keypadModeChanged","controlledKeypadModeChanged","equal","equals","propTypes","SlatePropTypes","isRequired","PropTypes","func","MathPlugin","toolbar","icon","inlineMath","insertInline","supports","object","type","schema","match","pluginStyles","parentNode","p","position","top","renderNode","html","attributes","__html","ROUND_BRACKETS","SQUARE_BRACKETS","DOLLAR","DOUBLE_DOLLAR","Inline","create","isVoid","htmlDecode","input","doc","DOMParser","parseFromString","documentElement","textContent","getTagName","el","tagName","toLowerCase","lessThanHandling","arrowSplit","split","length","reduce","st","part","serialization","deserialize","hasMathChild","BLOCK_TAGS","childNodes","firstChild","dataset","newHtml","innerHTML","outerHTML","nodeType","hasLatex","hasAttribute","unwrapped","wrapType","nodes","wrapper","serialize","l","decoded"],"mappings":";;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;;;AACA,IAAMA,GAAG,GAAG,uBAAM,qCAAN,CAAZ;AAEA,IAAMC,SAAS,GAAG,CAAlB;;AAEA,SAASC,sBAAT,GAA8C;AAAA,MAAdC,OAAc,uEAAJ,EAAI;AAC5C,SAAOA,OAAO,CAACC,GAAR,CAAY,UAACC,GAAD;AAAA,WAAU;AAC3BC,MAAAA,IAAI,EAAED,GADqB;AAE3BE,MAAAA,KAAK,EAAEF,GAFoB;AAG3BG,MAAAA,KAAK,EAAEH,GAHoB;AAI3BI,MAAAA,KAAK,EAAEJ;AAJoB,KAAV;AAAA,GAAZ,CAAP;AAMD;;AAEM,IAAMK,iBAAiB,gBAAGC,kBAAMC,IAAN,CAC/B,UAACC,KAAD,EAAW;AACT,MAAQC,IAAR,GAAkDD,KAAlD,CAAQC,IAAR;AAAA,MAAcC,KAAd,GAAkDF,KAAlD,CAAcE,KAAd;AAAA,MAAqBC,OAArB,GAAkDH,KAAlD,CAAqBG,OAArB;AAAA,MAA8BC,MAA9B,GAAkDJ,KAAlD,CAA8BI,MAA9B;AAAA,MAAsCC,OAAtC,GAAkDL,KAAlD,CAAsCK,OAAtC;;AACA,aAAwBL,KAAK,IAAI,EAAjC;AAAA,MAAQM,WAAR,QAAQA,WAAR;;AACA,cAAiBA,WAAW,IAAI,EAAhC;AAAA,MAAQC,IAAR,SAAQA,IAAR;;AACA,cAAgEA,IAAI,IAAI,EAAxE;AAAA,MAAQC,UAAR,SAAQA,UAAR;AAAA,MAAoBC,UAApB,SAAoBA,UAApB;AAAA,oCAAgCC,oBAAhC;AAAA,MAAgCA,oBAAhC,sCAAuD,IAAvD;;AAEA,MAAMC,MAAM,GAAG,SAATA,MAAS,CAACjB,KAAD,EAAW;AACxB,QAAMkB,MAAM,mCACPX,IAAI,CAACY,IAAL,CAAUC,QAAV,EADO;AAEVpB,MAAAA,KAAK,EAALA;AAFU,MAAZ;;AAIA,QAAMqB,MAAM,GAAGb,KAAK,CAACa,MAAN,GAAeC,YAAf,CAA4Bf,IAAI,CAACT,GAAjC,EAAsC;AAAEqB,MAAAA,IAAI,EAAED;AAAR,KAAtC,CAAf;AAEA,QAAMK,QAAQ,GAAGf,KAAK,CAACgB,QAAN,CAAeC,WAAf,CAA2BlB,IAAI,CAACT,GAAhC,CAAjB;AAEAuB,IAAAA,MAAM,CAACK,WAAP,CAAmBH,QAAQ,CAACzB,GAA5B,EAAiC,CAAjC,EAAoC6B,YAApC,CAAiDJ,QAAQ,CAACzB,GAA1D,EAA+D,CAA/D;AAEAQ,IAAAA,KAAK,CAACsB,aAAN,CAAoBP,MAApB,EAA4B,KAA5B;AACD,GAZD;;AAcA,MAAMQ,QAAQ,GAAG,SAAXA,QAAW,CAAC7B,KAAD,EAAW;AAC1B,QAAMkB,MAAM,mCACPX,IAAI,CAACY,IAAL,CAAUC,QAAV,EADO;AAEVpB,MAAAA,KAAK,EAALA;AAFU,MAAZ;;AAIA,QAAMqB,MAAM,GAAGb,KAAK,CAACa,MAAN,GAAeC,YAAf,CAA4Bf,IAAI,CAACT,GAAjC,EAAsC;AAAEqB,MAAAA,IAAI,EAAED;AAAR,KAAtC,CAAf;AACAzB,IAAAA,GAAG,CAAC,uBAAD,EAA0B4B,MAA1B,CAAH;AACAf,IAAAA,KAAK,CAACwB,YAAN,CAAmBvB,IAAI,CAACT,GAAxB,EAA6BoB,MAA7B;AACD,GARD;;AAUA,MAAMlB,KAAK,GAAGO,IAAI,CAACY,IAAL,CAAUY,GAAV,CAAc,OAAd,CAAd;AAEA,sBACE,gCAAC,wBAAD;AACE,IAAA,SAAS,MADX;AAEE,IAAA,cAAc,EAAEpC,sBAAsB,CAACoB,UAAD,CAFxC;AAGE,IAAA,KAAK,EAAEf,KAHT;AAIE,IAAA,QAAQ,EAAE6B,QAJZ;AAKE,IAAA,MAAM,EAAEZ,MALV;AAME,IAAA,MAAM,EAAEP,MANV;AAOE,IAAA,OAAO,EAAED,OAPX;AAQE,IAAA,OAAO,EAAEE,OARX;AASE,IAAA,UAAU,EAAEG,UATd;AAUE,IAAA,oBAAoB,EAAEE;AAVxB,IADF;AAcD,CA/C8B,EAgD/B,UAACgB,IAAD,EAAOC,IAAP,EAAgB;AACd,MAAQ1B,IAAR,GAAwFyB,IAAxF,CAAQzB,IAAR;AAAA,0BAAwFyB,IAAxF,CAAcpB,WAAd;AAAA,qDAAiF,EAAjF;AAAA,gDAA6BC,IAA7B;AAAA,6DAA0E,EAA1E;AAAA,MAAqCC,UAArC,yBAAqCA,UAArC;AAAA,MAAiDE,oBAAjD,yBAAiDA,oBAAjD;AACA,MACQkB,QADR,GAGID,IAHJ,CACE1B,IADF;AAAA,0BAGI0B,IAHJ,CAEErB,WAFF;AAAA,qDAE+G,EAF/G;AAAA,gDAEiBC,IAFjB;AAAA,6DAEwG,EAFxG;AAAA,MAEqCsB,cAFrC,yBAEyBrB,UAFzB;AAAA,MAE2EsB,wBAF3E,yBAEqDpB,oBAFrD;AAIA,MAAMqB,iBAAiB,GAAGvB,UAAU,KAAKqB,cAAzC;AACA,MAAMG,2BAA2B,GAAGtB,oBAAoB,KAAKoB,wBAA7D;AAEA,MAAMG,KAAK,GAAGhC,IAAI,CAACiC,MAAL,CAAYN,QAAZ,CAAd;AACA,SAAOK,KAAK,IAAI,CAACF,iBAAV,IAA+B,CAACC,2BAAvC;AACD,CA3D8B,CAA1B;;;AA8DPnC,iBAAiB,CAACsC,SAAlB,GAA8B;AAC5BlC,EAAAA,IAAI,EAAEmC,2BAAenC,IAAf,CAAoBoC,UADE;AAE5BnC,EAAAA,KAAK,EAAEkC,2BAAelC,KAFM;AAG5BoB,EAAAA,aAAa,EAAEgB,sBAAUC,IAHG;AAI5Bf,EAAAA,YAAY,EAAEc,sBAAUC,IAJI;AAK5BpC,EAAAA,OAAO,EAAEmC,sBAAUC,IALS;AAM5BlC,EAAAA,OAAO,EAAEiC,sBAAUC,IANS;AAO5BnC,EAAAA,MAAM,EAAEkC,sBAAUC;AAPU,CAA9B;;AAUe,SAASC,UAAT,GAAsB;AACnC,SAAO;AACL/C,IAAAA,IAAI,EAAE,MADD;AAELgD,IAAAA,OAAO,EAAE;AACPC,MAAAA,IAAI,eAAE,gCAAC,qBAAD,OADC;AAEPrC,MAAAA,OAAO,EAAE,iBAACH,KAAD,EAAQqB,QAAR,EAAqB;AAC5BpC,QAAAA,GAAG,CAAC,cAAD,CAAH;AACA,YAAMoB,IAAI,GAAGoC,UAAU,EAAvB;AACA,YAAM5B,MAAM,GAAGb,KAAK,CAACa,MAAN,GAAe6B,YAAf,CAA4BrC,IAA5B,CAAf;AACAgB,QAAAA,QAAQ,CAACR,MAAD,CAAR;AACD,OAPM;AAQP8B,MAAAA,QAAQ,EAAE,kBAAC5C,IAAD;AAAA,eAAUA,IAAI,IAAIA,IAAI,CAAC6C,MAAL,KAAgB,QAAxB,IAAoC7C,IAAI,CAAC8C,IAAL,KAAc,MAA5D;AAAA,OARH;;AASP;AACN;AACA;AACA;AACA;AACA;AACA;AACMlD,MAAAA,iBAAiB,EAAjBA;AAhBO,KAFJ;AAoBLmD,IAAAA,MAAM,EAAE;AACN9B,MAAAA,QAAQ,EAAE;AAAE+B,QAAAA,KAAK,EAAE,CAAC;AAAEF,UAAAA,IAAI,EAAE;AAAR,SAAD;AAAT;AADJ,KApBH;AAwBLG,IAAAA,YAAY,EAAE,sBAACjD,IAAD,EAAOkD,UAAP,EAAmBC,CAAnB,EAAyB;AACrC,UAAIA,CAAJ,EAAO;AACL,eAAO;AACLC,UAAAA,QAAQ,EAAE,UADL;AAELC,UAAAA,GAAG,EAAE;AAFA,SAAP;AAID;AACF,KA/BI;AAiCLC,IAAAA,UAAU,EAAE,oBAACvD,KAAD,EAAW;AACrB,UAAIA,KAAK,CAACC,IAAN,CAAW8C,IAAX,KAAoB,MAAxB,EAAgC;AAC9B5D,QAAAA,GAAG,CAAC,qBAAD,EAAwBa,KAAK,CAACC,IAAN,CAAWY,IAAnC,CAAH;AACA,4BAAO,gCAAC,wBAAD,EAAiBb,KAAjB,CAAP;AACD;AAED;AACN;AACA;;;AACM,UAAIA,KAAK,CAACC,IAAN,CAAW8C,IAAX,KAAoB,QAAxB,EAAkC;AAChC,YAAMS,IAAI,GAAGxD,KAAK,CAACC,IAAN,CAAWY,IAAX,CAAgBY,GAAhB,CAAoB,MAApB,CAAb;AAEA,4BAAO,sEAAUzB,KAAK,CAACyD,UAAhB;AAA4B,UAAA,uBAAuB,EAAE;AAAEC,YAAAA,MAAM,EAAEF;AAAV;AAArD,WAAP;AACD;AACF;AA/CI,GAAP;AAiDD;;AAEDhB,UAAU,CAACmB,cAAX,GAA4B,gBAA5B;AACAnB,UAAU,CAACoB,eAAX,GAA6B,iBAA7B;AACApB,UAAU,CAACqB,MAAX,GAAoB,QAApB;AACArB,UAAU,CAACsB,aAAX,GAA2B,eAA3B;;AAEO,IAAMnB,UAAU,GAAG,SAAbA,UAAa;AAAA,SACxBoB,cAAOC,MAAP,CAAc;AACZlB,IAAAA,MAAM,EAAE,QADI;AAEZC,IAAAA,IAAI,EAAE,MAFM;AAGZkB,IAAAA,MAAM,EAAE,IAHI;AAIZpD,IAAAA,IAAI,EAAE;AACJnB,MAAAA,KAAK,EAAE;AADH;AAJM,GAAd,CADwB;AAAA,CAAnB;;;;AAUP,IAAMwE,UAAU,GAAG,SAAbA,UAAa,CAACC,KAAD,EAAW;AAC5B,MAAMC,GAAG,GAAG,IAAIC,SAAJ,GAAgBC,eAAhB,CAAgCH,KAAhC,EAAuC,WAAvC,CAAZ;AAEA,SAAOC,GAAG,CAACG,eAAJ,CAAoBC,WAA3B;AACD,CAJD;;AAMA,IAAMC,UAAU,GAAG,SAAbA,UAAa,CAACC,EAAD,EAAQ;AACzB,SAAO,CAAEA,EAAE,IAAIA,EAAE,CAACC,OAAV,IAAsB,EAAvB,EAA2BC,WAA3B,EAAP;AACD,CAFD;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAmB,CAACV,KAAD,EAAW;AAClC,MAAMW,UAAU,GAAGX,KAAK,CAACY,KAAN,CAAY,GAAZ,CAAnB,CADkC,CAGlC;;AACA,MAAIZ,KAAK,CAACa,MAAN,GAAe,CAAnB,EAAsB;AACpB,WAAOF,UAAU,CAACG,MAAX,CAAkB,UAACC,EAAD,EAAKC,IAAL,EAAc;AACrC;AACN;AACA;AACA;AACA;AACA;AACM,UAAIA,IAAI,CAAClC,KAAL,CAAW,sBAAX,CAAJ,EAAwC;AACtC,yBAAUiC,EAAV,SAAeA,EAAE,GAAG,GAAH,GAAS,EAA1B,SAA+BC,IAA/B;AACD;;AAED,uBAAUD,EAAV,SAAeA,EAAE,GAAG,MAAH,GAAY,EAA7B,SAAkCC,IAAlC;AACD,KAZM,EAYJ,EAZI,CAAP;AAaD;;AAED,SAAOhB,KAAP;AACD,CArBD;;AAuBO,IAAMiB,aAAa,GAAG;AAC3BC,EAAAA,WAD2B,uBACfX,EADe,EACX;AACd,QAAMC,OAAO,GAAGF,UAAU,CAACC,EAAD,CAA1B;AACA;AACJ;AACA;AACA;AACA;AACA;AACA;;AACI,QAAMY,YAAY,GAAGC,0BAAWZ,OAAX,KAAuBD,EAAE,CAACc,UAAH,CAAcR,MAAd,KAAyB,CAAhD,IAAqDP,UAAU,CAACC,EAAE,CAACe,UAAJ,CAAV,KAA8B,MAAxG;AACAtG,IAAAA,GAAG,CAAC,sBAAD,EAAyBwF,OAAzB,CAAH;AAEA;AACJ;AACA;;AACI,QAAIA,OAAO,KAAK,MAAZ,IAAuBD,EAAE,CAACgB,OAAH,IAAchB,EAAE,CAACgB,OAAH,CAAW3C,IAAX,KAAoB,QAAzD,IAAsEuC,YAA1E,EAAwF;AACtF,UAAMK,OAAO,GAAGL,YAAY,GAAGZ,EAAE,CAACkB,SAAN,GAAkBlB,EAAE,CAACmB,SAAjD;AAEA,aAAO;AACL/C,QAAAA,MAAM,EAAE,QADH;AAELmB,QAAAA,MAAM,EAAE,IAFH;AAGLlB,QAAAA,IAAI,EAAE,QAHD;AAILlC,QAAAA,IAAI,EAAE;AACJ2C,UAAAA,IAAI,EAAEmC;AADF;AAJD,OAAP;AAQD;;AAED,QAAIjB,EAAE,CAACoB,QAAH,KAAgB1G,SAApB,EAA+B;AAC7B;AACD;;AAED,QAAIuF,OAAO,KAAK,MAAhB,EAAwB;AACtB;AACD;;AAED,QAAMoB,QAAQ,GAAGrB,EAAE,CAACsB,YAAH,CAAgB,YAAhB,KAAiCtB,EAAE,CAACsB,YAAH,CAAgB,OAAhB,CAAlD;;AAEA,QAAID,QAAJ,EAAc;AACZ,UAAMrG,KAAK,GAAGwE,UAAU,CAACQ,EAAE,CAACkB,SAAJ,CAAxB;;AACA,wBAAgC,+BAAWlG,KAAX,CAAhC;AAAA,UAAQuG,SAAR,eAAQA,SAAR;AAAA,UAAmBC,QAAnB,eAAmBA,QAAnB;;AACA/G,MAAAA,GAAG,CAAC,6BAAD,EAAgC8G,SAAhC,EAA2CC,QAA3C,CAAH;AACA,aAAO;AACLpD,QAAAA,MAAM,EAAE,QADH;AAELC,QAAAA,IAAI,EAAE,MAFD;AAGLkB,QAAAA,MAAM,EAAE,IAHH;AAILkC,QAAAA,KAAK,EAAE,EAJF;AAKLtF,QAAAA,IAAI,EAAE;AACJnB,UAAAA,KAAK,EAAEuG,SADH;AAEJG,UAAAA,OAAO,EAAEF;AAFL;AALD,OAAP;AAUD;AACF,GAtD0B;AAuD3BG,EAAAA,SAvD2B,qBAuDjBvD,MAvDiB,EAuDT;AAChB,QAAIA,MAAM,CAACC,IAAP,KAAgB,MAApB,EAA4B;AAC1B,UAAMuD,CAAC,GAAGxD,MAAM,CAACjC,IAAP,CAAYY,GAAZ,CAAgB,OAAhB,CAAV;AACA,UAAM2E,OAAO,GAAGtD,MAAM,CAACjC,IAAP,CAAYY,GAAZ,CAAgB,SAAhB,CAAhB;AACAtC,MAAAA,GAAG,CAAC,qBAAD,EAAwBmH,CAAxB,CAAH;AACA,UAAMC,OAAO,GAAGrC,UAAU,CAACW,gBAAgB,CAACyB,CAAD,CAAjB,CAA1B;AACA,0BACE;AAAM,sBAAW,EAAjB;AAAoB,oBAAUC;AAA9B,SACG,6BAASA,OAAT,EAAkBH,OAAlB,CADH,CADF;AAKD;AAED;AACJ;AACA;;;AACI,QAAItD,MAAM,CAACC,IAAP,KAAgB,QAApB,EAA8B;AAC5B,UAAMS,IAAI,GAAGV,MAAM,CAACjC,IAAP,CAAYY,GAAZ,CAAgB,MAAhB,CAAb;AAEA,0BAAO;AAAM,qBAAU,QAAhB;AAAyB,QAAA,uBAAuB,EAAE;AAAEiC,UAAAA,MAAM,EAAEF;AAAV;AAAlD,QAAP;AACD;AACF;AA5E0B,CAAtB","sourcesContent":["import Functions from '@material-ui/icons/Functions';\nimport { Inline } from 'slate';\nimport { MathPreview, MathToolbar } from '@pie-lib/math-toolbar';\nimport { wrapMath, unWrapMath } from '@pie-lib/math-rendering';\nimport React from 'react';\nimport debug from 'debug';\nimport SlatePropTypes from 'slate-prop-types';\nimport PropTypes from 'prop-types';\n\nimport { BLOCK_TAGS } from '../../serialization';\nconst log = debug('@pie-lib:editable-html:plugins:math');\n\nconst TEXT_NODE = 3;\n\nfunction generateAdditionalKeys(keyData = []) {\n return keyData.map((key) => ({\n name: key,\n latex: key,\n write: key,\n label: key,\n }));\n}\n\nexport const CustomToolbarComp = React.memo(\n (props) => {\n const { node, value, onFocus, onBlur, onClick } = props;\n const { pluginProps } = props || {};\n const { math } = pluginProps || {};\n const { keypadMode, customKeys, controlledKeypadMode = true } = math || {};\n\n const onDone = (latex) => {\n const update = {\n ...node.data.toObject(),\n latex,\n };\n const change = value.change().setNodeByKey(node.key, { data: update });\n\n const nextText = value.document.getNextText(node.key);\n\n change.moveFocusTo(nextText.key, 0).moveAnchorTo(nextText.key, 0);\n\n props.onToolbarDone(change, false);\n };\n\n const onChange = (latex) => {\n const update = {\n ...node.data.toObject(),\n latex,\n };\n const change = value.change().setNodeByKey(node.key, { data: update });\n log('call onToolbarChange:', change);\n props.onDataChange(node.key, update);\n };\n\n const latex = node.data.get('latex');\n\n return (\n <MathToolbar\n autoFocus\n additionalKeys={generateAdditionalKeys(customKeys)}\n latex={latex}\n onChange={onChange}\n onDone={onDone}\n onBlur={onBlur}\n onFocus={onFocus}\n onClick={onClick}\n keypadMode={keypadMode}\n controlledKeypadMode={controlledKeypadMode}\n />\n );\n },\n (prev, next) => {\n const { node, pluginProps: { math: { keypadMode, controlledKeypadMode } = {} } = {} } = prev;\n const {\n node: nodeNext,\n pluginProps: { math: { keypadMode: keypadModeNext, controlledKeypadMode: controlledKeypadModeNext } = {} } = {},\n } = next;\n const keypadModeChanged = keypadMode !== keypadModeNext;\n const controlledKeypadModeChanged = controlledKeypadMode !== controlledKeypadModeNext;\n\n const equal = node.equals(nodeNext);\n return equal && !keypadModeChanged && !controlledKeypadModeChanged;\n },\n);\n\nCustomToolbarComp.propTypes = {\n node: SlatePropTypes.node.isRequired,\n value: SlatePropTypes.value,\n onToolbarDone: PropTypes.func,\n onDataChange: PropTypes.func,\n onFocus: PropTypes.func,\n onClick: PropTypes.func,\n onBlur: PropTypes.func,\n};\n\nexport default function MathPlugin() {\n return {\n name: 'math',\n toolbar: {\n icon: <Functions />,\n onClick: (value, onChange) => {\n log('[insertMath]');\n const math = inlineMath();\n const change = value.change().insertInline(math);\n onChange(change);\n },\n supports: (node) => node && node.object === 'inline' && node.type === 'math',\n /**\n * Return a react component function\n * @param node {Slate.Node}\n * @param value {Slate.Value}\n * @param onDone {(change?: Slate.Change, finishEditing :boolea) => void} - a function to call once the toolbar\n * has made any changes, call with the node.key and a data object.\n */\n CustomToolbarComp,\n },\n schema: {\n document: { match: [{ type: 'math' }] },\n },\n\n pluginStyles: (node, parentNode, p) => {\n if (p) {\n return {\n position: 'absolute',\n top: 'initial',\n };\n }\n },\n\n renderNode: (props) => {\n if (props.node.type === 'math') {\n log('[renderNode]: data:', props.node.data);\n return <MathPreview {...props} />;\n }\n\n /**\n * Here for rendering mathml content\n */\n if (props.node.type === 'mathml') {\n const html = props.node.data.get('html');\n\n return <span {...props.attributes} dangerouslySetInnerHTML={{ __html: html }} />;\n }\n },\n };\n}\n\nMathPlugin.ROUND_BRACKETS = 'round_brackets';\nMathPlugin.SQUARE_BRACKETS = 'square_brackets';\nMathPlugin.DOLLAR = 'dollar';\nMathPlugin.DOUBLE_DOLLAR = 'double_dollar';\n\nexport const inlineMath = () =>\n Inline.create({\n object: 'inline',\n type: 'math',\n isVoid: true,\n data: {\n latex: '',\n },\n });\n\nconst htmlDecode = (input) => {\n const doc = new DOMParser().parseFromString(input, 'text/html');\n\n return doc.documentElement.textContent;\n};\n\nconst getTagName = (el) => {\n return ((el && el.tagName) || '').toLowerCase();\n};\n\n/**\n * Makes sure that strings that contain stuff like:\n * x<y are not transformed into x by the DOMParser because it thinks\n * that <y is the start of a dom element tag\n * @param input\n * @returns {*}\n */\nconst lessThanHandling = (input) => {\n const arrowSplit = input.split('<');\n\n // if we don't have at least 2 characters there's no point in checking\n if (input.length > 2) {\n return arrowSplit.reduce((st, part) => {\n /*\n We check if this element resulted is:\n div - continuation of a beginning of a HTML element\n /div - closing of a HTML tag\n br/> - beginning and closing of a html TAG\n */\n if (part.match(/<[a-zA-Z/][\\s\\S]*>/gi)) {\n return `${st}${st ? '<' : ''}${part}`;\n }\n\n return `${st}${st ? '<' : ''}${part}`;\n }, '');\n }\n\n return input;\n};\n\nexport const serialization = {\n deserialize(el) {\n const tagName = getTagName(el);\n /**\n * This is used for when there's a wrapper over the mathml element.\n * Because of this slate rule: \"Only allow block nodes or inline and text nodes in blocks.\"\n * The element that contains only the mathml is removed (along with the math) because it has\n * an inline child and the block is of type block\n * This is for legacy content only since our math rendering is valid for the core slate rules\n */\n const hasMathChild = BLOCK_TAGS[tagName] && el.childNodes.length === 1 && getTagName(el.firstChild) === 'math';\n log('[deserialize] name: ', tagName);\n\n /**\n * This is here in order to be able to render mathml content\n */\n if (tagName === 'math' || (el.dataset && el.dataset.type === 'mathml') || hasMathChild) {\n const newHtml = hasMathChild ? el.innerHTML : el.outerHTML;\n\n return {\n object: 'inline',\n isVoid: true,\n type: 'mathml',\n data: {\n html: newHtml,\n },\n };\n }\n\n if (el.nodeType === TEXT_NODE) {\n return;\n }\n\n if (tagName !== 'span') {\n return;\n }\n\n const hasLatex = el.hasAttribute('data-latex') || el.hasAttribute('latex');\n\n if (hasLatex) {\n const latex = htmlDecode(el.innerHTML);\n const { unwrapped, wrapType } = unWrapMath(latex);\n log('[deserialize]: noBrackets: ', unwrapped, wrapType);\n return {\n object: 'inline',\n type: 'math',\n isVoid: true,\n nodes: [],\n data: {\n latex: unwrapped,\n wrapper: wrapType,\n },\n };\n }\n },\n serialize(object) {\n if (object.type === 'math') {\n const l = object.data.get('latex');\n const wrapper = object.data.get('wrapper');\n log('[serialize] latex: ', l);\n const decoded = htmlDecode(lessThanHandling(l));\n return (\n <span data-latex=\"\" data-raw={decoded}>\n {wrapMath(decoded, wrapper)}\n </span>\n );\n }\n\n /**\n * Here for rendering mathml content\n */\n if (object.type === 'mathml') {\n const html = object.data.get('html');\n\n return <span data-type=\"mathml\" dangerouslySetInnerHTML={{ __html: html }} />;\n }\n },\n};\n"],"file":"index.js"}
|
|
1
|
+
{"version":3,"file":"index.js","names":["log","debug","TEXT_NODE","generateAdditionalKeys","keyData","map","key","name","latex","write","label","CustomToolbarComp","React","memo","props","node","onFocus","onBlur","onClick","editor","nodePath","pluginProps","math","keypadMode","customKeys","controlledKeypadMode","onDone","update","data","apply","type","path","properties","newProperties","ReactEditor","focus","Transforms","move","distance","unit","prev","next","nodeNext","keypadModeNext","controlledKeypadModeNext","keypadModeChanged","controlledKeypadModeChanged","equal","isEqual","propTypes","PropTypes","object","shape","string","children","array","isRequired","value","arrayOf","onToolbarDone","func","MathPlugin","toolbar","icon","inlineMath","insertNode","rules","isVoid","isInline","element","supports","schema","document","match","pluginStyles","parentNode","p","position","top","renderNode","html","get","attributes","__html","ROUND_BRACKETS","SQUARE_BRACKETS","DOLLAR","DOUBLE_DOLLAR","text","htmlDecode","input","doc","DOMParser","parseFromString","documentElement","textContent","getTagName","el","tagName","toLowerCase","lessThanHandling","arrowSplit","split","length","reduce","st","part","serialization","deserialize","hasMathChild","BLOCK_TAGS","childNodes","firstChild","dataset","newHtml","innerHTML","outerHTML","jsx","nodeType","hasLatex","hasAttribute","unWrapMath","unwrapped","wrapType","wrapper","serialize","decoded","wrapMath"],"sources":["../../../src/plugins/math/index.jsx"],"sourcesContent":["import React from 'react';\nimport { Editor, Inline, Transforms } from 'slate';\nimport { ReactEditor } from 'slate-react';\nimport { jsx } from 'slate-hyperscript';\nimport Functions from '@material-ui/icons/Functions';\nimport { MathPreview, MathToolbar } from '@pie-lib/math-toolbar';\nimport { wrapMath, unWrapMath } from '@pie-lib/math-rendering';\nimport debug from 'debug';\nimport PropTypes from 'prop-types';\nimport isEqual from 'lodash/isEqual';\n\nimport { BLOCK_TAGS } from '../../new-serialization';\nconst log = debug('@pie-lib:editable-html:plugins:math');\n\nconst TEXT_NODE = 3;\n\nfunction generateAdditionalKeys(keyData = []) {\n return keyData.map(key => ({\n name: key,\n latex: key,\n write: key,\n label: key\n }));\n}\n\nexport const CustomToolbarComp = React.memo(\n props => {\n const { node, onFocus, onBlur, onClick, editor, nodePath } = props;\n const { pluginProps } = props || {};\n const { math } = pluginProps || {};\n const { keypadMode, customKeys, controlledKeypadMode = true } = math || {};\n\n const onDone = latex => {\n const update = {\n ...node.data,\n latex\n };\n editor.apply({\n type: 'set_node',\n path: nodePath,\n properties: {\n data: node.data\n },\n newProperties: { data: update }\n });\n ReactEditor.focus(editor);\n Transforms.move(editor, { distance: 1, unit: 'offset' });\n };\n\n const latex = node.data.latex;\n\n return (\n <MathToolbar\n autoFocus\n additionalKeys={generateAdditionalKeys(customKeys)}\n latex={latex}\n onDone={onDone}\n onBlur={onBlur}\n onFocus={onFocus}\n onClick={onClick}\n keypadMode={keypadMode}\n controlledKeypadMode={controlledKeypadMode}\n />\n );\n },\n (prev, next) => {\n const { node, pluginProps: { math: { keypadMode, controlledKeypadMode } = {} } = {} } = prev;\n const {\n node: nodeNext,\n pluginProps: {\n math: { keypadMode: keypadModeNext, controlledKeypadMode: controlledKeypadModeNext } = {}\n } = {}\n } = next;\n const keypadModeChanged = keypadMode !== keypadModeNext;\n const controlledKeypadModeChanged = controlledKeypadMode !== controlledKeypadModeNext;\n\n const equal = isEqual(node, nodeNext);\n return equal && !keypadModeChanged && !controlledKeypadModeChanged;\n }\n);\n\nCustomToolbarComp.propTypes = {\n editor: PropTypes.object,\n node: PropTypes.shape({\n type: PropTypes.string,\n children: PropTypes.array,\n data: PropTypes.object\n }).isRequired,\n value: PropTypes.arrayOf(\n PropTypes.shape({\n type: PropTypes.string,\n children: PropTypes.array,\n data: PropTypes.object\n })\n ).isRequired,\n onToolbarDone: PropTypes.func,\n onFocus: PropTypes.func,\n onClick: PropTypes.func,\n onBlur: PropTypes.func\n};\n\nexport default function MathPlugin() {\n return {\n name: 'math',\n toolbar: {\n icon: <Functions />,\n onClick: editor => {\n log('[insertMath]');\n const math = inlineMath();\n\n editor.insertNode(math);\n },\n /**\n * Return a react component function\n * @param node {Slate.Node}\n * @param value {Slate.Value}\n * @param onDone {(change?: Slate.Change, finishEditing :boolea) => void} - a function to call once the toolbar\n * has made any changes, call with the node.key and a data object.\n */\n CustomToolbarComp\n },\n rules: editor => {\n const { isVoid, isInline } = editor;\n\n editor.isVoid = element => {\n return element.type === 'math' ? true : isVoid(element);\n };\n\n editor.isInline = element => {\n return element.type === 'math' ? true : isInline(element);\n };\n\n return editor;\n },\n supports: node => node && node.type === 'math',\n schema: {\n document: { match: [{ type: 'math' }] }\n },\n\n pluginStyles: (node, parentNode, p) => {\n if (p) {\n return {\n position: 'absolute',\n top: 'initial'\n };\n }\n },\n\n renderNode: props => {\n if (props.node.type === 'math') {\n log('[renderNode]: data:', props.node.data);\n return <MathPreview {...props} />;\n }\n\n /**\n * Here for rendering mathml content\n */\n if (props.node.type === 'mathml') {\n const html = props.node.data.get('html');\n\n return <span {...props.attributes} dangerouslySetInnerHTML={{ __html: html }} />;\n }\n }\n };\n}\n\nMathPlugin.ROUND_BRACKETS = 'round_brackets';\nMathPlugin.SQUARE_BRACKETS = 'square_brackets';\nMathPlugin.DOLLAR = 'dollar';\nMathPlugin.DOUBLE_DOLLAR = 'double_dollar';\n\nexport const inlineMath = () => ({\n type: 'math',\n data: {\n latex: ''\n },\n children: [{ text: '' }]\n});\n\nconst htmlDecode = input => {\n const doc = new DOMParser().parseFromString(input, 'text/html');\n\n return doc.documentElement.textContent;\n};\n\nconst getTagName = el => {\n return ((el && el.tagName) || '').toLowerCase();\n};\n\n/**\n * Makes sure that strings that contain stuff like:\n * x<y are not transformed into x by the DOMParser because it thinks\n * that <y is the start of a dom element tag\n * @param input\n * @returns {*}\n */\nconst lessThanHandling = input => {\n const arrowSplit = input.split('<');\n\n // if we don't have at least 2 characters there's no point in checking\n if (input.length > 2) {\n return arrowSplit.reduce((st, part) => {\n /*\n We check if this element resulted is:\n div - continuation of a beginning of a HTML element\n /div - closing of a HTML tag\n br/> - beginning and closing of a html TAG\n */\n if (part.match(/<[a-zA-Z/][\\s\\S]*>/gi)) {\n return `${st}${st ? '<' : ''}${part}`;\n }\n\n return `${st}${st ? '<' : ''}${part}`;\n }, '');\n }\n\n return input;\n};\n\nexport const serialization = {\n deserialize(el, children) {\n const tagName = getTagName(el);\n /**\n * This is used for when there's a wrapper over the mathml element.\n * Because of this slate rule: \"Only allow block nodes or inline and text nodes in blocks.\"\n * The element that contains only the mathml is removed (along with the math) because it has\n * an inline child and the block is of type block\n * This is for legacy content only since our math rendering is valid for the core slate rules\n */\n const hasMathChild =\n BLOCK_TAGS[tagName] && el.childNodes.length === 1 && getTagName(el.firstChild) === 'math';\n log('[deserialize] name: ', tagName);\n\n /**\n * This is here in order to be able to render mathml content\n */\n if (tagName === 'math' || (el.dataset && el.dataset.type === 'mathml') || hasMathChild) {\n const newHtml = hasMathChild ? el.innerHTML : el.outerHTML;\n\n return jsx('element', {\n type: 'mathml',\n data: {\n html: newHtml\n }\n });\n }\n\n if (el.nodeType === TEXT_NODE) {\n return;\n }\n\n if (tagName !== 'span') {\n return;\n }\n\n const hasLatex = el.hasAttribute('data-latex') || el.hasAttribute('latex');\n\n if (hasLatex) {\n const latex = htmlDecode(el.innerHTML);\n const { unwrapped, wrapType } = unWrapMath(latex);\n log('[deserialize]: noBrackets: ', unwrapped, wrapType);\n\n return jsx('element', {\n type: 'math',\n data: {\n latex: unwrapped,\n wrapper: wrapType\n }\n });\n }\n },\n serialize(object) {\n if (object.type === 'math') {\n const { latex, wrapper } = object.data || {};\n log('[serialize] latex: ', latex);\n const decoded = htmlDecode(lessThanHandling(latex));\n return (\n <span data-latex=\"\" data-raw={decoded}>\n {wrapMath(decoded, wrapper)}\n </span>\n );\n }\n\n /**\n * Here for rendering mathml content\n */\n if (object.type === 'mathml') {\n const { html } = object.data || {};\n\n return <span data-type=\"mathml\" dangerouslySetInnerHTML={{ __html: html }} />;\n }\n }\n};\n"],"mappings":"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"}
|
|
@@ -10,6 +10,8 @@ exports.serialization = exports.insertDialog = void 0;
|
|
|
10
10
|
|
|
11
11
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
12
12
|
|
|
13
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
14
|
+
|
|
13
15
|
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
14
16
|
|
|
15
17
|
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
@@ -20,10 +22,18 @@ var _reactDom = _interopRequireDefault(require("react-dom"));
|
|
|
20
22
|
|
|
21
23
|
var _slate = require("slate");
|
|
22
24
|
|
|
25
|
+
var _slateHyperscript = require("slate-hyperscript");
|
|
26
|
+
|
|
27
|
+
var _slateReact = require("slate-react");
|
|
28
|
+
|
|
23
29
|
var _Theaters = _interopRequireDefault(require("@material-ui/icons/Theaters"));
|
|
24
30
|
|
|
25
31
|
var _VolumeUp = _interopRequireDefault(require("@material-ui/icons/VolumeUp"));
|
|
26
32
|
|
|
33
|
+
var _get = _interopRequireDefault(require("lodash/get"));
|
|
34
|
+
|
|
35
|
+
var _omit2 = _interopRequireDefault(require("lodash/omit"));
|
|
36
|
+
|
|
27
37
|
var _debug = _interopRequireDefault(require("debug"));
|
|
28
38
|
|
|
29
39
|
var _mediaDialog = _interopRequireDefault(require("./media-dialog"));
|
|
@@ -39,6 +49,12 @@ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (O
|
|
|
39
49
|
|
|
40
50
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
41
51
|
|
|
52
|
+
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
|
|
53
|
+
|
|
54
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
55
|
+
|
|
56
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
57
|
+
|
|
42
58
|
var log = (0, _debug["default"])('@pie-lib:editable-html:plugins:image');
|
|
43
59
|
|
|
44
60
|
var removeDialogs = function removeDialogs() {
|
|
@@ -79,18 +95,59 @@ var insertDialog = function insertDialog(props) {
|
|
|
79
95
|
};
|
|
80
96
|
|
|
81
97
|
exports.insertDialog = insertDialog;
|
|
98
|
+
|
|
99
|
+
var getNodeBy = function getNodeBy(editor, callback) {
|
|
100
|
+
var descendants = _slate.Node.descendants(editor, {
|
|
101
|
+
reverse: true
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
var _iterator = _createForOfIteratorHelper(descendants),
|
|
105
|
+
_step;
|
|
106
|
+
|
|
107
|
+
try {
|
|
108
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
109
|
+
var _step$value = (0, _slicedToArray2["default"])(_step.value, 2),
|
|
110
|
+
descendant = _step$value[0],
|
|
111
|
+
descendantPath = _step$value[1];
|
|
112
|
+
|
|
113
|
+
if (callback(descendant, descendantPath)) {
|
|
114
|
+
return [descendant, descendantPath];
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
} catch (err) {
|
|
118
|
+
_iterator.e(err);
|
|
119
|
+
} finally {
|
|
120
|
+
_iterator.f();
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
|
|
124
|
+
var moveFocusAfterMedia = function moveFocusAfterMedia(editor, node) {
|
|
125
|
+
if (!editor || !node) {
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
setTimeout(function () {
|
|
130
|
+
_slateReact.ReactEditor.focus(editor);
|
|
131
|
+
|
|
132
|
+
_slate.Transforms.move(editor, {
|
|
133
|
+
distance: 1,
|
|
134
|
+
unit: 'offset'
|
|
135
|
+
});
|
|
136
|
+
}, 0);
|
|
137
|
+
};
|
|
138
|
+
|
|
82
139
|
var types = ['audio', 'video'];
|
|
83
140
|
|
|
84
141
|
function MediaPlugin(type, opts) {
|
|
85
142
|
var toolbar = {
|
|
86
143
|
icon: type === 'audio' ? /*#__PURE__*/_react["default"].createElement(_VolumeUp["default"], null) : /*#__PURE__*/_react["default"].createElement(_Theaters["default"], null),
|
|
87
|
-
onClick: function onClick(
|
|
144
|
+
onClick: function onClick(editor) {
|
|
88
145
|
log('[toolbar] onClick');
|
|
89
|
-
|
|
90
|
-
var inline = _slate.Inline.create({
|
|
146
|
+
var inline = {
|
|
91
147
|
type: type,
|
|
92
148
|
isVoid: true,
|
|
93
149
|
data: {
|
|
150
|
+
newMedia: true,
|
|
94
151
|
editing: false,
|
|
95
152
|
ends: undefined,
|
|
96
153
|
height: undefined,
|
|
@@ -99,104 +156,142 @@ function MediaPlugin(type, opts) {
|
|
|
99
156
|
src: undefined,
|
|
100
157
|
url: undefined,
|
|
101
158
|
width: undefined
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
159
|
+
},
|
|
160
|
+
children: [{
|
|
161
|
+
text: ''
|
|
162
|
+
}]
|
|
163
|
+
};
|
|
164
|
+
editor.insertNode(inline);
|
|
107
165
|
insertDialog({
|
|
108
166
|
type: type,
|
|
109
167
|
opts: opts,
|
|
110
168
|
callback: function callback(val, data) {
|
|
111
|
-
var
|
|
112
|
-
return
|
|
113
|
-
})
|
|
114
|
-
|
|
115
|
-
|
|
169
|
+
var _getNodeBy = getNodeBy(editor, function (descendant) {
|
|
170
|
+
return descendant.type === type && (0, _get["default"])(descendant, 'data.newMedia');
|
|
171
|
+
}),
|
|
172
|
+
_getNodeBy2 = (0, _slicedToArray2["default"])(_getNodeBy, 2),
|
|
173
|
+
node = _getNodeBy2[0],
|
|
174
|
+
nodePath = _getNodeBy2[1];
|
|
175
|
+
|
|
176
|
+
if (node) {
|
|
116
177
|
if (!val) {
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
178
|
+
editor.apply({
|
|
179
|
+
type: 'remove_node',
|
|
180
|
+
path: nodePath
|
|
120
181
|
});
|
|
121
182
|
} else {
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
183
|
+
editor.apply({
|
|
184
|
+
type: 'set_node',
|
|
185
|
+
path: nodePath,
|
|
186
|
+
properties: {
|
|
187
|
+
data: node.data
|
|
188
|
+
},
|
|
189
|
+
newProperties: {
|
|
190
|
+
data: _objectSpread(_objectSpread({}, data), {}, {
|
|
191
|
+
newMedia: false
|
|
192
|
+
})
|
|
193
|
+
}
|
|
128
194
|
});
|
|
129
195
|
}
|
|
130
|
-
} else {
|
|
131
|
-
opts.focus();
|
|
132
196
|
}
|
|
197
|
+
|
|
198
|
+
moveFocusAfterMedia(editor, node);
|
|
133
199
|
}
|
|
134
200
|
});
|
|
135
|
-
},
|
|
136
|
-
supports: function supports(node) {
|
|
137
|
-
return node.object === 'inline' && node.type === type;
|
|
138
201
|
}
|
|
139
202
|
};
|
|
140
203
|
return {
|
|
141
204
|
name: type,
|
|
142
205
|
toolbar: toolbar,
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
206
|
+
rules: function rules(editor) {
|
|
207
|
+
var isVoid = editor.isVoid,
|
|
208
|
+
isInline = editor.isInline;
|
|
209
|
+
|
|
210
|
+
editor.isVoid = function (element) {
|
|
211
|
+
return ['audio', 'video'].includes(element.type) ? true : isVoid(element);
|
|
212
|
+
};
|
|
213
|
+
|
|
214
|
+
editor.isInline = function (element) {
|
|
215
|
+
return ['audio', 'video'].includes(element.type) ? true : isInline(element);
|
|
216
|
+
};
|
|
217
|
+
|
|
218
|
+
return editor;
|
|
219
|
+
},
|
|
220
|
+
supports: function supports(node) {
|
|
221
|
+
return node.type === type;
|
|
147
222
|
},
|
|
148
223
|
renderNode: function renderNode(props) {
|
|
149
224
|
if (props.node.type === type) {
|
|
150
225
|
var node = props.node,
|
|
151
|
-
|
|
226
|
+
editor = props.editor;
|
|
152
227
|
var data = node.data;
|
|
153
|
-
|
|
154
|
-
var
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
228
|
+
|
|
229
|
+
var _omit = (0, _omit2["default"])(data, ['newMedia', 'urlToUse']),
|
|
230
|
+
src = _omit.src,
|
|
231
|
+
height = _omit.height,
|
|
232
|
+
width = _omit.width,
|
|
233
|
+
editing = _omit.editing,
|
|
234
|
+
tag = _omit.tag,
|
|
235
|
+
rest = (0, _objectWithoutProperties2["default"])(_omit, _excluded2);
|
|
236
|
+
|
|
237
|
+
var attributes = _objectSpread(_objectSpread({}, rest), props.attributes);
|
|
238
|
+
|
|
239
|
+
var handleEdit = function handleEdit(event) {
|
|
240
|
+
var nodeToEdit = _slateReact.ReactEditor.toSlateNode(editor, event.target);
|
|
241
|
+
|
|
242
|
+
var nodePath = _slateReact.ReactEditor.findPath(editor, nodeToEdit);
|
|
243
|
+
|
|
244
|
+
editor.apply({
|
|
245
|
+
type: 'set_node',
|
|
246
|
+
path: nodePath,
|
|
247
|
+
properties: {
|
|
248
|
+
data: node.data
|
|
249
|
+
},
|
|
250
|
+
newProperties: {
|
|
251
|
+
data: _objectSpread(_objectSpread({}, data), {}, {
|
|
252
|
+
editing: true
|
|
253
|
+
})
|
|
254
|
+
}
|
|
167
255
|
});
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
256
|
+
insertDialog(_objectSpread(_objectSpread({}, data), {}, {
|
|
257
|
+
edit: true,
|
|
258
|
+
type: type,
|
|
259
|
+
opts: opts,
|
|
260
|
+
callback: function callback(val, data) {
|
|
261
|
+
var _getNodeBy3 = getNodeBy(editor, function (descendant) {
|
|
262
|
+
return descendant.type === type && (0, _get["default"])(descendant, 'data.editing');
|
|
263
|
+
}),
|
|
264
|
+
_getNodeBy4 = (0, _slicedToArray2["default"])(_getNodeBy3, 2),
|
|
265
|
+
nodeIsThere = _getNodeBy4[0],
|
|
266
|
+
nodePath = _getNodeBy4[1];
|
|
267
|
+
|
|
268
|
+
if (nodeIsThere && val) {
|
|
269
|
+
editor.apply({
|
|
270
|
+
type: 'set_node',
|
|
271
|
+
path: nodePath,
|
|
272
|
+
properties: {
|
|
273
|
+
data: node.data
|
|
274
|
+
},
|
|
275
|
+
newProperties: {
|
|
276
|
+
data: _objectSpread(_objectSpread({}, data), {}, {
|
|
277
|
+
editing: true
|
|
278
|
+
})
|
|
279
|
+
}
|
|
177
280
|
});
|
|
178
|
-
|
|
179
|
-
if (nodeIsThere && val) {
|
|
180
|
-
var _c2 = change.setNodeByKey(key, {
|
|
181
|
-
data: data,
|
|
182
|
-
editing: false
|
|
183
|
-
});
|
|
184
|
-
|
|
185
|
-
opts.onChange(_c2, function () {
|
|
186
|
-
return opts.focus('beginning', nodeIsThere);
|
|
187
|
-
});
|
|
188
|
-
} else {
|
|
189
|
-
opts.focus();
|
|
190
|
-
}
|
|
191
281
|
}
|
|
192
|
-
}
|
|
193
|
-
});
|
|
282
|
+
}
|
|
283
|
+
}));
|
|
194
284
|
};
|
|
195
285
|
|
|
196
|
-
var handleDelete = function handleDelete() {
|
|
197
|
-
var
|
|
198
|
-
|
|
199
|
-
|
|
286
|
+
var handleDelete = function handleDelete(event) {
|
|
287
|
+
var nodeToEdit = _slateReact.ReactEditor.toSlateNode(editor, event.target);
|
|
288
|
+
|
|
289
|
+
var nodePath = _slateReact.ReactEditor.findPath(editor, nodeToEdit);
|
|
290
|
+
|
|
291
|
+
editor.apply({
|
|
292
|
+
type: 'remove_node',
|
|
293
|
+
path: nodePath
|
|
294
|
+
});
|
|
200
295
|
};
|
|
201
296
|
|
|
202
297
|
var style = {};
|
|
@@ -210,11 +305,11 @@ function MediaPlugin(type, opts) {
|
|
|
210
305
|
}
|
|
211
306
|
|
|
212
307
|
if (tag === 'audio') {
|
|
213
|
-
return /*#__PURE__*/_react["default"].createElement(_mediaWrapper["default"],
|
|
214
|
-
editor: true,
|
|
308
|
+
return /*#__PURE__*/_react["default"].createElement(_mediaWrapper["default"], {
|
|
215
309
|
"data-type": type,
|
|
216
|
-
width: style.width
|
|
217
|
-
|
|
310
|
+
width: style.width,
|
|
311
|
+
attributes: attributes
|
|
312
|
+
}, /*#__PURE__*/_react["default"].createElement("audio", {
|
|
218
313
|
controls: "controls"
|
|
219
314
|
}, /*#__PURE__*/_react["default"].createElement("source", {
|
|
220
315
|
type: "audio/mp3",
|
|
@@ -222,14 +317,16 @@ function MediaPlugin(type, opts) {
|
|
|
222
317
|
})), /*#__PURE__*/_react["default"].createElement(_mediaToolbar["default"], {
|
|
223
318
|
hideEdit: true,
|
|
224
319
|
onRemove: handleDelete
|
|
225
|
-
}));
|
|
320
|
+
}), props.children);
|
|
226
321
|
}
|
|
227
322
|
|
|
228
|
-
return /*#__PURE__*/_react["default"].createElement(_mediaWrapper["default"],
|
|
229
|
-
editor: true,
|
|
323
|
+
return /*#__PURE__*/_react["default"].createElement(_mediaWrapper["default"], {
|
|
230
324
|
"data-type": type,
|
|
231
|
-
width: style.width
|
|
232
|
-
|
|
325
|
+
width: style.width,
|
|
326
|
+
attributes: attributes
|
|
327
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
328
|
+
contentEditable: false
|
|
329
|
+
}, /*#__PURE__*/_react["default"].createElement("iframe", (0, _extends2["default"])({
|
|
233
330
|
frameBorder: "0",
|
|
234
331
|
allow: "accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture",
|
|
235
332
|
allowFullScreen: true,
|
|
@@ -238,37 +335,8 @@ function MediaPlugin(type, opts) {
|
|
|
238
335
|
}, rest, style)), /*#__PURE__*/_react["default"].createElement(_mediaToolbar["default"], {
|
|
239
336
|
onEdit: handleEdit,
|
|
240
337
|
onRemove: handleDelete
|
|
241
|
-
}));
|
|
338
|
+
})), props.children);
|
|
242
339
|
}
|
|
243
|
-
},
|
|
244
|
-
normalizeNode: function normalizeNode(node) {
|
|
245
|
-
var textNodeMap = {};
|
|
246
|
-
var updateNodesArray = [];
|
|
247
|
-
var index = 0;
|
|
248
|
-
if (node.object !== 'document') return;
|
|
249
|
-
node.findDescendant(function (d) {
|
|
250
|
-
if (d.object === 'text') {
|
|
251
|
-
textNodeMap[index] = d;
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
var isMedia = types.indexOf(d.type) >= 0;
|
|
255
|
-
|
|
256
|
-
if (isMedia) {
|
|
257
|
-
if (index > 0 && textNodeMap[index - 1] && textNodeMap[index - 1].text === '') {
|
|
258
|
-
updateNodesArray.push(textNodeMap[index - 1]);
|
|
259
|
-
}
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
index++;
|
|
263
|
-
});
|
|
264
|
-
if (!updateNodesArray.length) return;
|
|
265
|
-
return function (change) {
|
|
266
|
-
change.withoutNormalization(function () {
|
|
267
|
-
updateNodesArray.forEach(function (n) {
|
|
268
|
-
return change.insertTextByKey(n.key, 0, ' ');
|
|
269
|
-
});
|
|
270
|
-
});
|
|
271
|
-
};
|
|
272
340
|
}
|
|
273
341
|
};
|
|
274
342
|
}
|
|
@@ -304,10 +372,8 @@ var serialization = {
|
|
|
304
372
|
log('deserialize: ', name);
|
|
305
373
|
var width = parseInt(el.getAttribute('width'), 10) || null;
|
|
306
374
|
var height = parseInt(el.getAttribute('height'), 10) || null;
|
|
307
|
-
var out = {
|
|
308
|
-
object: 'inline',
|
|
375
|
+
var out = (0, _slateHyperscript.jsx)('element', {
|
|
309
376
|
type: type,
|
|
310
|
-
isVoid: true,
|
|
311
377
|
data: {
|
|
312
378
|
tag: tag,
|
|
313
379
|
src: src || el.getAttribute('src'),
|
|
@@ -319,26 +385,30 @@ var serialization = {
|
|
|
319
385
|
width: width,
|
|
320
386
|
url: url
|
|
321
387
|
}
|
|
322
|
-
};
|
|
388
|
+
});
|
|
323
389
|
log('return object: ', out);
|
|
324
390
|
return out;
|
|
325
391
|
},
|
|
326
|
-
serialize: function serialize(object
|
|
327
|
-
/*, children*/
|
|
328
|
-
) {
|
|
392
|
+
serialize: function serialize(object) {
|
|
329
393
|
var typeIndex = types.indexOf(object.type);
|
|
330
|
-
|
|
394
|
+
|
|
395
|
+
if (typeIndex < 0) {
|
|
396
|
+
return;
|
|
397
|
+
}
|
|
398
|
+
|
|
331
399
|
var type = types[typeIndex];
|
|
332
|
-
|
|
333
|
-
var
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
400
|
+
|
|
401
|
+
var _ref2 = object.data || {},
|
|
402
|
+
editing = _ref2.editing,
|
|
403
|
+
tag = _ref2.tag,
|
|
404
|
+
ends = _ref2.ends,
|
|
405
|
+
src = _ref2.src,
|
|
406
|
+
starts = _ref2.starts,
|
|
407
|
+
title = _ref2.title,
|
|
408
|
+
width = _ref2.width,
|
|
409
|
+
height = _ref2.height,
|
|
410
|
+
url = _ref2.url;
|
|
411
|
+
|
|
342
412
|
var style = {};
|
|
343
413
|
|
|
344
414
|
if (width) {
|
|
@@ -381,4 +451,4 @@ var serialization = {
|
|
|
381
451
|
}
|
|
382
452
|
};
|
|
383
453
|
exports.serialization = serialization;
|
|
384
|
-
//# sourceMappingURL=index.js.map
|
|
454
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["log","debug","removeDialogs","prevDialogs","document","querySelectorAll","forEach","s","remove","insertDialog","props","newEl","createElement","type","callback","opts","rest","initialBodyOverflow","body","style","overflow","className","handleClose","val","data","el","uploadSoundSupport","ReactDOM","render","appendChild","getNodeBy","editor","descendants","SlateNode","reverse","descendant","descendantPath","moveFocusAfterMedia","node","setTimeout","ReactEditor","focus","Transforms","move","distance","unit","types","MediaPlugin","toolbar","icon","onClick","inline","isVoid","newMedia","editing","ends","undefined","height","title","starts","src","url","width","children","text","insertNode","get","nodePath","apply","path","properties","newProperties","name","rules","isInline","element","includes","supports","renderNode","omit","tag","attributes","handleEdit","event","nodeToEdit","toSlateNode","target","findPath","edit","nodeIsThere","handleDelete","serialization","deserialize","dataset","typeIndex","indexOf","Element","tagName","toLowerCase","firstChild","getAttribute","parseInt","out","jsx","serialize","object","divProps"],"sources":["../../../src/plugins/media/index.jsx"],"sourcesContent":["import React from 'react';\nimport ReactDOM from 'react-dom';\nimport { Node as SlateNode, Transforms } from 'slate';\nimport { jsx } from 'slate-hyperscript';\nimport { ReactEditor } from 'slate-react';\nimport TheatersIcon from '@material-ui/icons/Theaters';\nimport VolumeUpIcon from '@material-ui/icons/VolumeUp';\nimport get from 'lodash/get';\nimport omit from 'lodash/omit';\n\nimport debug from 'debug';\nimport MediaDialog from './media-dialog';\nimport MediaToolbar from './media-toolbar';\nimport MediaWrapper from './media-wrapper';\n\nconst log = debug('@pie-lib:editable-html:plugins:image');\n\nconst removeDialogs = () => {\n  const prevDialogs = document.querySelectorAll('.insert-media-dialog');\n\n  prevDialogs.forEach(s => s.remove());\n};\n\nexport const insertDialog = props => {\n  const newEl = document.createElement('div');\n  const { type, callback, opts, ...rest } = props;\n  const initialBodyOverflow = document.body.style.overflow;\n\n  removeDialogs();\n\n  newEl.className = 'insert-media-dialog';\n  document.body.style.overflow = 'hidden';\n\n  const handleClose = (val, data) => {\n    callback(val, data);\n    newEl.remove();\n    document.body.style.overflow = initialBodyOverflow;\n  };\n\n  const el = (\n    <MediaDialog\n      {...rest}\n      uploadSoundSupport={opts.uploadSoundSupport}\n      type={type}\n      disablePortal={true}\n      open={true}\n      handleClose={handleClose}\n    />\n  );\n\n  ReactDOM.render(el, newEl);\n\n  document.body.appendChild(newEl);\n};\n\nconst getNodeBy = (editor, callback) => {\n  const descendants = SlateNode.descendants(editor, {\n    reverse: true\n  });\n\n  for (const [descendant, descendantPath] of descendants) {\n    if (callback(descendant, descendantPath)) {\n      return [descendant, descendantPath];\n    }\n  }\n};\n\nconst moveFocusAfterMedia = (editor, node) => {\n  if (!editor || !node) {\n    return;\n  }\n\n  setTimeout(() => {\n    ReactEditor.focus(editor);\n    Transforms.move(editor, { distance: 1, unit: 'offset' });\n  }, 0);\n};\n\nconst types = ['audio', 'video'];\n\nexport default function MediaPlugin(type, opts) {\n  const toolbar = {\n    icon: type === 'audio' ? <VolumeUpIcon /> : <TheatersIcon />,\n    onClick: editor => {\n      log('[toolbar] onClick');\n      const inline = {\n        type: type,\n        isVoid: true,\n        data: {\n          newMedia: true,\n          editing: false,\n          ends: undefined,\n          height: undefined,\n          title: undefined,\n          starts: undefined,\n          src: undefined,\n          url: undefined,\n          width: undefined\n        },\n        children: [{ text: '' }]\n      };\n\n      editor.insertNode(inline);\n\n      insertDialog({\n        type,\n        opts,\n        callback: (val, data) => {\n          const [node, nodePath] = getNodeBy(\n            editor,\n            descendant => descendant.type === type && get(descendant, 'data.newMedia')\n          );\n\n          if (node) {\n            if (!val) {\n              editor.apply({\n                type: 'remove_node',\n                path: nodePath\n              });\n            } else {\n              editor.apply({\n                type: 'set_node',\n                path: nodePath,\n                properties: {\n                  data: node.data\n                },\n                newProperties: {\n                  data: {\n                    ...data,\n                    newMedia: false\n                  }\n                }\n              });\n            }\n          }\n\n          moveFocusAfterMedia(editor, node);\n        }\n      });\n    }\n  };\n\n  return {\n    name: type,\n    toolbar,\n    rules: editor => {\n      const { isVoid, isInline } = editor;\n\n      editor.isVoid = element => {\n        return ['audio', 'video'].includes(element.type) ? true : isVoid(element);\n      };\n\n      editor.isInline = element => {\n        return ['audio', 'video'].includes(element.type) ? true : isInline(element);\n      };\n\n      return editor;\n    },\n    supports: node => node.type === type,\n    renderNode(props) {\n      if (props.node.type === type) {\n        const { node, editor } = props;\n        const { data } = node;\n        const { src, height, width, editing, tag, ...rest } = omit(data, ['newMedia', 'urlToUse']);\n        const attributes = { ...rest, ...props.attributes };\n        const handleEdit = event => {\n          const nodeToEdit = ReactEditor.toSlateNode(editor, event.target);\n          const nodePath = ReactEditor.findPath(editor, nodeToEdit);\n\n          editor.apply({\n            type: 'set_node',\n            path: nodePath,\n            properties: {\n              data: node.data\n            },\n            newProperties: {\n              data: {\n                ...data,\n                editing: true\n              }\n            }\n          });\n\n          insertDialog({\n            ...data,\n            edit: true,\n            type,\n            opts,\n            callback: (val, data) => {\n              const [nodeIsThere, nodePath] = getNodeBy(\n                editor,\n                descendant => descendant.type === type && get(descendant, 'data.editing')\n              );\n\n              if (nodeIsThere && val) {\n                editor.apply({\n                  type: 'set_node',\n                  path: nodePath,\n                  properties: {\n                    data: node.data\n                  },\n                  newProperties: {\n                    data: {\n                      ...data,\n                      editing: true\n                    }\n                  }\n                });\n              }\n            }\n          });\n        };\n        const handleDelete = event => {\n          const nodeToEdit = ReactEditor.toSlateNode(editor, event.target);\n          const nodePath = ReactEditor.findPath(editor, nodeToEdit);\n\n          editor.apply({\n            type: 'remove_node',\n            path: nodePath\n          });\n        };\n        const style = {};\n\n        if (width) {\n          style.width = `${width}px`;\n        }\n\n        if (height) {\n          style.height = `${height}px`;\n        }\n\n        if (tag === 'audio') {\n          return (\n            <MediaWrapper data-type={type} width={style.width} attributes={attributes}>\n              <audio controls=\"controls\">\n                <source type=\"audio/mp3\" src={src} />\n              </audio>\n              <MediaToolbar hideEdit onRemove={handleDelete} />\n              {props.children}\n            </MediaWrapper>\n          );\n        }\n\n        return (\n          <MediaWrapper data-type={type} width={style.width} attributes={attributes}>\n            <div contentEditable={false}>\n              <iframe\n                frameBorder=\"0\"\n                allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n                allowFullScreen\n                src={src}\n                editing={editing ? 1 : 0}\n                {...rest}\n                {...style}\n              />\n              <MediaToolbar onEdit={handleEdit} onRemove={handleDelete} />\n            </div>\n            {props.children}\n          </MediaWrapper>\n        );\n      }\n    },\n  };\n}\n\nexport const serialization = {\n  deserialize(el /*, next*/) {\n    let type = el.dataset && el.dataset.type;\n    let tag = 'iframe';\n    let src;\n    const typeIndex = types.indexOf(type);\n\n    if (typeIndex < 0) {\n      if (el instanceof Element && el.tagName.toLowerCase() === 'audio') {\n        type = 'audio';\n        tag = 'audio';\n        src = el.firstChild?.getAttribute('src');\n      } else {\n        return;\n      }\n    }\n\n    const { ends, starts, title, editing, url } = el.dataset || {};\n\n    log('deserialize: ', name);\n    const width = parseInt(el.getAttribute('width'), 10) || null;\n    const height = parseInt(el.getAttribute('height'), 10) || null;\n\n    const out = jsx('element', {\n      type,\n      data: {\n        tag,\n        src: src || el.getAttribute('src'),\n        editing,\n        ends,\n        height,\n        starts,\n        title,\n        width,\n        url\n      }\n    });\n\n    log('return object: ', out);\n    return out;\n  },\n  serialize(object) {\n    const typeIndex = types.indexOf(object.type);\n\n    if (typeIndex < 0) {\n      return;\n    }\n\n    const type = types[typeIndex];\n\n    const { editing, tag, ends, src, starts, title, width, height, url } = object.data || {};\n    const style = {};\n\n    if (width) {\n      style.width = `${width}px`;\n    }\n\n    if (height) {\n      style.height = `${height}px`;\n    }\n\n    const divProps = {\n      'data-editing': editing,\n      'data-ends': ends,\n      'data-starts': starts,\n      'data-title': title,\n      'data-url': url\n    };\n    const props = {\n      ...style,\n      src\n    };\n\n    if (tag === 'audio') {\n      return (\n        <audio controls=\"controls\">\n          <source type=\"audio/mp3\" src={src} />\n        </audio>\n      );\n    }\n\n    return (\n      <iframe\n        data-type={type}\n        src={src}\n        {...divProps}\n        frameBorder=\"0\"\n        allow=\"accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture\"\n        allowFullScreen\n        {...props}\n      />\n    );\n  }\n};\n"],"mappings":"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"}
|