yapp 4.0.227 → 4.0.229

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.
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", {
3
+ value: true
4
+ });
5
+ Object.defineProperty(exports, "CONTENT_CHANGE_CUSTOM_EVENT_TYPE", {
6
+ enumerable: true,
7
+ get: function() {
8
+ return CONTENT_CHANGE_CUSTOM_EVENT_TYPE;
9
+ }
10
+ });
11
+ var CONTENT_CHANGE_CUSTOM_EVENT_TYPE = "contentchange-custom";
12
+
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jdXN0b21FdmVudFR5cGVzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5leHBvcnQgY29uc3QgQ09OVEVOVF9DSEFOR0VfQ1VTVE9NX0VWRU5UX1RZUEUgPSBcImNvbnRlbnRjaGFuZ2UtY3VzdG9tXCI7XG4iXSwibmFtZXMiOlsiQ09OVEVOVF9DSEFOR0VfQ1VTVE9NX0VWRU5UX1RZUEUiXSwibWFwcGluZ3MiOiJBQUFBOzs7OytCQUVhQTs7O2VBQUFBOzs7QUFBTixJQUFNQSxtQ0FBbUMifQ==
@@ -212,21 +212,21 @@ function _create_super(Derived) {
212
212
  }
213
213
  function _templateObject() {
214
214
  var data = _tagged_template_literal([
215
- "\n\n z-index: 0;\n width: auto;\n height: auto;\n overflow: hidden;\n position: relative;\n grid-area: overlay-rich-textarea;\n\n color: inherit;\n font-size: inherit;\n line-height: inherit;\n font-family: inherit;\n font-weight: inherit;\n caret-color: inherit;\n border-color: inherit;\n text-rendering: inherit;\n background-color: inherit;\n font-feature-settings: inherit;\n\n"
215
+ "\n\n z-index: 0;\n width: auto;\n height: auto;\n overflow: hidden;\n position: relative;\n grid-area: pretty-rich-textarea;\n\n color: inherit;\n font-size: inherit;\n line-height: inherit;\n font-family: inherit;\n font-weight: inherit;\n caret-color: inherit;\n border-color: inherit;\n text-rendering: inherit;\n background-color: inherit;\n font-feature-settings: inherit;\n\n"
216
216
  ]);
217
217
  _templateObject = function _templateObject() {
218
218
  return data;
219
219
  };
220
220
  return data;
221
221
  }
222
- var OverlayDiv = /*#__PURE__*/ function(Element) {
223
- _inherits(OverlayDiv, Element);
224
- var _super = _create_super(OverlayDiv);
225
- function OverlayDiv() {
226
- _class_call_check(this, OverlayDiv);
222
+ var PrettyDiv = /*#__PURE__*/ function(Element) {
223
+ _inherits(PrettyDiv, Element);
224
+ var _super = _create_super(PrettyDiv);
225
+ function PrettyDiv() {
226
+ _class_call_check(this, PrettyDiv);
227
227
  return _super.apply(this, arguments);
228
228
  }
229
- _create_class(OverlayDiv, [
229
+ _create_class(PrettyDiv, [
230
230
  {
231
231
  key: "update",
232
232
  value: function update(tokens) {
@@ -262,10 +262,10 @@ var OverlayDiv = /*#__PURE__*/ function(Element) {
262
262
  {
263
263
  key: "parentContext",
264
264
  value: function parentContext() {
265
- var context = this.getContext(), updateOverlayDiv = this.update.bind(this), scrollOverlayDiv = this.scroll.bind(this); ///
265
+ var context = this.getContext(), updatePrettyDiv = this.update.bind(this), scrollPrettyDiv = this.scroll.bind(this); ///
266
266
  return _object_spread_props(_object_spread({}, context), {
267
- updateOverlayDiv: updateOverlayDiv,
268
- scrollOverlayDiv: scrollOverlayDiv
267
+ updatePrettyDiv: updatePrettyDiv,
268
+ scrollPrettyDiv: scrollPrettyDiv
269
269
  });
270
270
  }
271
271
  },
@@ -279,15 +279,15 @@ var OverlayDiv = /*#__PURE__*/ function(Element) {
279
279
  }
280
280
  }
281
281
  ]);
282
- return OverlayDiv;
282
+ return PrettyDiv;
283
283
  }(_wrap_native_super(_easy.Element));
284
- _define_property(OverlayDiv, "tagName", "div");
285
- _define_property(OverlayDiv, "ignoredProperties", [
284
+ _define_property(PrettyDiv, "tagName", "div");
285
+ _define_property(PrettyDiv, "ignoredProperties", [
286
286
  "scrollbarThickness"
287
287
  ]);
288
- _define_property(OverlayDiv, "defaultProperties", {
289
- className: "overlay"
288
+ _define_property(PrettyDiv, "defaultProperties", {
289
+ className: "pretty"
290
290
  });
291
- var _default = (0, _easywithstyle.default)(OverlayDiv)(_templateObject());
291
+ var _default = (0, _easywithstyle.default)(PrettyDiv)(_templateObject());
292
292
 
293
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kaXYvb3ZlcmxheS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJcInVzZSBzdHJpY3RcIjtcclxuXHJcbmltcG9ydCB3aXRoU3R5bGUgZnJvbSBcImVhc3ktd2l0aC1zdHlsZVwiOyAgLy8vXHJcblxyXG5pbXBvcnQgeyBFbGVtZW50IH0gZnJvbSBcImVhc3lcIjtcclxuXHJcbmltcG9ydCBTeW50YXhEaXYgZnJvbSBcIi4uL2Rpdi9zeW50YXhcIjtcclxuXHJcbmltcG9ydCB7IE1BUkdJTl9SSUdIVCwgTUFSR0lOX0JPVFRPTSB9IGZyb20gXCIuLi9jb25zdGFudHNcIjtcclxuXHJcbmNsYXNzIE92ZXJsYXlEaXYgZXh0ZW5kcyBFbGVtZW50IHtcclxuICB1cGRhdGUodG9rZW5zKSB7XHJcbiAgICB0aGlzLnVwZGF0ZVN5bnRheERpdih0b2tlbnMpO1xyXG4gIH1cclxuXHJcbiAgc2Nyb2xsKHNjcm9sbFRvcCwgc2Nyb2xsTGVmdCkge1xyXG4gICAgdGhpcy5zY3JvbGxTeW50YXhEaXYoc2Nyb2xsVG9wLCBzY3JvbGxMZWZ0KTtcclxuICB9XHJcblxyXG4gIGRpZE1vdW50KCkge1xyXG4gICAgY29uc3QgeyBzY3JvbGxiYXJUaGlja25lc3MgfSA9IHRoaXMucHJvcGVydGllcyxcclxuICAgICAgICAgIG1hcmdpblJpZ2h0ID0gYCR7c2Nyb2xsYmFyVGhpY2tuZXNzfXB4YCxcclxuICAgICAgICAgIG1hcmdpbkJvdHRvbSA9IGAke3Njcm9sbGJhclRoaWNrbmVzc31weGA7XHJcblxyXG4gICAgdGhpcy5zdHlsZShNQVJHSU5fUklHSFQsIG1hcmdpblJpZ2h0KTtcclxuICAgIHRoaXMuc3R5bGUoTUFSR0lOX0JPVFRPTSwgbWFyZ2luQm90dG9tKTtcclxuICB9XHJcblxyXG4gIHdpbGxVbm1vdW50KCkge1xyXG4gICAgLy8vXHJcbiAgfVxyXG5cclxuICBjaGlsZEVsZW1lbnRzKCkge1xyXG4gICAgcmV0dXJuIChcclxuXHJcbiAgICAgIDxTeW50YXhEaXYvPlxyXG5cclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwYXJlbnRDb250ZXh0KCkge1xyXG5cdCAgY29uc3QgY29udGV4dCA9IHRoaXMuZ2V0Q29udGV4dCgpLFxyXG4gICAgICAgICAgdXBkYXRlT3ZlcmxheURpdiA9IHRoaXMudXBkYXRlLmJpbmQodGhpcyksICAvLy9cclxuXHRcdFx0XHQgIHNjcm9sbE92ZXJsYXlEaXYgPSB0aGlzLnNjcm9sbC5iaW5kKHRoaXMpOyAgLy8vXHJcblxyXG4gICAgcmV0dXJuICh7XHJcbiAgICAgIC4uLmNvbnRleHQsXHJcbiAgICAgIHVwZGF0ZU92ZXJsYXlEaXYsXHJcbiAgICAgIHNjcm9sbE92ZXJsYXlEaXZcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgaW5pdGlhbGlzZSgpIHtcclxuICAgIHRoaXMuYXNzaWduQ29udGV4dChbXHJcbiAgICAgIFwidXBkYXRlU3ludGF4RGl2XCIsXHJcbiAgICAgIFwic2Nyb2xsU3ludGF4RGl2XCJcclxuICAgIF0pO1xyXG4gIH1cclxuXHJcbiAgc3RhdGljIHRhZ05hbWUgPSBcImRpdlwiO1xyXG5cclxuICBzdGF0aWMgaWdub3JlZFByb3BlcnRpZXMgPSBbXHJcbiAgICBcInNjcm9sbGJhclRoaWNrbmVzc1wiXHJcbiAgXTtcclxuXHJcbiAgc3RhdGljIGRlZmF1bHRQcm9wZXJ0aWVzID0ge1xyXG4gICAgY2xhc3NOYW1lOiBcIm92ZXJsYXlcIlxyXG4gIH07XHJcbn1cclxuXHJcbmV4cG9ydCBkZWZhdWx0IHdpdGhTdHlsZShPdmVybGF5RGl2KWBcclxuXHJcbiAgei1pbmRleDogMDtcclxuICB3aWR0aDogYXV0bztcclxuICBoZWlnaHQ6IGF1dG87XHJcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcclxuICBwb3NpdGlvbjogcmVsYXRpdmU7XHJcbiAgZ3JpZC1hcmVhOiBvdmVybGF5LXJpY2gtdGV4dGFyZWE7XHJcblxyXG4gIGNvbG9yOiBpbmhlcml0O1xyXG4gIGZvbnQtc2l6ZTogaW5oZXJpdDtcclxuICBsaW5lLWhlaWdodDogaW5oZXJpdDtcclxuICBmb250LWZhbWlseTogaW5oZXJpdDtcclxuICBmb250LXdlaWdodDogaW5oZXJpdDtcclxuICBjYXJldC1jb2xvcjogaW5oZXJpdDtcclxuICBib3JkZXItY29sb3I6IGluaGVyaXQ7XHJcbiAgdGV4dC1yZW5kZXJpbmc6IGluaGVyaXQ7XHJcbiAgYmFja2dyb3VuZC1jb2xvcjogaW5oZXJpdDtcclxuICBmb250LWZlYXR1cmUtc2V0dGluZ3M6IGluaGVyaXQ7XHJcblxyXG5gO1xyXG4iXSwibmFtZXMiOlsiT3ZlcmxheURpdiIsInVwZGF0ZSIsInRva2VucyIsInVwZGF0ZVN5bnRheERpdiIsInNjcm9sbCIsInNjcm9sbFRvcCIsInNjcm9sbExlZnQiLCJzY3JvbGxTeW50YXhEaXYiLCJkaWRNb3VudCIsInNjcm9sbGJhclRoaWNrbmVzcyIsInByb3BlcnRpZXMiLCJtYXJnaW5SaWdodCIsIm1hcmdpbkJvdHRvbSIsInN0eWxlIiwiTUFSR0lOX1JJR0hUIiwiTUFSR0lOX0JPVFRPTSIsIndpbGxVbm1vdW50IiwiY2hpbGRFbGVtZW50cyIsIlN5bnRheERpdiIsInBhcmVudENvbnRleHQiLCJjb250ZXh0IiwiZ2V0Q29udGV4dCIsInVwZGF0ZU92ZXJsYXlEaXYiLCJiaW5kIiwic2Nyb2xsT3ZlcmxheURpdiIsImluaXRpYWxpc2UiLCJhc3NpZ25Db250ZXh0IiwiRWxlbWVudCIsInRhZ05hbWUiLCJpZ25vcmVkUHJvcGVydGllcyIsImRlZmF1bHRQcm9wZXJ0aWVzIiwiY2xhc3NOYW1lIiwid2l0aFN0eWxlIl0sIm1hcHBpbmdzIjoiQUFBQTs7OzsrQkFzRUE7OztlQUFBOzs7b0VBcEVzQjtvQkFFRTs2REFFRjt5QkFFc0I7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFNUMsSUFBQSxBQUFNQSwyQkFBRCxBQUFMO2NBQU1BOytCQUFBQTthQUFBQTtnQ0FBQUE7OztrQkFBQUE7O1lBQ0pDLEtBQUFBO21CQUFBQSxTQUFBQSxPQUFPQyxNQUFNO2dCQUNYLElBQUksQ0FBQ0MsZUFBZSxDQUFDRDtZQUN2Qjs7O1lBRUFFLEtBQUFBO21CQUFBQSxTQUFBQSxPQUFPQyxTQUFTLEVBQUVDLFVBQVU7Z0JBQzFCLElBQUksQ0FBQ0MsZUFBZSxDQUFDRixXQUFXQztZQUNsQzs7O1lBRUFFLEtBQUFBO21CQUFBQSxTQUFBQTtnQkFDRSxJQUFNLEFBQUVDLHFCQUF1QixJQUFJLENBQUNDLFVBQVUsQ0FBdENELG9CQUNGRSxjQUFjLEFBQUMsR0FBcUIsT0FBbkJGLG9CQUFtQixPQUNwQ0csZUFBZSxBQUFDLEdBQXFCLE9BQW5CSCxvQkFBbUI7Z0JBRTNDLElBQUksQ0FBQ0ksS0FBSyxDQUFDQyx1QkFBWSxFQUFFSDtnQkFDekIsSUFBSSxDQUFDRSxLQUFLLENBQUNFLHdCQUFhLEVBQUVIO1lBQzVCOzs7WUFFQUksS0FBQUE7bUJBQUFBLFNBQUFBO1lBQ0UsR0FBRztZQUNMOzs7WUFFQUMsS0FBQUE7bUJBQUFBLFNBQUFBO2dCQUNFLHFCQUVFLG9CQUFDQyxlQUFTO1lBR2Q7OztZQUVBQyxLQUFBQTttQkFBQUEsU0FBQUE7Z0JBQ0MsSUFBTUMsVUFBVSxJQUFJLENBQUNDLFVBQVUsSUFDeEJDLG1CQUFtQixJQUFJLENBQUNyQixNQUFNLENBQUNzQixJQUFJLENBQUMsSUFBSSxHQUM1Q0MsbUJBQW1CLElBQUksQ0FBQ3BCLE1BQU0sQ0FBQ21CLElBQUksQ0FBQyxJQUFJLEdBQUksR0FBRztnQkFFakQsT0FBUSx3Q0FDSEg7b0JBQ0hFLGtCQUFBQTtvQkFDQUUsa0JBQUFBOztZQUVKOzs7WUFFQUMsS0FBQUE7bUJBQUFBLFNBQUFBO2dCQUNFLElBQUksQ0FBQ0MsYUFBYSxDQUFDO29CQUNqQjtvQkFDQTtpQkFDRDtZQUNIOzs7V0EvQ0kxQjtxQkFBbUIyQixhQUFPO0FBaUQ5QixpQkFqREkzQixZQWlERzRCLFdBQVU7QUFFakIsaUJBbkRJNUIsWUFtREc2QixxQkFBb0I7SUFDekI7Q0FDRDtBQUVELGlCQXZESTdCLFlBdURHOEIscUJBQW9CO0lBQ3pCQyxXQUFXO0FBQ2I7SUFHRixXQUFlQyxJQUFBQSxzQkFBUyxFQUFDaEMifQ==
293
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kaXYvcHJldHR5LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xyXG5cclxuaW1wb3J0IHdpdGhTdHlsZSBmcm9tIFwiZWFzeS13aXRoLXN0eWxlXCI7ICAvLy9cclxuXHJcbmltcG9ydCB7IEVsZW1lbnQgfSBmcm9tIFwiZWFzeVwiO1xyXG5cclxuaW1wb3J0IFN5bnRheERpdiBmcm9tIFwiLi4vZGl2L3N5bnRheFwiO1xyXG5cclxuaW1wb3J0IHsgTUFSR0lOX1JJR0hULCBNQVJHSU5fQk9UVE9NIH0gZnJvbSBcIi4uL2NvbnN0YW50c1wiO1xyXG5cclxuY2xhc3MgUHJldHR5RGl2IGV4dGVuZHMgRWxlbWVudCB7XHJcbiAgdXBkYXRlKHRva2Vucykge1xyXG4gICAgdGhpcy51cGRhdGVTeW50YXhEaXYodG9rZW5zKTtcclxuICB9XHJcblxyXG4gIHNjcm9sbChzY3JvbGxUb3AsIHNjcm9sbExlZnQpIHtcclxuICAgIHRoaXMuc2Nyb2xsU3ludGF4RGl2KHNjcm9sbFRvcCwgc2Nyb2xsTGVmdCk7XHJcbiAgfVxyXG5cclxuICBkaWRNb3VudCgpIHtcclxuICAgIGNvbnN0IHsgc2Nyb2xsYmFyVGhpY2tuZXNzIH0gPSB0aGlzLnByb3BlcnRpZXMsXHJcbiAgICAgICAgICBtYXJnaW5SaWdodCA9IGAke3Njcm9sbGJhclRoaWNrbmVzc31weGAsXHJcbiAgICAgICAgICBtYXJnaW5Cb3R0b20gPSBgJHtzY3JvbGxiYXJUaGlja25lc3N9cHhgO1xyXG5cclxuICAgIHRoaXMuc3R5bGUoTUFSR0lOX1JJR0hULCBtYXJnaW5SaWdodCk7XHJcbiAgICB0aGlzLnN0eWxlKE1BUkdJTl9CT1RUT00sIG1hcmdpbkJvdHRvbSk7XHJcbiAgfVxyXG5cclxuICB3aWxsVW5tb3VudCgpIHtcclxuICAgIC8vL1xyXG4gIH1cclxuXHJcbiAgY2hpbGRFbGVtZW50cygpIHtcclxuICAgIHJldHVybiAoXHJcblxyXG4gICAgICA8U3ludGF4RGl2Lz5cclxuXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgcGFyZW50Q29udGV4dCgpIHtcclxuXHQgIGNvbnN0IGNvbnRleHQgPSB0aGlzLmdldENvbnRleHQoKSxcclxuICAgICAgICAgIHVwZGF0ZVByZXR0eURpdiA9IHRoaXMudXBkYXRlLmJpbmQodGhpcyksICAvLy9cclxuXHRcdFx0XHQgIHNjcm9sbFByZXR0eURpdiA9IHRoaXMuc2Nyb2xsLmJpbmQodGhpcyk7ICAvLy9cclxuXHJcbiAgICByZXR1cm4gKHtcclxuICAgICAgLi4uY29udGV4dCxcclxuICAgICAgdXBkYXRlUHJldHR5RGl2LFxyXG4gICAgICBzY3JvbGxQcmV0dHlEaXZcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgaW5pdGlhbGlzZSgpIHtcclxuICAgIHRoaXMuYXNzaWduQ29udGV4dChbXHJcbiAgICAgIFwidXBkYXRlU3ludGF4RGl2XCIsXHJcbiAgICAgIFwic2Nyb2xsU3ludGF4RGl2XCJcclxuICAgIF0pO1xyXG4gIH1cclxuXHJcbiAgc3RhdGljIHRhZ05hbWUgPSBcImRpdlwiO1xyXG5cclxuICBzdGF0aWMgaWdub3JlZFByb3BlcnRpZXMgPSBbXHJcbiAgICBcInNjcm9sbGJhclRoaWNrbmVzc1wiXHJcbiAgXTtcclxuXHJcbiAgc3RhdGljIGRlZmF1bHRQcm9wZXJ0aWVzID0ge1xyXG4gICAgY2xhc3NOYW1lOiBcInByZXR0eVwiXHJcbiAgfTtcclxufVxyXG5cclxuZXhwb3J0IGRlZmF1bHQgd2l0aFN0eWxlKFByZXR0eURpdilgXHJcblxyXG4gIHotaW5kZXg6IDA7XHJcbiAgd2lkdGg6IGF1dG87XHJcbiAgaGVpZ2h0OiBhdXRvO1xyXG4gIG92ZXJmbG93OiBoaWRkZW47XHJcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xyXG4gIGdyaWQtYXJlYTogcHJldHR5LXJpY2gtdGV4dGFyZWE7XHJcblxyXG4gIGNvbG9yOiBpbmhlcml0O1xyXG4gIGZvbnQtc2l6ZTogaW5oZXJpdDtcclxuICBsaW5lLWhlaWdodDogaW5oZXJpdDtcclxuICBmb250LWZhbWlseTogaW5oZXJpdDtcclxuICBmb250LXdlaWdodDogaW5oZXJpdDtcclxuICBjYXJldC1jb2xvcjogaW5oZXJpdDtcclxuICBib3JkZXItY29sb3I6IGluaGVyaXQ7XHJcbiAgdGV4dC1yZW5kZXJpbmc6IGluaGVyaXQ7XHJcbiAgYmFja2dyb3VuZC1jb2xvcjogaW5oZXJpdDtcclxuICBmb250LWZlYXR1cmUtc2V0dGluZ3M6IGluaGVyaXQ7XHJcblxyXG5gO1xyXG4iXSwibmFtZXMiOlsiUHJldHR5RGl2IiwidXBkYXRlIiwidG9rZW5zIiwidXBkYXRlU3ludGF4RGl2Iiwic2Nyb2xsIiwic2Nyb2xsVG9wIiwic2Nyb2xsTGVmdCIsInNjcm9sbFN5bnRheERpdiIsImRpZE1vdW50Iiwic2Nyb2xsYmFyVGhpY2tuZXNzIiwicHJvcGVydGllcyIsIm1hcmdpblJpZ2h0IiwibWFyZ2luQm90dG9tIiwic3R5bGUiLCJNQVJHSU5fUklHSFQiLCJNQVJHSU5fQk9UVE9NIiwid2lsbFVubW91bnQiLCJjaGlsZEVsZW1lbnRzIiwiU3ludGF4RGl2IiwicGFyZW50Q29udGV4dCIsImNvbnRleHQiLCJnZXRDb250ZXh0IiwidXBkYXRlUHJldHR5RGl2IiwiYmluZCIsInNjcm9sbFByZXR0eURpdiIsImluaXRpYWxpc2UiLCJhc3NpZ25Db250ZXh0IiwiRWxlbWVudCIsInRhZ05hbWUiLCJpZ25vcmVkUHJvcGVydGllcyIsImRlZmF1bHRQcm9wZXJ0aWVzIiwiY2xhc3NOYW1lIiwid2l0aFN0eWxlIl0sIm1hcHBpbmdzIjoiQUFBQTs7OzsrQkFzRUE7OztlQUFBOzs7b0VBcEVzQjtvQkFFRTs2REFFRjt5QkFFc0I7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFNUMsSUFBQSxBQUFNQSwwQkFBRCxBQUFMO2NBQU1BOytCQUFBQTthQUFBQTtnQ0FBQUE7OztrQkFBQUE7O1lBQ0pDLEtBQUFBO21CQUFBQSxTQUFBQSxPQUFPQyxNQUFNO2dCQUNYLElBQUksQ0FBQ0MsZUFBZSxDQUFDRDtZQUN2Qjs7O1lBRUFFLEtBQUFBO21CQUFBQSxTQUFBQSxPQUFPQyxTQUFTLEVBQUVDLFVBQVU7Z0JBQzFCLElBQUksQ0FBQ0MsZUFBZSxDQUFDRixXQUFXQztZQUNsQzs7O1lBRUFFLEtBQUFBO21CQUFBQSxTQUFBQTtnQkFDRSxJQUFNLEFBQUVDLHFCQUF1QixJQUFJLENBQUNDLFVBQVUsQ0FBdENELG9CQUNGRSxjQUFjLEFBQUMsR0FBcUIsT0FBbkJGLG9CQUFtQixPQUNwQ0csZUFBZSxBQUFDLEdBQXFCLE9BQW5CSCxvQkFBbUI7Z0JBRTNDLElBQUksQ0FBQ0ksS0FBSyxDQUFDQyx1QkFBWSxFQUFFSDtnQkFDekIsSUFBSSxDQUFDRSxLQUFLLENBQUNFLHdCQUFhLEVBQUVIO1lBQzVCOzs7WUFFQUksS0FBQUE7bUJBQUFBLFNBQUFBO1lBQ0UsR0FBRztZQUNMOzs7WUFFQUMsS0FBQUE7bUJBQUFBLFNBQUFBO2dCQUNFLHFCQUVFLG9CQUFDQyxlQUFTO1lBR2Q7OztZQUVBQyxLQUFBQTttQkFBQUEsU0FBQUE7Z0JBQ0MsSUFBTUMsVUFBVSxJQUFJLENBQUNDLFVBQVUsSUFDeEJDLGtCQUFrQixJQUFJLENBQUNyQixNQUFNLENBQUNzQixJQUFJLENBQUMsSUFBSSxHQUMzQ0Msa0JBQWtCLElBQUksQ0FBQ3BCLE1BQU0sQ0FBQ21CLElBQUksQ0FBQyxJQUFJLEdBQUksR0FBRztnQkFFaEQsT0FBUSx3Q0FDSEg7b0JBQ0hFLGlCQUFBQTtvQkFDQUUsaUJBQUFBOztZQUVKOzs7WUFFQUMsS0FBQUE7bUJBQUFBLFNBQUFBO2dCQUNFLElBQUksQ0FBQ0MsYUFBYSxDQUFDO29CQUNqQjtvQkFDQTtpQkFDRDtZQUNIOzs7V0EvQ0kxQjtxQkFBa0IyQixhQUFPO0FBaUQ3QixpQkFqREkzQixXQWlERzRCLFdBQVU7QUFFakIsaUJBbkRJNUIsV0FtREc2QixxQkFBb0I7SUFDekI7Q0FDRDtBQUVELGlCQXZESTdCLFdBdURHOEIscUJBQW9CO0lBQ3pCQyxXQUFXO0FBQ2I7SUFHRixXQUFlQyxJQUFBQSxzQkFBUyxFQUFDaEMifQ==
@@ -198,7 +198,7 @@ var View = /*#__PURE__*/ function(Element) {
198
198
  _class_call_check(this, View);
199
199
  var _this;
200
200
  _this = _super.apply(this, arguments);
201
- _define_property(_assert_this_initialized(_this), "contentChangeHandler", function(event, element) {
201
+ _define_property(_assert_this_initialized(_this), "customContentChangeHandler", function(event, element) {
202
202
  _this.update();
203
203
  });
204
204
  _define_property(_assert_this_initialized(_this), "keyUpHandler", function(event, element) {
@@ -266,7 +266,7 @@ var View = /*#__PURE__*/ function(Element) {
266
266
  return /*#__PURE__*/ React.createElement(_easylayout.ColumnsDiv, null, /*#__PURE__*/ React.createElement(_left.default, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_top.default, null, /*#__PURE__*/ React.createElement(_yapp.default, {
267
267
  Plugin: Plugin,
268
268
  firaCode: firaCode,
269
- onContentChange: this.contentChangeHandler
269
+ onCustomContentChange: this.customContentChangeHandler
270
270
  }, initialContent)), /*#__PURE__*/ React.createElement(_easylayout.HorizontalSplitterDiv, null), /*#__PURE__*/ React.createElement(_easylayout.RowDiv, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_middle.default, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_subHeading.default, null, "Tokens"), /*#__PURE__*/ React.createElement(_tokens.default, null))), /*#__PURE__*/ React.createElement(_easylayout.HorizontalSplitterDiv, null), /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_subHeading.default, null, "Parse tree"), /*#__PURE__*/ React.createElement(_parseTree.default, null)))))), /*#__PURE__*/ React.createElement(_easylayout.VerticalSplitterDiv, null), /*#__PURE__*/ React.createElement(_easylayout.ColumnDiv, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_right.default, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_subHeading.default, null, "Lexical entries"), /*#__PURE__*/ React.createElement(_lexicalEntries.default, {
271
271
  onKeyUp: this.keyUpHandler
272
272
  }))), /*#__PURE__*/ React.createElement(_easylayout.HorizontalSplitterDiv, null), /*#__PURE__*/ React.createElement(_easylayout.RowDiv, null, /*#__PURE__*/ React.createElement(_easylayout.RowsDiv, null, /*#__PURE__*/ React.createElement(_subHeading.default, null, "BNF"), /*#__PURE__*/ React.createElement(_bnf.default, {
@@ -292,4 +292,4 @@ _define_property(View, "defaultProperties", {
292
292
  });
293
293
  var _default = (0, _easywithstyle.default)(View)(_templateObject());
294
294
 
295
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/example/view.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { Element } from \"easy\";\nimport { parserUtilities } from \"occam-parsers\";\nimport { RowDiv, RowsDiv, ColumnDiv, ColumnsDiv, VerticalSplitterDiv, HorizontalSplitterDiv } from \"easy-layout\";\n\nimport Yapp from \"./yapp\";\nimport SubHeading from \"./view/subHeading\";\nimport BNFTextarea from \"./view/textarea/bnf\";\nimport TokensTextarea from \"./view/textarea/tokens\";\nimport TopSizeableDiv from \"./view/div/sizeable/top\";\nimport LeftSizeableDiv from \"./view/div/sizeable/left\";\nimport RightSizeableDiv from \"./view/div/sizeable/right\";\nimport MiddleSizeableDiv from \"./view/div/sizeable/middle\";\nimport ParseTreeTextarea from \"./view/textarea/parseTree\";\nimport LexicalEntriesTextarea from \"./view/textarea/lexicalEntries\";\n\nconst { rulesFromBNF } = parserUtilities;\n\nclass View extends Element {\n  contentChangeHandler = (event, element) => {\n    this.update();\n  }\n\n  lexerFromEntries(entries) {\n    const { Plugin } = this.constructor,\n          { Lexer } = Plugin,\n          lexer = Lexer.fromEntries(entries);\n\n    return lexer;\n  }\n\n  parserFromBNF(bnf) {\n    const { Plugin } = this.constructor,\n          { Parser } = Plugin,\n          rules = rulesFromBNF(bnf),\n          parser = Parser.fromRules(rules);\n\n    return parser;\n  }\n\n  keyUpHandler = (event, element) => {\n    try {\n      const lexicalEntries = this.getLexicalEntries(),\n            entries = lexicalEntries, ///\n            bnf = this.getBNF(),\n            lexer = this.lexerFromEntries(entries),\n            parser = this.parserFromBNF(bnf),\n            yappLexer = lexer,  ///\n            yappParser = parser;  ///\n\n      this.setYappLexer(yappLexer);\n\n      this.setYappParser(yappParser);\n\n      this.updateYapp();\n\n      this.update();\n    } catch (error) {\n      console.log(error);\n    }\n  }\n\n  update() {\n    try {\n      let parseTree = null;\n\n      const plugin = this.getPlugin(),\n            tokens = plugin.getTokens(),\n            node = plugin.getNode();\n\n      if (node !== null) {\n        parseTree = node.asParseTree(tokens);\n      }\n\n      this.setTokens(tokens);\n\n      this.setParseTree(parseTree);\n    } catch (error) {\n      console.log(error);\n\n      this.clearTokens();\n\n      this.clearParseTree();\n    }\n  }\n\n  didMount() {\n    this.update();\n  }\n\n  willUnmount() {\n    ///\n  }\n\n  childElements() {\n    const { Plugin, firaCode, initialContent } = this.constructor;\n\n    return (\n\n      <ColumnsDiv>\n        <LeftSizeableDiv>\n          <RowsDiv>\n            <TopSizeableDiv>\n              <Yapp Plugin={Plugin} firaCode={firaCode} onContentChange={this.contentChangeHandler} >\n                {initialContent}\n              </Yapp>\n            </TopSizeableDiv>\n            <HorizontalSplitterDiv/>\n            <RowDiv>\n              <RowsDiv>\n                <MiddleSizeableDiv>\n                  <RowsDiv>\n                    <SubHeading>\n                      Tokens\n                    </SubHeading>\n                    <TokensTextarea/>\n                  </RowsDiv>\n                </MiddleSizeableDiv>\n                <HorizontalSplitterDiv/>\n                <RowsDiv>\n                  <SubHeading>\n                    Parse tree\n                  </SubHeading>\n                  <ParseTreeTextarea />\n                </RowsDiv>\n              </RowsDiv>\n            </RowDiv>\n          </RowsDiv>\n        </LeftSizeableDiv>\n        <VerticalSplitterDiv/>\n        <ColumnDiv>\n          <RowsDiv>\n            <RightSizeableDiv>\n              <RowsDiv>\n                <SubHeading>\n                  Lexical entries\n                </SubHeading>\n                <LexicalEntriesTextarea onKeyUp={this.keyUpHandler} />\n              </RowsDiv>\n            </RightSizeableDiv>\n            <HorizontalSplitterDiv/>\n            <RowDiv>\n              <RowsDiv>\n                <SubHeading>\n                  BNF\n                </SubHeading>\n                <BNFTextarea onKeyUp={this.keyUpHandler} />\n              </RowsDiv>\n            </RowDiv>\n          </RowsDiv>\n        </ColumnDiv>\n      </ColumnsDiv>\n\n    );\n  }\n\n  initialise() {\n    this.assignContext();\n\n    const { Plugin } = this.constructor,\n          { Lexer, Parser } = Plugin,\n          { bnf } = Parser,\n          { entries } = Lexer,\n          lexicalEntries = entries; ///\n\n    this.setBNF(bnf);\n\n    this.setLexicalEntries(lexicalEntries);\n  }\n\n  static tagName = \"div\";\n\n  static defaultProperties = {\n    className: \"view\"\n  };\n}\n\nexport default withStyle(View)`\n\n  width: 100%;\n  height: 100vh;\n  display: flex;\n  padding: 1rem;\n  \n`;\n"],"names":["rulesFromBNF","parserUtilities","View","contentChangeHandler","event","element","update","keyUpHandler","lexicalEntries","getLexicalEntries","entries","bnf","getBNF","lexer","lexerFromEntries","parser","parserFromBNF","yappLexer","yappParser","setYappLexer","setYappParser","updateYapp","error","console","log","Plugin","constructor","Lexer","fromEntries","Parser","rules","fromRules","parseTree","plugin","getPlugin","tokens","getTokens","node","getNode","asParseTree","setTokens","setParseTree","clearTokens","clearParseTree","didMount","willUnmount","childElements","firaCode","initialContent","ColumnsDiv","LeftSizeableDiv","RowsDiv","TopSizeableDiv","Yapp","onContentChange","HorizontalSplitterDiv","RowDiv","MiddleSizeableDiv","SubHeading","TokensTextarea","ParseTreeTextarea","VerticalSplitterDiv","ColumnDiv","RightSizeableDiv","LexicalEntriesTextarea","onKeyUp","BNFTextarea","initialise","assignContext","setBNF","setLexicalEntries","Element","tagName","defaultProperties","className","withStyle"],"mappings":"AAAA;;;;+BAoLA;;;eAAA;;;oEAlLsB;oBAEE;4BACQ;0BACmE;2DAElF;iEACM;0DACC;6DACG;0DACA;2DACC;4DACC;6DACC;gEACA;qEACK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEnC,IAAM,AAAEA,eAAiBC,6BAAe,CAAhCD;AAER,IAAA,AAAME,qBAAD,AAAL;cAAMA;+BAAAA;aAAAA;gCAAAA;;;QACJC,kDAAAA,wBAAuB,SAACC,OAAOC;YAC7B,MAAKC,MAAM;QACb;QAmBAC,kDAAAA,gBAAe,SAACH,OAAOC;YACrB,IAAI;gBACF,IAAMG,iBAAiB,MAAKC,iBAAiB,IACvCC,UAAUF,gBACVG,MAAM,MAAKC,MAAM,IACjBC,QAAQ,MAAKC,gBAAgB,CAACJ,UAC9BK,SAAS,MAAKC,aAAa,CAACL,MAC5BM,YAAYJ,OACZK,aAAaH,QAAS,GAAG;gBAE/B,MAAKI,YAAY,CAACF;gBAElB,MAAKG,aAAa,CAACF;gBAEnB,MAAKG,UAAU;gBAEf,MAAKf,MAAM;YACb,EAAE,OAAOgB,OAAO;gBACdC,QAAQC,GAAG,CAACF;YACd;QACF;;;kBA1CIpB;;YAKJY,KAAAA;mBAAAA,SAAAA,iBAAiBJ,OAAO;gBACtB,IAAM,AAAEe,SAAW,IAAI,CAACC,WAAW,CAA3BD,QACF,AAAEE,QAAUF,OAAVE,OACFd,QAAQc,MAAMC,WAAW,CAAClB;gBAEhC,OAAOG;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA,cAAcL,GAAG;gBACf,IAAM,AAAEc,SAAW,IAAI,CAACC,WAAW,CAA3BD,QACF,AAAEI,SAAWJ,OAAXI,QACFC,QAAQ9B,aAAaW,MACrBI,SAASc,OAAOE,SAAS,CAACD;gBAEhC,OAAOf;YACT;;;YAwBAT,KAAAA;mBAAAA,SAAAA;gBACE,IAAI;oBACF,IAAI0B,YAAY;oBAEhB,IAAMC,SAAS,IAAI,CAACC,SAAS,IACvBC,SAASF,OAAOG,SAAS,IACzBC,OAAOJ,OAAOK,OAAO;oBAE3B,IAAID,SAAS,MAAM;wBACjBL,YAAYK,KAAKE,WAAW,CAACJ;oBAC/B;oBAEA,IAAI,CAACK,SAAS,CAACL;oBAEf,IAAI,CAACM,YAAY,CAACT;gBACpB,EAAE,OAAOV,OAAO;oBACdC,QAAQC,GAAG,CAACF;oBAEZ,IAAI,CAACoB,WAAW;oBAEhB,IAAI,CAACC,cAAc;gBACrB;YACF;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAAI,CAACtC,MAAM;YACb;;;YAEAuC,KAAAA;mBAAAA,SAAAA;YACE,GAAG;YACL;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAA6C,oBAAA,IAAI,CAACpB,WAAW,EAArDD,SAAqC,kBAArCA,QAAQsB,WAA6B,kBAA7BA,UAAUC,iBAAmB,kBAAnBA;gBAE1B,qBAEE,oBAACC,sBAAU,sBACT,oBAACC,aAAe,sBACd,oBAACC,mBAAO,sBACN,oBAACC,YAAc,sBACb,oBAACC,aAAI;oBAAC5B,QAAQA;oBAAQsB,UAAUA;oBAAUO,iBAAiB,IAAI,CAACnD,oBAAoB;mBACjF6C,gCAGL,oBAACO,iCAAqB,uBACtB,oBAACC,kBAAM,sBACL,oBAACL,mBAAO,sBACN,oBAACM,eAAiB,sBAChB,oBAACN,mBAAO,sBACN,oBAACO,mBAAU,QAAC,yBAGZ,oBAACC,eAAc,yBAGnB,oBAACJ,iCAAqB,uBACtB,oBAACJ,mBAAO,sBACN,oBAACO,mBAAU,QAAC,6BAGZ,oBAACE,kBAAiB,4BAM5B,oBAACC,+BAAmB,uBACpB,oBAACC,qBAAS,sBACR,oBAACX,mBAAO,sBACN,oBAACY,cAAgB,sBACf,oBAACZ,mBAAO,sBACN,oBAACO,mBAAU,QAAC,kCAGZ,oBAACM,uBAAsB;oBAACC,SAAS,IAAI,CAAC1D,YAAY;oCAGtD,oBAACgD,iCAAqB,uBACtB,oBAACC,kBAAM,sBACL,oBAACL,mBAAO,sBACN,oBAACO,mBAAU,QAAC,sBAGZ,oBAACQ,YAAW;oBAACD,SAAS,IAAI,CAAC1D,YAAY;;YAQrD;;;YAEA4D,KAAAA;mBAAAA,SAAAA;gBACE,IAAI,CAACC,aAAa;gBAElB,IAAM,AAAE3C,SAAW,IAAI,CAACC,WAAW,CAA3BD,QACAE,QAAkBF,OAAlBE,OAAOE,SAAWJ,OAAXI,QACT,AAAElB,MAAQkB,OAARlB,KACF,AAAED,UAAYiB,MAAZjB,SACFF,iBAAiBE,SAAS,GAAG;gBAEnC,IAAI,CAAC2D,MAAM,CAAC1D;gBAEZ,IAAI,CAAC2D,iBAAiB,CAAC9D;YACzB;;;WAtJIN;qBAAaqE,aAAO;AAwJxB,iBAxJIrE,MAwJGsE,WAAU;AAEjB,iBA1JItE,MA0JGuE,qBAAoB;IACzBC,WAAW;AACb;IAGF,WAAeC,IAAAA,sBAAS,EAACzE"}
295
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/example/view.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { Element } from \"easy\";\nimport { parserUtilities } from \"occam-parsers\";\nimport { RowDiv, RowsDiv, ColumnDiv, ColumnsDiv, VerticalSplitterDiv, HorizontalSplitterDiv } from \"easy-layout\";\n\nimport Yapp from \"./yapp\";\nimport SubHeading from \"./view/subHeading\";\nimport BNFTextarea from \"./view/textarea/bnf\";\nimport TokensTextarea from \"./view/textarea/tokens\";\nimport TopSizeableDiv from \"./view/div/sizeable/top\";\nimport LeftSizeableDiv from \"./view/div/sizeable/left\";\nimport RightSizeableDiv from \"./view/div/sizeable/right\";\nimport MiddleSizeableDiv from \"./view/div/sizeable/middle\";\nimport ParseTreeTextarea from \"./view/textarea/parseTree\";\nimport LexicalEntriesTextarea from \"./view/textarea/lexicalEntries\";\n\nconst { rulesFromBNF } = parserUtilities;\n\nclass View extends Element {\n  customContentChangeHandler = (event, element) => {\n    this.update();\n  }\n\n  lexerFromEntries(entries) {\n    const { Plugin } = this.constructor,\n          { Lexer } = Plugin,\n          lexer = Lexer.fromEntries(entries);\n\n    return lexer;\n  }\n\n  parserFromBNF(bnf) {\n    const { Plugin } = this.constructor,\n          { Parser } = Plugin,\n          rules = rulesFromBNF(bnf),\n          parser = Parser.fromRules(rules);\n\n    return parser;\n  }\n\n  keyUpHandler = (event, element) => {\n    try {\n      const lexicalEntries = this.getLexicalEntries(),\n            entries = lexicalEntries, ///\n            bnf = this.getBNF(),\n            lexer = this.lexerFromEntries(entries),\n            parser = this.parserFromBNF(bnf),\n            yappLexer = lexer,  ///\n            yappParser = parser;  ///\n\n      this.setYappLexer(yappLexer);\n\n      this.setYappParser(yappParser);\n\n      this.updateYapp();\n\n      this.update();\n    } catch (error) {\n      console.log(error);\n    }\n  }\n\n  update() {\n    try {\n      let parseTree = null;\n\n      const plugin = this.getPlugin(),\n            tokens = plugin.getTokens(),\n            node = plugin.getNode();\n\n      if (node !== null) {\n        parseTree = node.asParseTree(tokens);\n      }\n\n      this.setTokens(tokens);\n\n      this.setParseTree(parseTree);\n    } catch (error) {\n      console.log(error);\n\n      this.clearTokens();\n\n      this.clearParseTree();\n    }\n  }\n\n  didMount() {\n    this.update();\n  }\n\n  willUnmount() {\n    ///\n  }\n\n  childElements() {\n    const { Plugin, firaCode, initialContent } = this.constructor;\n\n    return (\n\n      <ColumnsDiv>\n        <LeftSizeableDiv>\n          <RowsDiv>\n            <TopSizeableDiv>\n              <Yapp Plugin={Plugin} firaCode={firaCode} onCustomContentChange={this.customContentChangeHandler} >\n                {initialContent}\n              </Yapp>\n            </TopSizeableDiv>\n            <HorizontalSplitterDiv/>\n            <RowDiv>\n              <RowsDiv>\n                <MiddleSizeableDiv>\n                  <RowsDiv>\n                    <SubHeading>\n                      Tokens\n                    </SubHeading>\n                    <TokensTextarea/>\n                  </RowsDiv>\n                </MiddleSizeableDiv>\n                <HorizontalSplitterDiv/>\n                <RowsDiv>\n                  <SubHeading>\n                    Parse tree\n                  </SubHeading>\n                  <ParseTreeTextarea />\n                </RowsDiv>\n              </RowsDiv>\n            </RowDiv>\n          </RowsDiv>\n        </LeftSizeableDiv>\n        <VerticalSplitterDiv/>\n        <ColumnDiv>\n          <RowsDiv>\n            <RightSizeableDiv>\n              <RowsDiv>\n                <SubHeading>\n                  Lexical entries\n                </SubHeading>\n                <LexicalEntriesTextarea onKeyUp={this.keyUpHandler} />\n              </RowsDiv>\n            </RightSizeableDiv>\n            <HorizontalSplitterDiv/>\n            <RowDiv>\n              <RowsDiv>\n                <SubHeading>\n                  BNF\n                </SubHeading>\n                <BNFTextarea onKeyUp={this.keyUpHandler} />\n              </RowsDiv>\n            </RowDiv>\n          </RowsDiv>\n        </ColumnDiv>\n      </ColumnsDiv>\n\n    );\n  }\n\n  initialise() {\n    this.assignContext();\n\n    const { Plugin } = this.constructor,\n          { Lexer, Parser } = Plugin,\n          { bnf } = Parser,\n          { entries } = Lexer,\n          lexicalEntries = entries; ///\n\n    this.setBNF(bnf);\n\n    this.setLexicalEntries(lexicalEntries);\n  }\n\n  static tagName = \"div\";\n\n  static defaultProperties = {\n    className: \"view\"\n  };\n}\n\nexport default withStyle(View)`\n\n  width: 100%;\n  height: 100vh;\n  display: flex;\n  padding: 1rem;\n  \n`;\n"],"names":["rulesFromBNF","parserUtilities","View","customContentChangeHandler","event","element","update","keyUpHandler","lexicalEntries","getLexicalEntries","entries","bnf","getBNF","lexer","lexerFromEntries","parser","parserFromBNF","yappLexer","yappParser","setYappLexer","setYappParser","updateYapp","error","console","log","Plugin","constructor","Lexer","fromEntries","Parser","rules","fromRules","parseTree","plugin","getPlugin","tokens","getTokens","node","getNode","asParseTree","setTokens","setParseTree","clearTokens","clearParseTree","didMount","willUnmount","childElements","firaCode","initialContent","ColumnsDiv","LeftSizeableDiv","RowsDiv","TopSizeableDiv","Yapp","onCustomContentChange","HorizontalSplitterDiv","RowDiv","MiddleSizeableDiv","SubHeading","TokensTextarea","ParseTreeTextarea","VerticalSplitterDiv","ColumnDiv","RightSizeableDiv","LexicalEntriesTextarea","onKeyUp","BNFTextarea","initialise","assignContext","setBNF","setLexicalEntries","Element","tagName","defaultProperties","className","withStyle"],"mappings":"AAAA;;;;+BAoLA;;;eAAA;;;oEAlLsB;oBAEE;4BACQ;0BACmE;2DAElF;iEACM;0DACC;6DACG;0DACA;2DACC;4DACC;6DACC;gEACA;qEACK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEnC,IAAM,AAAEA,eAAiBC,6BAAe,CAAhCD;AAER,IAAA,AAAME,qBAAD,AAAL;cAAMA;+BAAAA;aAAAA;gCAAAA;;;QACJC,kDAAAA,8BAA6B,SAACC,OAAOC;YACnC,MAAKC,MAAM;QACb;QAmBAC,kDAAAA,gBAAe,SAACH,OAAOC;YACrB,IAAI;gBACF,IAAMG,iBAAiB,MAAKC,iBAAiB,IACvCC,UAAUF,gBACVG,MAAM,MAAKC,MAAM,IACjBC,QAAQ,MAAKC,gBAAgB,CAACJ,UAC9BK,SAAS,MAAKC,aAAa,CAACL,MAC5BM,YAAYJ,OACZK,aAAaH,QAAS,GAAG;gBAE/B,MAAKI,YAAY,CAACF;gBAElB,MAAKG,aAAa,CAACF;gBAEnB,MAAKG,UAAU;gBAEf,MAAKf,MAAM;YACb,EAAE,OAAOgB,OAAO;gBACdC,QAAQC,GAAG,CAACF;YACd;QACF;;;kBA1CIpB;;YAKJY,KAAAA;mBAAAA,SAAAA,iBAAiBJ,OAAO;gBACtB,IAAM,AAAEe,SAAW,IAAI,CAACC,WAAW,CAA3BD,QACF,AAAEE,QAAUF,OAAVE,OACFd,QAAQc,MAAMC,WAAW,CAAClB;gBAEhC,OAAOG;YACT;;;YAEAG,KAAAA;mBAAAA,SAAAA,cAAcL,GAAG;gBACf,IAAM,AAAEc,SAAW,IAAI,CAACC,WAAW,CAA3BD,QACF,AAAEI,SAAWJ,OAAXI,QACFC,QAAQ9B,aAAaW,MACrBI,SAASc,OAAOE,SAAS,CAACD;gBAEhC,OAAOf;YACT;;;YAwBAT,KAAAA;mBAAAA,SAAAA;gBACE,IAAI;oBACF,IAAI0B,YAAY;oBAEhB,IAAMC,SAAS,IAAI,CAACC,SAAS,IACvBC,SAASF,OAAOG,SAAS,IACzBC,OAAOJ,OAAOK,OAAO;oBAE3B,IAAID,SAAS,MAAM;wBACjBL,YAAYK,KAAKE,WAAW,CAACJ;oBAC/B;oBAEA,IAAI,CAACK,SAAS,CAACL;oBAEf,IAAI,CAACM,YAAY,CAACT;gBACpB,EAAE,OAAOV,OAAO;oBACdC,QAAQC,GAAG,CAACF;oBAEZ,IAAI,CAACoB,WAAW;oBAEhB,IAAI,CAACC,cAAc;gBACrB;YACF;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAAI,CAACtC,MAAM;YACb;;;YAEAuC,KAAAA;mBAAAA,SAAAA;YACE,GAAG;YACL;;;YAEAC,KAAAA;mBAAAA,SAAAA;gBACE,IAA6C,oBAAA,IAAI,CAACpB,WAAW,EAArDD,SAAqC,kBAArCA,QAAQsB,WAA6B,kBAA7BA,UAAUC,iBAAmB,kBAAnBA;gBAE1B,qBAEE,oBAACC,sBAAU,sBACT,oBAACC,aAAe,sBACd,oBAACC,mBAAO,sBACN,oBAACC,YAAc,sBACb,oBAACC,aAAI;oBAAC5B,QAAQA;oBAAQsB,UAAUA;oBAAUO,uBAAuB,IAAI,CAACnD,0BAA0B;mBAC7F6C,gCAGL,oBAACO,iCAAqB,uBACtB,oBAACC,kBAAM,sBACL,oBAACL,mBAAO,sBACN,oBAACM,eAAiB,sBAChB,oBAACN,mBAAO,sBACN,oBAACO,mBAAU,QAAC,yBAGZ,oBAACC,eAAc,yBAGnB,oBAACJ,iCAAqB,uBACtB,oBAACJ,mBAAO,sBACN,oBAACO,mBAAU,QAAC,6BAGZ,oBAACE,kBAAiB,4BAM5B,oBAACC,+BAAmB,uBACpB,oBAACC,qBAAS,sBACR,oBAACX,mBAAO,sBACN,oBAACY,cAAgB,sBACf,oBAACZ,mBAAO,sBACN,oBAACO,mBAAU,QAAC,kCAGZ,oBAACM,uBAAsB;oBAACC,SAAS,IAAI,CAAC1D,YAAY;oCAGtD,oBAACgD,iCAAqB,uBACtB,oBAACC,kBAAM,sBACL,oBAACL,mBAAO,sBACN,oBAACO,mBAAU,QAAC,sBAGZ,oBAACQ,YAAW;oBAACD,SAAS,IAAI,CAAC1D,YAAY;;YAQrD;;;YAEA4D,KAAAA;mBAAAA,SAAAA;gBACE,IAAI,CAACC,aAAa;gBAElB,IAAM,AAAE3C,SAAW,IAAI,CAACC,WAAW,CAA3BD,QACAE,QAAkBF,OAAlBE,OAAOE,SAAWJ,OAAXI,QACT,AAAElB,MAAQkB,OAARlB,KACF,AAAED,UAAYiB,MAAZjB,SACFF,iBAAiBE,SAAS,GAAG;gBAEnC,IAAI,CAAC2D,MAAM,CAAC1D;gBAEZ,IAAI,CAAC2D,iBAAiB,CAAC9D;YACzB;;;WAtJIN;qBAAaqE,aAAO;AAwJxB,iBAxJIrE,MAwJGsE,WAAU;AAEjB,iBA1JItE,MA0JGuE,qBAAoB;IACzBC,WAAW;AACb;IAGF,WAAeC,IAAAA,sBAAS,EAACzE"}
@@ -10,8 +10,9 @@ Object.defineProperty(exports, "default", {
10
10
  });
11
11
  var _easywithstyle = /*#__PURE__*/ _interop_require_default(require("easy-with-style"));
12
12
  var _easy = require("easy");
13
+ var _easyrichtextarea = require("easy-richtextarea");
13
14
  var _gutter = /*#__PURE__*/ _interop_require_default(require("./div/gutter"));
14
- var _overlay = /*#__PURE__*/ _interop_require_default(require("./div/overlay"));
15
+ var _pretty = /*#__PURE__*/ _interop_require_default(require("./div/pretty"));
15
16
  var _richTextarea = /*#__PURE__*/ _interop_require_default(require("./richTextarea"));
16
17
  var _scrollbar = require("./utilities/scrollbar");
17
18
  function _assert_this_initialized(self) {
@@ -214,13 +215,14 @@ function _create_super(Derived) {
214
215
  }
215
216
  function _templateObject() {
216
217
  var data = _tagged_template_literal([
217
- '\n\n width: 100%;\n height: 100%;\n display: grid;\n overflow: hidden;\n grid-template-rows: auto;\n grid-template-areas: "gutter overlay-rich-textarea";\n grid-template-columns: min-content auto; \n\n color: inherit;\n font-size: inherit;\n line-height: inherit;\n font-family: inherit;\n font-weight: inherit;\n caret-color: inherit;\n border-color: inherit;\n text-rendering: inherit;\n background-color: transparent;\n font-feature-settings: inherit;\n\n'
218
+ '\n\n width: 100%;\n height: 100%;\n display: grid;\n overflow: hidden;\n grid-template-rows: auto;\n grid-template-areas: "gutter pretty-rich-textarea";\n grid-template-columns: min-content auto; \n\n color: inherit;\n font-size: inherit;\n line-height: inherit;\n font-family: inherit;\n font-weight: inherit;\n caret-color: inherit;\n border-color: inherit;\n text-rendering: inherit;\n background-color: transparent;\n font-feature-settings: inherit;\n\n'
218
219
  ]);
219
220
  _templateObject = function _templateObject() {
220
221
  return data;
221
222
  };
222
223
  return data;
223
224
  }
225
+ var CHANGE_CUSTOM_EVENT_TYPE = _easyrichtextarea.customEventTypes.CHANGE_CUSTOM_EVENT_TYPE;
224
226
  var PrettyPrinter = /*#__PURE__*/ function(Element) {
225
227
  _inherits(PrettyPrinter, Element);
226
228
  var _super = _create_super(PrettyPrinter);
@@ -228,10 +230,14 @@ var PrettyPrinter = /*#__PURE__*/ function(Element) {
228
230
  _class_call_check(this, PrettyPrinter);
229
231
  var _this;
230
232
  _this = _super.apply(this, arguments);
231
- _define_property(_assert_this_initialized(_this), "scrollHandler", function(event, element) {
233
+ _define_property(_assert_this_initialized(_this), "customChangeHandler", function(event, element) {
234
+ var customEventType = CHANGE_CUSTOM_EVENT_TYPE; ///
235
+ _this.callCustomHandlers(customEventType);
236
+ });
237
+ _define_property(_assert_this_initialized(_this), "customScrollHandler", function(event, element) {
232
238
  var richTextarea = element, scrollTop = richTextarea.getScrollTop(), scrollLeft = richTextarea.getScrollLeft();
233
239
  _this.scrollGutterDiv(scrollTop, scrollLeft);
234
- _this.scrollOverlayDiv(scrollTop, scrollLeft);
240
+ _this.scrollPrettyDiv(scrollTop, scrollLeft);
235
241
  });
236
242
  return _this;
237
243
  }
@@ -240,26 +246,26 @@ var PrettyPrinter = /*#__PURE__*/ function(Element) {
240
246
  key: "update",
241
247
  value: function update(tokens) {
242
248
  this.updateGutterDiv(tokens);
243
- this.updateOverlayDiv(tokens);
249
+ this.updatePrettyDiv(tokens);
244
250
  }
245
251
  },
246
252
  {
247
253
  key: "childElements",
248
254
  value: function childElements() {
249
- var _this_properties = this.properties, editable = _this_properties.editable, onChange = _this_properties.onChange, hiddenGutter = _this_properties.hiddenGutter, fancyScrollbars = _this_properties.fancyScrollbars, hiddenScrollbars = _this_properties.hiddenScrollbars, hidden = hiddenGutter, readOnly = !editable, changeHandler = onChange, scrollbarThickness = (0, _scrollbar.getScrollbarThickness)(hiddenScrollbars, fancyScrollbars);
255
+ var _this_properties = this.properties, editable = _this_properties.editable, hiddenGutter = _this_properties.hiddenGutter, fancyScrollbars = _this_properties.fancyScrollbars, hiddenScrollbars = _this_properties.hiddenScrollbars, scrollbarThickness = (0, _scrollbar.getScrollbarThickness)(hiddenScrollbars, fancyScrollbars), readOnly = !editable, hidden = hiddenGutter; ///
250
256
  return [
251
257
  /*#__PURE__*/ _easy.React.createElement(_gutter.default, {
252
258
  hidden: hidden
253
259
  }),
254
- /*#__PURE__*/ _easy.React.createElement(_overlay.default, {
260
+ /*#__PURE__*/ _easy.React.createElement(_pretty.default, {
255
261
  scrollbarThickness: scrollbarThickness
256
262
  }),
257
263
  /*#__PURE__*/ _easy.React.createElement(_richTextarea.default, {
258
- onScroll: this.scrollHandler,
259
- onChange: changeHandler,
264
+ readOnly: readOnly,
260
265
  fancyScrollbars: fancyScrollbars,
261
266
  hiddenScrollbars: hiddenScrollbars,
262
- readOnly: readOnly
267
+ onCustomChange: this.customChangeHandler,
268
+ onCustomScroll: this.customScrollHandler
263
269
  })
264
270
  ];
265
271
  }
@@ -279,8 +285,8 @@ var PrettyPrinter = /*#__PURE__*/ function(Element) {
279
285
  this.assignContext([
280
286
  "updateGutterDiv",
281
287
  "scrollGutterDiv",
282
- "updateOverlayDiv",
283
- "scrollOverlayDiv"
288
+ "updatePrettyDiv",
289
+ "scrollPrettyDiv"
284
290
  ]);
285
291
  }
286
292
  }
@@ -300,4 +306,4 @@ _define_property(PrettyPrinter, "ignoredProperties", [
300
306
  ]);
301
307
  var _default = (0, _easywithstyle.default)(PrettyPrinter)(_templateObject());
302
308
 
303
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wcmV0dHlQcmludGVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5pbXBvcnQgd2l0aFN0eWxlIGZyb20gXCJlYXN5LXdpdGgtc3R5bGVcIjsgIC8vL1xuXG5pbXBvcnQgeyBSZWFjdCwgRWxlbWVudCB9IGZyb20gXCJlYXN5XCI7XG5cbmltcG9ydCBHdXR0ZXJEaXYgZnJvbSBcIi4vZGl2L2d1dHRlclwiO1xuaW1wb3J0IE92ZXJsYXlEaXYgZnJvbSBcIi4vZGl2L292ZXJsYXlcIjtcbmltcG9ydCBSaWNoVGV4dGFyZWEgZnJvbSBcIi4vcmljaFRleHRhcmVhXCI7XG5cbmltcG9ydCB7IGdldFNjcm9sbGJhclRoaWNrbmVzcyB9IGZyb20gXCIuL3V0aWxpdGllcy9zY3JvbGxiYXJcIjtcblxuY2xhc3MgUHJldHR5UHJpbnRlciBleHRlbmRzIEVsZW1lbnQge1xuICBzY3JvbGxIYW5kbGVyID0gKGV2ZW50LCBlbGVtZW50KSA9PiB7XG4gICAgY29uc3QgcmljaFRleHRhcmVhID0gZWxlbWVudCwgLy8vXG4gICAgICAgICAgc2Nyb2xsVG9wID0gcmljaFRleHRhcmVhLmdldFNjcm9sbFRvcCgpLFxuICAgICAgICAgIHNjcm9sbExlZnQgPSByaWNoVGV4dGFyZWEuZ2V0U2Nyb2xsTGVmdCgpO1xuXG4gICAgdGhpcy5zY3JvbGxHdXR0ZXJEaXYoc2Nyb2xsVG9wICxzY3JvbGxMZWZ0KTtcblxuICAgIHRoaXMuc2Nyb2xsT3ZlcmxheURpdihzY3JvbGxUb3AsIHNjcm9sbExlZnQpO1xuICB9XG5cbiAgdXBkYXRlKHRva2Vucykge1xuICAgIHRoaXMudXBkYXRlR3V0dGVyRGl2KHRva2Vucyk7XG5cbiAgICB0aGlzLnVwZGF0ZU92ZXJsYXlEaXYodG9rZW5zKTtcbiAgfVxuXG4gIGNoaWxkRWxlbWVudHMoKSB7XG4gICAgY29uc3QgeyBlZGl0YWJsZSwgb25DaGFuZ2UsIGhpZGRlbkd1dHRlciwgZmFuY3lTY3JvbGxiYXJzLCBoaWRkZW5TY3JvbGxiYXJzIH0gPSB0aGlzLnByb3BlcnRpZXMsXG4gICAgICAgICAgaGlkZGVuID0gaGlkZGVuR3V0dGVyLCAgLy8vXG4gICAgICAgICAgcmVhZE9ubHkgPSAhZWRpdGFibGUsXG4gICAgICAgICAgY2hhbmdlSGFuZGxlciA9IG9uQ2hhbmdlLCAvLy9cbiAgICAgICAgICBzY3JvbGxiYXJUaGlja25lc3MgPSBnZXRTY3JvbGxiYXJUaGlja25lc3MoaGlkZGVuU2Nyb2xsYmFycywgZmFuY3lTY3JvbGxiYXJzKTtcblxuICAgIHJldHVybiAoW1xuXG4gICAgICA8R3V0dGVyRGl2IGhpZGRlbj17aGlkZGVufSAvPixcbiAgICAgIDxPdmVybGF5RGl2IHNjcm9sbGJhclRoaWNrbmVzcz17c2Nyb2xsYmFyVGhpY2tuZXNzfSAvPixcbiAgICAgIDxSaWNoVGV4dGFyZWEgb25TY3JvbGw9e3RoaXMuc2Nyb2xsSGFuZGxlcn0gb25DaGFuZ2U9e2NoYW5nZUhhbmRsZXJ9IGZhbmN5U2Nyb2xsYmFycz17ZmFuY3lTY3JvbGxiYXJzfSBoaWRkZW5TY3JvbGxiYXJzPXtoaWRkZW5TY3JvbGxiYXJzfSByZWFkT25seT17cmVhZE9ubHl9IC8+XG5cbiAgICBdKTtcbiAgfVxuICBcbiAgcGFyZW50Q29udGV4dCgpIHtcbiAgICBjb25zdCBjb250ZXh0ID0gdGhpcy5nZXRDb250ZXh0KCksXG4gICAgICAgICAgdXBkYXRlUHJldHR5UHJpbnRlciA9IHRoaXMudXBkYXRlLmJpbmQodGhpcyk7IC8vL1xuXG4gICAgcmV0dXJuICh7XG4gICAgICAuLi5jb250ZXh0LFxuICAgICAgdXBkYXRlUHJldHR5UHJpbnRlclxuICAgIH0pO1xuICB9XG5cbiAgaW5pdGlhbGlzZSgpIHtcbiAgICB0aGlzLmFzc2lnbkNvbnRleHQoW1xuICAgICAgXCJ1cGRhdGVHdXR0ZXJEaXZcIixcbiAgICAgIFwic2Nyb2xsR3V0dGVyRGl2XCIsXG4gICAgICBcInVwZGF0ZU92ZXJsYXlEaXZcIixcbiAgICAgIFwic2Nyb2xsT3ZlcmxheURpdlwiXG4gICAgXSk7XG4gIH1cblxuICBzdGF0aWMgdGFnTmFtZSA9IFwiZGl2XCI7XG5cbiAgc3RhdGljIGRlZmF1bHRQcm9wZXJ0aWVzID0ge1xuICAgIGNsYXNzTmFtZTogXCJwcmV0dHktcHJpbnRlclwiXG4gIH07XG5cbiAgc3RhdGljIGlnbm9yZWRQcm9wZXJ0aWVzID0gW1xuICAgIFwib25DaGFuZ2VcIixcbiAgICBcImVkaXRhYmxlXCIsXG4gICAgXCJoaWRkZW5HdXR0ZXJcIixcbiAgICBcIm5vU2Nyb2xsYmFyc1wiLFxuICAgIFwiZmFuY3lTY3JvbGxiYXJzXCJcbiAgXTtcbn1cblxuZXhwb3J0IGRlZmF1bHQgd2l0aFN0eWxlKFByZXR0eVByaW50ZXIpYFxuXG4gIHdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDEwMCU7XG4gIGRpc3BsYXk6IGdyaWQ7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGdyaWQtdGVtcGxhdGUtcm93czogYXV0bztcbiAgZ3JpZC10ZW1wbGF0ZS1hcmVhczogXCJndXR0ZXIgb3ZlcmxheS1yaWNoLXRleHRhcmVhXCI7XG4gIGdyaWQtdGVtcGxhdGUtY29sdW1uczogbWluLWNvbnRlbnQgYXV0bzsgIFxuXG4gIGNvbG9yOiBpbmhlcml0O1xuICBmb250LXNpemU6IGluaGVyaXQ7XG4gIGxpbmUtaGVpZ2h0OiBpbmhlcml0O1xuICBmb250LWZhbWlseTogaW5oZXJpdDtcbiAgZm9udC13ZWlnaHQ6IGluaGVyaXQ7XG4gIGNhcmV0LWNvbG9yOiBpbmhlcml0O1xuICBib3JkZXItY29sb3I6IGluaGVyaXQ7XG4gIHRleHQtcmVuZGVyaW5nOiBpbmhlcml0O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbiAgZm9udC1mZWF0dXJlLXNldHRpbmdzOiBpbmhlcml0O1xuXG5gO1xuIl0sIm5hbWVzIjpbIlByZXR0eVByaW50ZXIiLCJzY3JvbGxIYW5kbGVyIiwiZXZlbnQiLCJlbGVtZW50IiwicmljaFRleHRhcmVhIiwic2Nyb2xsVG9wIiwiZ2V0U2Nyb2xsVG9wIiwic2Nyb2xsTGVmdCIsImdldFNjcm9sbExlZnQiLCJzY3JvbGxHdXR0ZXJEaXYiLCJzY3JvbGxPdmVybGF5RGl2IiwidXBkYXRlIiwidG9rZW5zIiwidXBkYXRlR3V0dGVyRGl2IiwidXBkYXRlT3ZlcmxheURpdiIsImNoaWxkRWxlbWVudHMiLCJwcm9wZXJ0aWVzIiwiZWRpdGFibGUiLCJvbkNoYW5nZSIsImhpZGRlbkd1dHRlciIsImZhbmN5U2Nyb2xsYmFycyIsImhpZGRlblNjcm9sbGJhcnMiLCJoaWRkZW4iLCJyZWFkT25seSIsImNoYW5nZUhhbmRsZXIiLCJzY3JvbGxiYXJUaGlja25lc3MiLCJnZXRTY3JvbGxiYXJUaGlja25lc3MiLCJHdXR0ZXJEaXYiLCJPdmVybGF5RGl2IiwiUmljaFRleHRhcmVhIiwib25TY3JvbGwiLCJwYXJlbnRDb250ZXh0IiwiY29udGV4dCIsImdldENvbnRleHQiLCJ1cGRhdGVQcmV0dHlQcmludGVyIiwiYmluZCIsImluaXRpYWxpc2UiLCJhc3NpZ25Db250ZXh0IiwiRWxlbWVudCIsInRhZ05hbWUiLCJkZWZhdWx0UHJvcGVydGllcyIsImNsYXNzTmFtZSIsImlnbm9yZWRQcm9wZXJ0aWVzIiwid2l0aFN0eWxlIl0sIm1hcHBpbmdzIjoiQUFBQTs7OzsrQkErRUE7OztlQUFBOzs7b0VBN0VzQjtvQkFFUzs2REFFVDs4REFDQzttRUFDRTt5QkFFYTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUV0QyxJQUFBLEFBQU1BLDhCQUFELEFBQUw7Y0FBTUE7K0JBQUFBO2FBQUFBO2dDQUFBQTs7O1FBQ0pDLGtEQUFBQSxpQkFBZ0IsU0FBQ0MsT0FBT0M7WUFDdEIsSUFBTUMsZUFBZUQsU0FDZkUsWUFBWUQsYUFBYUUsWUFBWSxJQUNyQ0MsYUFBYUgsYUFBYUksYUFBYTtZQUU3QyxNQUFLQyxlQUFlLENBQUNKLFdBQVdFO1lBRWhDLE1BQUtHLGdCQUFnQixDQUFDTCxXQUFXRTtRQUNuQzs7O2tCQVRJUDs7WUFXSlcsS0FBQUE7bUJBQUFBLFNBQUFBLE9BQU9DLE1BQU07Z0JBQ1gsSUFBSSxDQUFDQyxlQUFlLENBQUNEO2dCQUVyQixJQUFJLENBQUNFLGdCQUFnQixDQUFDRjtZQUN4Qjs7O1lBRUFHLEtBQUFBO21CQUFBQSxTQUFBQTtnQkFDRSxJQUFnRixtQkFBQSxJQUFJLENBQUNDLFVBQVUsRUFBdkZDLFdBQXdFLGlCQUF4RUEsVUFBVUMsV0FBOEQsaUJBQTlEQSxVQUFVQyxlQUFvRCxpQkFBcERBLGNBQWNDLGtCQUFzQyxpQkFBdENBLGlCQUFpQkMsbUJBQXFCLGlCQUFyQkEsa0JBQ3JEQyxTQUFTSCxjQUNUSSxXQUFXLENBQUNOLFVBQ1pPLGdCQUFnQk4sVUFDaEJPLHFCQUFxQkMsSUFBQUEsZ0NBQXFCLEVBQUNMLGtCQUFrQkQ7Z0JBRW5FLE9BQVE7a0NBRU4sMEJBQUNPLGVBQVM7d0JBQUNMLFFBQVFBOztrQ0FDbkIsMEJBQUNNLGdCQUFVO3dCQUFDSCxvQkFBb0JBOztrQ0FDaEMsMEJBQUNJLHFCQUFZO3dCQUFDQyxVQUFVLElBQUksQ0FBQzdCLGFBQWE7d0JBQUVpQixVQUFVTTt3QkFBZUosaUJBQWlCQTt3QkFBaUJDLGtCQUFrQkE7d0JBQWtCRSxVQUFVQTs7aUJBRXRKO1lBQ0g7OztZQUVBUSxLQUFBQTttQkFBQUEsU0FBQUE7Z0JBQ0UsSUFBTUMsVUFBVSxJQUFJLENBQUNDLFVBQVUsSUFDekJDLHNCQUFzQixJQUFJLENBQUN2QixNQUFNLENBQUN3QixJQUFJLENBQUMsSUFBSSxHQUFHLEdBQUc7Z0JBRXZELE9BQVEsd0NBQ0hIO29CQUNIRSxxQkFBQUE7O1lBRUo7OztZQUVBRSxLQUFBQTttQkFBQUEsU0FBQUE7Z0JBQ0UsSUFBSSxDQUFDQyxhQUFhLENBQUM7b0JBQ2pCO29CQUNBO29CQUNBO29CQUNBO2lCQUNEO1lBQ0g7OztXQWxESXJDO3FCQUFzQnNDLGFBQU87QUFvRGpDLGlCQXBESXRDLGVBb0RHdUMsV0FBVTtBQUVqQixpQkF0REl2QyxlQXNER3dDLHFCQUFvQjtJQUN6QkMsV0FBVztBQUNiO0FBRUEsaUJBMURJekMsZUEwREcwQyxxQkFBb0I7SUFDekI7SUFDQTtJQUNBO0lBQ0E7SUFDQTtDQUNEO0lBR0gsV0FBZUMsSUFBQUEsc0JBQVMsRUFBQzNDIn0=
309
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wcmV0dHlQcmludGVyLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIlwidXNlIHN0cmljdFwiO1xuXG5pbXBvcnQgd2l0aFN0eWxlIGZyb20gXCJlYXN5LXdpdGgtc3R5bGVcIjsgIC8vL1xuXG5pbXBvcnQgeyBSZWFjdCwgRWxlbWVudCB9IGZyb20gXCJlYXN5XCI7XG5pbXBvcnQgeyBjdXN0b21FdmVudFR5cGVzICB9IGZyb20gXCJlYXN5LXJpY2h0ZXh0YXJlYVwiO1xuXG5pbXBvcnQgR3V0dGVyRGl2IGZyb20gXCIuL2Rpdi9ndXR0ZXJcIjtcbmltcG9ydCBQcmV0dHlEaXYgZnJvbSBcIi4vZGl2L3ByZXR0eVwiO1xuaW1wb3J0IFJpY2hUZXh0YXJlYSBmcm9tIFwiLi9yaWNoVGV4dGFyZWFcIjtcblxuaW1wb3J0IHsgZ2V0U2Nyb2xsYmFyVGhpY2tuZXNzIH0gZnJvbSBcIi4vdXRpbGl0aWVzL3Njcm9sbGJhclwiO1xuXG5jb25zdCB7IENIQU5HRV9DVVNUT01fRVZFTlRfVFlQRSB9ID0gY3VzdG9tRXZlbnRUeXBlcztcblxuY2xhc3MgUHJldHR5UHJpbnRlciBleHRlbmRzIEVsZW1lbnQge1xuICBjdXN0b21DaGFuZ2VIYW5kbGVyID0gKGV2ZW50LCBlbGVtZW50KSA9PiB7XG4gICAgY29uc3QgY3VzdG9tRXZlbnRUeXBlID0gQ0hBTkdFX0NVU1RPTV9FVkVOVF9UWVBFOyAvLy9cblxuICAgIHRoaXMuY2FsbEN1c3RvbUhhbmRsZXJzKGN1c3RvbUV2ZW50VHlwZSk7XG4gIH1cblxuICBjdXN0b21TY3JvbGxIYW5kbGVyID0gKGV2ZW50LCBlbGVtZW50KSA9PiB7XG4gICAgY29uc3QgcmljaFRleHRhcmVhID0gZWxlbWVudCwgLy8vXG4gICAgICAgICAgc2Nyb2xsVG9wID0gcmljaFRleHRhcmVhLmdldFNjcm9sbFRvcCgpLFxuICAgICAgICAgIHNjcm9sbExlZnQgPSByaWNoVGV4dGFyZWEuZ2V0U2Nyb2xsTGVmdCgpO1xuXG4gICAgdGhpcy5zY3JvbGxHdXR0ZXJEaXYoc2Nyb2xsVG9wICxzY3JvbGxMZWZ0KTtcblxuICAgIHRoaXMuc2Nyb2xsUHJldHR5RGl2KHNjcm9sbFRvcCwgc2Nyb2xsTGVmdCk7XG4gIH1cblxuICB1cGRhdGUodG9rZW5zKSB7XG4gICAgdGhpcy51cGRhdGVHdXR0ZXJEaXYodG9rZW5zKTtcbiAgICB0aGlzLnVwZGF0ZVByZXR0eURpdih0b2tlbnMpO1xuICB9XG5cbiAgY2hpbGRFbGVtZW50cygpIHtcbiAgICBjb25zdCB7IGVkaXRhYmxlLCBoaWRkZW5HdXR0ZXIsIGZhbmN5U2Nyb2xsYmFycywgaGlkZGVuU2Nyb2xsYmFycyB9ID0gdGhpcy5wcm9wZXJ0aWVzLFxuICAgICAgICAgIHNjcm9sbGJhclRoaWNrbmVzcyA9IGdldFNjcm9sbGJhclRoaWNrbmVzcyhoaWRkZW5TY3JvbGxiYXJzLCBmYW5jeVNjcm9sbGJhcnMpLFxuICAgICAgICAgIHJlYWRPbmx5ID0gIWVkaXRhYmxlLFxuICAgICAgICAgIGhpZGRlbiA9IGhpZGRlbkd1dHRlcjsgIC8vL1xuXG4gICAgcmV0dXJuIChbXG5cbiAgICAgIDxHdXR0ZXJEaXYgaGlkZGVuPXtoaWRkZW59IC8+LFxuICAgICAgPFByZXR0eURpdiBzY3JvbGxiYXJUaGlja25lc3M9e3Njcm9sbGJhclRoaWNrbmVzc30gLz4sXG4gICAgICA8UmljaFRleHRhcmVhIHJlYWRPbmx5PXtyZWFkT25seX1cbiAgICAgICAgICAgICAgICAgICAgZmFuY3lTY3JvbGxiYXJzPXtmYW5jeVNjcm9sbGJhcnN9XG4gICAgICAgICAgICAgICAgICAgIGhpZGRlblNjcm9sbGJhcnM9e2hpZGRlblNjcm9sbGJhcnN9XG4gICAgICAgICAgICAgICAgICAgIG9uQ3VzdG9tQ2hhbmdlPXt0aGlzLmN1c3RvbUNoYW5nZUhhbmRsZXJ9XG4gICAgICAgICAgICAgICAgICAgIG9uQ3VzdG9tU2Nyb2xsPXt0aGlzLmN1c3RvbVNjcm9sbEhhbmRsZXJ9XG4gICAgICAvPlxuXG4gICAgXSk7XG4gIH1cbiAgXG4gIHBhcmVudENvbnRleHQoKSB7XG4gICAgY29uc3QgY29udGV4dCA9IHRoaXMuZ2V0Q29udGV4dCgpLFxuICAgICAgICAgIHVwZGF0ZVByZXR0eVByaW50ZXIgPSB0aGlzLnVwZGF0ZS5iaW5kKHRoaXMpOyAvLy9cblxuICAgIHJldHVybiAoe1xuICAgICAgLi4uY29udGV4dCxcbiAgICAgIHVwZGF0ZVByZXR0eVByaW50ZXJcbiAgICB9KTtcbiAgfVxuXG4gIGluaXRpYWxpc2UoKSB7XG4gICAgdGhpcy5hc3NpZ25Db250ZXh0KFtcbiAgICAgIFwidXBkYXRlR3V0dGVyRGl2XCIsXG4gICAgICBcInNjcm9sbEd1dHRlckRpdlwiLFxuICAgICAgXCJ1cGRhdGVQcmV0dHlEaXZcIixcbiAgICAgIFwic2Nyb2xsUHJldHR5RGl2XCJcbiAgICBdKTtcbiAgfVxuXG4gIHN0YXRpYyB0YWdOYW1lID0gXCJkaXZcIjtcblxuICBzdGF0aWMgZGVmYXVsdFByb3BlcnRpZXMgPSB7XG4gICAgY2xhc3NOYW1lOiBcInByZXR0eS1wcmludGVyXCJcbiAgfTtcblxuICBzdGF0aWMgaWdub3JlZFByb3BlcnRpZXMgPSBbXG4gICAgXCJvbkNoYW5nZVwiLFxuICAgIFwiZWRpdGFibGVcIixcbiAgICBcImhpZGRlbkd1dHRlclwiLFxuICAgIFwibm9TY3JvbGxiYXJzXCIsXG4gICAgXCJmYW5jeVNjcm9sbGJhcnNcIlxuICBdO1xufVxuXG5leHBvcnQgZGVmYXVsdCB3aXRoU3R5bGUoUHJldHR5UHJpbnRlcilgXG5cbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMTAwJTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgZ3JpZC10ZW1wbGF0ZS1yb3dzOiBhdXRvO1xuICBncmlkLXRlbXBsYXRlLWFyZWFzOiBcImd1dHRlciBwcmV0dHktcmljaC10ZXh0YXJlYVwiO1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IG1pbi1jb250ZW50IGF1dG87ICBcblxuICBjb2xvcjogaW5oZXJpdDtcbiAgZm9udC1zaXplOiBpbmhlcml0O1xuICBsaW5lLWhlaWdodDogaW5oZXJpdDtcbiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gIGZvbnQtd2VpZ2h0OiBpbmhlcml0O1xuICBjYXJldC1jb2xvcjogaW5oZXJpdDtcbiAgYm9yZGVyLWNvbG9yOiBpbmhlcml0O1xuICB0ZXh0LXJlbmRlcmluZzogaW5oZXJpdDtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIGZvbnQtZmVhdHVyZS1zZXR0aW5nczogaW5oZXJpdDtcblxuYDtcbiJdLCJuYW1lcyI6WyJDSEFOR0VfQ1VTVE9NX0VWRU5UX1RZUEUiLCJjdXN0b21FdmVudFR5cGVzIiwiUHJldHR5UHJpbnRlciIsImN1c3RvbUNoYW5nZUhhbmRsZXIiLCJldmVudCIsImVsZW1lbnQiLCJjdXN0b21FdmVudFR5cGUiLCJjYWxsQ3VzdG9tSGFuZGxlcnMiLCJjdXN0b21TY3JvbGxIYW5kbGVyIiwicmljaFRleHRhcmVhIiwic2Nyb2xsVG9wIiwiZ2V0U2Nyb2xsVG9wIiwic2Nyb2xsTGVmdCIsImdldFNjcm9sbExlZnQiLCJzY3JvbGxHdXR0ZXJEaXYiLCJzY3JvbGxQcmV0dHlEaXYiLCJ1cGRhdGUiLCJ0b2tlbnMiLCJ1cGRhdGVHdXR0ZXJEaXYiLCJ1cGRhdGVQcmV0dHlEaXYiLCJjaGlsZEVsZW1lbnRzIiwicHJvcGVydGllcyIsImVkaXRhYmxlIiwiaGlkZGVuR3V0dGVyIiwiZmFuY3lTY3JvbGxiYXJzIiwiaGlkZGVuU2Nyb2xsYmFycyIsInNjcm9sbGJhclRoaWNrbmVzcyIsImdldFNjcm9sbGJhclRoaWNrbmVzcyIsInJlYWRPbmx5IiwiaGlkZGVuIiwiR3V0dGVyRGl2IiwiUHJldHR5RGl2IiwiUmljaFRleHRhcmVhIiwib25DdXN0b21DaGFuZ2UiLCJvbkN1c3RvbVNjcm9sbCIsInBhcmVudENvbnRleHQiLCJjb250ZXh0IiwiZ2V0Q29udGV4dCIsInVwZGF0ZVByZXR0eVByaW50ZXIiLCJiaW5kIiwiaW5pdGlhbGlzZSIsImFzc2lnbkNvbnRleHQiLCJFbGVtZW50IiwidGFnTmFtZSIsImRlZmF1bHRQcm9wZXJ0aWVzIiwiY2xhc3NOYW1lIiwiaWdub3JlZFByb3BlcnRpZXMiLCJ3aXRoU3R5bGUiXSwibWFwcGluZ3MiOiJBQUFBOzs7OytCQTJGQTs7O2VBQUE7OztvRUF6RnNCO29CQUVTO2dDQUNHOzZEQUVaOzZEQUNBO21FQUNHO3lCQUVhOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRXRDLElBQU0sQUFBRUEsMkJBQTZCQyxrQ0FBZ0IsQ0FBN0NEO0FBRVIsSUFBQSxBQUFNRSw4QkFBRCxBQUFMO2NBQU1BOytCQUFBQTthQUFBQTtnQ0FBQUE7OztRQUNKQyxrREFBQUEsdUJBQXNCLFNBQUNDLE9BQU9DO1lBQzVCLElBQU1DLGtCQUFrQk4sMEJBQTBCLEdBQUc7WUFFckQsTUFBS08sa0JBQWtCLENBQUNEO1FBQzFCO1FBRUFFLGtEQUFBQSx1QkFBc0IsU0FBQ0osT0FBT0M7WUFDNUIsSUFBTUksZUFBZUosU0FDZkssWUFBWUQsYUFBYUUsWUFBWSxJQUNyQ0MsYUFBYUgsYUFBYUksYUFBYTtZQUU3QyxNQUFLQyxlQUFlLENBQUNKLFdBQVdFO1lBRWhDLE1BQUtHLGVBQWUsQ0FBQ0wsV0FBV0U7UUFDbEM7OztrQkFmSVY7O1lBaUJKYyxLQUFBQTttQkFBQUEsU0FBQUEsT0FBT0MsTUFBTTtnQkFDWCxJQUFJLENBQUNDLGVBQWUsQ0FBQ0Q7Z0JBQ3JCLElBQUksQ0FBQ0UsZUFBZSxDQUFDRjtZQUN2Qjs7O1lBRUFHLEtBQUFBO21CQUFBQSxTQUFBQTtnQkFDRSxJQUFzRSxtQkFBQSxJQUFJLENBQUNDLFVBQVUsRUFBN0VDLFdBQThELGlCQUE5REEsVUFBVUMsZUFBb0QsaUJBQXBEQSxjQUFjQyxrQkFBc0MsaUJBQXRDQSxpQkFBaUJDLG1CQUFxQixpQkFBckJBLGtCQUMzQ0MscUJBQXFCQyxJQUFBQSxnQ0FBcUIsRUFBQ0Ysa0JBQWtCRCxrQkFDN0RJLFdBQVcsQ0FBQ04sVUFDWk8sU0FBU04sY0FBZSxHQUFHO2dCQUVqQyxPQUFRO2tDQUVOLDBCQUFDTyxlQUFTO3dCQUFDRCxRQUFRQTs7a0NBQ25CLDBCQUFDRSxlQUFTO3dCQUFDTCxvQkFBb0JBOztrQ0FDL0IsMEJBQUNNLHFCQUFZO3dCQUFDSixVQUFVQTt3QkFDVkosaUJBQWlCQTt3QkFDakJDLGtCQUFrQkE7d0JBQ2xCUSxnQkFBZ0IsSUFBSSxDQUFDOUIsbUJBQW1CO3dCQUN4QytCLGdCQUFnQixJQUFJLENBQUMxQixtQkFBbUI7O2lCQUd2RDtZQUNIOzs7WUFFQTJCLEtBQUFBO21CQUFBQSxTQUFBQTtnQkFDRSxJQUFNQyxVQUFVLElBQUksQ0FBQ0MsVUFBVSxJQUN6QkMsc0JBQXNCLElBQUksQ0FBQ3RCLE1BQU0sQ0FBQ3VCLElBQUksQ0FBQyxJQUFJLEdBQUcsR0FBRztnQkFFdkQsT0FBUSx3Q0FDSEg7b0JBQ0hFLHFCQUFBQTs7WUFFSjs7O1lBRUFFLEtBQUFBO21CQUFBQSxTQUFBQTtnQkFDRSxJQUFJLENBQUNDLGFBQWEsQ0FBQztvQkFDakI7b0JBQ0E7b0JBQ0E7b0JBQ0E7aUJBQ0Q7WUFDSDs7O1dBM0RJdkM7cUJBQXNCd0MsYUFBTztBQTZEakMsaUJBN0RJeEMsZUE2REd5QyxXQUFVO0FBRWpCLGlCQS9ESXpDLGVBK0RHMEMscUJBQW9CO0lBQ3pCQyxXQUFXO0FBQ2I7QUFFQSxpQkFuRUkzQyxlQW1FRzRDLHFCQUFvQjtJQUN6QjtJQUNBO0lBQ0E7SUFDQTtJQUNBO0NBQ0Q7SUFHSCxXQUFlQyxJQUFBQSxzQkFBUyxFQUFDN0MifQ==
@@ -150,7 +150,7 @@ function _create_super(Derived) {
150
150
  }
151
151
  function _templateObject() {
152
152
  var data = _tagged_template_literal([
153
- "\n\n color: transparent;\n width: 100%;\n height: 100%;\n cursor: auto;\n resize: none;\n outline: none;\n z-index: 1;\n tab-size: 2;\n overflow: scroll;\n position: relative;\n grid-area: overlay-rich-textarea;\n white-space: pre;\n overflow-wrap: normal;\n background-color: transparent;\n\n ::selection {\n color: ",
153
+ "\n\n color: transparent;\n width: 100%;\n height: 100%;\n cursor: auto;\n resize: none;\n outline: none;\n z-index: 1;\n tab-size: 2;\n overflow: scroll;\n position: relative;\n grid-area: pretty-rich-textarea;\n white-space: pre;\n overflow-wrap: normal;\n background-color: transparent;\n\n ::selection {\n color: ",
154
154
  ";\n background-color: ",
155
155
  ";\n }\n \n .hidden-scrollbars {\n overflow: hidden;\n }\n \n .fancy-scrollbars {\n scrollbar-color: ",
156
156
  " transparent;\n scrollbar-gutter: auto;\n }\n \n .fancy-scrollbars::-webkit-scrollbar {\n width: ",
@@ -203,12 +203,13 @@ var _default = (0, _easywithstyle.default)((_class = /*#__PURE__*/ function(Rich
203
203
  {
204
204
  key: "parentContext",
205
205
  value: function parentContext() {
206
- var getContent = this.getContent.bind(this), activateRichTextarea = this.activate.bind(this), getRichTextareaContent = this.getContent.bind(this), setRichTextareaContent = this.setContent.bind(this); ///
206
+ var getContent = this.getContent.bind(this), activateRichTextarea = this.activate.bind(this), getRichTextareaContent = this.getContent.bind(this), setRichTextareaContent = this.setContent.bind(this), hasRichTextareaContentChanged = this.hasContentChanged.bind(this); ///
207
207
  return {
208
208
  getContent: getContent,
209
209
  activateRichTextarea: activateRichTextarea,
210
210
  getRichTextareaContent: getRichTextareaContent,
211
- setRichTextareaContent: setRichTextareaContent
211
+ setRichTextareaContent: setRichTextareaContent,
212
+ hasRichTextareaContentChanged: hasRichTextareaContentChanged
212
213
  };
213
214
  }
214
215
  }
@@ -221,4 +222,4 @@ var _default = (0, _easywithstyle.default)((_class = /*#__PURE__*/ function(Rich
221
222
  "hiddenScrollbars"
222
223
  ]), _class))(_templateObject(), _colour.selectionColour, _colour.selectionBackgroundColour, _colour.scrollbarColour, _styles.scrollbarThickness, _styles.scrollbarThickness, _colour.backgroundColour, _styles.scrollbarThumbBorderRadius, _colour.scrollbarColour);
223
224
 
224
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yaWNoVGV4dGFyZWEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB3aXRoU3R5bGUgZnJvbSBcImVhc3ktd2l0aC1zdHlsZVwiOyAgLy8vXG5cbmltcG9ydCB7IFJpY2hUZXh0YXJlYSB9IGZyb20gXCJlYXN5LXJpY2h0ZXh0YXJlYVwiO1xuaW1wb3J0IHsgc2Nyb2xsYmFyVGhpY2tuZXNzLCBzY3JvbGxiYXJUaHVtYkJvcmRlclJhZGl1cyB9IGZyb20gXCIuL3N0eWxlc1wiO1xuaW1wb3J0IHsgc2Nyb2xsYmFyQ29sb3VyLCBzZWxlY3Rpb25Db2xvdXIsIGJhY2tncm91bmRDb2xvdXIsIHNlbGVjdGlvbkJhY2tncm91bmRDb2xvdXIgIH0gZnJvbSBcIi4vc2NoZW1lL2NvbG91clwiO1xuXG5leHBvcnQgZGVmYXVsdCB3aXRoU3R5bGUoY2xhc3MgZXh0ZW5kcyBSaWNoVGV4dGFyZWEge1xuICBkaWRNb3VudCgpIHtcbiAgICBjb25zdCB7IGZhbmN5U2Nyb2xsYmFycywgaGlkZGVuU2Nyb2xsYmFycyB9ID0gdGhpcy5wcm9wZXJ0aWVzO1xuXG4gICAgaWYgKGZhbmN5U2Nyb2xsYmFycykge1xuICAgICAgdGhpcy5hZGRDbGFzcyhcImZhbmN5LXNjcm9sbGJhcnNcIik7XG4gICAgfVxuXG4gICAgaWYgKGhpZGRlblNjcm9sbGJhcnMpIHtcbiAgICAgIHRoaXMuYWRkQ2xhc3MoXCJoaWRkZW4tc2Nyb2xsYmFyc1wiKTtcbiAgICB9XG5cbiAgICBzdXBlci5kaWRNb3VudCgpO1xuICB9XG5cbiAgd2lsbFVubW91bnQoKSB7XG4gICAgY29uc3QgeyBmYW5jeVNjcm9sbGJhcnMsIGhpZGRlblNjcm9sbGJhcnMgfSA9IHRoaXMucHJvcGVydGllcztcblxuICAgIGlmIChmYW5jeVNjcm9sbGJhcnMpIHtcbiAgICAgIHRoaXMucmVtb3ZlQ2xhc3MoXCJmYW5jeS1zY3JvbGxiYXJzXCIpO1xuICAgIH1cblxuICAgIGlmIChoaWRkZW5TY3JvbGxiYXJzKSB7XG4gICAgICB0aGlzLnJlbW92ZUNsYXNzKFwiaGlkZGVuLXNjcm9sbGJhcnNcIik7XG4gICAgfVxuXG4gICAgc3VwZXIud2lsbFVubW91bnQoKTtcbiAgfVxuXG4gIHBhcmVudENvbnRleHQoKSB7XG4gICAgY29uc3QgZ2V0Q29udGVudCA9IHRoaXMuZ2V0Q29udGVudC5iaW5kKHRoaXMpLCAgLy8vXG4gICAgICAgICAgYWN0aXZhdGVSaWNoVGV4dGFyZWEgPSB0aGlzLmFjdGl2YXRlLmJpbmQodGhpcyksICAvLy9cbiAgICAgICAgICBnZXRSaWNoVGV4dGFyZWFDb250ZW50ID0gdGhpcy5nZXRDb250ZW50LmJpbmQodGhpcyksICAvLy9cbiAgICAgICAgICBzZXRSaWNoVGV4dGFyZWFDb250ZW50ID0gdGhpcy5zZXRDb250ZW50LmJpbmQodGhpcyk7ICAvLy9cblxuICAgIHJldHVybiAoe1xuICAgICAgZ2V0Q29udGVudCxcbiAgICAgIGFjdGl2YXRlUmljaFRleHRhcmVhLFxuICAgICAgZ2V0UmljaFRleHRhcmVhQ29udGVudCxcbiAgICAgIHNldFJpY2hUZXh0YXJlYUNvbnRlbnRcbiAgICB9KTtcbiAgfVxuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcGVydGllcyA9IHtcbiAgICBzcGVsbENoZWNrOiBcImZhbHNlXCJcbiAgfTtcblxuICBzdGF0aWMgaWdub3JlZFByb3BlcnRpZXMgPSBbXG4gICAgXCJmYW5jeVNjcm9sbGJhcnNcIixcbiAgICBcImhpZGRlblNjcm9sbGJhcnNcIlxuICBdO1xufSlgXG5cbiAgY29sb3I6IHRyYW5zcGFyZW50O1xuICB3aWR0aDogMTAwJTtcbiAgaGVpZ2h0OiAxMDAlO1xuICBjdXJzb3I6IGF1dG87XG4gIHJlc2l6ZTogbm9uZTtcbiAgb3V0bGluZTogbm9uZTtcbiAgei1pbmRleDogMTtcbiAgdGFiLXNpemU6IDI7XG4gIG92ZXJmbG93OiBzY3JvbGw7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZ3JpZC1hcmVhOiBvdmVybGF5LXJpY2gtdGV4dGFyZWE7XG4gIHdoaXRlLXNwYWNlOiBwcmU7XG4gIG92ZXJmbG93LXdyYXA6IG5vcm1hbDtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cbiAgOjpzZWxlY3Rpb24ge1xuICAgIGNvbG9yOiAke3NlbGVjdGlvbkNvbG91cn07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtzZWxlY3Rpb25CYWNrZ3JvdW5kQ29sb3VyfTtcbiAgfVxuICBcbiAgLmhpZGRlbi1zY3JvbGxiYXJzIHtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICB9XG4gIFxuICAuZmFuY3ktc2Nyb2xsYmFycyB7XG4gICAgc2Nyb2xsYmFyLWNvbG9yOiAke3Njcm9sbGJhckNvbG91cn0gdHJhbnNwYXJlbnQ7XG4gICAgc2Nyb2xsYmFyLWd1dHRlcjogYXV0bztcbiAgfVxuICBcbiAgLmZhbmN5LXNjcm9sbGJhcnM6Oi13ZWJraXQtc2Nyb2xsYmFyIHtcbiAgICB3aWR0aDogJHtzY3JvbGxiYXJUaGlja25lc3N9O1xuICAgIGhlaWdodDogJHtzY3JvbGxiYXJUaGlja25lc3N9O1xuICB9XG5cbiAgLmZhbmN5LXNjcm9sbGJhcnM6Oi13ZWJraXQtc2Nyb2xsYmFyLXRyYWNrIHtcbiAgICBkaXNwbGF5OiBub25lO1xuICB9XG5cbiAgLmZhbmN5LXNjcm9sbGJhcnM6Oi13ZWJraXQtc2Nyb2xsYmFyLXRodW1iIHtcbiAgICBib3JkZXI6IDJweCBzb2xpZCAke2JhY2tncm91bmRDb2xvdXJ9O1xuICAgIGJvcmRlci1yYWRpdXM6ICR7c2Nyb2xsYmFyVGh1bWJCb3JkZXJSYWRpdXN9O1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7c2Nyb2xsYmFyQ29sb3VyfTtcbiAgfVxuXG4gIC5mYW5jeS1zY3JvbGxiYXJzOjotd2Via2l0LXNjcm9sbGJhci1jb3JuZXIge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gIH1cblxuICBjb2xvcjogdHJhbnNwYXJlbnQ7XG4gIGZvbnQtc2l6ZTogaW5oZXJpdDtcbiAgbGluZS1oZWlnaHQ6IGluaGVyaXQ7XG4gIGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuICBmb250LXdlaWdodDogaW5oZXJpdDtcbiAgY2FyZXQtY29sb3I6IGluaGVyaXQ7XG4gIGJvcmRlci1jb2xvcjogaW5pdGlhbDtcbiAgdGV4dC1yZW5kZXJpbmc6IGluaGVyaXQ7XG4gIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBmb250LWZlYXR1cmUtc2V0dGluZ3M6IGluaGVyaXQ7XG5cbmA7XG4iXSwibmFtZXMiOlsid2l0aFN0eWxlIiwiZGlkTW91bnQiLCJwcm9wZXJ0aWVzIiwiZmFuY3lTY3JvbGxiYXJzIiwiaGlkZGVuU2Nyb2xsYmFycyIsImFkZENsYXNzIiwid2lsbFVubW91bnQiLCJyZW1vdmVDbGFzcyIsInBhcmVudENvbnRleHQiLCJnZXRDb250ZW50IiwiYmluZCIsImFjdGl2YXRlUmljaFRleHRhcmVhIiwiYWN0aXZhdGUiLCJnZXRSaWNoVGV4dGFyZWFDb250ZW50Iiwic2V0UmljaFRleHRhcmVhQ29udGVudCIsInNldENvbnRlbnQiLCJSaWNoVGV4dGFyZWEiLCJkZWZhdWx0UHJvcGVydGllcyIsInNwZWxsQ2hlY2siLCJpZ25vcmVkUHJvcGVydGllcyIsInNlbGVjdGlvbkNvbG91ciIsInNlbGVjdGlvbkJhY2tncm91bmRDb2xvdXIiLCJzY3JvbGxiYXJDb2xvdXIiLCJzY3JvbGxiYXJUaGlja25lc3MiLCJiYWNrZ3JvdW5kQ29sb3VyIiwic2Nyb2xsYmFyVGh1bWJCb3JkZXJSYWRpdXMiXSwibWFwcGluZ3MiOiJBQUFBOzs7OytCQVFBOzs7ZUFBQTs7O29FQU5zQjtnQ0FFTztzQkFDa0M7c0JBQ2dDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQUUvRixXQUFlQSxJQUFBQSxzQkFBUywwQkFBQzs7Ozs7Ozs7O1lBQ3ZCQyxLQUFBQTttQkFBQUEsU0FBQUE7Z0JBQ0UsSUFBOEMsbUJBQUEsSUFBSSxDQUFDQyxVQUFVLEVBQXJEQyxrQkFBc0MsaUJBQXRDQSxpQkFBaUJDLG1CQUFxQixpQkFBckJBO2dCQUV6QixJQUFJRCxpQkFBaUI7b0JBQ25CLElBQUksQ0FBQ0UsUUFBUSxDQUFDO2dCQUNoQjtnQkFFQSxJQUFJRCxrQkFBa0I7b0JBQ3BCLElBQUksQ0FBQ0MsUUFBUSxDQUFDO2dCQUNoQjtnQkFFQSwwQ0FBTUosWUFBTixJQUFLO1lBQ1A7OztZQUVBSyxLQUFBQTttQkFBQUEsU0FBQUE7Z0JBQ0UsSUFBOEMsbUJBQUEsSUFBSSxDQUFDSixVQUFVLEVBQXJEQyxrQkFBc0MsaUJBQXRDQSxpQkFBaUJDLG1CQUFxQixpQkFBckJBO2dCQUV6QixJQUFJRCxpQkFBaUI7b0JBQ25CLElBQUksQ0FBQ0ksV0FBVyxDQUFDO2dCQUNuQjtnQkFFQSxJQUFJSCxrQkFBa0I7b0JBQ3BCLElBQUksQ0FBQ0csV0FBVyxDQUFDO2dCQUNuQjtnQkFFQSwwQ0FBTUQsZUFBTixJQUFLO1lBQ1A7OztZQUVBRSxLQUFBQTttQkFBQUEsU0FBQUE7Z0JBQ0UsSUFBTUMsYUFBYSxJQUFJLENBQUNBLFVBQVUsQ0FBQ0MsSUFBSSxDQUFDLElBQUksR0FDdENDLHVCQUF1QixJQUFJLENBQUNDLFFBQVEsQ0FBQ0YsSUFBSSxDQUFDLElBQUksR0FDOUNHLHlCQUF5QixJQUFJLENBQUNKLFVBQVUsQ0FBQ0MsSUFBSSxDQUFDLElBQUksR0FDbERJLHlCQUF5QixJQUFJLENBQUNDLFVBQVUsQ0FBQ0wsSUFBSSxDQUFDLElBQUksR0FBSSxHQUFHO2dCQUUvRCxPQUFRO29CQUNORCxZQUFBQTtvQkFDQUUsc0JBQUFBO29CQUNBRSx3QkFBQUE7b0JBQ0FDLHdCQUFBQTtnQkFDRjtZQUNGOzs7O0VBekNxQ0UsOEJBQVksR0EyQ2pELHlCQUFPQyxxQkFBb0I7SUFDekJDLFlBQVk7QUFDZCxJQUVBLHlCQUFPQyxxQkFBb0I7SUFDekI7SUFDQTtDQUNELCtCQW1CVUMsdUJBQWUsRUFDSkMsaUNBQXlCLEVBUTFCQyx1QkFBZSxFQUt6QkMsMEJBQWtCLEVBQ2pCQSwwQkFBa0IsRUFRUkMsd0JBQWdCLEVBQ25CQyxrQ0FBMEIsRUFDdkJILHVCQUFlIn0=
225
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9yaWNoVGV4dGFyZWEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB3aXRoU3R5bGUgZnJvbSBcImVhc3ktd2l0aC1zdHlsZVwiOyAgLy8vXG5cbmltcG9ydCB7IFJpY2hUZXh0YXJlYSB9IGZyb20gXCJlYXN5LXJpY2h0ZXh0YXJlYVwiO1xuaW1wb3J0IHsgc2Nyb2xsYmFyVGhpY2tuZXNzLCBzY3JvbGxiYXJUaHVtYkJvcmRlclJhZGl1cyB9IGZyb20gXCIuL3N0eWxlc1wiO1xuaW1wb3J0IHsgc2Nyb2xsYmFyQ29sb3VyLCBzZWxlY3Rpb25Db2xvdXIsIGJhY2tncm91bmRDb2xvdXIsIHNlbGVjdGlvbkJhY2tncm91bmRDb2xvdXIgIH0gZnJvbSBcIi4vc2NoZW1lL2NvbG91clwiO1xuXG5leHBvcnQgZGVmYXVsdCB3aXRoU3R5bGUoY2xhc3MgZXh0ZW5kcyBSaWNoVGV4dGFyZWEge1xuICBkaWRNb3VudCgpIHtcbiAgICBjb25zdCB7IGZhbmN5U2Nyb2xsYmFycywgaGlkZGVuU2Nyb2xsYmFycyB9ID0gdGhpcy5wcm9wZXJ0aWVzO1xuXG4gICAgaWYgKGZhbmN5U2Nyb2xsYmFycykge1xuICAgICAgdGhpcy5hZGRDbGFzcyhcImZhbmN5LXNjcm9sbGJhcnNcIik7XG4gICAgfVxuXG4gICAgaWYgKGhpZGRlblNjcm9sbGJhcnMpIHtcbiAgICAgIHRoaXMuYWRkQ2xhc3MoXCJoaWRkZW4tc2Nyb2xsYmFyc1wiKTtcbiAgICB9XG5cbiAgICBzdXBlci5kaWRNb3VudCgpO1xuICB9XG5cbiAgd2lsbFVubW91bnQoKSB7XG4gICAgY29uc3QgeyBmYW5jeVNjcm9sbGJhcnMsIGhpZGRlblNjcm9sbGJhcnMgfSA9IHRoaXMucHJvcGVydGllcztcblxuICAgIGlmIChmYW5jeVNjcm9sbGJhcnMpIHtcbiAgICAgIHRoaXMucmVtb3ZlQ2xhc3MoXCJmYW5jeS1zY3JvbGxiYXJzXCIpO1xuICAgIH1cblxuICAgIGlmIChoaWRkZW5TY3JvbGxiYXJzKSB7XG4gICAgICB0aGlzLnJlbW92ZUNsYXNzKFwiaGlkZGVuLXNjcm9sbGJhcnNcIik7XG4gICAgfVxuXG4gICAgc3VwZXIud2lsbFVubW91bnQoKTtcbiAgfVxuXG4gIHBhcmVudENvbnRleHQoKSB7XG4gICAgY29uc3QgZ2V0Q29udGVudCA9IHRoaXMuZ2V0Q29udGVudC5iaW5kKHRoaXMpLCAgLy8vXG4gICAgICAgICAgYWN0aXZhdGVSaWNoVGV4dGFyZWEgPSB0aGlzLmFjdGl2YXRlLmJpbmQodGhpcyksICAvLy9cbiAgICAgICAgICBnZXRSaWNoVGV4dGFyZWFDb250ZW50ID0gdGhpcy5nZXRDb250ZW50LmJpbmQodGhpcyksICAvLy9cbiAgICAgICAgICBzZXRSaWNoVGV4dGFyZWFDb250ZW50ID0gdGhpcy5zZXRDb250ZW50LmJpbmQodGhpcyksICAvLy9cbiAgICAgICAgICBoYXNSaWNoVGV4dGFyZWFDb250ZW50Q2hhbmdlZCA9IHRoaXMuaGFzQ29udGVudENoYW5nZWQuYmluZCh0aGlzKTsgIC8vL1xuXG4gICAgcmV0dXJuICh7XG4gICAgICBnZXRDb250ZW50LFxuICAgICAgYWN0aXZhdGVSaWNoVGV4dGFyZWEsXG4gICAgICBnZXRSaWNoVGV4dGFyZWFDb250ZW50LFxuICAgICAgc2V0UmljaFRleHRhcmVhQ29udGVudCxcbiAgICAgIGhhc1JpY2hUZXh0YXJlYUNvbnRlbnRDaGFuZ2VkXG4gICAgfSk7XG4gIH1cblxuICBzdGF0aWMgZGVmYXVsdFByb3BlcnRpZXMgPSB7XG4gICAgc3BlbGxDaGVjazogXCJmYWxzZVwiXG4gIH07XG5cbiAgc3RhdGljIGlnbm9yZWRQcm9wZXJ0aWVzID0gW1xuICAgIFwiZmFuY3lTY3JvbGxiYXJzXCIsXG4gICAgXCJoaWRkZW5TY3JvbGxiYXJzXCJcbiAgXTtcbn0pYFxuXG4gIGNvbG9yOiB0cmFuc3BhcmVudDtcbiAgd2lkdGg6IDEwMCU7XG4gIGhlaWdodDogMTAwJTtcbiAgY3Vyc29yOiBhdXRvO1xuICByZXNpemU6IG5vbmU7XG4gIG91dGxpbmU6IG5vbmU7XG4gIHotaW5kZXg6IDE7XG4gIHRhYi1zaXplOiAyO1xuICBvdmVyZmxvdzogc2Nyb2xsO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGdyaWQtYXJlYTogcHJldHR5LXJpY2gtdGV4dGFyZWE7XG4gIHdoaXRlLXNwYWNlOiBwcmU7XG4gIG92ZXJmbG93LXdyYXA6IG5vcm1hbDtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG5cbiAgOjpzZWxlY3Rpb24ge1xuICAgIGNvbG9yOiAke3NlbGVjdGlvbkNvbG91cn07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtzZWxlY3Rpb25CYWNrZ3JvdW5kQ29sb3VyfTtcbiAgfVxuICBcbiAgLmhpZGRlbi1zY3JvbGxiYXJzIHtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICB9XG4gIFxuICAuZmFuY3ktc2Nyb2xsYmFycyB7XG4gICAgc2Nyb2xsYmFyLWNvbG9yOiAke3Njcm9sbGJhckNvbG91cn0gdHJhbnNwYXJlbnQ7XG4gICAgc2Nyb2xsYmFyLWd1dHRlcjogYXV0bztcbiAgfVxuICBcbiAgLmZhbmN5LXNjcm9sbGJhcnM6Oi13ZWJraXQtc2Nyb2xsYmFyIHtcbiAgICB3aWR0aDogJHtzY3JvbGxiYXJUaGlja25lc3N9O1xuICAgIGhlaWdodDogJHtzY3JvbGxiYXJUaGlja25lc3N9O1xuICB9XG5cbiAgLmZhbmN5LXNjcm9sbGJhcnM6Oi13ZWJraXQtc2Nyb2xsYmFyLXRyYWNrIHtcbiAgICBkaXNwbGF5OiBub25lO1xuICB9XG5cbiAgLmZhbmN5LXNjcm9sbGJhcnM6Oi13ZWJraXQtc2Nyb2xsYmFyLXRodW1iIHtcbiAgICBib3JkZXI6IDJweCBzb2xpZCAke2JhY2tncm91bmRDb2xvdXJ9O1xuICAgIGJvcmRlci1yYWRpdXM6ICR7c2Nyb2xsYmFyVGh1bWJCb3JkZXJSYWRpdXN9O1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7c2Nyb2xsYmFyQ29sb3VyfTtcbiAgfVxuXG4gIC5mYW5jeS1zY3JvbGxiYXJzOjotd2Via2l0LXNjcm9sbGJhci1jb3JuZXIge1xuICAgIGRpc3BsYXk6IG5vbmU7XG4gIH1cblxuICBjb2xvcjogdHJhbnNwYXJlbnQ7XG4gIGZvbnQtc2l6ZTogaW5oZXJpdDtcbiAgbGluZS1oZWlnaHQ6IGluaGVyaXQ7XG4gIGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuICBmb250LXdlaWdodDogaW5oZXJpdDtcbiAgY2FyZXQtY29sb3I6IGluaGVyaXQ7XG4gIGJvcmRlci1jb2xvcjogaW5pdGlhbDtcbiAgdGV4dC1yZW5kZXJpbmc6IGluaGVyaXQ7XG4gIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBmb250LWZlYXR1cmUtc2V0dGluZ3M6IGluaGVyaXQ7XG5cbmA7XG4iXSwibmFtZXMiOlsid2l0aFN0eWxlIiwiZGlkTW91bnQiLCJwcm9wZXJ0aWVzIiwiZmFuY3lTY3JvbGxiYXJzIiwiaGlkZGVuU2Nyb2xsYmFycyIsImFkZENsYXNzIiwid2lsbFVubW91bnQiLCJyZW1vdmVDbGFzcyIsInBhcmVudENvbnRleHQiLCJnZXRDb250ZW50IiwiYmluZCIsImFjdGl2YXRlUmljaFRleHRhcmVhIiwiYWN0aXZhdGUiLCJnZXRSaWNoVGV4dGFyZWFDb250ZW50Iiwic2V0UmljaFRleHRhcmVhQ29udGVudCIsInNldENvbnRlbnQiLCJoYXNSaWNoVGV4dGFyZWFDb250ZW50Q2hhbmdlZCIsImhhc0NvbnRlbnRDaGFuZ2VkIiwiUmljaFRleHRhcmVhIiwiZGVmYXVsdFByb3BlcnRpZXMiLCJzcGVsbENoZWNrIiwiaWdub3JlZFByb3BlcnRpZXMiLCJzZWxlY3Rpb25Db2xvdXIiLCJzZWxlY3Rpb25CYWNrZ3JvdW5kQ29sb3VyIiwic2Nyb2xsYmFyQ29sb3VyIiwic2Nyb2xsYmFyVGhpY2tuZXNzIiwiYmFja2dyb3VuZENvbG91ciIsInNjcm9sbGJhclRodW1iQm9yZGVyUmFkaXVzIl0sIm1hcHBpbmdzIjoiQUFBQTs7OzsrQkFRQTs7O2VBQUE7OztvRUFOc0I7Z0NBRU87c0JBQ2tDO3NCQUNnQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFFL0YsV0FBZUEsSUFBQUEsc0JBQVMsMEJBQUM7Ozs7Ozs7OztZQUN2QkMsS0FBQUE7bUJBQUFBLFNBQUFBO2dCQUNFLElBQThDLG1CQUFBLElBQUksQ0FBQ0MsVUFBVSxFQUFyREMsa0JBQXNDLGlCQUF0Q0EsaUJBQWlCQyxtQkFBcUIsaUJBQXJCQTtnQkFFekIsSUFBSUQsaUJBQWlCO29CQUNuQixJQUFJLENBQUNFLFFBQVEsQ0FBQztnQkFDaEI7Z0JBRUEsSUFBSUQsa0JBQWtCO29CQUNwQixJQUFJLENBQUNDLFFBQVEsQ0FBQztnQkFDaEI7Z0JBRUEsMENBQU1KLFlBQU4sSUFBSztZQUNQOzs7WUFFQUssS0FBQUE7bUJBQUFBLFNBQUFBO2dCQUNFLElBQThDLG1CQUFBLElBQUksQ0FBQ0osVUFBVSxFQUFyREMsa0JBQXNDLGlCQUF0Q0EsaUJBQWlCQyxtQkFBcUIsaUJBQXJCQTtnQkFFekIsSUFBSUQsaUJBQWlCO29CQUNuQixJQUFJLENBQUNJLFdBQVcsQ0FBQztnQkFDbkI7Z0JBRUEsSUFBSUgsa0JBQWtCO29CQUNwQixJQUFJLENBQUNHLFdBQVcsQ0FBQztnQkFDbkI7Z0JBRUEsMENBQU1ELGVBQU4sSUFBSztZQUNQOzs7WUFFQUUsS0FBQUE7bUJBQUFBLFNBQUFBO2dCQUNFLElBQU1DLGFBQWEsSUFBSSxDQUFDQSxVQUFVLENBQUNDLElBQUksQ0FBQyxJQUFJLEdBQ3RDQyx1QkFBdUIsSUFBSSxDQUFDQyxRQUFRLENBQUNGLElBQUksQ0FBQyxJQUFJLEdBQzlDRyx5QkFBeUIsSUFBSSxDQUFDSixVQUFVLENBQUNDLElBQUksQ0FBQyxJQUFJLEdBQ2xESSx5QkFBeUIsSUFBSSxDQUFDQyxVQUFVLENBQUNMLElBQUksQ0FBQyxJQUFJLEdBQ2xETSxnQ0FBZ0MsSUFBSSxDQUFDQyxpQkFBaUIsQ0FBQ1AsSUFBSSxDQUFDLElBQUksR0FBSSxHQUFHO2dCQUU3RSxPQUFRO29CQUNORCxZQUFBQTtvQkFDQUUsc0JBQUFBO29CQUNBRSx3QkFBQUE7b0JBQ0FDLHdCQUFBQTtvQkFDQUUsK0JBQUFBO2dCQUNGO1lBQ0Y7Ozs7RUEzQ3FDRSw4QkFBWSxHQTZDakQseUJBQU9DLHFCQUFvQjtJQUN6QkMsWUFBWTtBQUNkLElBRUEseUJBQU9DLHFCQUFvQjtJQUN6QjtJQUNBO0NBQ0QsK0JBbUJVQyx1QkFBZSxFQUNKQyxpQ0FBeUIsRUFRMUJDLHVCQUFlLEVBS3pCQywwQkFBa0IsRUFDakJBLDBCQUFrQixFQVFSQyx3QkFBZ0IsRUFDbkJDLGtDQUEwQixFQUN2QkgsdUJBQWUifQ==
package/lib/yapp.js CHANGED
@@ -14,6 +14,7 @@ var _style = /*#__PURE__*/ _interop_require_default(require("./mixins/style"));
14
14
  var _prettyPrinter = /*#__PURE__*/ _interop_require_default(require("./prettyPrinter"));
15
15
  var _scrollbar = require("./utilities/scrollbar");
16
16
  var _plugin = require("./utilities/plugin");
17
+ var _customEventTypes = require("./customEventTypes");
17
18
  var _properties = require("./utilities/properties");
18
19
  var _content = require("./utilities/content");
19
20
  var _colour = require("./scheme/colour");
@@ -197,15 +198,12 @@ var Yapp = /*#__PURE__*/ function(Element) {
197
198
  _class_call_check(this, Yapp);
198
199
  var _this;
199
200
  _this = _super.call(this, selector);
200
- _define_property(_assert_this_initialized(_this), "changeHandler", function(event, element) {
201
- var richTextarea = element, contentChanged = richTextarea.hasContentChanged();
201
+ _define_property(_assert_this_initialized(_this), "customChangeHandler", function(event, element) {
202
+ var contentChanged = _this.hasContentChanged();
202
203
  if (contentChanged) {
203
- var _this_properties = _this.properties, _this_properties_onContentChange = _this_properties.onContentChange, onContentChange = _this_properties_onContentChange === void 0 ? null : _this_properties_onContentChange, contentChangeHandler = onContentChange; ///
204
+ var content = _this.getContent(), customEventType = _customEventTypes.CONTENT_CHANGE_CUSTOM_EVENT_TYPE;
204
205
  _this.update();
205
- if (contentChangeHandler) {
206
- element = _assert_this_initialized(_this); ///
207
- contentChangeHandler(event, element);
208
- }
206
+ _this.callCustomHandlers(customEventType, content);
209
207
  }
210
208
  });
211
209
  _this.plugin = plugin;
@@ -225,6 +223,13 @@ var Yapp = /*#__PURE__*/ function(Element) {
225
223
  return content;
226
224
  }
227
225
  },
226
+ {
227
+ key: "hasContentChanged",
228
+ value: function hasContentChanged() {
229
+ var richTextareaContentChanged = this.hasRichTextareaContentChanged(), contentChanged = richTextareaContentChanged; ///
230
+ return contentChanged;
231
+ }
232
+ },
228
233
  {
229
234
  key: "getInitialLineCount",
230
235
  value: function getInitialLineCount() {
@@ -288,9 +293,9 @@ var Yapp = /*#__PURE__*/ function(Element) {
288
293
  {
289
294
  key: "childElements",
290
295
  value: function childElements() {
291
- var _this_properties = this.properties, _this_properties_editable = _this_properties.editable, editable = _this_properties_editable === void 0 ? _defaults.DEFAULT_EDITABLE : _this_properties_editable, _this_properties_hiddenGutter = _this_properties.hiddenGutter, hiddenGutter = _this_properties_hiddenGutter === void 0 ? _defaults.DEFAULT_HIDDEN_GUTTER : _this_properties_hiddenGutter, _this_properties_hiddenScrollbars = _this_properties.hiddenScrollbars, hiddenScrollbars = _this_properties_hiddenScrollbars === void 0 ? _defaults.DEFAULT_HIDDEN_SCROLLBARS : _this_properties_hiddenScrollbars, _this_properties_fancyScrollbars = _this_properties.fancyScrollbars, fancyScrollbars = _this_properties_fancyScrollbars === void 0 ? _defaults.DEFAULT_FANCY_SCROLLBARS : _this_properties_fancyScrollbars;
296
+ var _this_properties = this.properties, _this_properties_editable = _this_properties.editable, editable = _this_properties_editable === void 0 ? _defaults.DEFAULT_EDITABLE : _this_properties_editable, _this_properties_hiddenGutter = _this_properties.hiddenGutter, hiddenGutter = _this_properties_hiddenGutter === void 0 ? _defaults.DEFAULT_HIDDEN_GUTTER : _this_properties_hiddenGutter, _this_properties_fancyScrollbars = _this_properties.fancyScrollbars, fancyScrollbars = _this_properties_fancyScrollbars === void 0 ? _defaults.DEFAULT_FANCY_SCROLLBARS : _this_properties_fancyScrollbars, _this_properties_hiddenScrollbars = _this_properties.hiddenScrollbars, hiddenScrollbars = _this_properties_hiddenScrollbars === void 0 ? _defaults.DEFAULT_HIDDEN_SCROLLBARS : _this_properties_hiddenScrollbars;
292
297
  return /*#__PURE__*/ _easy.React.createElement(_prettyPrinter.default, {
293
- onChange: this.changeHandler,
298
+ onCustomChange: this.customChangeHandler,
294
299
  editable: editable,
295
300
  hiddenGutter: hiddenGutter,
296
301
  fancyScrollbars: fancyScrollbars,
@@ -349,10 +354,9 @@ _define_property(Yapp, "ignoredProperties", [
349
354
  "autoHeight",
350
355
  "hiddenGutter",
351
356
  "noScrollbars",
352
- "fancyScrollbars",
353
- "onContentChange"
357
+ "fancyScrollbars"
354
358
  ]);
355
359
  Object.assign(Yapp.prototype, _style.default);
356
360
  var _default = (0, _easywithstyle.default)(Yapp)(_templateObject(), _colour.colour, _colour.caretColour, _colour.borderColour, _colour.backgroundColour);
357
361
 
358
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/yapp.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { React, Element } from \"easy\";\n\nimport styleMixins from \"./mixins/style\";\nimport PrettyPrinter from \"./prettyPrinter\";\n\nimport { getScrollbarThickness } from \"./utilities/scrollbar\";\nimport { pluginFromLanguageAndPlugin } from \"./utilities/plugin\";\nimport { propertiesFromContentLanguagePluginAndOptions } from \"./utilities/properties\";\nimport { lineCountFromContent, contentFromChildElements } from \"./utilities/content\";\nimport { colour, caretColour, borderColour, backgroundColour } from \"./scheme/colour\";\nimport { DEFAULT_EDITABLE, DEFAULT_FIRA_CODE, DEFAULT_AUTO_HEIGHT, DEFAULT_HIDDEN_GUTTER, DEFAULT_HIDDEN_SCROLLBARS, DEFAULT_FANCY_SCROLLBARS } from \"./defaults\";\n\nclass Yapp extends Element {\n  constructor(selector, plugin) {\n    super(selector);\n\n    this.plugin = plugin;\n  }\n\n  getPlugin() {\n    return this.plugin;\n  }\n\n  getContent() {\n    const richTextareaContent = this.getRichTextareaContent(),\n          content = richTextareaContent;  ///\n\n    return content;\n  }\n\n  getInitialLineCount() {\n    const content = this.getContent(),\n          lineCount = lineCountFromContent(content),\n          initialLineCount = lineCount; ///\n\n    return initialLineCount;\n  }\n\n  setLexer(lexer) { this.plugin.setLexer(lexer); }\n\n  setParser(parser) { this.plugin.setParser(parser); }\n\n  enableFiraCode() {\n    this.addClass(\"fira-code\");\n  }\n\n  disableFiraCode() {\n    this.removeClass(\"fira-code\");\n  }\n\n  changeHandler = (event, element) => {\n    const richTextarea = element, ///\n          contentChanged = richTextarea.hasContentChanged();\n\n    if (contentChanged) {\n      const { onContentChange = null } = this.properties,\n            contentChangeHandler = onContentChange;  ///\n\n      this.update();\n\n      if (contentChangeHandler) {\n        element = this; ///\n\n        contentChangeHandler(event, element);\n      }\n    }\n  }\n\n  update() {\n    const content = this.getContent();\n\n    this.plugin.update(content);\n\n    const tokens = this.plugin.getTokens();\n\n    this.updatePrettyPrinter(tokens);\n  }\n\n  didMount() {\n    const { childElements, firaCode = DEFAULT_FIRA_CODE, autoHeight = DEFAULT_AUTO_HEIGHT } = this.properties,\n          content = contentFromChildElements(childElements);\n\n    firaCode && this.enableFiraCode();\n\n    this.activateRichTextarea();\n\n    this.setRichTextareaContent(content);\n\n    if (autoHeight) {\n      const lineHeight = this.getLineHeight(),\n            paddingTop = this.getPaddingTop(),\n            paddingBottom = this.getPaddingBottom(),\n            borderTopWidth = this.getBorderTopWidth(),\n            initialLineCount = this.getInitialLineCount(),\n            borderBottomWidth = this.getBorderBottomWidth(),\n            scrollbarThickness = getScrollbarThickness(),\n            height = borderTopWidth + paddingTop + initialLineCount * lineHeight + paddingBottom + borderBottomWidth + scrollbarThickness;\n\n      this.setHeight(height);\n    }\n\n    this.update();\n  }\n\n  willUnmount() {\n    ///\n  }\n\n  childElements() {\n    const { editable = DEFAULT_EDITABLE, hiddenGutter = DEFAULT_HIDDEN_GUTTER, hiddenScrollbars = DEFAULT_HIDDEN_SCROLLBARS, fancyScrollbars = DEFAULT_FANCY_SCROLLBARS } = this.properties;\n\n    return (\n\n      <PrettyPrinter onChange={this.changeHandler} editable={editable} hiddenGutter={hiddenGutter} fancyScrollbars={fancyScrollbars} hiddenScrollbars={hiddenScrollbars} />\n\n    );\n  }\n\n  parentContext() {\n    const getPlugin = this.getPlugin.bind(this),\n          getContent = this.getContent.bind(this),\n          updateYapp = this.update.bind(this),  ///\n          setYappLexer = this.setLexer.bind(this),  ///\n          setYappParser = this.setParser.bind(this);  ///\n\n    return ({\n      getPlugin,\n      getContent,\n      updateYapp,\n      setYappLexer,\n      setYappParser\n    });\n  }\n\n  initialise() {\n    this.assignContext();\n\n    const language = this.plugin.getLanguage();\n\n    this.setLanguage(language);\n  }\n\n  static tagName = \"div\";\n\n  static defaultProperties = {\n    className: \"yapp\"\n  };\n\n  static ignoredProperties = [\n    \"Plugin\",\n    \"language\",\n    \"firaCode\",\n    \"editable\",\n    \"autoHeight\",\n    \"hiddenGutter\",\n    \"noScrollbars\",\n    \"fancyScrollbars\",\n    \"onContentChange\"\n  ];\n\n  static fromContent(content, language, Plugin, options) {\n    const Class = Yapp,\n          properties = propertiesFromContentLanguagePluginAndOptions(content, language, Plugin, options),\n          plugin = pluginFromLanguageAndPlugin(language, Plugin),\n          yapp = Element.fromClass(Class, properties, plugin);\n\n    return yapp;\n  }\n\n  static fromClass(Class, properties) {\n    const { language, Plugin } = properties,\n          plugin = pluginFromLanguageAndPlugin(language, Plugin),\n          yapp = Element.fromClass(Class, properties, plugin);\n\n    return yapp;\n  }\n}\n\nObject.assign(Yapp.prototype, styleMixins);\n\nexport default withStyle(Yapp)`\n\n  width: 100%;\n  height: 100%;\n  border: 1px solid;\n  \n  color: ${colour};\n  font-size: 13px;\n  line-height: 20px;\n  font-family: \"Menlo\", \"Lucida Sans Typewriter\", monospace;\n  font-weight: normal;\n  caret-color: ${caretColour};\n  border-color: ${borderColour};\n  text-rendering: initial;\n  background-color: ${backgroundColour};\n  font-feature-settings: initial;\n\n  .fira-code {\n\n    font-family: \"Fira Code\";\n    text-rendering: optimizeLegibility;\n    font-feature-settings: \"calt\" 1;\n    \n  }\n\n`;\n"],"names":["Yapp","selector","plugin","changeHandler","event","element","richTextarea","contentChanged","hasContentChanged","properties","onContentChange","contentChangeHandler","update","getPlugin","getContent","richTextareaContent","getRichTextareaContent","content","getInitialLineCount","lineCount","lineCountFromContent","initialLineCount","setLexer","lexer","setParser","parser","enableFiraCode","addClass","disableFiraCode","removeClass","tokens","getTokens","updatePrettyPrinter","didMount","childElements","firaCode","DEFAULT_FIRA_CODE","autoHeight","DEFAULT_AUTO_HEIGHT","contentFromChildElements","activateRichTextarea","setRichTextareaContent","lineHeight","getLineHeight","paddingTop","getPaddingTop","paddingBottom","getPaddingBottom","borderTopWidth","getBorderTopWidth","borderBottomWidth","getBorderBottomWidth","scrollbarThickness","getScrollbarThickness","height","setHeight","willUnmount","editable","DEFAULT_EDITABLE","hiddenGutter","DEFAULT_HIDDEN_GUTTER","hiddenScrollbars","DEFAULT_HIDDEN_SCROLLBARS","fancyScrollbars","DEFAULT_FANCY_SCROLLBARS","PrettyPrinter","onChange","parentContext","bind","updateYapp","setYappLexer","setYappParser","initialise","assignContext","language","getLanguage","setLanguage","fromContent","Plugin","options","Class","propertiesFromContentLanguagePluginAndOptions","pluginFromLanguageAndPlugin","yapp","Element","fromClass","tagName","defaultProperties","className","ignoredProperties","Object","assign","prototype","styleMixins","withStyle","colour","caretColour","borderColour","backgroundColour"],"mappings":"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"}
362
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/yapp.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { React, Element } from \"easy\";\n\nimport styleMixins from \"./mixins/style\";\nimport PrettyPrinter from \"./prettyPrinter\";\n\nimport { getScrollbarThickness } from \"./utilities/scrollbar\";\nimport { pluginFromLanguageAndPlugin } from \"./utilities/plugin\";\nimport { CONTENT_CHANGE_CUSTOM_EVENT_TYPE } from \"./customEventTypes\";\nimport { propertiesFromContentLanguagePluginAndOptions } from \"./utilities/properties\";\nimport { lineCountFromContent, contentFromChildElements } from \"./utilities/content\";\nimport { colour, caretColour, borderColour, backgroundColour } from \"./scheme/colour\";\nimport { DEFAULT_EDITABLE, DEFAULT_FIRA_CODE, DEFAULT_AUTO_HEIGHT, DEFAULT_HIDDEN_GUTTER, DEFAULT_HIDDEN_SCROLLBARS, DEFAULT_FANCY_SCROLLBARS } from \"./defaults\";\n\nclass Yapp extends Element {\n  constructor(selector, plugin) {\n    super(selector);\n\n    this.plugin = plugin;\n  }\n\n  getPlugin() {\n    return this.plugin;\n  }\n\n  getContent() {\n    const richTextareaContent = this.getRichTextareaContent(),\n          content = richTextareaContent;  ///\n\n    return content;\n  }\n\n  hasContentChanged() {\n    const richTextareaContentChanged = this.hasRichTextareaContentChanged(),\n          contentChanged = richTextareaContentChanged;  ///\n\n    return contentChanged;\n  }\n\n  getInitialLineCount() {\n    const content = this.getContent(),\n          lineCount = lineCountFromContent(content),\n          initialLineCount = lineCount; ///\n\n    return initialLineCount;\n  }\n\n  customChangeHandler = (event, element) => {\n    const contentChanged = this.hasContentChanged();\n\n    if (contentChanged) {\n      const content = this.getContent(),\n            customEventType = CONTENT_CHANGE_CUSTOM_EVENT_TYPE;\n\n      this.update();\n\n      this.callCustomHandlers(customEventType, content);\n    }\n  }\n\n  setLexer(lexer) { this.plugin.setLexer(lexer); }\n\n  setParser(parser) { this.plugin.setParser(parser); }\n\n  enableFiraCode() {\n    this.addClass(\"fira-code\");\n  }\n\n  disableFiraCode() {\n    this.removeClass(\"fira-code\");\n  }\n\n  update() {\n    const content = this.getContent();\n\n    this.plugin.update(content);\n\n    const tokens = this.plugin.getTokens();\n\n    this.updatePrettyPrinter(tokens);\n  }\n\n  didMount() {\n    const { childElements, firaCode = DEFAULT_FIRA_CODE, autoHeight = DEFAULT_AUTO_HEIGHT } = this.properties,\n          content = contentFromChildElements(childElements);\n\n    firaCode && this.enableFiraCode();\n\n    this.activateRichTextarea();\n\n    this.setRichTextareaContent(content);\n\n    if (autoHeight) {\n      const lineHeight = this.getLineHeight(),\n            paddingTop = this.getPaddingTop(),\n            paddingBottom = this.getPaddingBottom(),\n            borderTopWidth = this.getBorderTopWidth(),\n            initialLineCount = this.getInitialLineCount(),\n            borderBottomWidth = this.getBorderBottomWidth(),\n            scrollbarThickness = getScrollbarThickness(),\n            height = borderTopWidth + paddingTop + initialLineCount * lineHeight + paddingBottom + borderBottomWidth + scrollbarThickness;\n\n      this.setHeight(height);\n    }\n\n    this.update();\n  }\n\n  willUnmount() {\n    ///\n  }\n\n  childElements() {\n    const { editable = DEFAULT_EDITABLE,\n            hiddenGutter = DEFAULT_HIDDEN_GUTTER,\n            fancyScrollbars = DEFAULT_FANCY_SCROLLBARS,\n            hiddenScrollbars = DEFAULT_HIDDEN_SCROLLBARS } = this.properties;\n\n    return (\n\n      <PrettyPrinter onCustomChange={this.customChangeHandler} editable={editable} hiddenGutter={hiddenGutter} fancyScrollbars={fancyScrollbars} hiddenScrollbars={hiddenScrollbars} />\n\n    );\n  }\n\n  parentContext() {\n    const getPlugin = this.getPlugin.bind(this),\n          getContent = this.getContent.bind(this),\n          updateYapp = this.update.bind(this),  ///\n          setYappLexer = this.setLexer.bind(this),  ///\n          setYappParser = this.setParser.bind(this);  ///\n\n    return ({\n      getPlugin,\n      getContent,\n      updateYapp,\n      setYappLexer,\n      setYappParser\n    });\n  }\n\n  initialise() {\n    this.assignContext();\n\n    const language = this.plugin.getLanguage();\n\n    this.setLanguage(language);\n  }\n\n  static tagName = \"div\";\n\n  static defaultProperties = {\n    className: \"yapp\"\n  };\n\n  static ignoredProperties = [\n    \"Plugin\",\n    \"language\",\n    \"firaCode\",\n    \"editable\",\n    \"autoHeight\",\n    \"hiddenGutter\",\n    \"noScrollbars\",\n    \"fancyScrollbars\"\n  ];\n\n  static fromContent(content, language, Plugin, options) {\n    const Class = Yapp,\n          properties = propertiesFromContentLanguagePluginAndOptions(content, language, Plugin, options),\n          plugin = pluginFromLanguageAndPlugin(language, Plugin),\n          yapp = Element.fromClass(Class, properties, plugin);\n\n    return yapp;\n  }\n\n  static fromClass(Class, properties) {\n    const { language, Plugin } = properties,\n          plugin = pluginFromLanguageAndPlugin(language, Plugin),\n          yapp = Element.fromClass(Class, properties, plugin);\n\n    return yapp;\n  }\n}\n\nObject.assign(Yapp.prototype, styleMixins);\n\nexport default withStyle(Yapp)`\n\n  width: 100%;\n  height: 100%;\n  border: 1px solid;\n  \n  color: ${colour};\n  font-size: 13px;\n  line-height: 20px;\n  font-family: \"Menlo\", \"Lucida Sans Typewriter\", monospace;\n  font-weight: normal;\n  caret-color: ${caretColour};\n  border-color: ${borderColour};\n  text-rendering: initial;\n  background-color: ${backgroundColour};\n  font-feature-settings: initial;\n\n  .fira-code {\n\n    font-family: \"Fira Code\";\n    text-rendering: optimizeLegibility;\n    font-feature-settings: \"calt\" 1;\n    \n  }\n\n`;\n"],"names":["Yapp","selector","plugin","customChangeHandler","event","element","contentChanged","hasContentChanged","content","getContent","customEventType","CONTENT_CHANGE_CUSTOM_EVENT_TYPE","update","callCustomHandlers","getPlugin","richTextareaContent","getRichTextareaContent","richTextareaContentChanged","hasRichTextareaContentChanged","getInitialLineCount","lineCount","lineCountFromContent","initialLineCount","setLexer","lexer","setParser","parser","enableFiraCode","addClass","disableFiraCode","removeClass","tokens","getTokens","updatePrettyPrinter","didMount","properties","childElements","firaCode","DEFAULT_FIRA_CODE","autoHeight","DEFAULT_AUTO_HEIGHT","contentFromChildElements","activateRichTextarea","setRichTextareaContent","lineHeight","getLineHeight","paddingTop","getPaddingTop","paddingBottom","getPaddingBottom","borderTopWidth","getBorderTopWidth","borderBottomWidth","getBorderBottomWidth","scrollbarThickness","getScrollbarThickness","height","setHeight","willUnmount","editable","DEFAULT_EDITABLE","hiddenGutter","DEFAULT_HIDDEN_GUTTER","fancyScrollbars","DEFAULT_FANCY_SCROLLBARS","hiddenScrollbars","DEFAULT_HIDDEN_SCROLLBARS","PrettyPrinter","onCustomChange","parentContext","bind","updateYapp","setYappLexer","setYappParser","initialise","assignContext","language","getLanguage","setLanguage","fromContent","Plugin","options","Class","propertiesFromContentLanguagePluginAndOptions","pluginFromLanguageAndPlugin","yapp","Element","fromClass","tagName","defaultProperties","className","ignoredProperties","Object","assign","prototype","styleMixins","withStyle","colour","caretColour","borderColour","backgroundColour"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "yapp",
3
3
  "author": "James Smith",
4
- "version": "4.0.227",
4
+ "version": "4.0.229",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/yapp",
7
7
  "description": "Yet Another Pretty Printer.",
@@ -11,7 +11,7 @@
11
11
  },
12
12
  "dependencies": {
13
13
  "easy": "^16.0.5",
14
- "easy-richtextarea": "^4.0.112",
14
+ "easy-richtextarea": "^4.0.116",
15
15
  "easy-with-style": "^3.0.276",
16
16
  "necessary": "^13.1.4",
17
17
  "occam-dom": "^3.1.91",
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+
3
+ export const CONTENT_CHANGE_CUSTOM_EVENT_TYPE = "contentchange-custom";
@@ -8,7 +8,7 @@ import SyntaxDiv from "../div/syntax";
8
8
 
9
9
  import { MARGIN_RIGHT, MARGIN_BOTTOM } from "../constants";
10
10
 
11
- class OverlayDiv extends Element {
11
+ class PrettyDiv extends Element {
12
12
  update(tokens) {
13
13
  this.updateSyntaxDiv(tokens);
14
14
  }
@@ -40,13 +40,13 @@ class OverlayDiv extends Element {
40
40
 
41
41
  parentContext() {
42
42
  const context = this.getContext(),
43
- updateOverlayDiv = this.update.bind(this), ///
44
- scrollOverlayDiv = this.scroll.bind(this); ///
43
+ updatePrettyDiv = this.update.bind(this), ///
44
+ scrollPrettyDiv = this.scroll.bind(this); ///
45
45
 
46
46
  return ({
47
47
  ...context,
48
- updateOverlayDiv,
49
- scrollOverlayDiv
48
+ updatePrettyDiv,
49
+ scrollPrettyDiv
50
50
  });
51
51
  }
52
52
 
@@ -64,18 +64,18 @@ class OverlayDiv extends Element {
64
64
  ];
65
65
 
66
66
  static defaultProperties = {
67
- className: "overlay"
67
+ className: "pretty"
68
68
  };
69
69
  }
70
70
 
71
- export default withStyle(OverlayDiv)`
71
+ export default withStyle(PrettyDiv)`
72
72
 
73
73
  z-index: 0;
74
74
  width: auto;
75
75
  height: auto;
76
76
  overflow: hidden;
77
77
  position: relative;
78
- grid-area: overlay-rich-textarea;
78
+ grid-area: pretty-rich-textarea;
79
79
 
80
80
  color: inherit;
81
81
  font-size: inherit;
@@ -20,7 +20,7 @@ import LexicalEntriesTextarea from "./view/textarea/lexicalEntries";
20
20
  const { rulesFromBNF } = parserUtilities;
21
21
 
22
22
  class View extends Element {
23
- contentChangeHandler = (event, element) => {
23
+ customContentChangeHandler = (event, element) => {
24
24
  this.update();
25
25
  }
26
26
 
@@ -104,7 +104,7 @@ class View extends Element {
104
104
  <LeftSizeableDiv>
105
105
  <RowsDiv>
106
106
  <TopSizeableDiv>
107
- <Yapp Plugin={Plugin} firaCode={firaCode} onContentChange={this.contentChangeHandler} >
107
+ <Yapp Plugin={Plugin} firaCode={firaCode} onCustomContentChange={this.customContentChangeHandler} >
108
108
  {initialContent}
109
109
  </Yapp>
110
110
  </TopSizeableDiv>