diff --git a/app/admin/controller/Login.php b/app/admin/controller/Login.php
index 0d4a81332..22de348d3 100644
--- a/app/admin/controller/Login.php
+++ b/app/admin/controller/Login.php
@@ -96,7 +96,7 @@ class Login extends Controller
$this->app->session->set('user', $user->toArray());
$this->app->session->delete('LoginInputSessionError');
// 更新登录次数
- SystemUser::mk()->where(['id' => $user->getAttr('id')])->inc('login_num')->update([
+ $user->where(['id' => $user->getAttr('id')])->inc('login_num')->update([
'login_at' => date('Y-m-d H:i:s'), 'login_ip' => $this->app->request->ip(),
]);
// 刷新用户权限
diff --git a/app/admin/view/config/index.html b/app/admin/view/config/index.html
index 002b490b2..aaa6f720b 100644
--- a/app/admin/view/config/index.html
+++ b/app/admin/view/config/index.html
@@ -43,8 +43,8 @@
- {if !in_array(sysconf('base.editor'),['ckeditor4','ckeditor5','auto'])}{php}sysconf('base.editor','ckeditor4');{/php}{/if}
- {foreach ['ckeditor4'=>'CKEditor4','ckeditor5'=>'CKEditor5','auto'=>lang('自适应模式')] as $k => $v}{if sysconf('base.editor') eq $k}
+ {if !in_array(sysconf('base.editor'),['ckeditor4','ckeditor5','wangEditor','auto'])}{php}sysconf('base.editor','ckeditor4');{/php}{/if}
+ {foreach ['ckeditor4'=>'CKEditor4','ckeditor5'=>'CKEditor5','wangEditor'=>'wangEditor','auto'=>lang('自适应模式')] as $k => $v}{if sysconf('base.editor') eq $k}
{if auth('storage')}
{$v}{else}
{$v}{/if}
{else}
{if auth('storage')}
{$v}{else}
{$v}{/if}
@@ -53,6 +53,7 @@
CKEditor4:{:lang('旧版本编辑器,对浏览器兼容较好,但内容编辑体验稍有不足。')}
CKEditor5:{:lang('新版本编辑器,只支持新特性浏览器,对内容编辑体验较好,推荐使用。')}
+
wangEditor:{:lang('国产优质富文本编辑器,对于小程序及App内容支持会更友好,推荐使用。')}
{:lang('自适应模式')}:{:lang('优先使用新版本编辑器,若浏览器不支持新版本时自动降级为旧版本编辑器。')}
diff --git a/public/static/admin.js b/public/static/admin.js
index fd1f0fdeb..e46cc8681 100644
--- a/public/static/admin.js
+++ b/public/static/admin.js
@@ -48,6 +48,7 @@ require.config({
'angular': ['plugs/angular/angular.min'],
'cropper': ['plugs/cropper/cropper.min'],
'echarts': ['plugs/echarts/echarts.min'],
+ 'weditor': ['plugs/editor/create'],
'ckeditor4': ['plugs/ckeditor4/ckeditor'],
'ckeditor5': ['plugs/ckeditor5/ckeditor'],
'artplayer': ['plugs/jquery/artplayer.min'],
@@ -55,6 +56,7 @@ require.config({
'websocket': ['plugs/socket/websocket'],
'compressor': ['plugs/jquery/compressor.min'],
'sortablejs': ['plugs/sortable/sortable.min'],
+ '_weditor': ['plugs/editor/index'],
'vue.sortable': ['plugs/sortable/vue.draggable.min'],
'jquery.ztree': ['plugs/ztree/ztree.all.min'],
'jquery.masonry': ['plugs/jquery/masonry.min'],
@@ -65,6 +67,7 @@ require.config({
'excel': {deps: [baseRoot + 'plugs/layui_exts/excel.js']},
'notify': {deps: ['css!' + baseRoot + 'plugs/notify/theme.css']},
'cropper': {deps: ['css!' + baseRoot + 'plugs/cropper/cropper.min.css']},
+ '_weditor': {deps: ['css!' + baseRoot + 'plugs/editor/css/style.css']},
'websocket': {deps: [baseRoot + 'plugs/socket/swfobject.js']},
'ckeditor5': {deps: ['jquery', 'upload', 'css!' + baseRoot + 'plugs/ckeditor5/ckeditor.css']},
'vue.sortable': {deps: ['vue', 'sortablejs']},
@@ -80,12 +83,17 @@ define('jquery', [], function () {
/*! 注册 ckeditor 组件 */
define('ckeditor', (function (type) {
+ if (type === 'wangEditor') return ['weditor'];
if (/^ckeditor[45]$/.test(type)) return [type];
return [Object.fromEntries ? 'ckeditor5' : 'ckeditor4'];
})(window.taEditor || 'ckeditor4'), function (ckeditor) {
return ckeditor;
});
+require(['ckeditor'], function () {
+
+})
+
$(function () {
window.$body = $('body');
diff --git a/public/static/plugs/editor/create.js b/public/static/plugs/editor/create.js
new file mode 100644
index 000000000..e46d021ae
--- /dev/null
+++ b/public/static/plugs/editor/create.js
@@ -0,0 +1,66 @@
+define(['_weditor', 'upload'], function (editor) {
+ window.wangEditor = editor;
+ window.createEditor = function (ele, option) {
+ if ($(ele).data('editorLayout')) return;
+ const $layout = $('
');
+ $(ele).hide().data('editorLayout', $layout).after($layout).parent();
+ // 创建编辑器
+ const _editor = editor.createEditor({
+ html: '
',
+ selector: $layout.find("div:last").get(0),
+ config: {
+ height: (option || {}).height || 500,
+ MENU_CONF: {
+ uploadImage: {
+ async customUpload(file, insertFn) {
+ if (window.AdminUploadAdapter) {
+ new window.AdminUploadAdapter().upload([file], url => insertFn(url, file.name))
+ } else {
+ let reader = new window.FileReader();
+ reader.addEventListener('load', () => insertFn(reader.result, file.name));
+ reader.readAsDataURL(file);
+ }
+ }
+ },
+ uploadVideo: {
+ async customUpload(file, insertFn) {
+ if (window.AdminUploadAdapter) {
+ new window.AdminUploadAdapter().upload([file], url => insertFn(url, file.name))
+ } else {
+ let reader = new window.FileReader();
+ reader.addEventListener('load', () => insertFn(reader.result, file.name));
+ reader.readAsDataURL(file);
+ }
+ }
+ }
+ },
+ placeholder: 'Type here...',
+ onCreated(editor) {
+ editor.setHtml($(ele).val());
+ },
+ onChange(editor) {
+ $(ele).val(editor.getHtml())
+ }
+ },
+ mode: 'default', // or 'simple'
+ })
+ // 设置工具栏
+ editor.createToolbar({
+ editor: _editor,
+ selector: $layout.find('div:first').get(0),
+ config: {
+ excludeKeys: ['fullScreen']
+ },
+ mode: 'default',
+ })
+ // 兼容其他版本
+ _editor.getData = function () {
+ return _editor.getHtml()
+ }
+ _editor.setData = function (html) {
+ return _editor.setHtml(html)
+ }
+
+ return _editor;
+ }
+})
\ No newline at end of file
diff --git a/public/static/plugs/editor/css/style.css b/public/static/plugs/editor/css/style.css
new file mode 100644
index 000000000..6d13c9120
--- /dev/null
+++ b/public/static/plugs/editor/css/style.css
@@ -0,0 +1,27 @@
+:root,
+:host {
+ --w-e-textarea-bg-color: #fff;
+ --w-e-textarea-color: #333;
+ --w-e-textarea-border-color: #ccc;
+ --w-e-textarea-slight-border-color: #e8e8e8;
+ --w-e-textarea-slight-color: #d4d4d4;
+ --w-e-textarea-slight-bg-color: #f5f2f0;
+ --w-e-textarea-selected-border-color: #B4D5FF;
+ --w-e-textarea-handler-bg-color: #4290f7;
+ --w-e-toolbar-color: #595959;
+ --w-e-toolbar-bg-color: #fff;
+ --w-e-toolbar-active-color: #333;
+ --w-e-toolbar-active-bg-color: #f1f1f1;
+ --w-e-toolbar-disabled-color: #999;
+ --w-e-toolbar-border-color: #e8e8e8;
+ --w-e-modal-button-bg-color: #fafafa;
+ --w-e-modal-button-border-color: #d9d9d9;
+}
+
+.w-e-text-container *,.w-e-toolbar *{box-sizing:border-box;margin:0;outline:none;padding:0}.w-e-text-container blockquote,.w-e-text-container li,.w-e-text-container p,.w-e-text-container td,.w-e-text-container th,.w-e-toolbar *{line-height:1.5}.w-e-text-container{background-color:var(--w-e-textarea-bg-color);color:var(--w-e-textarea-color);height:100%;position:relative}.w-e-text-container .w-e-scroll{-webkit-overflow-scrolling:touch;height:100%}.w-e-text-container [data-slate-editor]{word-wrap:break-word;border-top:1px solid transparent;min-height:100%;outline:0;padding:0 10px;white-space:pre-wrap}.w-e-text-container [data-slate-editor] p{margin:15px 0}.w-e-text-container [data-slate-editor] h1,.w-e-text-container [data-slate-editor] h2,.w-e-text-container [data-slate-editor] h3,.w-e-text-container [data-slate-editor] h4,.w-e-text-container [data-slate-editor] h5{margin:20px 0}.w-e-text-container [data-slate-editor] img{cursor:default;display:inline!important;max-width:100%;min-height:20px;min-width:20px}.w-e-text-container [data-slate-editor] span{text-indent:0}.w-e-text-container [data-slate-editor] [data-selected=true]{box-shadow:0 0 0 2px var(--w-e-textarea-selected-border-color)}.w-e-text-placeholder{font-style:italic;left:10px;top:17px;width:90%}.w-e-max-length-info,.w-e-text-placeholder{color:var(--w-e-textarea-slight-color);pointer-events:none;position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none}.w-e-max-length-info{bottom:.5em;right:1em}.w-e-bar{background-color:var(--w-e-toolbar-bg-color);color:var(--w-e-toolbar-color);font-size:14px;padding:0 5px}.w-e-bar svg{fill:var(--w-e-toolbar-color);height:14px;width:14px}.w-e-bar-show{display:flex}.w-e-bar-hidden{display:none}.w-e-hover-bar{border:1px solid var(--w-e-toolbar-border-color);border-radius:3px;box-shadow:0 2px 5px #0000001f;position:absolute}.w-e-toolbar{flex-wrap:wrap;position:relative}.w-e-bar-divider{background-color:var(--w-e-toolbar-border-color);display:inline-flex;height:40px;margin:0 5px;width:1px}.w-e-bar-item{display:flex;height:40px;padding:4px;position:relative;text-align:center}.w-e-bar-item,.w-e-bar-item button{align-items:center;justify-content:center}.w-e-bar-item button{background:transparent;border:none;color:var(--w-e-toolbar-color);cursor:pointer;display:inline-flex;height:32px;overflow:hidden;padding:0 8px;white-space:nowrap}.w-e-bar-item button:hover{background-color:var(--w-e-toolbar-active-bg-color);color:var(--w-e-toolbar-active-color)}.w-e-bar-item button .title{margin-left:5px}.w-e-bar-item .active{background-color:var(--w-e-toolbar-active-bg-color);color:var(--w-e-toolbar-active-color)}.w-e-bar-item .disabled{color:var(--w-e-toolbar-disabled-color);cursor:not-allowed}.w-e-bar-item .disabled svg{fill:var(--w-e-toolbar-disabled-color)}.w-e-bar-item .disabled:hover{background-color:var(--w-e-toolbar-bg-color);color:var(--w-e-toolbar-disabled-color)}.w-e-bar-item .disabled:hover svg{fill:var(--w-e-toolbar-disabled-color)}.w-e-menu-tooltip-v5:before{background-color:var(--w-e-toolbar-active-color);border-radius:5px;color:var(--w-e-toolbar-bg-color);content:attr(data-tooltip);font-size:.75em;opacity:0;padding:5px 10px;position:absolute;text-align:center;top:40px;transition:opacity .6s;visibility:hidden;white-space:pre;z-index:1}.w-e-menu-tooltip-v5:after{border:5px solid transparent;border-bottom:5px solid var(--w-e-toolbar-active-color);content:"";opacity:0;position:absolute;top:30px;transition:opacity .6s;visibility:hidden}.w-e-menu-tooltip-v5:hover:after,.w-e-menu-tooltip-v5:hover:before{opacity:1;visibility:visible}.w-e-menu-tooltip-v5.tooltip-right:before{left:100%;top:10px}.w-e-menu-tooltip-v5.tooltip-right:after{border-bottom-color:transparent;border-left-color:transparent;border-right-color:var(--w-e-toolbar-active-color);border-top-color:transparent;left:100%;margin-left:-10px;top:16px}.w-e-bar-item-group .w-e-bar-item-menus-container{background-color:var(--w-e-toolbar-bg-color);border:1px solid var(--w-e-toolbar-border-color);border-radius:3px;box-shadow:0 2px 10px #0000001f;display:none;left:0;margin-top:40px;position:absolute;top:0;z-index:1}.w-e-bar-item-group:hover .w-e-bar-item-menus-container{display:block}.w-e-select-list{background-color:var(--w-e-toolbar-bg-color);border:1px solid var(--w-e-toolbar-border-color);border-radius:3px;box-shadow:0 2px 10px #0000001f;left:0;margin-top:40px;max-height:350px;min-width:100px;overflow-y:auto;position:absolute;top:0;z-index:1}.w-e-select-list ul{line-height:1;list-style:none}.w-e-select-list ul .selected{background-color:var(--w-e-toolbar-active-bg-color)}.w-e-select-list ul li{cursor:pointer;padding:7px 0 7px 25px;position:relative;text-align:left;white-space:nowrap}.w-e-select-list ul li:hover{background-color:var(--w-e-toolbar-active-bg-color)}.w-e-select-list ul li svg{left:0;margin-left:5px;margin-top:-7px;position:absolute;top:50%}.w-e-bar-bottom .w-e-select-list{bottom:0;margin-bottom:40px;margin-top:0;top:inherit}.w-e-drop-panel{background-color:var(--w-e-toolbar-bg-color);border:1px solid var(--w-e-toolbar-border-color);border-radius:3px;box-shadow:0 2px 10px #0000001f;margin-top:40px;min-width:200px;padding:10px;position:absolute;top:0;z-index:1}.w-e-bar-bottom .w-e-drop-panel{bottom:0;margin-bottom:40px;margin-top:0;top:inherit}.w-e-modal{background-color:var(--w-e-toolbar-bg-color);border:1px solid var(--w-e-toolbar-border-color);border-radius:3px;box-shadow:0 2px 10px #0000001f;color:var(--w-e-toolbar-color);font-size:14px;min-height:40px;min-width:100px;padding:20px 15px 0;position:absolute;text-align:left;z-index:1}.w-e-modal .btn-close{cursor:pointer;line-height:1;padding:5px;position:absolute;right:8px;top:7px}.w-e-modal .btn-close svg{fill:var(--w-e-toolbar-color);height:10px;width:10px}.w-e-modal .babel-container{display:block;margin-bottom:15px}.w-e-modal .babel-container span{display:block;margin-bottom:10px}.w-e-modal .button-container{margin-bottom:15px}.w-e-modal button{background-color:var(--w-e-modal-button-bg-color);border:1px solid var(--w-e-modal-button-border-color);border-radius:4px;color:var(--w-e-toolbar-color);cursor:pointer;font-weight:400;height:32px;padding:4.5px 15px;text-align:center;touch-action:manipulation;transition:all .3s cubic-bezier(.645,.045,.355,1);-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap}.w-e-modal input[type=number],.w-e-modal input[type=text],.w-e-modal textarea{font-feature-settings:"tnum";background-color:var(--w-e-toolbar-bg-color);border:1px solid var(--w-e-modal-button-border-color);border-radius:4px;color:var(--w-e-toolbar-color);font-variant:tabular-nums;padding:4.5px 11px;transition:all .3s;width:100%}.w-e-modal textarea{min-height:60px}body .w-e-modal,body .w-e-modal *{box-sizing:border-box}.w-e-progress-bar{background-color:var(--w-e-textarea-handler-bg-color);height:1px;position:absolute;transition:width .3s;width:0}.w-e-full-screen-container{bottom:0!important;display:flex!important;flex-direction:column!important;height:100%!important;left:0!important;margin:0!important;padding:0!important;position:fixed;right:0!important;top:0!important;width:100%!important}.w-e-full-screen-container [data-w-e-textarea=true]{flex:1!important}
+.w-e-text-container [data-slate-editor] code{background-color:var(--w-e-textarea-slight-bg-color);border-radius:3px;font-family:monospace;padding:3px}.w-e-panel-content-color{list-style:none;text-align:left;width:230px}.w-e-panel-content-color li{border:1px solid var(--w-e-toolbar-bg-color);border-radius:3px 3px;cursor:pointer;display:inline-block;padding:2px}.w-e-panel-content-color li:hover{border-color:var(--w-e-toolbar-color)}.w-e-panel-content-color li .color-block{border:1px solid var(--w-e-toolbar-border-color);border-radius:3px 3px;height:17px;width:17px}.w-e-panel-content-color .active{border-color:var(--w-e-toolbar-color)}.w-e-panel-content-color .clear{line-height:1.5;margin-bottom:5px;width:100%}.w-e-panel-content-color .clear svg{height:16px;margin-bottom:-4px;width:16px}.w-e-text-container [data-slate-editor] blockquote{background-color:var(--w-e-textarea-slight-bg-color);border-left:8px solid var(--w-e-textarea-selected-border-color);display:block;font-size:100%;line-height:1.5;margin:10px 0;padding:10px}.w-e-panel-content-emotion{font-size:20px;list-style:none;text-align:left;width:300px}.w-e-panel-content-emotion li{border-radius:3px 3px;cursor:pointer;display:inline-block;padding:0 5px}.w-e-panel-content-emotion li:hover{background-color:var(--w-e-textarea-slight-bg-color)}.w-e-textarea-divider{border-radius:3px;margin:20px auto;padding:20px}.w-e-textarea-divider hr{background-color:var(--w-e-textarea-border-color);border:0;display:block;height:1px}.w-e-text-container [data-slate-editor] pre>code{background-color:var(--w-e-textarea-slight-bg-color);border:1px solid var(--w-e-textarea-slight-border-color);border-radius:4px 4px;display:block;font-size:14px;padding:10px;text-indent:0}.w-e-text-container [data-slate-editor] .w-e-image-container{display:inline-block;margin:0 3px}.w-e-text-container [data-slate-editor] .w-e-image-container:hover{box-shadow:0 0 0 2px var(--w-e-textarea-selected-border-color)}.w-e-text-container [data-slate-editor] .w-e-selected-image-container{overflow:hidden;position:relative}.w-e-text-container [data-slate-editor] .w-e-selected-image-container .w-e-image-dragger{background-color:var(--w-e-textarea-handler-bg-color);height:7px;position:absolute;width:7px}.w-e-text-container [data-slate-editor] .w-e-selected-image-container .left-top{cursor:nwse-resize;left:0;top:0}.w-e-text-container [data-slate-editor] .w-e-selected-image-container .right-top{cursor:nesw-resize;right:0;top:0}.w-e-text-container [data-slate-editor] .w-e-selected-image-container .left-bottom{bottom:0;cursor:nesw-resize;left:0}.w-e-text-container [data-slate-editor] .w-e-selected-image-container .right-bottom{bottom:0;cursor:nwse-resize;right:0}.w-e-text-container [data-slate-editor] .w-e-selected-image-container:hover{box-shadow:none}.w-e-text-container [contenteditable=false] .w-e-image-container:hover{box-shadow:none}
+
+.w-e-text-container [data-slate-editor] .table-container{border:1px dashed var(--w-e-textarea-border-color);border-radius:5px;margin-top:10px;overflow-x:auto;padding:10px;width:100%}.w-e-text-container [data-slate-editor] table{border-collapse:collapse}.w-e-text-container [data-slate-editor] table td,.w-e-text-container [data-slate-editor] table th{border:1px solid var(--w-e-textarea-border-color);line-height:1.5;min-width:30px;padding:3px 5px;text-align:left}.w-e-text-container [data-slate-editor] table th{background-color:var(--w-e-textarea-slight-bg-color);font-weight:700;text-align:center}.w-e-panel-content-table{background-color:var(--w-e-toolbar-bg-color)}.w-e-panel-content-table table{border-collapse:collapse}.w-e-panel-content-table td{border:1px solid var(--w-e-toolbar-border-color);cursor:pointer;height:15px;padding:3px 5px;width:20px}.w-e-panel-content-table td.active{background-color:var(--w-e-toolbar-active-bg-color)}
+.w-e-textarea-video-container{background-image:linear-gradient(45deg,#eee 25%,transparent 0,transparent 75%,#eee 0,#eee),linear-gradient(45deg,#eee 25%,#fff 0,#fff 75%,#eee 0,#eee);background-position:0 0,10px 10px;background-size:20px 20px;border:1px dashed var(--w-e-textarea-border-color);border-radius:5px;margin:10px auto 0;padding:10px 0;text-align:center}
+
+.w-e-text-container [data-slate-editor] pre>code{word-wrap:normal;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;-webkit-hyphens:none;hyphens:none;line-height:1.5;margin:.5em 0;overflow:auto;padding:1em;-moz-tab-size:4;-o-tab-size:4;tab-size:4;text-align:left;text-shadow:0 1px #fff;white-space:pre;word-break:normal;word-spacing:normal}.w-e-text-container [data-slate-editor] pre>code .token.cdata,.w-e-text-container [data-slate-editor] pre>code .token.comment,.w-e-text-container [data-slate-editor] pre>code .token.doctype,.w-e-text-container [data-slate-editor] pre>code .token.prolog{color:#708090}.w-e-text-container [data-slate-editor] pre>code .token.punctuation{color:#999}.w-e-text-container [data-slate-editor] pre>code .token.namespace{opacity:.7}.w-e-text-container [data-slate-editor] pre>code .token.boolean,.w-e-text-container [data-slate-editor] pre>code .token.constant,.w-e-text-container [data-slate-editor] pre>code .token.deleted,.w-e-text-container [data-slate-editor] pre>code .token.number,.w-e-text-container [data-slate-editor] pre>code .token.property,.w-e-text-container [data-slate-editor] pre>code .token.symbol,.w-e-text-container [data-slate-editor] pre>code .token.tag{color:#905}.w-e-text-container [data-slate-editor] pre>code .token.attr-name,.w-e-text-container [data-slate-editor] pre>code .token.builtin,.w-e-text-container [data-slate-editor] pre>code .token.char,.w-e-text-container [data-slate-editor] pre>code .token.inserted,.w-e-text-container [data-slate-editor] pre>code .token.selector,.w-e-text-container [data-slate-editor] pre>code .token.string{color:#690}.w-e-text-container [data-slate-editor] pre>code .language-css .token.string,.w-e-text-container [data-slate-editor] pre>code .style .token.string,.w-e-text-container [data-slate-editor] pre>code .token.entity,.w-e-text-container [data-slate-editor] pre>code .token.operator,.w-e-text-container [data-slate-editor] pre>code .token.url{color:#9a6e3a}.w-e-text-container [data-slate-editor] pre>code .token.atrule,.w-e-text-container [data-slate-editor] pre>code .token.attr-value,.w-e-text-container [data-slate-editor] pre>code .token.keyword{color:#07a}.w-e-text-container [data-slate-editor] pre>code .token.class-name,.w-e-text-container [data-slate-editor] pre>code .token.function{color:#dd4a68}.w-e-text-container [data-slate-editor] pre>code .token.important,.w-e-text-container [data-slate-editor] pre>code .token.regex,.w-e-text-container [data-slate-editor] pre>code .token.variable{color:#e90}.w-e-text-container [data-slate-editor] pre>code .token.bold,.w-e-text-container [data-slate-editor] pre>code .token.important{font-weight:700}.w-e-text-container [data-slate-editor] pre>code .token.italic{font-style:italic}.w-e-text-container [data-slate-editor] pre>code .token.entity{cursor:help}
\ No newline at end of file
diff --git a/public/static/plugs/editor/index.js b/public/static/plugs/editor/index.js
new file mode 100644
index 000000000..a2233e40d
--- /dev/null
+++ b/public/static/plugs/editor/index.js
@@ -0,0 +1,24129 @@
+(function (global, factory) {
+ typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :
+ typeof define === 'function' && define.amd ? define(['exports'], factory) :
+ (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.wangEditor = {}));
+})(this, (function (exports) { 'use strict';
+
+ /**
+ * @description browser polyfill
+ * @author wangfupeng
+ */
+ var _a;
+ // @ts-nocheck
+ // 必须是浏览器环境
+ if (typeof global === 'undefined') {
+ // 检查 IE 浏览器
+ if ('ActiveXObject' in window) {
+ var info = '抱歉,wangEditor V5+ 版本开始,不在支持 IE 浏览器';
+ info += '\n Sorry, wangEditor V5+ versions do not support IE browser.';
+ console.error(info);
+ }
+ globalThisPolyfill();
+ AggregateErrorPolyfill();
+ }
+ else if (global && ((_a = global.navigator) === null || _a === void 0 ? void 0 : _a.userAgent.match('QQBrowser'))) {
+ // 兼容 QQ 浏览器 AggregateError 报错
+ globalThisPolyfill();
+ AggregateErrorPolyfill();
+ }
+ function globalThisPolyfill() {
+ // 部分浏览器不支持 globalThis
+ if (typeof globalThis === 'undefined') {
+ // @ts-ignore
+ window.globalThis = window;
+ }
+ }
+ function AggregateErrorPolyfill() {
+ if (typeof AggregateError === 'undefined') {
+ window.AggregateError = function (errors, msg) {
+ var err = new Error(msg);
+ err.errors = errors;
+ return err;
+ };
+ }
+ }
+
+ /**
+ * @description node polyfill
+ * @author wangfupeng
+ */
+ // @ts-nocheck
+ // 必须是 node 环境
+ if (typeof global === 'object') {
+ // 用于 nodejs ,避免报错
+ var globalProperty = Object.getOwnPropertyDescriptor(global, 'window');
+ // global.window 为空则直接写入
+ // 部分框架下已经定义了global.window且是不可写属性
+ if (!global.window || globalProperty.set) {
+ global.window = global;
+ global.requestAnimationFrame = function () { };
+ global.navigator = {
+ userAgent: '',
+ };
+ global.location = {
+ hostname: '0.0.0.0',
+ port: 0,
+ protocol: 'http:',
+ };
+ global.btoa = function () { };
+ global.crypto = {
+ getRandomValues: function (buffer) {
+ return nodeCrypto.randomFillSync(buffer);
+ },
+ };
+ }
+ if (global.document != null) {
+ // SSR 环境下可能会报错 (issue 4409)
+ if (global.document.getElementsByTagName == null) {
+ global.document.getElementsByTagName = function () { return []; };
+ }
+ }
+ }
+
+ var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
+
+ function getDefaultExportFromCjs (x) {
+ return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
+ }
+
+ function createCommonjsModule$1(fn) {
+ var module = { exports: {} };
+ return fn(module, module.exports), module.exports;
+ }
+
+ /*!
+ * is-plain-object
+ *
+ * Copyright (c) 2014-2017, Jon Schlinkert.
+ * Released under the MIT License.
+ */
+
+ function isObject$4(o) {
+ return Object.prototype.toString.call(o) === '[object Object]';
+ }
+
+ function isPlainObject$2(o) {
+ var ctor,prot;
+
+ if (isObject$4(o) === false) return false;
+
+ // If has modified constructor
+ ctor = o.constructor;
+ if (ctor === undefined) return true;
+
+ // If has modified prototype
+ prot = ctor.prototype;
+ if (isObject$4(prot) === false) return false;
+
+ // If constructor does not have an Object-specific method
+ if (prot.hasOwnProperty('isPrototypeOf') === false) {
+ return false;
+ }
+
+ // Most likely a plain Object
+ return true;
+ }
+
+ var isPlainObject_2 = isPlainObject$2;
+
+ var isPlainObject_1 = /*#__PURE__*/Object.defineProperty({
+ isPlainObject: isPlainObject_2
+ }, '__esModule', {value: true});
+
+ var _ref;
+
+ // Should be no imports here!
+ // Some things that should be evaluated before all else...
+ // We only want to know if non-polyfilled symbols are available
+ var hasSymbol = typeof Symbol !== "undefined" && typeof
+ /*#__PURE__*/
+ Symbol("x") === "symbol";
+ var hasMap = typeof Map !== "undefined";
+ var hasSet = typeof Set !== "undefined";
+ var hasProxies = typeof Proxy !== "undefined" && typeof Proxy.revocable !== "undefined" && typeof Reflect !== "undefined";
+ /**
+ * The sentinel value returned by producers to replace the draft with undefined.
+ */
+
+ var NOTHING = hasSymbol ?
+ /*#__PURE__*/
+ Symbol.for("immer-nothing") : (_ref = {}, _ref["immer-nothing"] = true, _ref);
+ /**
+ * To let Immer treat your class instances as plain immutable objects
+ * (albeit with a custom prototype), you must define either an instance property
+ * or a static property on each of your custom classes.
+ *
+ * Otherwise, your class instance will never be drafted, which means it won't be
+ * safe to mutate in a produce callback.
+ */
+
+ var DRAFTABLE = hasSymbol ?
+ /*#__PURE__*/
+ Symbol.for("immer-draftable") : "__$immer_draftable";
+ var DRAFT_STATE = hasSymbol ?
+ /*#__PURE__*/
+ Symbol.for("immer-state") : "__$immer_state"; // Even a polyfilled Symbol might provide Symbol.iterator
+
+ var iteratorSymbol$1 = typeof Symbol != "undefined" && Symbol.iterator || "@@iterator";
+
+ var errors = {
+ 0: "Illegal state",
+ 1: "Immer drafts cannot have computed properties",
+ 2: "This object has been frozen and should not be mutated",
+ 3: function _(data) {
+ return "Cannot use a proxy that has been revoked. Did you pass an object from inside an immer function to an async process? " + data;
+ },
+ 4: "An immer producer returned a new value *and* modified its draft. Either return a new value *or* modify the draft.",
+ 5: "Immer forbids circular references",
+ 6: "The first or second argument to `produce` must be a function",
+ 7: "The third argument to `produce` must be a function or undefined",
+ 8: "First argument to `createDraft` must be a plain object, an array, or an immerable object",
+ 9: "First argument to `finishDraft` must be a draft returned by `createDraft`",
+ 10: "The given draft is already finalized",
+ 11: "Object.defineProperty() cannot be used on an Immer draft",
+ 12: "Object.setPrototypeOf() cannot be used on an Immer draft",
+ 13: "Immer only supports deleting array indices",
+ 14: "Immer only supports setting array indices and the 'length' property",
+ 15: function _(path) {
+ return "Cannot apply patch, path doesn't resolve: " + path;
+ },
+ 16: 'Sets cannot have "replace" patches.',
+ 17: function _(op) {
+ return "Unsupported patch operation: " + op;
+ },
+ 18: function _(plugin) {
+ return "The plugin for '" + plugin + "' has not been loaded into Immer. To enable the plugin, import and call `enable" + plugin + "()` when initializing your application.";
+ },
+ 20: "Cannot use proxies if Proxy, Proxy.revocable or Reflect are not available",
+ 21: function _(thing) {
+ return "produce can only be called on things that are draftable: plain objects, arrays, Map, Set or classes that are marked with '[immerable]: true'. Got '" + thing + "'";
+ },
+ 22: function _(thing) {
+ return "'current' expects a draft, got: " + thing;
+ },
+ 23: function _(thing) {
+ return "'original' expects a draft, got: " + thing;
+ },
+ 24: "Patching reserved attributes like __proto__, prototype and constructor is not allowed"
+ };
+ function die(error) {
+ for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
+ args[_key - 1] = arguments[_key];
+ }
+
+ {
+ var e = errors[error];
+ var msg = !e ? "unknown error nr: " + error : typeof e === "function" ? e.apply(null, args) : e;
+ throw new Error("[Immer] " + msg);
+ }
+ }
+
+ /** Returns true if the given value is an Immer draft */
+
+
+
+ function isDraft(value) {
+ return !!value && !!value[DRAFT_STATE];
+ }
+ /** Returns true if the given value can be drafted by Immer */
+
+
+
+ function isDraftable(value) {
+ if (!value) return false;
+ return isPlainObject$1(value) || Array.isArray(value) || !!value[DRAFTABLE] || !!value.constructor[DRAFTABLE] || isMap(value) || isSet(value);
+ }
+ var objectCtorString =
+ /*#__PURE__*/
+ Object.prototype.constructor.toString();
+
+
+ function isPlainObject$1(value) {
+ if (!value || typeof value !== "object") return false;
+ var proto = Object.getPrototypeOf(value);
+
+ if (proto === null) {
+ return true;
+ }
+
+ var Ctor = Object.hasOwnProperty.call(proto, "constructor") && proto.constructor;
+ if (Ctor === Object) return true;
+ return typeof Ctor == "function" && Function.toString.call(Ctor) === objectCtorString;
+ }
+ function original(value) {
+ if (!isDraft(value)) die(23, value);
+ return value[DRAFT_STATE].base_;
+ }
+
+
+ var ownKeys$a = typeof Reflect !== "undefined" && Reflect.ownKeys ? Reflect.ownKeys : typeof Object.getOwnPropertySymbols !== "undefined" ? function (obj) {
+ return Object.getOwnPropertyNames(obj).concat(Object.getOwnPropertySymbols(obj));
+ } :
+ /* istanbul ignore next */
+ Object.getOwnPropertyNames;
+ var getOwnPropertyDescriptors = Object.getOwnPropertyDescriptors || function getOwnPropertyDescriptors(target) {
+ // Polyfill needed for Hermes and IE, see https://github.com/facebook/hermes/issues/274
+ var res = {};
+ ownKeys$a(target).forEach(function (key) {
+ res[key] = Object.getOwnPropertyDescriptor(target, key);
+ });
+ return res;
+ };
+ function each$1(obj, iter, enumerableOnly) {
+ if (enumerableOnly === void 0) {
+ enumerableOnly = false;
+ }
+
+ if (getArchtype(obj) === 0
+ /* Object */
+ ) {
+ (enumerableOnly ? Object.keys : ownKeys$a)(obj).forEach(function (key) {
+ if (!enumerableOnly || typeof key !== "symbol") iter(key, obj[key], obj);
+ });
+ } else {
+ obj.forEach(function (entry, index) {
+ return iter(index, entry, obj);
+ });
+ }
+ }
+
+
+ function getArchtype(thing) {
+ /* istanbul ignore next */
+ var state = thing[DRAFT_STATE];
+ return state ? state.type_ > 3 ? state.type_ - 4 // cause Object and Array map back from 4 and 5
+ : state.type_ // others are the same
+ : Array.isArray(thing) ? 1
+ /* Array */
+ : isMap(thing) ? 2
+ /* Map */
+ : isSet(thing) ? 3
+ /* Set */
+ : 0
+ /* Object */
+ ;
+ }
+
+
+ function has(thing, prop) {
+ return getArchtype(thing) === 2
+ /* Map */
+ ? thing.has(prop) : Object.prototype.hasOwnProperty.call(thing, prop);
+ }
+
+
+ function get(thing, prop) {
+ // @ts-ignore
+ return getArchtype(thing) === 2
+ /* Map */
+ ? thing.get(prop) : thing[prop];
+ }
+
+
+ function set(thing, propOrOldValue, value) {
+ var t = getArchtype(thing);
+ if (t === 2
+ /* Map */
+ ) thing.set(propOrOldValue, value);else if (t === 3
+ /* Set */
+ ) {
+ thing.delete(propOrOldValue);
+ thing.add(value);
+ } else thing[propOrOldValue] = value;
+ }
+
+
+ function is$1(x, y) {
+ // From: https://github.com/facebook/fbjs/blob/c69904a511b900266935168223063dd8772dfc40/packages/fbjs/src/core/shallowEqual.js
+ if (x === y) {
+ return x !== 0 || 1 / x === 1 / y;
+ } else {
+ return x !== x && y !== y;
+ }
+ }
+
+
+ function isMap(target) {
+ return hasMap && target instanceof Map;
+ }
+
+
+ function isSet(target) {
+ return hasSet && target instanceof Set;
+ }
+
+
+ function latest(state) {
+ return state.copy_ || state.base_;
+ }
+
+
+ function shallowCopy(base) {
+ if (Array.isArray(base)) return Array.prototype.slice.call(base);
+ var descriptors = getOwnPropertyDescriptors(base);
+ delete descriptors[DRAFT_STATE];
+ var keys = ownKeys$a(descriptors);
+
+ for (var i = 0; i < keys.length; i++) {
+ var key = keys[i];
+ var desc = descriptors[key];
+
+ if (desc.writable === false) {
+ desc.writable = true;
+ desc.configurable = true;
+ } // like object.assign, we will read any _own_, get/set accessors. This helps in dealing
+ // with libraries that trap values, like mobx or vue
+ // unlike object.assign, non-enumerables will be copied as well
+
+
+ if (desc.get || desc.set) descriptors[key] = {
+ configurable: true,
+ writable: true,
+ enumerable: desc.enumerable,
+ value: base[key]
+ };
+ }
+
+ return Object.create(Object.getPrototypeOf(base), descriptors);
+ }
+ function freeze(obj, deep) {
+ if (deep === void 0) {
+ deep = false;
+ }
+
+ if (isFrozen(obj) || isDraft(obj) || !isDraftable(obj)) return obj;
+
+ if (getArchtype(obj) > 1
+ /* Map or Set */
+ ) {
+ obj.set = obj.add = obj.clear = obj.delete = dontMutateFrozenCollections;
+ }
+
+ Object.freeze(obj);
+ if (deep) each$1(obj, function (key, value) {
+ return freeze(value, true);
+ }, true);
+ return obj;
+ }
+
+ function dontMutateFrozenCollections() {
+ die(2);
+ }
+
+ function isFrozen(obj) {
+ if (obj == null || typeof obj !== "object") return true; // See #600, IE dies on non-objects in Object.isFrozen
+
+ return Object.isFrozen(obj);
+ }
+
+ /** Plugin utilities */
+
+ var plugins = {};
+ function getPlugin(pluginKey) {
+ var plugin = plugins[pluginKey];
+
+ if (!plugin) {
+ die(18, pluginKey);
+ } // @ts-ignore
+
+
+ return plugin;
+ }
+ function loadPlugin(pluginKey, implementation) {
+ if (!plugins[pluginKey]) plugins[pluginKey] = implementation;
+ }
+
+ var currentScope;
+ function getCurrentScope() {
+ if ( !currentScope) die(0);
+ return currentScope;
+ }
+
+ function createScope(parent_, immer_) {
+ return {
+ drafts_: [],
+ parent_: parent_,
+ immer_: immer_,
+ // Whenever the modified draft contains a draft from another scope, we
+ // need to prevent auto-freezing so the unowned draft can be finalized.
+ canAutoFreeze_: true,
+ unfinalizedDrafts_: 0
+ };
+ }
+
+ function usePatchesInScope(scope, patchListener) {
+ if (patchListener) {
+ getPlugin("Patches"); // assert we have the plugin
+
+ scope.patches_ = [];
+ scope.inversePatches_ = [];
+ scope.patchListener_ = patchListener;
+ }
+ }
+ function revokeScope(scope) {
+ leaveScope(scope);
+ scope.drafts_.forEach(revokeDraft); // @ts-ignore
+
+ scope.drafts_ = null;
+ }
+ function leaveScope(scope) {
+ if (scope === currentScope) {
+ currentScope = scope.parent_;
+ }
+ }
+ function enterScope(immer) {
+ return currentScope = createScope(currentScope, immer);
+ }
+
+ function revokeDraft(draft) {
+ var state = draft[DRAFT_STATE];
+ if (state.type_ === 0
+ /* ProxyObject */
+ || state.type_ === 1
+ /* ProxyArray */
+ ) state.revoke_();else state.revoked_ = true;
+ }
+
+ function processResult(result, scope) {
+ scope.unfinalizedDrafts_ = scope.drafts_.length;
+ var baseDraft = scope.drafts_[0];
+ var isReplaced = result !== undefined && result !== baseDraft;
+ if (!scope.immer_.useProxies_) getPlugin("ES5").willFinalizeES5_(scope, result, isReplaced);
+
+ if (isReplaced) {
+ if (baseDraft[DRAFT_STATE].modified_) {
+ revokeScope(scope);
+ die(4);
+ }
+
+ if (isDraftable(result)) {
+ // Finalize the result in case it contains (or is) a subset of the draft.
+ result = finalize(scope, result);
+ if (!scope.parent_) maybeFreeze(scope, result);
+ }
+
+ if (scope.patches_) {
+ getPlugin("Patches").generateReplacementPatches_(baseDraft[DRAFT_STATE], result, scope.patches_, scope.inversePatches_);
+ }
+ } else {
+ // Finalize the base draft.
+ result = finalize(scope, baseDraft, []);
+ }
+
+ revokeScope(scope);
+
+ if (scope.patches_) {
+ scope.patchListener_(scope.patches_, scope.inversePatches_);
+ }
+
+ return result !== NOTHING ? result : undefined;
+ }
+
+ function finalize(rootScope, value, path) {
+ // Don't recurse in tho recursive data structures
+ if (isFrozen(value)) return value;
+ var state = value[DRAFT_STATE]; // A plain object, might need freezing, might contain drafts
+
+ if (!state) {
+ each$1(value, function (key, childValue) {
+ return finalizeProperty(rootScope, state, value, key, childValue, path);
+ }, true // See #590, don't recurse into non-enumerable of non drafted objects
+ );
+ return value;
+ } // Never finalize drafts owned by another scope.
+
+
+ if (state.scope_ !== rootScope) return value; // Unmodified draft, return the (frozen) original
+
+ if (!state.modified_) {
+ maybeFreeze(rootScope, state.base_, true);
+ return state.base_;
+ } // Not finalized yet, let's do that now
+
+
+ if (!state.finalized_) {
+ state.finalized_ = true;
+ state.scope_.unfinalizedDrafts_--;
+ var result = // For ES5, create a good copy from the draft first, with added keys and without deleted keys.
+ state.type_ === 4
+ /* ES5Object */
+ || state.type_ === 5
+ /* ES5Array */
+ ? state.copy_ = shallowCopy(state.draft_) : state.copy_; // Finalize all children of the copy
+ // For sets we clone before iterating, otherwise we can get in endless loop due to modifying during iteration, see #628
+ // Although the original test case doesn't seem valid anyway, so if this in the way we can turn the next line
+ // back to each(result, ....)
+
+ each$1(state.type_ === 3
+ /* Set */
+ ? new Set(result) : result, function (key, childValue) {
+ return finalizeProperty(rootScope, state, result, key, childValue, path);
+ }); // everything inside is frozen, we can freeze here
+
+ maybeFreeze(rootScope, result, false); // first time finalizing, let's create those patches
+
+ if (path && rootScope.patches_) {
+ getPlugin("Patches").generatePatches_(state, path, rootScope.patches_, rootScope.inversePatches_);
+ }
+ }
+
+ return state.copy_;
+ }
+
+ function finalizeProperty(rootScope, parentState, targetObject, prop, childValue, rootPath) {
+ if ( childValue === targetObject) die(5);
+
+ if (isDraft(childValue)) {
+ var path = rootPath && parentState && parentState.type_ !== 3
+ /* Set */
+ && // Set objects are atomic since they have no keys.
+ !has(parentState.assigned_, prop) // Skip deep patches for assigned keys.
+ ? rootPath.concat(prop) : undefined; // Drafts owned by `scope` are finalized here.
+
+ var res = finalize(rootScope, childValue, path);
+ set(targetObject, prop, res); // Drafts from another scope must prevented to be frozen
+ // if we got a draft back from finalize, we're in a nested produce and shouldn't freeze
+
+ if (isDraft(res)) {
+ rootScope.canAutoFreeze_ = false;
+ } else return;
+ } // Search new objects for unfinalized drafts. Frozen objects should never contain drafts.
+
+
+ if (isDraftable(childValue) && !isFrozen(childValue)) {
+ if (!rootScope.immer_.autoFreeze_ && rootScope.unfinalizedDrafts_ < 1) {
+ // optimization: if an object is not a draft, and we don't have to
+ // deepfreeze everything, and we are sure that no drafts are left in the remaining object
+ // cause we saw and finalized all drafts already; we can stop visiting the rest of the tree.
+ // This benefits especially adding large data tree's without further processing.
+ // See add-data.js perf test
+ return;
+ }
+
+ finalize(rootScope, childValue); // immer deep freezes plain objects, so if there is no parent state, we freeze as well
+
+ if (!parentState || !parentState.scope_.parent_) maybeFreeze(rootScope, childValue);
+ }
+ }
+
+ function maybeFreeze(scope, value, deep) {
+ if (deep === void 0) {
+ deep = false;
+ }
+
+ if (scope.immer_.autoFreeze_ && scope.canAutoFreeze_) {
+ freeze(value, deep);
+ }
+ }
+
+ /**
+ * Returns a new draft of the `base` object.
+ *
+ * The second argument is the parent draft-state (used internally).
+ */
+
+ function createProxyProxy(base, parent) {
+ var isArray = Array.isArray(base);
+ var state = {
+ type_: isArray ? 1
+ /* ProxyArray */
+ : 0
+ /* ProxyObject */
+ ,
+ // Track which produce call this is associated with.
+ scope_: parent ? parent.scope_ : getCurrentScope(),
+ // True for both shallow and deep changes.
+ modified_: false,
+ // Used during finalization.
+ finalized_: false,
+ // Track which properties have been assigned (true) or deleted (false).
+ assigned_: {},
+ // The parent draft state.
+ parent_: parent,
+ // The base state.
+ base_: base,
+ // The base proxy.
+ draft_: null,
+ // The base copy with any updated values.
+ copy_: null,
+ // Called by the `produce` function.
+ revoke_: null,
+ isManual_: false
+ }; // the traps must target something, a bit like the 'real' base.
+ // but also, we need to be able to determine from the target what the relevant state is
+ // (to avoid creating traps per instance to capture the state in closure,
+ // and to avoid creating weird hidden properties as well)
+ // So the trick is to use 'state' as the actual 'target'! (and make sure we intercept everything)
+ // Note that in the case of an array, we put the state in an array to have better Reflect defaults ootb
+
+ var target = state;
+ var traps = objectTraps;
+
+ if (isArray) {
+ target = [state];
+ traps = arrayTraps;
+ }
+
+ var _Proxy$revocable = Proxy.revocable(target, traps),
+ revoke = _Proxy$revocable.revoke,
+ proxy = _Proxy$revocable.proxy;
+
+ state.draft_ = proxy;
+ state.revoke_ = revoke;
+ return proxy;
+ }
+ /**
+ * Object drafts
+ */
+
+ var objectTraps = {
+ get: function get(state, prop) {
+ if (prop === DRAFT_STATE) return state;
+ var source = latest(state);
+
+ if (!has(source, prop)) {
+ // non-existing or non-own property...
+ return readPropFromProto(state, source, prop);
+ }
+
+ var value = source[prop];
+
+ if (state.finalized_ || !isDraftable(value)) {
+ return value;
+ } // Check for existing draft in modified state.
+ // Assigned values are never drafted. This catches any drafts we created, too.
+
+
+ if (value === peek(state.base_, prop)) {
+ prepareCopy(state);
+ return state.copy_[prop] = createProxy(state.scope_.immer_, value, state);
+ }
+
+ return value;
+ },
+ has: function has(state, prop) {
+ return prop in latest(state);
+ },
+ ownKeys: function ownKeys(state) {
+ return Reflect.ownKeys(latest(state));
+ },
+ set: function set(state, prop
+ /* strictly not, but helps TS */
+ , value) {
+ var desc = getDescriptorFromProto(latest(state), prop);
+
+ if (desc === null || desc === void 0 ? void 0 : desc.set) {
+ // special case: if this write is captured by a setter, we have
+ // to trigger it with the correct context
+ desc.set.call(state.draft_, value);
+ return true;
+ }
+
+ if (!state.modified_) {
+ // the last check is because we need to be able to distinguish setting a non-existing to undefined (which is a change)
+ // from setting an existing property with value undefined to undefined (which is not a change)
+ var current = peek(latest(state), prop); // special case, if we assigning the original value to a draft, we can ignore the assignment
+
+ var currentState = current === null || current === void 0 ? void 0 : current[DRAFT_STATE];
+
+ if (currentState && currentState.base_ === value) {
+ state.copy_[prop] = value;
+ state.assigned_[prop] = false;
+ return true;
+ }
+
+ if (is$1(value, current) && (value !== undefined || has(state.base_, prop))) return true;
+ prepareCopy(state);
+ markChanged(state);
+ }
+
+ if (state.copy_[prop] === value && // special case: NaN
+ typeof value !== "number" && ( // special case: handle new props with value 'undefined'
+ value !== undefined || prop in state.copy_)) return true; // @ts-ignore
+
+ state.copy_[prop] = value;
+ state.assigned_[prop] = true;
+ return true;
+ },
+ deleteProperty: function deleteProperty(state, prop) {
+ // The `undefined` check is a fast path for pre-existing keys.
+ if (peek(state.base_, prop) !== undefined || prop in state.base_) {
+ state.assigned_[prop] = false;
+ prepareCopy(state);
+ markChanged(state);
+ } else {
+ // if an originally not assigned property was deleted
+ delete state.assigned_[prop];
+ } // @ts-ignore
+
+
+ if (state.copy_) delete state.copy_[prop];
+ return true;
+ },
+ // Note: We never coerce `desc.value` into an Immer draft, because we can't make
+ // the same guarantee in ES5 mode.
+ getOwnPropertyDescriptor: function getOwnPropertyDescriptor(state, prop) {
+ var owner = latest(state);
+ var desc = Reflect.getOwnPropertyDescriptor(owner, prop);
+ if (!desc) return desc;
+ return {
+ writable: true,
+ configurable: state.type_ !== 1
+ /* ProxyArray */
+ || prop !== "length",
+ enumerable: desc.enumerable,
+ value: owner[prop]
+ };
+ },
+ defineProperty: function defineProperty() {
+ die(11);
+ },
+ getPrototypeOf: function getPrototypeOf(state) {
+ return Object.getPrototypeOf(state.base_);
+ },
+ setPrototypeOf: function setPrototypeOf() {
+ die(12);
+ }
+ };
+ /**
+ * Array drafts
+ */
+
+ var arrayTraps = {};
+ each$1(objectTraps, function (key, fn) {
+ // @ts-ignore
+ arrayTraps[key] = function () {
+ arguments[0] = arguments[0][0];
+ return fn.apply(this, arguments);
+ };
+ });
+
+ arrayTraps.deleteProperty = function (state, prop) {
+ if ( isNaN(parseInt(prop))) die(13);
+ return objectTraps.deleteProperty.call(this, state[0], prop);
+ };
+
+ arrayTraps.set = function (state, prop, value) {
+ if ( prop !== "length" && isNaN(parseInt(prop))) die(14);
+ return objectTraps.set.call(this, state[0], prop, value, state[0]);
+ }; // Access a property without creating an Immer draft.
+
+
+ function peek(draft, prop) {
+ var state = draft[DRAFT_STATE];
+ var source = state ? latest(state) : draft;
+ return source[prop];
+ }
+
+ function readPropFromProto(state, source, prop) {
+ var _desc$get;
+
+ var desc = getDescriptorFromProto(source, prop);
+ return desc ? "value" in desc ? desc.value : // This is a very special case, if the prop is a getter defined by the
+ // prototype, we should invoke it with the draft as context!
+ (_desc$get = desc.get) === null || _desc$get === void 0 ? void 0 : _desc$get.call(state.draft_) : undefined;
+ }
+
+ function getDescriptorFromProto(source, prop) {
+ // 'in' checks proto!
+ if (!(prop in source)) return undefined;
+ var proto = Object.getPrototypeOf(source);
+
+ while (proto) {
+ var desc = Object.getOwnPropertyDescriptor(proto, prop);
+ if (desc) return desc;
+ proto = Object.getPrototypeOf(proto);
+ }
+
+ return undefined;
+ }
+
+ function markChanged(state) {
+ if (!state.modified_) {
+ state.modified_ = true;
+
+ if (state.parent_) {
+ markChanged(state.parent_);
+ }
+ }
+ }
+ function prepareCopy(state) {
+ if (!state.copy_) {
+ state.copy_ = shallowCopy(state.base_);
+ }
+ }
+
+ var Immer =
+ /*#__PURE__*/
+ function () {
+ function Immer(config) {
+ var _this = this;
+
+ this.useProxies_ = hasProxies;
+ this.autoFreeze_ = true;
+ /**
+ * The `produce` function takes a value and a "recipe function" (whose
+ * return value often depends on the base state). The recipe function is
+ * free to mutate its first argument however it wants. All mutations are
+ * only ever applied to a __copy__ of the base state.
+ *
+ * Pass only a function to create a "curried producer" which relieves you
+ * from passing the recipe function every time.
+ *
+ * Only plain objects and arrays are made mutable. All other objects are
+ * considered uncopyable.
+ *
+ * Note: This function is __bound__ to its `Immer` instance.
+ *
+ * @param {any} base - the initial state
+ * @param {Function} producer - function that receives a proxy of the base state as first argument and which can be freely modified
+ * @param {Function} patchListener - optional function that will be called with all the patches produced here
+ * @returns {any} a new state, or the initial state if nothing was modified
+ */
+
+ this.produce = function (base, recipe, patchListener) {
+ // curried invocation
+ if (typeof base === "function" && typeof recipe !== "function") {
+ var defaultBase = recipe;
+ recipe = base;
+ var self = _this;
+ return function curriedProduce(base) {
+ var _this2 = this;
+
+ if (base === void 0) {
+ base = defaultBase;
+ }
+
+ for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
+ args[_key - 1] = arguments[_key];
+ }
+
+ return self.produce(base, function (draft) {
+ var _recipe;
+
+ return (_recipe = recipe).call.apply(_recipe, [_this2, draft].concat(args));
+ }); // prettier-ignore
+ };
+ }
+
+ if (typeof recipe !== "function") die(6);
+ if (patchListener !== undefined && typeof patchListener !== "function") die(7);
+ var result; // Only plain objects, arrays, and "immerable classes" are drafted.
+
+ if (isDraftable(base)) {
+ var scope = enterScope(_this);
+ var proxy = createProxy(_this, base, undefined);
+ var hasError = true;
+
+ try {
+ result = recipe(proxy);
+ hasError = false;
+ } finally {
+ // finally instead of catch + rethrow better preserves original stack
+ if (hasError) revokeScope(scope);else leaveScope(scope);
+ }
+
+ if (typeof Promise !== "undefined" && result instanceof Promise) {
+ return result.then(function (result) {
+ usePatchesInScope(scope, patchListener);
+ return processResult(result, scope);
+ }, function (error) {
+ revokeScope(scope);
+ throw error;
+ });
+ }
+
+ usePatchesInScope(scope, patchListener);
+ return processResult(result, scope);
+ } else if (!base || typeof base !== "object") {
+ result = recipe(base);
+ if (result === NOTHING) return undefined;
+ if (result === undefined) result = base;
+ if (_this.autoFreeze_) freeze(result, true);
+ return result;
+ } else die(21, base);
+ };
+
+ this.produceWithPatches = function (arg1, arg2, arg3) {
+ if (typeof arg1 === "function") {
+ return function (state) {
+ for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
+ args[_key2 - 1] = arguments[_key2];
+ }
+
+ return _this.produceWithPatches(state, function (draft) {
+ return arg1.apply(void 0, [draft].concat(args));
+ });
+ };
+ }
+
+ var patches, inversePatches;
+
+ var nextState = _this.produce(arg1, arg2, function (p, ip) {
+ patches = p;
+ inversePatches = ip;
+ });
+
+ return [nextState, patches, inversePatches];
+ };
+
+ if (typeof (config === null || config === void 0 ? void 0 : config.useProxies) === "boolean") this.setUseProxies(config.useProxies);
+ if (typeof (config === null || config === void 0 ? void 0 : config.autoFreeze) === "boolean") this.setAutoFreeze(config.autoFreeze);
+ }
+
+ var _proto = Immer.prototype;
+
+ _proto.createDraft = function createDraft(base) {
+ if (!isDraftable(base)) die(8);
+ if (isDraft(base)) base = current(base);
+ var scope = enterScope(this);
+ var proxy = createProxy(this, base, undefined);
+ proxy[DRAFT_STATE].isManual_ = true;
+ leaveScope(scope);
+ return proxy;
+ };
+
+ _proto.finishDraft = function finishDraft(draft, patchListener) {
+ var state = draft && draft[DRAFT_STATE];
+
+ {
+ if (!state || !state.isManual_) die(9);
+ if (state.finalized_) die(10);
+ }
+
+ var scope = state.scope_;
+ usePatchesInScope(scope, patchListener);
+ return processResult(undefined, scope);
+ }
+ /**
+ * Pass true to automatically freeze all copies created by Immer.
+ *
+ * By default, auto-freezing is enabled.
+ */
+ ;
+
+ _proto.setAutoFreeze = function setAutoFreeze(value) {
+ this.autoFreeze_ = value;
+ }
+ /**
+ * Pass true to use the ES2015 `Proxy` class when creating drafts, which is
+ * always faster than using ES5 proxies.
+ *
+ * By default, feature detection is used, so calling this is rarely necessary.
+ */
+ ;
+
+ _proto.setUseProxies = function setUseProxies(value) {
+ if (value && !hasProxies) {
+ die(20);
+ }
+
+ this.useProxies_ = value;
+ };
+
+ _proto.applyPatches = function applyPatches(base, patches) {
+ // If a patch replaces the entire state, take that replacement as base
+ // before applying patches
+ var i;
+
+ for (i = patches.length - 1; i >= 0; i--) {
+ var patch = patches[i];
+
+ if (patch.path.length === 0 && patch.op === "replace") {
+ base = patch.value;
+ break;
+ }
+ } // If there was a patch that replaced the entire state, start from the
+ // patch after that.
+
+
+ if (i > -1) {
+ patches = patches.slice(i + 1);
+ }
+
+ var applyPatchesImpl = getPlugin("Patches").applyPatches_;
+
+ if (isDraft(base)) {
+ // N.B: never hits if some patch a replacement, patches are never drafts
+ return applyPatchesImpl(base, patches);
+ } // Otherwise, produce a copy of the base state.
+
+
+ return this.produce(base, function (draft) {
+ return applyPatchesImpl(draft, patches);
+ });
+ };
+
+ return Immer;
+ }();
+ function createProxy(immer, value, parent) {
+ // precondition: createProxy should be guarded by isDraftable, so we know we can safely draft
+ var draft = isMap(value) ? getPlugin("MapSet").proxyMap_(value, parent) : isSet(value) ? getPlugin("MapSet").proxySet_(value, parent) : immer.useProxies_ ? createProxyProxy(value, parent) : getPlugin("ES5").createES5Proxy_(value, parent);
+ var scope = parent ? parent.scope_ : getCurrentScope();
+ scope.drafts_.push(draft);
+ return draft;
+ }
+
+ function current(value) {
+ if (!isDraft(value)) die(22, value);
+ return currentImpl(value);
+ }
+
+ function currentImpl(value) {
+ if (!isDraftable(value)) return value;
+ var state = value[DRAFT_STATE];
+ var copy;
+ var archType = getArchtype(value);
+
+ if (state) {
+ if (!state.modified_ && (state.type_ < 4 || !getPlugin("ES5").hasChanges_(state))) return state.base_; // Optimization: avoid generating new drafts during copying
+
+ state.finalized_ = true;
+ copy = copyHelper(value, archType);
+ state.finalized_ = false;
+ } else {
+ copy = copyHelper(value, archType);
+ }
+
+ each$1(copy, function (key, childValue) {
+ if (state && get(state.base_, key) === childValue) return; // no need to copy or search in something that didn't change
+
+ set(copy, key, currentImpl(childValue));
+ }); // In the future, we might consider freezing here, based on the current settings
+
+ return archType === 3
+ /* Set */
+ ? new Set(copy) : copy;
+ }
+
+ function copyHelper(value, archType) {
+ // creates a shallow copy, even if it is a map or set
+ switch (archType) {
+ case 2
+ /* Map */
+ :
+ return new Map(value);
+
+ case 3
+ /* Set */
+ :
+ // Set will be cloned as array temporarily, so that we can replace individual items
+ return Array.from(value);
+ }
+
+ return shallowCopy(value);
+ }
+
+ function enableES5() {
+ function willFinalizeES5_(scope, result, isReplaced) {
+ if (!isReplaced) {
+ if (scope.patches_) {
+ markChangesRecursively(scope.drafts_[0]);
+ } // This is faster when we don't care about which attributes changed.
+
+
+ markChangesSweep(scope.drafts_);
+ } // When a child draft is returned, look for changes.
+ else if (isDraft(result) && result[DRAFT_STATE].scope_ === scope) {
+ markChangesSweep(scope.drafts_);
+ }
+ }
+
+ function createES5Draft(isArray, base) {
+ if (isArray) {
+ var draft = new Array(base.length);
+
+ for (var i = 0; i < base.length; i++) {
+ Object.defineProperty(draft, "" + i, proxyProperty(i, true));
+ }
+
+ return draft;
+ } else {
+ var _descriptors = getOwnPropertyDescriptors(base);
+
+ delete _descriptors[DRAFT_STATE];
+ var keys = ownKeys$a(_descriptors);
+
+ for (var _i = 0; _i < keys.length; _i++) {
+ var key = keys[_i];
+ _descriptors[key] = proxyProperty(key, isArray || !!_descriptors[key].enumerable);
+ }
+
+ return Object.create(Object.getPrototypeOf(base), _descriptors);
+ }
+ }
+
+ function createES5Proxy_(base, parent) {
+ var isArray = Array.isArray(base);
+ var draft = createES5Draft(isArray, base);
+ var state = {
+ type_: isArray ? 5
+ /* ES5Array */
+ : 4
+ /* ES5Object */
+ ,
+ scope_: parent ? parent.scope_ : getCurrentScope(),
+ modified_: false,
+ finalized_: false,
+ assigned_: {},
+ parent_: parent,
+ // base is the object we are drafting
+ base_: base,
+ // draft is the draft object itself, that traps all reads and reads from either the base (if unmodified) or copy (if modified)
+ draft_: draft,
+ copy_: null,
+ revoked_: false,
+ isManual_: false
+ };
+ Object.defineProperty(draft, DRAFT_STATE, {
+ value: state,
+ // enumerable: false <- the default
+ writable: true
+ });
+ return draft;
+ } // property descriptors are recycled to make sure we don't create a get and set closure per property,
+ // but share them all instead
+
+
+ var descriptors = {};
+
+ function proxyProperty(prop, enumerable) {
+ var desc = descriptors[prop];
+
+ if (desc) {
+ desc.enumerable = enumerable;
+ } else {
+ descriptors[prop] = desc = {
+ configurable: true,
+ enumerable: enumerable,
+ get: function get() {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state); // @ts-ignore
+
+ return objectTraps.get(state, prop);
+ },
+ set: function set(value) {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state); // @ts-ignore
+
+ objectTraps.set(state, prop, value);
+ }
+ };
+ }
+
+ return desc;
+ } // This looks expensive, but only proxies are visited, and only objects without known changes are scanned.
+
+
+ function markChangesSweep(drafts) {
+ // The natural order of drafts in the `scope` array is based on when they
+ // were accessed. By processing drafts in reverse natural order, we have a
+ // better chance of processing leaf nodes first. When a leaf node is known to
+ // have changed, we can avoid any traversal of its ancestor nodes.
+ for (var i = drafts.length - 1; i >= 0; i--) {
+ var state = drafts[i][DRAFT_STATE];
+
+ if (!state.modified_) {
+ switch (state.type_) {
+ case 5
+ /* ES5Array */
+ :
+ if (hasArrayChanges(state)) markChanged(state);
+ break;
+
+ case 4
+ /* ES5Object */
+ :
+ if (hasObjectChanges(state)) markChanged(state);
+ break;
+ }
+ }
+ }
+ }
+
+ function markChangesRecursively(object) {
+ if (!object || typeof object !== "object") return;
+ var state = object[DRAFT_STATE];
+ if (!state) return;
+ var base_ = state.base_,
+ draft_ = state.draft_,
+ assigned_ = state.assigned_,
+ type_ = state.type_;
+
+ if (type_ === 4
+ /* ES5Object */
+ ) {
+ // Look for added keys.
+ // probably there is a faster way to detect changes, as sweep + recurse seems to do some
+ // unnecessary work.
+ // also: probably we can store the information we detect here, to speed up tree finalization!
+ each$1(draft_, function (key) {
+ if (key === DRAFT_STATE) return; // The `undefined` check is a fast path for pre-existing keys.
+
+ if (base_[key] === undefined && !has(base_, key)) {
+ assigned_[key] = true;
+ markChanged(state);
+ } else if (!assigned_[key]) {
+ // Only untouched properties trigger recursion.
+ markChangesRecursively(draft_[key]);
+ }
+ }); // Look for removed keys.
+
+ each$1(base_, function (key) {
+ // The `undefined` check is a fast path for pre-existing keys.
+ if (draft_[key] === undefined && !has(draft_, key)) {
+ assigned_[key] = false;
+ markChanged(state);
+ }
+ });
+ } else if (type_ === 5
+ /* ES5Array */
+ ) {
+ if (hasArrayChanges(state)) {
+ markChanged(state);
+ assigned_.length = true;
+ }
+
+ if (draft_.length < base_.length) {
+ for (var i = draft_.length; i < base_.length; i++) {
+ assigned_[i] = false;
+ }
+ } else {
+ for (var _i2 = base_.length; _i2 < draft_.length; _i2++) {
+ assigned_[_i2] = true;
+ }
+ } // Minimum count is enough, the other parts has been processed.
+
+
+ var min = Math.min(draft_.length, base_.length);
+
+ for (var _i3 = 0; _i3 < min; _i3++) {
+ // Only untouched indices trigger recursion.
+ if (assigned_[_i3] === undefined) markChangesRecursively(draft_[_i3]);
+ }
+ }
+ }
+
+ function hasObjectChanges(state) {
+ var base_ = state.base_,
+ draft_ = state.draft_; // Search for added keys and changed keys. Start at the back, because
+ // non-numeric keys are ordered by time of definition on the object.
+
+ var keys = ownKeys$a(draft_);
+
+ for (var i = keys.length - 1; i >= 0; i--) {
+ var key = keys[i];
+ if (key === DRAFT_STATE) continue;
+ var baseValue = base_[key]; // The `undefined` check is a fast path for pre-existing keys.
+
+ if (baseValue === undefined && !has(base_, key)) {
+ return true;
+ } // Once a base key is deleted, future changes go undetected, because its
+ // descriptor is erased. This branch detects any missed changes.
+ else {
+ var value = draft_[key];
+
+ var _state = value && value[DRAFT_STATE];
+
+ if (_state ? _state.base_ !== baseValue : !is$1(value, baseValue)) {
+ return true;
+ }
+ }
+ } // At this point, no keys were added or changed.
+ // Compare key count to determine if keys were deleted.
+
+
+ var baseIsDraft = !!base_[DRAFT_STATE];
+ return keys.length !== ownKeys$a(base_).length + (baseIsDraft ? 0 : 1); // + 1 to correct for DRAFT_STATE
+ }
+
+ function hasArrayChanges(state) {
+ var draft_ = state.draft_;
+ if (draft_.length !== state.base_.length) return true; // See #116
+ // If we first shorten the length, our array interceptors will be removed.
+ // If after that new items are added, result in the same original length,
+ // those last items will have no intercepting property.
+ // So if there is no own descriptor on the last position, we know that items were removed and added
+ // N.B.: splice, unshift, etc only shift values around, but not prop descriptors, so we only have to check
+ // the last one
+
+ var descriptor = Object.getOwnPropertyDescriptor(draft_, draft_.length - 1); // descriptor can be null, but only for newly created sparse arrays, eg. new Array(10)
+
+ if (descriptor && !descriptor.get) return true; // For all other cases, we don't have to compare, as they would have been picked up by the index setters
+
+ return false;
+ }
+
+ function hasChanges_(state) {
+ return state.type_ === 4
+ /* ES5Object */
+ ? hasObjectChanges(state) : hasArrayChanges(state);
+ }
+
+ function assertUnrevoked(state
+ /*ES5State | MapState | SetState*/
+ ) {
+ if (state.revoked_) die(3, JSON.stringify(latest(state)));
+ }
+
+ loadPlugin("ES5", {
+ createES5Proxy_: createES5Proxy_,
+ willFinalizeES5_: willFinalizeES5_,
+ hasChanges_: hasChanges_
+ });
+ }
+
+ function enablePatches() {
+ var REPLACE = "replace";
+ var ADD = "add";
+ var REMOVE = "remove";
+
+ function generatePatches_(state, basePath, patches, inversePatches) {
+ switch (state.type_) {
+ case 0
+ /* ProxyObject */
+ :
+ case 4
+ /* ES5Object */
+ :
+ case 2
+ /* Map */
+ :
+ return generatePatchesFromAssigned(state, basePath, patches, inversePatches);
+
+ case 5
+ /* ES5Array */
+ :
+ case 1
+ /* ProxyArray */
+ :
+ return generateArrayPatches(state, basePath, patches, inversePatches);
+
+ case 3
+ /* Set */
+ :
+ return generateSetPatches(state, basePath, patches, inversePatches);
+ }
+ }
+
+ function generateArrayPatches(state, basePath, patches, inversePatches) {
+ var base_ = state.base_,
+ assigned_ = state.assigned_;
+ var copy_ = state.copy_; // Reduce complexity by ensuring `base` is never longer.
+
+ if (copy_.length < base_.length) {
+ var _ref = [copy_, base_];
+ base_ = _ref[0];
+ copy_ = _ref[1];
+ var _ref2 = [inversePatches, patches];
+ patches = _ref2[0];
+ inversePatches = _ref2[1];
+ } // Process replaced indices.
+
+
+ for (var i = 0; i < base_.length; i++) {
+ if (assigned_[i] && copy_[i] !== base_[i]) {
+ var path = basePath.concat([i]);
+ patches.push({
+ op: REPLACE,
+ path: path,
+ // Need to maybe clone it, as it can in fact be the original value
+ // due to the base/copy inversion at the start of this function
+ value: clonePatchValueIfNeeded(copy_[i])
+ });
+ inversePatches.push({
+ op: REPLACE,
+ path: path,
+ value: clonePatchValueIfNeeded(base_[i])
+ });
+ }
+ } // Process added indices.
+
+
+ for (var _i = base_.length; _i < copy_.length; _i++) {
+ var _path = basePath.concat([_i]);
+
+ patches.push({
+ op: ADD,
+ path: _path,
+ // Need to maybe clone it, as it can in fact be the original value
+ // due to the base/copy inversion at the start of this function
+ value: clonePatchValueIfNeeded(copy_[_i])
+ });
+ }
+
+ if (base_.length < copy_.length) {
+ inversePatches.push({
+ op: REPLACE,
+ path: basePath.concat(["length"]),
+ value: base_.length
+ });
+ }
+ } // This is used for both Map objects and normal objects.
+
+
+ function generatePatchesFromAssigned(state, basePath, patches, inversePatches) {
+ var base_ = state.base_,
+ copy_ = state.copy_;
+ each$1(state.assigned_, function (key, assignedValue) {
+ var origValue = get(base_, key);
+ var value = get(copy_, key);
+ var op = !assignedValue ? REMOVE : has(base_, key) ? REPLACE : ADD;
+ if (origValue === value && op === REPLACE) return;
+ var path = basePath.concat(key);
+ patches.push(op === REMOVE ? {
+ op: op,
+ path: path
+ } : {
+ op: op,
+ path: path,
+ value: value
+ });
+ inversePatches.push(op === ADD ? {
+ op: REMOVE,
+ path: path
+ } : op === REMOVE ? {
+ op: ADD,
+ path: path,
+ value: clonePatchValueIfNeeded(origValue)
+ } : {
+ op: REPLACE,
+ path: path,
+ value: clonePatchValueIfNeeded(origValue)
+ });
+ });
+ }
+
+ function generateSetPatches(state, basePath, patches, inversePatches) {
+ var base_ = state.base_,
+ copy_ = state.copy_;
+ var i = 0;
+ base_.forEach(function (value) {
+ if (!copy_.has(value)) {
+ var path = basePath.concat([i]);
+ patches.push({
+ op: REMOVE,
+ path: path,
+ value: value
+ });
+ inversePatches.unshift({
+ op: ADD,
+ path: path,
+ value: value
+ });
+ }
+
+ i++;
+ });
+ i = 0;
+ copy_.forEach(function (value) {
+ if (!base_.has(value)) {
+ var path = basePath.concat([i]);
+ patches.push({
+ op: ADD,
+ path: path,
+ value: value
+ });
+ inversePatches.unshift({
+ op: REMOVE,
+ path: path,
+ value: value
+ });
+ }
+
+ i++;
+ });
+ }
+
+ function generateReplacementPatches_(rootState, replacement, patches, inversePatches) {
+ patches.push({
+ op: REPLACE,
+ path: [],
+ value: replacement === NOTHING ? undefined : replacement
+ });
+ inversePatches.push({
+ op: REPLACE,
+ path: [],
+ value: rootState.base_
+ });
+ }
+
+ function applyPatches_(draft, patches) {
+ patches.forEach(function (patch) {
+ var path = patch.path,
+ op = patch.op;
+ var base = draft;
+
+ for (var i = 0; i < path.length - 1; i++) {
+ var parentType = getArchtype(base);
+ var p = "" + path[i]; // See #738, avoid prototype pollution
+
+ if ((parentType === 0
+ /* Object */
+ || parentType === 1
+ /* Array */
+ ) && (p === "__proto__" || p === "constructor")) die(24);
+ if (typeof base === "function" && p === "prototype") die(24);
+ base = get(base, p);
+ if (typeof base !== "object") die(15, path.join("/"));
+ }
+
+ var type = getArchtype(base);
+ var value = deepClonePatchValue(patch.value); // used to clone patch to ensure original patch is not modified, see #411
+
+ var key = path[path.length - 1];
+
+ switch (op) {
+ case REPLACE:
+ switch (type) {
+ case 2
+ /* Map */
+ :
+ return base.set(key, value);
+
+ /* istanbul ignore next */
+
+ case 3
+ /* Set */
+ :
+ die(16);
+
+ default:
+ // if value is an object, then it's assigned by reference
+ // in the following add or remove ops, the value field inside the patch will also be modifyed
+ // so we use value from the cloned patch
+ // @ts-ignore
+ return base[key] = value;
+ }
+
+ case ADD:
+ switch (type) {
+ case 1
+ /* Array */
+ :
+ return key === "-" ? base.push(value) : base.splice(key, 0, value);
+
+ case 2
+ /* Map */
+ :
+ return base.set(key, value);
+
+ case 3
+ /* Set */
+ :
+ return base.add(value);
+
+ default:
+ return base[key] = value;
+ }
+
+ case REMOVE:
+ switch (type) {
+ case 1
+ /* Array */
+ :
+ return base.splice(key, 1);
+
+ case 2
+ /* Map */
+ :
+ return base.delete(key);
+
+ case 3
+ /* Set */
+ :
+ return base.delete(patch.value);
+
+ default:
+ return delete base[key];
+ }
+
+ default:
+ die(17, op);
+ }
+ });
+ return draft;
+ }
+
+ function deepClonePatchValue(obj) {
+ if (!isDraftable(obj)) return obj;
+ if (Array.isArray(obj)) return obj.map(deepClonePatchValue);
+ if (isMap(obj)) return new Map(Array.from(obj.entries()).map(function (_ref3) {
+ var k = _ref3[0],
+ v = _ref3[1];
+ return [k, deepClonePatchValue(v)];
+ }));
+ if (isSet(obj)) return new Set(Array.from(obj).map(deepClonePatchValue));
+ var cloned = Object.create(Object.getPrototypeOf(obj));
+
+ for (var key in obj) {
+ cloned[key] = deepClonePatchValue(obj[key]);
+ }
+
+ if (has(obj, DRAFTABLE)) cloned[DRAFTABLE] = obj[DRAFTABLE];
+ return cloned;
+ }
+
+ function clonePatchValueIfNeeded(obj) {
+ if (isDraft(obj)) {
+ return deepClonePatchValue(obj);
+ } else return obj;
+ }
+
+ loadPlugin("Patches", {
+ applyPatches_: applyPatches_,
+ generatePatches_: generatePatches_,
+ generateReplacementPatches_: generateReplacementPatches_
+ });
+ }
+
+ // types only!
+ function enableMapSet() {
+ /* istanbul ignore next */
+ var _extendStatics = function extendStatics(d, b) {
+ _extendStatics = Object.setPrototypeOf || {
+ __proto__: []
+ } instanceof Array && function (d, b) {
+ d.__proto__ = b;
+ } || function (d, b) {
+ for (var p in b) {
+ if (b.hasOwnProperty(p)) d[p] = b[p];
+ }
+ };
+
+ return _extendStatics(d, b);
+ }; // Ugly hack to resolve #502 and inherit built in Map / Set
+
+
+ function __extends(d, b) {
+ _extendStatics(d, b);
+
+ function __() {
+ this.constructor = d;
+ }
+
+ d.prototype = ( // @ts-ignore
+ __.prototype = b.prototype, new __());
+ }
+
+ var DraftMap = function (_super) {
+ __extends(DraftMap, _super); // Create class manually, cause #502
+
+
+ function DraftMap(target, parent) {
+ this[DRAFT_STATE] = {
+ type_: 2
+ /* Map */
+ ,
+ parent_: parent,
+ scope_: parent ? parent.scope_ : getCurrentScope(),
+ modified_: false,
+ finalized_: false,
+ copy_: undefined,
+ assigned_: undefined,
+ base_: target,
+ draft_: this,
+ isManual_: false,
+ revoked_: false
+ };
+ return this;
+ }
+
+ var p = DraftMap.prototype;
+ Object.defineProperty(p, "size", {
+ get: function get() {
+ return latest(this[DRAFT_STATE]).size;
+ } // enumerable: false,
+ // configurable: true
+
+ });
+
+ p.has = function (key) {
+ return latest(this[DRAFT_STATE]).has(key);
+ };
+
+ p.set = function (key, value) {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state);
+
+ if (!latest(state).has(key) || latest(state).get(key) !== value) {
+ prepareMapCopy(state);
+ markChanged(state);
+ state.assigned_.set(key, true);
+ state.copy_.set(key, value);
+ state.assigned_.set(key, true);
+ }
+
+ return this;
+ };
+
+ p.delete = function (key) {
+ if (!this.has(key)) {
+ return false;
+ }
+
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state);
+ prepareMapCopy(state);
+ markChanged(state);
+ state.assigned_.set(key, false);
+ state.copy_.delete(key);
+ return true;
+ };
+
+ p.clear = function () {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state);
+
+ if (latest(state).size) {
+ prepareMapCopy(state);
+ markChanged(state);
+ state.assigned_ = new Map();
+ each$1(state.base_, function (key) {
+ state.assigned_.set(key, false);
+ });
+ state.copy_.clear();
+ }
+ };
+
+ p.forEach = function (cb, thisArg) {
+ var _this = this;
+
+ var state = this[DRAFT_STATE];
+ latest(state).forEach(function (_value, key, _map) {
+ cb.call(thisArg, _this.get(key), key, _this);
+ });
+ };
+
+ p.get = function (key) {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state);
+ var value = latest(state).get(key);
+
+ if (state.finalized_ || !isDraftable(value)) {
+ return value;
+ }
+
+ if (value !== state.base_.get(key)) {
+ return value; // either already drafted or reassigned
+ } // despite what it looks, this creates a draft only once, see above condition
+
+
+ var draft = createProxy(state.scope_.immer_, value, state);
+ prepareMapCopy(state);
+ state.copy_.set(key, draft);
+ return draft;
+ };
+
+ p.keys = function () {
+ return latest(this[DRAFT_STATE]).keys();
+ };
+
+ p.values = function () {
+ var _this2 = this,
+ _ref;
+
+ var iterator = this.keys();
+ return _ref = {}, _ref[iteratorSymbol$1] = function () {
+ return _this2.values();
+ }, _ref.next = function next() {
+ var r = iterator.next();
+ /* istanbul ignore next */
+
+ if (r.done) return r;
+
+ var value = _this2.get(r.value);
+
+ return {
+ done: false,
+ value: value
+ };
+ }, _ref;
+ };
+
+ p.entries = function () {
+ var _this3 = this,
+ _ref2;
+
+ var iterator = this.keys();
+ return _ref2 = {}, _ref2[iteratorSymbol$1] = function () {
+ return _this3.entries();
+ }, _ref2.next = function next() {
+ var r = iterator.next();
+ /* istanbul ignore next */
+
+ if (r.done) return r;
+
+ var value = _this3.get(r.value);
+
+ return {
+ done: false,
+ value: [r.value, value]
+ };
+ }, _ref2;
+ };
+
+ p[iteratorSymbol$1] = function () {
+ return this.entries();
+ };
+
+ return DraftMap;
+ }(Map);
+
+ function proxyMap_(target, parent) {
+ // @ts-ignore
+ return new DraftMap(target, parent);
+ }
+
+ function prepareMapCopy(state) {
+ if (!state.copy_) {
+ state.assigned_ = new Map();
+ state.copy_ = new Map(state.base_);
+ }
+ }
+
+ var DraftSet = function (_super) {
+ __extends(DraftSet, _super); // Create class manually, cause #502
+
+
+ function DraftSet(target, parent) {
+ this[DRAFT_STATE] = {
+ type_: 3
+ /* Set */
+ ,
+ parent_: parent,
+ scope_: parent ? parent.scope_ : getCurrentScope(),
+ modified_: false,
+ finalized_: false,
+ copy_: undefined,
+ base_: target,
+ draft_: this,
+ drafts_: new Map(),
+ revoked_: false,
+ isManual_: false
+ };
+ return this;
+ }
+
+ var p = DraftSet.prototype;
+ Object.defineProperty(p, "size", {
+ get: function get() {
+ return latest(this[DRAFT_STATE]).size;
+ } // enumerable: true,
+
+ });
+
+ p.has = function (value) {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state); // bit of trickery here, to be able to recognize both the value, and the draft of its value
+
+ if (!state.copy_) {
+ return state.base_.has(value);
+ }
+
+ if (state.copy_.has(value)) return true;
+ if (state.drafts_.has(value) && state.copy_.has(state.drafts_.get(value))) return true;
+ return false;
+ };
+
+ p.add = function (value) {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state);
+
+ if (!this.has(value)) {
+ prepareSetCopy(state);
+ markChanged(state);
+ state.copy_.add(value);
+ }
+
+ return this;
+ };
+
+ p.delete = function (value) {
+ if (!this.has(value)) {
+ return false;
+ }
+
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state);
+ prepareSetCopy(state);
+ markChanged(state);
+ return state.copy_.delete(value) || (state.drafts_.has(value) ? state.copy_.delete(state.drafts_.get(value)) :
+ /* istanbul ignore next */
+ false);
+ };
+
+ p.clear = function () {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state);
+
+ if (latest(state).size) {
+ prepareSetCopy(state);
+ markChanged(state);
+ state.copy_.clear();
+ }
+ };
+
+ p.values = function () {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state);
+ prepareSetCopy(state);
+ return state.copy_.values();
+ };
+
+ p.entries = function entries() {
+ var state = this[DRAFT_STATE];
+ assertUnrevoked(state);
+ prepareSetCopy(state);
+ return state.copy_.entries();
+ };
+
+ p.keys = function () {
+ return this.values();
+ };
+
+ p[iteratorSymbol$1] = function () {
+ return this.values();
+ };
+
+ p.forEach = function forEach(cb, thisArg) {
+ var iterator = this.values();
+ var result = iterator.next();
+
+ while (!result.done) {
+ cb.call(thisArg, result.value, result.value, this);
+ result = iterator.next();
+ }
+ };
+
+ return DraftSet;
+ }(Set);
+
+ function proxySet_(target, parent) {
+ // @ts-ignore
+ return new DraftSet(target, parent);
+ }
+
+ function prepareSetCopy(state) {
+ if (!state.copy_) {
+ // create drafts for all entries to preserve insertion order
+ state.copy_ = new Set();
+ state.base_.forEach(function (value) {
+ if (isDraftable(value)) {
+ var draft = createProxy(state.scope_.immer_, value, state);
+ state.drafts_.set(value, draft);
+ state.copy_.add(draft);
+ } else {
+ state.copy_.add(value);
+ }
+ });
+ }
+ }
+
+ function assertUnrevoked(state
+ /*ES5State | MapState | SetState*/
+ ) {
+ if (state.revoked_) die(3, JSON.stringify(latest(state)));
+ }
+
+ loadPlugin("MapSet", {
+ proxyMap_: proxyMap_,
+ proxySet_: proxySet_
+ });
+ }
+
+ function enableAllPlugins() {
+ enableES5();
+ enableMapSet();
+ enablePatches();
+ }
+
+ var immer$1 =
+ /*#__PURE__*/
+ new Immer();
+ /**
+ * The `produce` function takes a value and a "recipe function" (whose
+ * return value often depends on the base state). The recipe function is
+ * free to mutate its first argument however it wants. All mutations are
+ * only ever applied to a __copy__ of the base state.
+ *
+ * Pass only a function to create a "curried producer" which relieves you
+ * from passing the recipe function every time.
+ *
+ * Only plain objects and arrays are made mutable. All other objects are
+ * considered uncopyable.
+ *
+ * Note: This function is __bound__ to its `Immer` instance.
+ *
+ * @param {any} base - the initial state
+ * @param {Function} producer - function that receives a proxy of the base state as first argument and which can be freely modified
+ * @param {Function} patchListener - optional function that will be called with all the patches produced here
+ * @returns {any} a new state, or the initial state if nothing was modified
+ */
+
+ var produce = immer$1.produce;
+ /**
+ * Like `produce`, but `produceWithPatches` always returns a tuple
+ * [nextState, patches, inversePatches] (instead of just the next state)
+ */
+
+ var produceWithPatches =
+ /*#__PURE__*/
+ immer$1.produceWithPatches.bind(immer$1);
+ /**
+ * Pass true to automatically freeze all copies created by Immer.
+ *
+ * Always freeze by default, even in production mode
+ */
+
+ var setAutoFreeze =
+ /*#__PURE__*/
+ immer$1.setAutoFreeze.bind(immer$1);
+ /**
+ * Pass true to use the ES2015 `Proxy` class when creating drafts, which is
+ * always faster than using ES5 proxies.
+ *
+ * By default, feature detection is used, so calling this is rarely necessary.
+ */
+
+ var setUseProxies =
+ /*#__PURE__*/
+ immer$1.setUseProxies.bind(immer$1);
+ /**
+ * Apply an array of Immer patches to the first argument.
+ *
+ * This function is a producer, which means copy-on-write is in effect.
+ */
+
+ var applyPatches =
+ /*#__PURE__*/
+ immer$1.applyPatches.bind(immer$1);
+ /**
+ * Create an Immer draft from the given base state, which may be a draft itself.
+ * The draft can be modified until you finalize it with the `finishDraft` function.
+ */
+
+ var createDraft =
+ /*#__PURE__*/
+ immer$1.createDraft.bind(immer$1);
+ /**
+ * Finalize an Immer draft from a `createDraft` call, returning the base state
+ * (if no changes were made) or a modified copy. The draft must *not* be
+ * mutated afterwards.
+ *
+ * Pass a function as the 2nd argument to generate Immer patches based on the
+ * changes that were made.
+ */
+
+ var finishDraft =
+ /*#__PURE__*/
+ immer$1.finishDraft.bind(immer$1);
+ /**
+ * This function is actually a no-op, but can be used to cast an immutable type
+ * to an draft type and make TypeScript happy
+ *
+ * @param value
+ */
+
+ function castDraft(value) {
+ return value;
+ }
+ /**
+ * This function is actually a no-op, but can be used to cast a mutable type
+ * to an immutable type and make TypeScript happy
+ * @param value
+ */
+
+ function castImmutable(value) {
+ return value;
+ }
+
+ var Immer_1 = Immer;
+ var applyPatches_1 = applyPatches;
+ var castDraft_1 = castDraft;
+ var castImmutable_1 = castImmutable;
+ var createDraft_1 = createDraft;
+ var current_1 = current;
+ var _default$2 = produce;
+ var enableAllPlugins_1 = enableAllPlugins;
+ var enableES5_1 = enableES5;
+ var enableMapSet_1 = enableMapSet;
+ var enablePatches_1 = enablePatches;
+ var finishDraft_1 = finishDraft;
+ var freeze_1 = freeze;
+ var immerable = DRAFTABLE;
+ var isDraft_1 = isDraft;
+ var isDraftable_1 = isDraftable;
+ var nothing = NOTHING;
+ var original_1 = original;
+ var produce_1 = produce;
+ var produceWithPatches_1 = produceWithPatches;
+ var setAutoFreeze_1 = setAutoFreeze;
+ var setUseProxies_1 = setUseProxies;
+
+
+ var immer_cjs_development = /*#__PURE__*/Object.defineProperty({
+ Immer: Immer_1,
+ applyPatches: applyPatches_1,
+ castDraft: castDraft_1,
+ castImmutable: castImmutable_1,
+ createDraft: createDraft_1,
+ current: current_1,
+ default: _default$2,
+ enableAllPlugins: enableAllPlugins_1,
+ enableES5: enableES5_1,
+ enableMapSet: enableMapSet_1,
+ enablePatches: enablePatches_1,
+ finishDraft: finishDraft_1,
+ freeze: freeze_1,
+ immerable: immerable,
+ isDraft: isDraft_1,
+ isDraftable: isDraftable_1,
+ nothing: nothing,
+ original: original_1,
+ produce: produce_1,
+ produceWithPatches: produceWithPatches_1,
+ setAutoFreeze: setAutoFreeze_1,
+ setUseProxies: setUseProxies_1
+ }, '__esModule', {value: true});
+
+ var require$$1$1 = immer_cjs_development;
+
+ var dist$8 = createCommonjsModule$1(function (module) {
+
+ {
+ module.exports = require$$1$1;
+ }
+ });
+
+ var isPlainObject = isPlainObject_1;
+
+ var immer = dist$8;
+
+ function unwrapExports (x) {
+ return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
+ }
+
+ function createCommonjsModule(fn, module) {
+ return module = { exports: {} }, fn(module, module.exports), module.exports;
+ }
+
+ var arrayLikeToArray = createCommonjsModule(function (module) {
+ 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;
+ }
+
+ module.exports = _arrayLikeToArray;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ unwrapExports(arrayLikeToArray);
+
+ var arrayWithoutHoles = createCommonjsModule(function (module) {
+ function _arrayWithoutHoles(arr) {
+ if (Array.isArray(arr)) return arrayLikeToArray(arr);
+ }
+
+ module.exports = _arrayWithoutHoles;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ unwrapExports(arrayWithoutHoles);
+
+ var iterableToArray = createCommonjsModule(function (module) {
+ function _iterableToArray(iter) {
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
+ }
+
+ module.exports = _iterableToArray;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ unwrapExports(iterableToArray);
+
+ var unsupportedIterableToArray = createCommonjsModule(function (module) {
+ 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);
+ }
+
+ module.exports = _unsupportedIterableToArray;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ unwrapExports(unsupportedIterableToArray);
+
+ var nonIterableSpread = createCommonjsModule(function (module) {
+ function _nonIterableSpread() {
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
+ }
+
+ module.exports = _nonIterableSpread;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ unwrapExports(nonIterableSpread);
+
+ var toConsumableArray = createCommonjsModule(function (module) {
+ function _toConsumableArray(arr) {
+ return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();
+ }
+
+ module.exports = _toConsumableArray;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ var _toConsumableArray = unwrapExports(toConsumableArray);
+
+ var arrayWithHoles = createCommonjsModule(function (module) {
+ function _arrayWithHoles(arr) {
+ if (Array.isArray(arr)) return arr;
+ }
+
+ module.exports = _arrayWithHoles;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ unwrapExports(arrayWithHoles);
+
+ var iterableToArrayLimit = createCommonjsModule(function (module) {
+ function _iterableToArrayLimit(arr, i) {
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
+
+ if (_i == null) return;
+ var _arr = [];
+ var _n = true;
+ var _d = false;
+
+ var _s, _e;
+
+ try {
+ for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {
+ _arr.push(_s.value);
+
+ if (i && _arr.length === i) break;
+ }
+ } catch (err) {
+ _d = true;
+ _e = err;
+ } finally {
+ try {
+ if (!_n && _i["return"] != null) _i["return"]();
+ } finally {
+ if (_d) throw _e;
+ }
+ }
+
+ return _arr;
+ }
+
+ module.exports = _iterableToArrayLimit;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ unwrapExports(iterableToArrayLimit);
+
+ var nonIterableRest = createCommonjsModule(function (module) {
+ function _nonIterableRest() {
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
+ }
+
+ module.exports = _nonIterableRest;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ unwrapExports(nonIterableRest);
+
+ var slicedToArray = createCommonjsModule(function (module) {
+ function _slicedToArray(arr, i) {
+ return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();
+ }
+
+ module.exports = _slicedToArray;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ var _slicedToArray = unwrapExports(slicedToArray);
+
+ var defineProperty = createCommonjsModule(function (module) {
+ function _defineProperty(obj, key, value) {
+ if (key in obj) {
+ Object.defineProperty(obj, key, {
+ value: value,
+ enumerable: true,
+ configurable: true,
+ writable: true
+ });
+ } else {
+ obj[key] = value;
+ }
+
+ return obj;
+ }
+
+ module.exports = _defineProperty;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ var _defineProperty = unwrapExports(defineProperty);
+
+ var DIRTY_PATHS = new WeakMap();
+ var FLUSHING = new WeakMap();
+ var NORMALIZING = new WeakMap();
+ var PATH_REFS = new WeakMap();
+ var POINT_REFS = new WeakMap();
+ var RANGE_REFS = new WeakMap();
+
+ function ownKeys$9(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread$9(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$9(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$9(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+
+ function _createForOfIteratorHelper$7(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray$7(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; } } }; }
+
+ function _unsupportedIterableToArray$7(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray$7(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$7(o, minLen); }
+
+ function _arrayLikeToArray$7(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; }
+ /**
+ * Create a new Slate `Editor` object.
+ */
+
+ var createEditor$1 = function createEditor() {
+ var editor = {
+ children: [],
+ operations: [],
+ selection: null,
+ marks: null,
+ isInline: function isInline() {
+ return false;
+ },
+ isVoid: function isVoid() {
+ return false;
+ },
+ onChange: function onChange() {},
+ apply: function apply(op) {
+ var _iterator = _createForOfIteratorHelper$7(Editor.pathRefs(editor)),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var ref = _step.value;
+ PathRef.transform(ref, op);
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+
+ var _iterator2 = _createForOfIteratorHelper$7(Editor.pointRefs(editor)),
+ _step2;
+
+ try {
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
+ var _ref = _step2.value;
+ PointRef.transform(_ref, op);
+ }
+ } catch (err) {
+ _iterator2.e(err);
+ } finally {
+ _iterator2.f();
+ }
+
+ var _iterator3 = _createForOfIteratorHelper$7(Editor.rangeRefs(editor)),
+ _step3;
+
+ try {
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
+ var _ref2 = _step3.value;
+ RangeRef.transform(_ref2, op);
+ }
+ } catch (err) {
+ _iterator3.e(err);
+ } finally {
+ _iterator3.f();
+ }
+
+ var set = new Set();
+ var dirtyPaths = [];
+
+ var add = function add(path) {
+ if (path) {
+ var key = path.join(',');
+
+ if (!set.has(key)) {
+ set.add(key);
+ dirtyPaths.push(path);
+ }
+ }
+ };
+
+ var oldDirtyPaths = DIRTY_PATHS.get(editor) || [];
+ var newDirtyPaths = getDirtyPaths(op);
+
+ var _iterator4 = _createForOfIteratorHelper$7(oldDirtyPaths),
+ _step4;
+
+ try {
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
+ var path = _step4.value;
+ var newPath = Path.transform(path, op);
+ add(newPath);
+ }
+ } catch (err) {
+ _iterator4.e(err);
+ } finally {
+ _iterator4.f();
+ }
+
+ var _iterator5 = _createForOfIteratorHelper$7(newDirtyPaths),
+ _step5;
+
+ try {
+ for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
+ var _path = _step5.value;
+ add(_path);
+ }
+ } catch (err) {
+ _iterator5.e(err);
+ } finally {
+ _iterator5.f();
+ }
+
+ DIRTY_PATHS.set(editor, dirtyPaths);
+ Transforms.transform(editor, op);
+ editor.operations.push(op);
+ Editor.normalize(editor); // Clear any formats applied to the cursor if the selection changes.
+
+ if (op.type === 'set_selection') {
+ editor.marks = null;
+ }
+
+ if (!FLUSHING.get(editor)) {
+ FLUSHING.set(editor, true);
+ Promise.resolve().then(function () {
+ FLUSHING.set(editor, false);
+ editor.onChange();
+ editor.operations = [];
+ });
+ }
+ },
+ addMark: function addMark(key, value) {
+ var selection = editor.selection;
+
+ if (selection) {
+ if (Range.isExpanded(selection)) {
+ Transforms.setNodes(editor, _defineProperty({}, key, value), {
+ match: Text.isText,
+ split: true
+ });
+ } else {
+ var marks = _objectSpread$9(_objectSpread$9({}, Editor.marks(editor) || {}), {}, _defineProperty({}, key, value));
+
+ editor.marks = marks;
+
+ if (!FLUSHING.get(editor)) {
+ editor.onChange();
+ }
+ }
+ }
+ },
+ deleteBackward: function deleteBackward(unit) {
+ var selection = editor.selection;
+
+ if (selection && Range.isCollapsed(selection)) {
+ Transforms["delete"](editor, {
+ unit: unit,
+ reverse: true
+ });
+ }
+ },
+ deleteForward: function deleteForward(unit) {
+ var selection = editor.selection;
+
+ if (selection && Range.isCollapsed(selection)) {
+ Transforms["delete"](editor, {
+ unit: unit
+ });
+ }
+ },
+ deleteFragment: function deleteFragment(direction) {
+ var selection = editor.selection;
+
+ if (selection && Range.isExpanded(selection)) {
+ Transforms["delete"](editor, {
+ reverse: direction === 'backward'
+ });
+ }
+ },
+ getFragment: function getFragment() {
+ var selection = editor.selection;
+
+ if (selection) {
+ return Node$1.fragment(editor, selection);
+ }
+
+ return [];
+ },
+ insertBreak: function insertBreak() {
+ Transforms.splitNodes(editor, {
+ always: true
+ });
+ },
+ insertFragment: function insertFragment(fragment) {
+ Transforms.insertFragment(editor, fragment);
+ },
+ insertNode: function insertNode(node) {
+ Transforms.insertNodes(editor, node);
+ },
+ insertText: function insertText(text) {
+ var selection = editor.selection,
+ marks = editor.marks;
+
+ if (selection) {
+ if (marks) {
+ var node = _objectSpread$9({
+ text: text
+ }, marks);
+
+ Transforms.insertNodes(editor, node);
+ } else {
+ Transforms.insertText(editor, text);
+ }
+
+ editor.marks = null;
+ }
+ },
+ normalizeNode: function normalizeNode(entry) {
+ var _entry = _slicedToArray(entry, 2),
+ node = _entry[0],
+ path = _entry[1]; // There are no core normalizations for text nodes.
+
+
+ if (Text.isText(node)) {
+ return;
+ } // Ensure that block and inline nodes have at least one text child.
+
+
+ if (Element$1.isElement(node) && node.children.length === 0) {
+ var child = {
+ text: ''
+ };
+ Transforms.insertNodes(editor, child, {
+ at: path.concat(0),
+ voids: true
+ });
+ return;
+ } // Determine whether the node should have block or inline children.
+
+
+ var shouldHaveInlines = Editor.isEditor(node) ? false : Element$1.isElement(node) && (editor.isInline(node) || node.children.length === 0 || Text.isText(node.children[0]) || editor.isInline(node.children[0])); // Since we'll be applying operations while iterating, keep track of an
+ // index that accounts for any added/removed nodes.
+
+ var n = 0;
+
+ for (var i = 0; i < node.children.length; i++, n++) {
+ var currentNode = Node$1.get(editor, path);
+ if (Text.isText(currentNode)) continue;
+ var _child = node.children[i];
+ var prev = currentNode.children[n - 1];
+ var isLast = i === node.children.length - 1;
+ var isInlineOrText = Text.isText(_child) || Element$1.isElement(_child) && editor.isInline(_child); // Only allow block nodes in the top-level children and parent blocks
+ // that only contain block nodes. Similarly, only allow inline nodes in
+ // other inline nodes, or parent blocks that only contain inlines and
+ // text.
+
+ if (isInlineOrText !== shouldHaveInlines) {
+ Transforms.removeNodes(editor, {
+ at: path.concat(n),
+ voids: true
+ });
+ n--;
+ } else if (Element$1.isElement(_child)) {
+ // Ensure that inline nodes are surrounded by text nodes.
+ if (editor.isInline(_child)) {
+ if (prev == null || !Text.isText(prev)) {
+ var newChild = {
+ text: ''
+ };
+ Transforms.insertNodes(editor, newChild, {
+ at: path.concat(n),
+ voids: true
+ });
+ n++;
+ } else if (isLast) {
+ var _newChild = {
+ text: ''
+ };
+ Transforms.insertNodes(editor, _newChild, {
+ at: path.concat(n + 1),
+ voids: true
+ });
+ n++;
+ }
+ }
+ } else {
+ // Merge adjacent text nodes that are empty or match.
+ if (prev != null && Text.isText(prev)) {
+ if (Text.equals(_child, prev, {
+ loose: true
+ })) {
+ Transforms.mergeNodes(editor, {
+ at: path.concat(n),
+ voids: true
+ });
+ n--;
+ } else if (prev.text === '') {
+ Transforms.removeNodes(editor, {
+ at: path.concat(n - 1),
+ voids: true
+ });
+ n--;
+ } else if (_child.text === '') {
+ Transforms.removeNodes(editor, {
+ at: path.concat(n),
+ voids: true
+ });
+ n--;
+ }
+ }
+ }
+ }
+ },
+ removeMark: function removeMark(key) {
+ var selection = editor.selection;
+
+ if (selection) {
+ if (Range.isExpanded(selection)) {
+ Transforms.unsetNodes(editor, key, {
+ match: Text.isText,
+ split: true
+ });
+ } else {
+ var marks = _objectSpread$9({}, Editor.marks(editor) || {});
+
+ delete marks[key];
+ editor.marks = marks;
+
+ if (!FLUSHING.get(editor)) {
+ editor.onChange();
+ }
+ }
+ }
+ }
+ };
+ return editor;
+ };
+ /**
+ * Get the "dirty" paths generated from an operation.
+ */
+
+ var getDirtyPaths = function getDirtyPaths(op) {
+ switch (op.type) {
+ case 'insert_text':
+ case 'remove_text':
+ case 'set_node':
+ {
+ var path = op.path;
+ return Path.levels(path);
+ }
+
+ case 'insert_node':
+ {
+ var node = op.node,
+ _path2 = op.path;
+ var levels = Path.levels(_path2);
+ var descendants = Text.isText(node) ? [] : Array.from(Node$1.nodes(node), function (_ref3) {
+ var _ref4 = _slicedToArray(_ref3, 2),
+ p = _ref4[1];
+
+ return _path2.concat(p);
+ });
+ return [].concat(_toConsumableArray(levels), _toConsumableArray(descendants));
+ }
+
+ case 'merge_node':
+ {
+ var _path3 = op.path;
+ var ancestors = Path.ancestors(_path3);
+ var previousPath = Path.previous(_path3);
+ return [].concat(_toConsumableArray(ancestors), [previousPath]);
+ }
+
+ case 'move_node':
+ {
+ var _path4 = op.path,
+ newPath = op.newPath;
+
+ if (Path.equals(_path4, newPath)) {
+ return [];
+ }
+
+ var oldAncestors = [];
+ var newAncestors = [];
+
+ var _iterator6 = _createForOfIteratorHelper$7(Path.ancestors(_path4)),
+ _step6;
+
+ try {
+ for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) {
+ var ancestor = _step6.value;
+ var p = Path.transform(ancestor, op);
+ oldAncestors.push(p);
+ }
+ } catch (err) {
+ _iterator6.e(err);
+ } finally {
+ _iterator6.f();
+ }
+
+ var _iterator7 = _createForOfIteratorHelper$7(Path.ancestors(newPath)),
+ _step7;
+
+ try {
+ for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) {
+ var _ancestor = _step7.value;
+
+ var _p = Path.transform(_ancestor, op);
+
+ newAncestors.push(_p);
+ }
+ } catch (err) {
+ _iterator7.e(err);
+ } finally {
+ _iterator7.f();
+ }
+
+ var newParent = newAncestors[newAncestors.length - 1];
+ var newIndex = newPath[newPath.length - 1];
+ var resultPath = newParent.concat(newIndex);
+ return [].concat(oldAncestors, newAncestors, [resultPath]);
+ }
+
+ case 'remove_node':
+ {
+ var _path5 = op.path;
+
+ var _ancestors = Path.ancestors(_path5);
+
+ return _toConsumableArray(_ancestors);
+ }
+
+ case 'split_node':
+ {
+ var _path6 = op.path;
+
+ var _levels = Path.levels(_path6);
+
+ var nextPath = Path.next(_path6);
+ return [].concat(_toConsumableArray(_levels), [nextPath]);
+ }
+
+ default:
+ {
+ return [];
+ }
+ }
+ };
+
+ var objectWithoutPropertiesLoose = createCommonjsModule(function (module) {
+ function _objectWithoutPropertiesLoose(source, excluded) {
+ if (source == null) return {};
+ var target = {};
+ var sourceKeys = Object.keys(source);
+ var key, i;
+
+ for (i = 0; i < sourceKeys.length; i++) {
+ key = sourceKeys[i];
+ if (excluded.indexOf(key) >= 0) continue;
+ target[key] = source[key];
+ }
+
+ return target;
+ }
+
+ module.exports = _objectWithoutPropertiesLoose;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ unwrapExports(objectWithoutPropertiesLoose);
+
+ var objectWithoutProperties = createCommonjsModule(function (module) {
+ function _objectWithoutProperties(source, excluded) {
+ if (source == null) return {};
+ var target = objectWithoutPropertiesLoose(source, excluded);
+ var key, i;
+
+ if (Object.getOwnPropertySymbols) {
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
+
+ for (i = 0; i < sourceSymbolKeys.length; i++) {
+ key = sourceSymbolKeys[i];
+ if (excluded.indexOf(key) >= 0) continue;
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
+ target[key] = source[key];
+ }
+ }
+
+ return target;
+ }
+
+ module.exports = _objectWithoutProperties;
+ module.exports["default"] = module.exports, module.exports.__esModule = true;
+ });
+
+ var _objectWithoutProperties = unwrapExports(objectWithoutProperties);
+
+ function _createForOfIteratorHelper$6(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray$6(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; } } }; }
+
+ function _unsupportedIterableToArray$6(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray$6(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$6(o, minLen); }
+
+ function _arrayLikeToArray$6(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; }
+
+ // Character (grapheme cluster) boundaries are determined according to
+ // the default grapheme cluster boundary specification, extended grapheme clusters variant[1].
+ //
+ // References:
+ //
+ // [1] https://www.unicode.org/reports/tr29/#Default_Grapheme_Cluster_Table
+ // [2] https://www.unicode.org/Public/UCD/latest/ucd/auxiliary/GraphemeBreakProperty.txt
+ // [3] https://www.unicode.org/Public/UCD/latest/ucd/auxiliary/GraphemeBreakTest.html
+ // [4] https://www.unicode.org/Public/UCD/latest/ucd/auxiliary/GraphemeBreakTest.txt
+
+ /**
+ * Get the distance to the end of the first character in a string of text.
+ */
+ var getCharacterDistance = function getCharacterDistance(str) {
+ var isRTL = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
+ var isLTR = !isRTL;
+ var codepoints = isRTL ? codepointsIteratorRTL(str) : str;
+ var left = CodepointType.None;
+ var right = CodepointType.None;
+ var distance = 0; // Evaluation of these conditions are deferred.
+
+ var gb11 = null; // Is GB11 applicable?
+
+ var gb12Or13 = null; // Is GB12 or GB13 applicable?
+
+ var _iterator = _createForOfIteratorHelper$6(codepoints),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var _char = _step.value;
+
+ var code = _char.codePointAt(0);
+
+ if (!code) break;
+ var type = getCodepointType(_char, code);
+
+ var _ref = isLTR ? [right, type] : [type, left];
+
+ var _ref2 = _slicedToArray(_ref, 2);
+
+ left = _ref2[0];
+ right = _ref2[1];
+
+ if (intersects(left, CodepointType.ZWJ) && intersects(right, CodepointType.ExtPict)) {
+ if (isLTR) {
+ gb11 = endsWithEmojiZWJ(str.substring(0, distance));
+ } else {
+ gb11 = endsWithEmojiZWJ(str.substring(0, str.length - distance));
+ }
+
+ if (!gb11) break;
+ }
+
+ if (intersects(left, CodepointType.RI) && intersects(right, CodepointType.RI)) {
+ if (gb12Or13 !== null) {
+ gb12Or13 = !gb12Or13;
+ } else {
+ if (isLTR) {
+ gb12Or13 = true;
+ } else {
+ gb12Or13 = endsWithOddNumberOfRIs(str.substring(0, str.length - distance));
+ }
+ }
+
+ if (!gb12Or13) break;
+ }
+
+ if (left !== CodepointType.None && right !== CodepointType.None && isBoundaryPair(left, right)) {
+ break;
+ }
+
+ distance += _char.length;
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+
+ return distance || 1;
+ };
+ var SPACE = /\s/;
+ var PUNCTUATION = /[\u0021-\u0023\u0025-\u002A\u002C-\u002F\u003A\u003B\u003F\u0040\u005B-\u005D\u005F\u007B\u007D\u00A1\u00A7\u00AB\u00B6\u00B7\u00BB\u00BF\u037E\u0387\u055A-\u055F\u0589\u058A\u05BE\u05C0\u05C3\u05C6\u05F3\u05F4\u0609\u060A\u060C\u060D\u061B\u061E\u061F\u066A-\u066D\u06D4\u0700-\u070D\u07F7-\u07F9\u0830-\u083E\u085E\u0964\u0965\u0970\u0AF0\u0DF4\u0E4F\u0E5A\u0E5B\u0F04-\u0F12\u0F14\u0F3A-\u0F3D\u0F85\u0FD0-\u0FD4\u0FD9\u0FDA\u104A-\u104F\u10FB\u1360-\u1368\u1400\u166D\u166E\u169B\u169C\u16EB-\u16ED\u1735\u1736\u17D4-\u17D6\u17D8-\u17DA\u1800-\u180A\u1944\u1945\u1A1E\u1A1F\u1AA0-\u1AA6\u1AA8-\u1AAD\u1B5A-\u1B60\u1BFC-\u1BFF\u1C3B-\u1C3F\u1C7E\u1C7F\u1CC0-\u1CC7\u1CD3\u2010-\u2027\u2030-\u2043\u2045-\u2051\u2053-\u205E\u207D\u207E\u208D\u208E\u2329\u232A\u2768-\u2775\u27C5\u27C6\u27E6-\u27EF\u2983-\u2998\u29D8-\u29DB\u29FC\u29FD\u2CF9-\u2CFC\u2CFE\u2CFF\u2D70\u2E00-\u2E2E\u2E30-\u2E3B\u3001-\u3003\u3008-\u3011\u3014-\u301F\u3030\u303D\u30A0\u30FB\uA4FE\uA4FF\uA60D-\uA60F\uA673\uA67E\uA6F2-\uA6F7\uA874-\uA877\uA8CE\uA8CF\uA8F8-\uA8FA\uA92E\uA92F\uA95F\uA9C1-\uA9CD\uA9DE\uA9DF\uAA5C-\uAA5F\uAADE\uAADF\uAAF0\uAAF1\uABEB\uFD3E\uFD3F\uFE10-\uFE19\uFE30-\uFE52\uFE54-\uFE61\uFE63\uFE68\uFE6A\uFE6B\uFF01-\uFF03\uFF05-\uFF0A\uFF0C-\uFF0F\uFF1A\uFF1B\uFF1F\uFF20\uFF3B-\uFF3D\uFF3F\uFF5B\uFF5D\uFF5F-\uFF65]/;
+ var CHAMELEON = /['\u2018\u2019]/;
+ /**
+ * Get the distance to the end of the first word in a string of text.
+ */
+
+ var getWordDistance = function getWordDistance(text) {
+ var isRTL = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
+ var dist = 0;
+ var started = false;
+
+ while (text.length > 0) {
+ var charDist = getCharacterDistance(text, isRTL);
+
+ var _splitByCharacterDist = splitByCharacterDistance(text, charDist, isRTL),
+ _splitByCharacterDist2 = _slicedToArray(_splitByCharacterDist, 2),
+ _char2 = _splitByCharacterDist2[0],
+ remaining = _splitByCharacterDist2[1];
+
+ if (isWordCharacter(_char2, remaining, isRTL)) {
+ started = true;
+ dist += charDist;
+ } else if (!started) {
+ dist += charDist;
+ } else {
+ break;
+ }
+
+ text = remaining;
+ }
+
+ return dist;
+ };
+ /**
+ * Split a string in two parts at a given distance starting from the end when
+ * `isRTL` is set to `true`.
+ */
+
+ var splitByCharacterDistance = function splitByCharacterDistance(str, dist, isRTL) {
+ if (isRTL) {
+ var at = str.length - dist;
+ return [str.slice(at, str.length), str.slice(0, at)];
+ }
+
+ return [str.slice(0, dist), str.slice(dist)];
+ };
+ /**
+ * Check if a character is a word character. The `remaining` argument is used
+ * because sometimes you must read subsequent characters to truly determine it.
+ */
+
+ var isWordCharacter = function isWordCharacter(_char3, remaining) {
+ var isRTL = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
+
+ if (SPACE.test(_char3)) {
+ return false;
+ } // Chameleons count as word characters as long as they're in a word, so
+ // recurse to see if the next one is a word character or not.
+
+
+ if (CHAMELEON.test(_char3)) {
+ var charDist = getCharacterDistance(remaining, isRTL);
+
+ var _splitByCharacterDist3 = splitByCharacterDistance(remaining, charDist, isRTL),
+ _splitByCharacterDist4 = _slicedToArray(_splitByCharacterDist3, 2),
+ nextChar = _splitByCharacterDist4[0],
+ nextRemaining = _splitByCharacterDist4[1];
+
+ if (isWordCharacter(nextChar, nextRemaining, isRTL)) {
+ return true;
+ }
+ }
+
+ if (PUNCTUATION.test(_char3)) {
+ return false;
+ }
+
+ return true;
+ };
+ /**
+ * Iterate on codepoints from right to left.
+ */
+
+
+ var codepointsIteratorRTL = function* codepointsIteratorRTL(str) {
+ var end = str.length - 1;
+
+ for (var i = 0; i < str.length; i++) {
+ var char1 = str.charAt(end - i);
+
+ if (isLowSurrogate(char1.charCodeAt(0))) {
+ var char2 = str.charAt(end - i - 1);
+
+ if (isHighSurrogate(char2.charCodeAt(0))) {
+ yield char2 + char1;
+ i++;
+ continue;
+ }
+ }
+
+ yield char1;
+ }
+ };
+ /**
+ * Is `charCode` a high surrogate.
+ *
+ * https://en.wikipedia.org/wiki/Universal_Character_Set_characters#Surrogates
+ */
+
+ var isHighSurrogate = function isHighSurrogate(charCode) {
+ return charCode >= 0xd800 && charCode <= 0xdbff;
+ };
+ /**
+ * Is `charCode` a low surrogate.
+ *
+ * https://en.wikipedia.org/wiki/Universal_Character_Set_characters#Surrogates
+ */
+
+
+ var isLowSurrogate = function isLowSurrogate(charCode) {
+ return charCode >= 0xdc00 && charCode <= 0xdfff;
+ };
+
+ var CodepointType;
+
+ (function (CodepointType) {
+ CodepointType[CodepointType["None"] = 0] = "None";
+ CodepointType[CodepointType["Extend"] = 1] = "Extend";
+ CodepointType[CodepointType["ZWJ"] = 2] = "ZWJ";
+ CodepointType[CodepointType["RI"] = 4] = "RI";
+ CodepointType[CodepointType["Prepend"] = 8] = "Prepend";
+ CodepointType[CodepointType["SpacingMark"] = 16] = "SpacingMark";
+ CodepointType[CodepointType["L"] = 32] = "L";
+ CodepointType[CodepointType["V"] = 64] = "V";
+ CodepointType[CodepointType["T"] = 128] = "T";
+ CodepointType[CodepointType["LV"] = 256] = "LV";
+ CodepointType[CodepointType["LVT"] = 512] = "LVT";
+ CodepointType[CodepointType["ExtPict"] = 1024] = "ExtPict";
+ CodepointType[CodepointType["Any"] = 2048] = "Any";
+ })(CodepointType || (CodepointType = {}));
+
+ var reExtend = /^(?:[\u0300-\u036F\u0483-\u0489\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u065F\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u0711\u0730-\u074A\u07A6-\u07B0\u07EB-\u07F3\u07FD\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u08D3-\u08E1\u08E3-\u0902\u093A\u093C\u0941-\u0948\u094D\u0951-\u0957\u0962\u0963\u0981\u09BC\u09BE\u09C1-\u09C4\u09CD\u09D7\u09E2\u09E3\u09FE\u0A01\u0A02\u0A3C\u0A41\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A70\u0A71\u0A75\u0A81\u0A82\u0ABC\u0AC1-\u0AC5\u0AC7\u0AC8\u0ACD\u0AE2\u0AE3\u0AFA-\u0AFF\u0B01\u0B3C\u0B3E\u0B3F\u0B41-\u0B44\u0B4D\u0B55-\u0B57\u0B62\u0B63\u0B82\u0BBE\u0BC0\u0BCD\u0BD7\u0C00\u0C04\u0C3E-\u0C40\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C81\u0CBC\u0CBF\u0CC2\u0CC6\u0CCC\u0CCD\u0CD5\u0CD6\u0CE2\u0CE3\u0D00\u0D01\u0D3B\u0D3C\u0D3E\u0D41-\u0D44\u0D4D\u0D57\u0D62\u0D63\u0D81\u0DCA\u0DCF\u0DD2-\u0DD4\u0DD6\u0DDF\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0EB1\u0EB4-\u0EBC\u0EC8-\u0ECD\u0F18\u0F19\u0F35\u0F37\u0F39\u0F71-\u0F7E\u0F80-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102D-\u1030\u1032-\u1037\u1039\u103A\u103D\u103E\u1058\u1059\u105E-\u1060\u1071-\u1074\u1082\u1085\u1086\u108D\u109D\u135D-\u135F\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4\u17B5\u17B7-\u17BD\u17C6\u17C9-\u17D3\u17DD\u180B-\u180D\u1885\u1886\u18A9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193B\u1A17\u1A18\u1A1B\u1A56\u1A58-\u1A5E\u1A60\u1A62\u1A65-\u1A6C\u1A73-\u1A7C\u1A7F\u1AB0-\u1AC0\u1B00-\u1B03\u1B34-\u1B3A\u1B3C\u1B42\u1B6B-\u1B73\u1B80\u1B81\u1BA2-\u1BA5\u1BA8\u1BA9\u1BAB-\u1BAD\u1BE6\u1BE8\u1BE9\u1BED\u1BEF-\u1BF1\u1C2C-\u1C33\u1C36\u1C37\u1CD0-\u1CD2\u1CD4-\u1CE0\u1CE2-\u1CE8\u1CED\u1CF4\u1CF8\u1CF9\u1DC0-\u1DF9\u1DFB-\u1DFF\u200C\u20D0-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302F\u3099\u309A\uA66F-\uA672\uA674-\uA67D\uA69E\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA825\uA826\uA82C\uA8C4\uA8C5\uA8E0-\uA8F1\uA8FF\uA926-\uA92D\uA947-\uA951\uA980-\uA982\uA9B3\uA9B6-\uA9B9\uA9BC\uA9BD\uA9E5\uAA29-\uAA2E\uAA31\uAA32\uAA35\uAA36\uAA43\uAA4C\uAA7C\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEC\uAAED\uAAF6\uABE5\uABE8\uABED\uFB1E\uFE00-\uFE0F\uFE20-\uFE2F\uFF9E\uFF9F]|\uD800[\uDDFD\uDEE0\uDF76-\uDF7A]|\uD802[\uDE01-\uDE03\uDE05\uDE06\uDE0C-\uDE0F\uDE38-\uDE3A\uDE3F\uDEE5\uDEE6]|\uD803[\uDD24-\uDD27\uDEAB\uDEAC\uDF46-\uDF50]|\uD804[\uDC01\uDC38-\uDC46\uDC7F-\uDC81\uDCB3-\uDCB6\uDCB9\uDCBA\uDD00-\uDD02\uDD27-\uDD2B\uDD2D-\uDD34\uDD73\uDD80\uDD81\uDDB6-\uDDBE\uDDC9-\uDDCC\uDDCF\uDE2F-\uDE31\uDE34\uDE36\uDE37\uDE3E\uDEDF\uDEE3-\uDEEA\uDF00\uDF01\uDF3B\uDF3C\uDF3E\uDF40\uDF57\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC38-\uDC3F\uDC42-\uDC44\uDC46\uDC5E\uDCB0\uDCB3-\uDCB8\uDCBA\uDCBD\uDCBF\uDCC0\uDCC2\uDCC3\uDDAF\uDDB2-\uDDB5\uDDBC\uDDBD\uDDBF\uDDC0\uDDDC\uDDDD\uDE33-\uDE3A\uDE3D\uDE3F\uDE40\uDEAB\uDEAD\uDEB0-\uDEB5\uDEB7\uDF1D-\uDF1F\uDF22-\uDF25\uDF27-\uDF2B]|\uD806[\uDC2F-\uDC37\uDC39\uDC3A\uDD30\uDD3B\uDD3C\uDD3E\uDD43\uDDD4-\uDDD7\uDDDA\uDDDB\uDDE0\uDE01-\uDE0A\uDE33-\uDE38\uDE3B-\uDE3E\uDE47\uDE51-\uDE56\uDE59-\uDE5B\uDE8A-\uDE96\uDE98\uDE99]|\uD807[\uDC30-\uDC36\uDC38-\uDC3D\uDC3F\uDC92-\uDCA7\uDCAA-\uDCB0\uDCB2\uDCB3\uDCB5\uDCB6\uDD31-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD45\uDD47\uDD90\uDD91\uDD95\uDD97\uDEF3\uDEF4]|\uD81A[\uDEF0-\uDEF4\uDF30-\uDF36]|\uD81B[\uDF4F\uDF8F-\uDF92\uDFE4]|\uD82F[\uDC9D\uDC9E]|\uD834[\uDD65\uDD67-\uDD69\uDD6E-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A\uDD30-\uDD36\uDEEC-\uDEEF]|\uD83A[\uDCD0-\uDCD6\uDD44-\uDD4A]|\uD83C[\uDFFB-\uDFFF]|\uDB40[\uDC20-\uDC7F\uDD00-\uDDEF])$/;
+ var rePrepend = /^(?:[\u0600-\u0605\u06DD\u070F\u0890\u0891\u08E2\u0D4E]|\uD804[\uDCBD\uDCCD\uDDC2\uDDC3]|\uD806[\uDD3F\uDD41\uDE3A\uDE84-\uDE89]|\uD807\uDD46)$/;
+ var reSpacingMark = /^(?:[\u0903\u093B\u093E-\u0940\u0949-\u094C\u094E\u094F\u0982\u0983\u09BF\u09C0\u09C7\u09C8\u09CB\u09CC\u0A03\u0A3E-\u0A40\u0A83\u0ABE-\u0AC0\u0AC9\u0ACB\u0ACC\u0B02\u0B03\u0B40\u0B47\u0B48\u0B4B\u0B4C\u0BBF\u0BC1\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCC\u0C01-\u0C03\u0C41-\u0C44\u0C82\u0C83\u0CBE\u0CC0\u0CC1\u0CC3\u0CC4\u0CC7\u0CC8\u0CCA\u0CCB\u0D02\u0D03\u0D3F\u0D40\u0D46-\u0D48\u0D4A-\u0D4C\u0D82\u0D83\u0DD0\u0DD1\u0DD8-\u0DDE\u0DF2\u0DF3\u0E33\u0EB3\u0F3E\u0F3F\u0F7F\u1031\u103B\u103C\u1056\u1057\u1084\u1715\u1734\u17B6\u17BE-\u17C5\u17C7\u17C8\u1923-\u1926\u1929-\u192B\u1930\u1931\u1933-\u1938\u1A19\u1A1A\u1A55\u1A57\u1A6D-\u1A72\u1B04\u1B3B\u1B3D-\u1B41\u1B43\u1B44\u1B82\u1BA1\u1BA6\u1BA7\u1BAA\u1BE7\u1BEA-\u1BEC\u1BEE\u1BF2\u1BF3\u1C24-\u1C2B\u1C34\u1C35\u1CE1\u1CF7\uA823\uA824\uA827\uA880\uA881\uA8B4-\uA8C3\uA952\uA953\uA983\uA9B4\uA9B5\uA9BA\uA9BB\uA9BE-\uA9C0\uAA2F\uAA30\uAA33\uAA34\uAA4D\uAAEB\uAAEE\uAAEF\uAAF5\uABE3\uABE4\uABE6\uABE7\uABE9\uABEA\uABEC]|\uD804[\uDC00\uDC02\uDC82\uDCB0-\uDCB2\uDCB7\uDCB8\uDD2C\uDD45\uDD46\uDD82\uDDB3-\uDDB5\uDDBF\uDDC0\uDDCE\uDE2C-\uDE2E\uDE32\uDE33\uDE35\uDEE0-\uDEE2\uDF02\uDF03\uDF3F\uDF41-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF62\uDF63]|\uD805[\uDC35-\uDC37\uDC40\uDC41\uDC45\uDCB1\uDCB2\uDCB9\uDCBB\uDCBC\uDCBE\uDCC1\uDDB0\uDDB1\uDDB8-\uDDBB\uDDBE\uDE30-\uDE32\uDE3B\uDE3C\uDE3E\uDEAC\uDEAE\uDEAF\uDEB6\uDF26]|\uD806[\uDC2C-\uDC2E\uDC38\uDD31-\uDD35\uDD37\uDD38\uDD3D\uDD40\uDD42\uDDD1-\uDDD3\uDDDC-\uDDDF\uDDE4\uDE39\uDE57\uDE58\uDE97]|\uD807[\uDC2F\uDC3E\uDCA9\uDCB1\uDCB4\uDD8A-\uDD8E\uDD93\uDD94\uDD96\uDEF5\uDEF6]|\uD81B[\uDF51-\uDF87\uDFF0\uDFF1]|\uD834[\uDD66\uDD6D])$/;
+ var reL = /^[\u1100-\u115F\uA960-\uA97C]$/;
+ var reV = /^[\u1160-\u11A7\uD7B0-\uD7C6]$/;
+ var reT = /^[\u11A8-\u11FF\uD7CB-\uD7FB]$/;
+ var reLV = /^[\uAC00\uAC1C\uAC38\uAC54\uAC70\uAC8C\uACA8\uACC4\uACE0\uACFC\uAD18\uAD34\uAD50\uAD6C\uAD88\uADA4\uADC0\uADDC\uADF8\uAE14\uAE30\uAE4C\uAE68\uAE84\uAEA0\uAEBC\uAED8\uAEF4\uAF10\uAF2C\uAF48\uAF64\uAF80\uAF9C\uAFB8\uAFD4\uAFF0\uB00C\uB028\uB044\uB060\uB07C\uB098\uB0B4\uB0D0\uB0EC\uB108\uB124\uB140\uB15C\uB178\uB194\uB1B0\uB1CC\uB1E8\uB204\uB220\uB23C\uB258\uB274\uB290\uB2AC\uB2C8\uB2E4\uB300\uB31C\uB338\uB354\uB370\uB38C\uB3A8\uB3C4\uB3E0\uB3FC\uB418\uB434\uB450\uB46C\uB488\uB4A4\uB4C0\uB4DC\uB4F8\uB514\uB530\uB54C\uB568\uB584\uB5A0\uB5BC\uB5D8\uB5F4\uB610\uB62C\uB648\uB664\uB680\uB69C\uB6B8\uB6D4\uB6F0\uB70C\uB728\uB744\uB760\uB77C\uB798\uB7B4\uB7D0\uB7EC\uB808\uB824\uB840\uB85C\uB878\uB894\uB8B0\uB8CC\uB8E8\uB904\uB920\uB93C\uB958\uB974\uB990\uB9AC\uB9C8\uB9E4\uBA00\uBA1C\uBA38\uBA54\uBA70\uBA8C\uBAA8\uBAC4\uBAE0\uBAFC\uBB18\uBB34\uBB50\uBB6C\uBB88\uBBA4\uBBC0\uBBDC\uBBF8\uBC14\uBC30\uBC4C\uBC68\uBC84\uBCA0\uBCBC\uBCD8\uBCF4\uBD10\uBD2C\uBD48\uBD64\uBD80\uBD9C\uBDB8\uBDD4\uBDF0\uBE0C\uBE28\uBE44\uBE60\uBE7C\uBE98\uBEB4\uBED0\uBEEC\uBF08\uBF24\uBF40\uBF5C\uBF78\uBF94\uBFB0\uBFCC\uBFE8\uC004\uC020\uC03C\uC058\uC074\uC090\uC0AC\uC0C8\uC0E4\uC100\uC11C\uC138\uC154\uC170\uC18C\uC1A8\uC1C4\uC1E0\uC1FC\uC218\uC234\uC250\uC26C\uC288\uC2A4\uC2C0\uC2DC\uC2F8\uC314\uC330\uC34C\uC368\uC384\uC3A0\uC3BC\uC3D8\uC3F4\uC410\uC42C\uC448\uC464\uC480\uC49C\uC4B8\uC4D4\uC4F0\uC50C\uC528\uC544\uC560\uC57C\uC598\uC5B4\uC5D0\uC5EC\uC608\uC624\uC640\uC65C\uC678\uC694\uC6B0\uC6CC\uC6E8\uC704\uC720\uC73C\uC758\uC774\uC790\uC7AC\uC7C8\uC7E4\uC800\uC81C\uC838\uC854\uC870\uC88C\uC8A8\uC8C4\uC8E0\uC8FC\uC918\uC934\uC950\uC96C\uC988\uC9A4\uC9C0\uC9DC\uC9F8\uCA14\uCA30\uCA4C\uCA68\uCA84\uCAA0\uCABC\uCAD8\uCAF4\uCB10\uCB2C\uCB48\uCB64\uCB80\uCB9C\uCBB8\uCBD4\uCBF0\uCC0C\uCC28\uCC44\uCC60\uCC7C\uCC98\uCCB4\uCCD0\uCCEC\uCD08\uCD24\uCD40\uCD5C\uCD78\uCD94\uCDB0\uCDCC\uCDE8\uCE04\uCE20\uCE3C\uCE58\uCE74\uCE90\uCEAC\uCEC8\uCEE4\uCF00\uCF1C\uCF38\uCF54\uCF70\uCF8C\uCFA8\uCFC4\uCFE0\uCFFC\uD018\uD034\uD050\uD06C\uD088\uD0A4\uD0C0\uD0DC\uD0F8\uD114\uD130\uD14C\uD168\uD184\uD1A0\uD1BC\uD1D8\uD1F4\uD210\uD22C\uD248\uD264\uD280\uD29C\uD2B8\uD2D4\uD2F0\uD30C\uD328\uD344\uD360\uD37C\uD398\uD3B4\uD3D0\uD3EC\uD408\uD424\uD440\uD45C\uD478\uD494\uD4B0\uD4CC\uD4E8\uD504\uD520\uD53C\uD558\uD574\uD590\uD5AC\uD5C8\uD5E4\uD600\uD61C\uD638\uD654\uD670\uD68C\uD6A8\uD6C4\uD6E0\uD6FC\uD718\uD734\uD750\uD76C\uD788]$/;
+ var reLVT = /^[\uAC01-\uAC1B\uAC1D-\uAC37\uAC39-\uAC53\uAC55-\uAC6F\uAC71-\uAC8B\uAC8D-\uACA7\uACA9-\uACC3\uACC5-\uACDF\uACE1-\uACFB\uACFD-\uAD17\uAD19-\uAD33\uAD35-\uAD4F\uAD51-\uAD6B\uAD6D-\uAD87\uAD89-\uADA3\uADA5-\uADBF\uADC1-\uADDB\uADDD-\uADF7\uADF9-\uAE13\uAE15-\uAE2F\uAE31-\uAE4B\uAE4D-\uAE67\uAE69-\uAE83\uAE85-\uAE9F\uAEA1-\uAEBB\uAEBD-\uAED7\uAED9-\uAEF3\uAEF5-\uAF0F\uAF11-\uAF2B\uAF2D-\uAF47\uAF49-\uAF63\uAF65-\uAF7F\uAF81-\uAF9B\uAF9D-\uAFB7\uAFB9-\uAFD3\uAFD5-\uAFEF\uAFF1-\uB00B\uB00D-\uB027\uB029-\uB043\uB045-\uB05F\uB061-\uB07B\uB07D-\uB097\uB099-\uB0B3\uB0B5-\uB0CF\uB0D1-\uB0EB\uB0ED-\uB107\uB109-\uB123\uB125-\uB13F\uB141-\uB15B\uB15D-\uB177\uB179-\uB193\uB195-\uB1AF\uB1B1-\uB1CB\uB1CD-\uB1E7\uB1E9-\uB203\uB205-\uB21F\uB221-\uB23B\uB23D-\uB257\uB259-\uB273\uB275-\uB28F\uB291-\uB2AB\uB2AD-\uB2C7\uB2C9-\uB2E3\uB2E5-\uB2FF\uB301-\uB31B\uB31D-\uB337\uB339-\uB353\uB355-\uB36F\uB371-\uB38B\uB38D-\uB3A7\uB3A9-\uB3C3\uB3C5-\uB3DF\uB3E1-\uB3FB\uB3FD-\uB417\uB419-\uB433\uB435-\uB44F\uB451-\uB46B\uB46D-\uB487\uB489-\uB4A3\uB4A5-\uB4BF\uB4C1-\uB4DB\uB4DD-\uB4F7\uB4F9-\uB513\uB515-\uB52F\uB531-\uB54B\uB54D-\uB567\uB569-\uB583\uB585-\uB59F\uB5A1-\uB5BB\uB5BD-\uB5D7\uB5D9-\uB5F3\uB5F5-\uB60F\uB611-\uB62B\uB62D-\uB647\uB649-\uB663\uB665-\uB67F\uB681-\uB69B\uB69D-\uB6B7\uB6B9-\uB6D3\uB6D5-\uB6EF\uB6F1-\uB70B\uB70D-\uB727\uB729-\uB743\uB745-\uB75F\uB761-\uB77B\uB77D-\uB797\uB799-\uB7B3\uB7B5-\uB7CF\uB7D1-\uB7EB\uB7ED-\uB807\uB809-\uB823\uB825-\uB83F\uB841-\uB85B\uB85D-\uB877\uB879-\uB893\uB895-\uB8AF\uB8B1-\uB8CB\uB8CD-\uB8E7\uB8E9-\uB903\uB905-\uB91F\uB921-\uB93B\uB93D-\uB957\uB959-\uB973\uB975-\uB98F\uB991-\uB9AB\uB9AD-\uB9C7\uB9C9-\uB9E3\uB9E5-\uB9FF\uBA01-\uBA1B\uBA1D-\uBA37\uBA39-\uBA53\uBA55-\uBA6F\uBA71-\uBA8B\uBA8D-\uBAA7\uBAA9-\uBAC3\uBAC5-\uBADF\uBAE1-\uBAFB\uBAFD-\uBB17\uBB19-\uBB33\uBB35-\uBB4F\uBB51-\uBB6B\uBB6D-\uBB87\uBB89-\uBBA3\uBBA5-\uBBBF\uBBC1-\uBBDB\uBBDD-\uBBF7\uBBF9-\uBC13\uBC15-\uBC2F\uBC31-\uBC4B\uBC4D-\uBC67\uBC69-\uBC83\uBC85-\uBC9F\uBCA1-\uBCBB\uBCBD-\uBCD7\uBCD9-\uBCF3\uBCF5-\uBD0F\uBD11-\uBD2B\uBD2D-\uBD47\uBD49-\uBD63\uBD65-\uBD7F\uBD81-\uBD9B\uBD9D-\uBDB7\uBDB9-\uBDD3\uBDD5-\uBDEF\uBDF1-\uBE0B\uBE0D-\uBE27\uBE29-\uBE43\uBE45-\uBE5F\uBE61-\uBE7B\uBE7D-\uBE97\uBE99-\uBEB3\uBEB5-\uBECF\uBED1-\uBEEB\uBEED-\uBF07\uBF09-\uBF23\uBF25-\uBF3F\uBF41-\uBF5B\uBF5D-\uBF77\uBF79-\uBF93\uBF95-\uBFAF\uBFB1-\uBFCB\uBFCD-\uBFE7\uBFE9-\uC003\uC005-\uC01F\uC021-\uC03B\uC03D-\uC057\uC059-\uC073\uC075-\uC08F\uC091-\uC0AB\uC0AD-\uC0C7\uC0C9-\uC0E3\uC0E5-\uC0FF\uC101-\uC11B\uC11D-\uC137\uC139-\uC153\uC155-\uC16F\uC171-\uC18B\uC18D-\uC1A7\uC1A9-\uC1C3\uC1C5-\uC1DF\uC1E1-\uC1FB\uC1FD-\uC217\uC219-\uC233\uC235-\uC24F\uC251-\uC26B\uC26D-\uC287\uC289-\uC2A3\uC2A5-\uC2BF\uC2C1-\uC2DB\uC2DD-\uC2F7\uC2F9-\uC313\uC315-\uC32F\uC331-\uC34B\uC34D-\uC367\uC369-\uC383\uC385-\uC39F\uC3A1-\uC3BB\uC3BD-\uC3D7\uC3D9-\uC3F3\uC3F5-\uC40F\uC411-\uC42B\uC42D-\uC447\uC449-\uC463\uC465-\uC47F\uC481-\uC49B\uC49D-\uC4B7\uC4B9-\uC4D3\uC4D5-\uC4EF\uC4F1-\uC50B\uC50D-\uC527\uC529-\uC543\uC545-\uC55F\uC561-\uC57B\uC57D-\uC597\uC599-\uC5B3\uC5B5-\uC5CF\uC5D1-\uC5EB\uC5ED-\uC607\uC609-\uC623\uC625-\uC63F\uC641-\uC65B\uC65D-\uC677\uC679-\uC693\uC695-\uC6AF\uC6B1-\uC6CB\uC6CD-\uC6E7\uC6E9-\uC703\uC705-\uC71F\uC721-\uC73B\uC73D-\uC757\uC759-\uC773\uC775-\uC78F\uC791-\uC7AB\uC7AD-\uC7C7\uC7C9-\uC7E3\uC7E5-\uC7FF\uC801-\uC81B\uC81D-\uC837\uC839-\uC853\uC855-\uC86F\uC871-\uC88B\uC88D-\uC8A7\uC8A9-\uC8C3\uC8C5-\uC8DF\uC8E1-\uC8FB\uC8FD-\uC917\uC919-\uC933\uC935-\uC94F\uC951-\uC96B\uC96D-\uC987\uC989-\uC9A3\uC9A5-\uC9BF\uC9C1-\uC9DB\uC9DD-\uC9F7\uC9F9-\uCA13\uCA15-\uCA2F\uCA31-\uCA4B\uCA4D-\uCA67\uCA69-\uCA83\uCA85-\uCA9F\uCAA1-\uCABB\uCABD-\uCAD7\uCAD9-\uCAF3\uCAF5-\uCB0F\uCB11-\uCB2B\uCB2D-\uCB47\uCB49-\uCB63\uCB65-\uCB7F\uCB81-\uCB9B\uCB9D-\uCBB7\uCBB9-\uCBD3\uCBD5-\uCBEF\uCBF1-\uCC0B\uCC0D-\uCC27\uCC29-\uCC43\uCC45-\uCC5F\uCC61-\uCC7B\uCC7D-\uCC97\uCC99-\uCCB3\uCCB5-\uCCCF\uCCD1-\uCCEB\uCCED-\uCD07\uCD09-\uCD23\uCD25-\uCD3F\uCD41-\uCD5B\uCD5D-\uCD77\uCD79-\uCD93\uCD95-\uCDAF\uCDB1-\uCDCB\uCDCD-\uCDE7\uCDE9-\uCE03\uCE05-\uCE1F\uCE21-\uCE3B\uCE3D-\uCE57\uCE59-\uCE73\uCE75-\uCE8F\uCE91-\uCEAB\uCEAD-\uCEC7\uCEC9-\uCEE3\uCEE5-\uCEFF\uCF01-\uCF1B\uCF1D-\uCF37\uCF39-\uCF53\uCF55-\uCF6F\uCF71-\uCF8B\uCF8D-\uCFA7\uCFA9-\uCFC3\uCFC5-\uCFDF\uCFE1-\uCFFB\uCFFD-\uD017\uD019-\uD033\uD035-\uD04F\uD051-\uD06B\uD06D-\uD087\uD089-\uD0A3\uD0A5-\uD0BF\uD0C1-\uD0DB\uD0DD-\uD0F7\uD0F9-\uD113\uD115-\uD12F\uD131-\uD14B\uD14D-\uD167\uD169-\uD183\uD185-\uD19F\uD1A1-\uD1BB\uD1BD-\uD1D7\uD1D9-\uD1F3\uD1F5-\uD20F\uD211-\uD22B\uD22D-\uD247\uD249-\uD263\uD265-\uD27F\uD281-\uD29B\uD29D-\uD2B7\uD2B9-\uD2D3\uD2D5-\uD2EF\uD2F1-\uD30B\uD30D-\uD327\uD329-\uD343\uD345-\uD35F\uD361-\uD37B\uD37D-\uD397\uD399-\uD3B3\uD3B5-\uD3CF\uD3D1-\uD3EB\uD3ED-\uD407\uD409-\uD423\uD425-\uD43F\uD441-\uD45B\uD45D-\uD477\uD479-\uD493\uD495-\uD4AF\uD4B1-\uD4CB\uD4CD-\uD4E7\uD4E9-\uD503\uD505-\uD51F\uD521-\uD53B\uD53D-\uD557\uD559-\uD573\uD575-\uD58F\uD591-\uD5AB\uD5AD-\uD5C7\uD5C9-\uD5E3\uD5E5-\uD5FF\uD601-\uD61B\uD61D-\uD637\uD639-\uD653\uD655-\uD66F\uD671-\uD68B\uD68D-\uD6A7\uD6A9-\uD6C3\uD6C5-\uD6DF\uD6E1-\uD6FB\uD6FD-\uD717\uD719-\uD733\uD735-\uD74F\uD751-\uD76B\uD76D-\uD787\uD789-\uD7A3]$/;
+ var reExtPict = /^(?:[\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u231A\u231B\u2328\u2388\u23CF\u23E9-\u23F3\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB-\u25FE\u2600-\u2605\u2607-\u2612\u2614-\u2685\u2690-\u2705\u2708-\u2712\u2714\u2716\u271D\u2721\u2728\u2733\u2734\u2744\u2747\u274C\u274E\u2753-\u2755\u2757\u2763-\u2767\u2795-\u2797\u27A1\u27B0\u27BF\u2934\u2935\u2B05-\u2B07\u2B1B\u2B1C\u2B50\u2B55\u3030\u303D\u3297\u3299]|\uD83C[\uDC00-\uDCFF\uDD0D-\uDD0F\uDD2F\uDD6C-\uDD71\uDD7E\uDD7F\uDD8E\uDD91-\uDD9A\uDDAD-\uDDE5\uDE01-\uDE0F\uDE1A\uDE2F\uDE32-\uDE3A\uDE3C-\uDE3F\uDE49-\uDFFA]|\uD83D[\uDC00-\uDD3D\uDD46-\uDE4F\uDE80-\uDEFF\uDF74-\uDF7F\uDFD5-\uDFFF]|\uD83E[\uDC0C-\uDC0F\uDC48-\uDC4F\uDC5A-\uDC5F\uDC88-\uDC8F\uDCAE-\uDCFF\uDD0C-\uDD3A\uDD3C-\uDD45\uDD47-\uDEFF]|\uD83F[\uDC00-\uDFFD])$/;
+
+ var getCodepointType = function getCodepointType(_char4, code) {
+ var type = CodepointType.Any;
+
+ if (_char4.search(reExtend) !== -1) {
+ type |= CodepointType.Extend;
+ }
+
+ if (code === 0x200d) {
+ type |= CodepointType.ZWJ;
+ }
+
+ if (code >= 0x1f1e6 && code <= 0x1f1ff) {
+ type |= CodepointType.RI;
+ }
+
+ if (_char4.search(rePrepend) !== -1) {
+ type |= CodepointType.Prepend;
+ }
+
+ if (_char4.search(reSpacingMark) !== -1) {
+ type |= CodepointType.SpacingMark;
+ }
+
+ if (_char4.search(reL) !== -1) {
+ type |= CodepointType.L;
+ }
+
+ if (_char4.search(reV) !== -1) {
+ type |= CodepointType.V;
+ }
+
+ if (_char4.search(reT) !== -1) {
+ type |= CodepointType.T;
+ }
+
+ if (_char4.search(reLV) !== -1) {
+ type |= CodepointType.LV;
+ }
+
+ if (_char4.search(reLVT) !== -1) {
+ type |= CodepointType.LVT;
+ }
+
+ if (_char4.search(reExtPict) !== -1) {
+ type |= CodepointType.ExtPict;
+ }
+
+ return type;
+ };
+
+ function intersects(x, y) {
+ return (x & y) !== 0;
+ }
+
+ var NonBoundaryPairs = [// GB6
+ [CodepointType.L, CodepointType.L | CodepointType.V | CodepointType.LV | CodepointType.LVT], // GB7
+ [CodepointType.LV | CodepointType.V, CodepointType.V | CodepointType.T], // GB8
+ [CodepointType.LVT | CodepointType.T, CodepointType.T], // GB9
+ [CodepointType.Any, CodepointType.Extend | CodepointType.ZWJ], // GB9a
+ [CodepointType.Any, CodepointType.SpacingMark], // GB9b
+ [CodepointType.Prepend, CodepointType.Any], // GB11
+ [CodepointType.ZWJ, CodepointType.ExtPict], // GB12 and GB13
+ [CodepointType.RI, CodepointType.RI]];
+
+ function isBoundaryPair(left, right) {
+ return NonBoundaryPairs.findIndex(function (r) {
+ return intersects(left, r[0]) && intersects(right, r[1]);
+ }) === -1;
+ }
+
+ var endingEmojiZWJ = /(?:[\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u231A\u231B\u2328\u2388\u23CF\u23E9-\u23F3\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB-\u25FE\u2600-\u2605\u2607-\u2612\u2614-\u2685\u2690-\u2705\u2708-\u2712\u2714\u2716\u271D\u2721\u2728\u2733\u2734\u2744\u2747\u274C\u274E\u2753-\u2755\u2757\u2763-\u2767\u2795-\u2797\u27A1\u27B0\u27BF\u2934\u2935\u2B05-\u2B07\u2B1B\u2B1C\u2B50\u2B55\u3030\u303D\u3297\u3299]|\uD83C[\uDC00-\uDCFF\uDD0D-\uDD0F\uDD2F\uDD6C-\uDD71\uDD7E\uDD7F\uDD8E\uDD91-\uDD9A\uDDAD-\uDDE5\uDE01-\uDE0F\uDE1A\uDE2F\uDE32-\uDE3A\uDE3C-\uDE3F\uDE49-\uDFFA]|\uD83D[\uDC00-\uDD3D\uDD46-\uDE4F\uDE80-\uDEFF\uDF74-\uDF7F\uDFD5-\uDFFF]|\uD83E[\uDC0C-\uDC0F\uDC48-\uDC4F\uDC5A-\uDC5F\uDC88-\uDC8F\uDCAE-\uDCFF\uDD0C-\uDD3A\uDD3C-\uDD45\uDD47-\uDEFF]|\uD83F[\uDC00-\uDFFD])(?:[\u0300-\u036F\u0483-\u0489\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u0610-\u061A\u064B-\u065F\u0670\u06D6-\u06DC\u06DF-\u06E4\u06E7\u06E8\u06EA-\u06ED\u0711\u0730-\u074A\u07A6-\u07B0\u07EB-\u07F3\u07FD\u0816-\u0819\u081B-\u0823\u0825-\u0827\u0829-\u082D\u0859-\u085B\u08D3-\u08E1\u08E3-\u0902\u093A\u093C\u0941-\u0948\u094D\u0951-\u0957\u0962\u0963\u0981\u09BC\u09BE\u09C1-\u09C4\u09CD\u09D7\u09E2\u09E3\u09FE\u0A01\u0A02\u0A3C\u0A41\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A70\u0A71\u0A75\u0A81\u0A82\u0ABC\u0AC1-\u0AC5\u0AC7\u0AC8\u0ACD\u0AE2\u0AE3\u0AFA-\u0AFF\u0B01\u0B3C\u0B3E\u0B3F\u0B41-\u0B44\u0B4D\u0B55-\u0B57\u0B62\u0B63\u0B82\u0BBE\u0BC0\u0BCD\u0BD7\u0C00\u0C04\u0C3E-\u0C40\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C62\u0C63\u0C81\u0CBC\u0CBF\u0CC2\u0CC6\u0CCC\u0CCD\u0CD5\u0CD6\u0CE2\u0CE3\u0D00\u0D01\u0D3B\u0D3C\u0D3E\u0D41-\u0D44\u0D4D\u0D57\u0D62\u0D63\u0D81\u0DCA\u0DCF\u0DD2-\u0DD4\u0DD6\u0DDF\u0E31\u0E34-\u0E3A\u0E47-\u0E4E\u0EB1\u0EB4-\u0EBC\u0EC8-\u0ECD\u0F18\u0F19\u0F35\u0F37\u0F39\u0F71-\u0F7E\u0F80-\u0F84\u0F86\u0F87\u0F8D-\u0F97\u0F99-\u0FBC\u0FC6\u102D-\u1030\u1032-\u1037\u1039\u103A\u103D\u103E\u1058\u1059\u105E-\u1060\u1071-\u1074\u1082\u1085\u1086\u108D\u109D\u135D-\u135F\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17B4\u17B5\u17B7-\u17BD\u17C6\u17C9-\u17D3\u17DD\u180B-\u180D\u1885\u1886\u18A9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193B\u1A17\u1A18\u1A1B\u1A56\u1A58-\u1A5E\u1A60\u1A62\u1A65-\u1A6C\u1A73-\u1A7C\u1A7F\u1AB0-\u1AC0\u1B00-\u1B03\u1B34-\u1B3A\u1B3C\u1B42\u1B6B-\u1B73\u1B80\u1B81\u1BA2-\u1BA5\u1BA8\u1BA9\u1BAB-\u1BAD\u1BE6\u1BE8\u1BE9\u1BED\u1BEF-\u1BF1\u1C2C-\u1C33\u1C36\u1C37\u1CD0-\u1CD2\u1CD4-\u1CE0\u1CE2-\u1CE8\u1CED\u1CF4\u1CF8\u1CF9\u1DC0-\u1DF9\u1DFB-\u1DFF\u200C\u20D0-\u20F0\u2CEF-\u2CF1\u2D7F\u2DE0-\u2DFF\u302A-\u302F\u3099\u309A\uA66F-\uA672\uA674-\uA67D\uA69E\uA69F\uA6F0\uA6F1\uA802\uA806\uA80B\uA825\uA826\uA82C\uA8C4\uA8C5\uA8E0-\uA8F1\uA8FF\uA926-\uA92D\uA947-\uA951\uA980-\uA982\uA9B3\uA9B6-\uA9B9\uA9BC\uA9BD\uA9E5\uAA29-\uAA2E\uAA31\uAA32\uAA35\uAA36\uAA43\uAA4C\uAA7C\uAAB0\uAAB2-\uAAB4\uAAB7\uAAB8\uAABE\uAABF\uAAC1\uAAEC\uAAED\uAAF6\uABE5\uABE8\uABED\uFB1E\uFE00-\uFE0F\uFE20-\uFE2F\uFF9E\uFF9F]|\uD800[\uDDFD\uDEE0\uDF76-\uDF7A]|\uD802[\uDE01-\uDE03\uDE05\uDE06\uDE0C-\uDE0F\uDE38-\uDE3A\uDE3F\uDEE5\uDEE6]|\uD803[\uDD24-\uDD27\uDEAB\uDEAC\uDF46-\uDF50]|\uD804[\uDC01\uDC38-\uDC46\uDC7F-\uDC81\uDCB3-\uDCB6\uDCB9\uDCBA\uDD00-\uDD02\uDD27-\uDD2B\uDD2D-\uDD34\uDD73\uDD80\uDD81\uDDB6-\uDDBE\uDDC9-\uDDCC\uDDCF\uDE2F-\uDE31\uDE34\uDE36\uDE37\uDE3E\uDEDF\uDEE3-\uDEEA\uDF00\uDF01\uDF3B\uDF3C\uDF3E\uDF40\uDF57\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC38-\uDC3F\uDC42-\uDC44\uDC46\uDC5E\uDCB0\uDCB3-\uDCB8\uDCBA\uDCBD\uDCBF\uDCC0\uDCC2\uDCC3\uDDAF\uDDB2-\uDDB5\uDDBC\uDDBD\uDDBF\uDDC0\uDDDC\uDDDD\uDE33-\uDE3A\uDE3D\uDE3F\uDE40\uDEAB\uDEAD\uDEB0-\uDEB5\uDEB7\uDF1D-\uDF1F\uDF22-\uDF25\uDF27-\uDF2B]|\uD806[\uDC2F-\uDC37\uDC39\uDC3A\uDD30\uDD3B\uDD3C\uDD3E\uDD43\uDDD4-\uDDD7\uDDDA\uDDDB\uDDE0\uDE01-\uDE0A\uDE33-\uDE38\uDE3B-\uDE3E\uDE47\uDE51-\uDE56\uDE59-\uDE5B\uDE8A-\uDE96\uDE98\uDE99]|\uD807[\uDC30-\uDC36\uDC38-\uDC3D\uDC3F\uDC92-\uDCA7\uDCAA-\uDCB0\uDCB2\uDCB3\uDCB5\uDCB6\uDD31-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD45\uDD47\uDD90\uDD91\uDD95\uDD97\uDEF3\uDEF4]|\uD81A[\uDEF0-\uDEF4\uDF30-\uDF36]|\uD81B[\uDF4F\uDF8F-\uDF92\uDFE4]|\uD82F[\uDC9D\uDC9E]|\uD834[\uDD65\uDD67-\uDD69\uDD6E-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A\uDD30-\uDD36\uDEEC-\uDEEF]|\uD83A[\uDCD0-\uDCD6\uDD44-\uDD4A]|\uD83C[\uDFFB-\uDFFF]|\uDB40[\uDC20-\uDC7F\uDD00-\uDDEF])*\u200D$/;
+
+ var endsWithEmojiZWJ = function endsWithEmojiZWJ(str) {
+ return str.search(endingEmojiZWJ) !== -1;
+ };
+
+ var endingRIs = /(?:\uD83C[\uDDE6-\uDDFF])+$/g;
+
+ var endsWithOddNumberOfRIs = function endsWithOddNumberOfRIs(str) {
+ var match = str.match(endingRIs);
+
+ if (match === null) {
+ return false;
+ } else {
+ // A RI is represented by a surrogate pair.
+ var numRIs = match[0].length / 2;
+ return numRIs % 2 === 1;
+ }
+ };
+
+ /**
+ * Shared the function with isElementType utility
+ */
+
+ var isElement = function isElement(value) {
+ return isPlainObject.isPlainObject(value) && Node$1.isNodeList(value.children) && !Editor.isEditor(value);
+ };
+
+ var Element$1 = {
+ /**
+ * Check if a value implements the 'Ancestor' interface.
+ */
+ isAncestor: function isAncestor(value) {
+ return isPlainObject.isPlainObject(value) && Node$1.isNodeList(value.children);
+ },
+
+ /**
+ * Check if a value implements the `Element` interface.
+ */
+ isElement: isElement,
+
+ /**
+ * Check if a value is an array of `Element` objects.
+ */
+ isElementList: function isElementList(value) {
+ return Array.isArray(value) && value.every(function (val) {
+ return Element$1.isElement(val);
+ });
+ },
+
+ /**
+ * Check if a set of props is a partial of Element.
+ */
+ isElementProps: function isElementProps(props) {
+ return props.children !== undefined;
+ },
+
+ /**
+ * Check if a value implements the `Element` interface and has elementKey with selected value.
+ * Default it check to `type` key value
+ */
+ isElementType: function isElementType(value, elementVal) {
+ var elementKey = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'type';
+ return isElement(value) && value[elementKey] === elementVal;
+ },
+
+ /**
+ * Check if an element matches set of properties.
+ *
+ * Note: this checks custom properties, and it does not ensure that any
+ * children are equivalent.
+ */
+ matches: function matches(element, props) {
+ for (var key in props) {
+ if (key === 'children') {
+ continue;
+ }
+
+ if (element[key] !== props[key]) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+ };
+
+ var _excluded$4 = ["text"],
+ _excluded2$3 = ["text"];
+
+ function ownKeys$8(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread$8(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$8(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$8(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+
+ function _createForOfIteratorHelper$5(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray$5(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; } } }; }
+
+ function _unsupportedIterableToArray$5(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray$5(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$5(o, minLen); }
+
+ function _arrayLikeToArray$5(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; }
+ var IS_EDITOR_CACHE = new WeakMap();
+ var Editor = {
+ /**
+ * Get the ancestor above a location in the document.
+ */
+ above: function above(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$voids = options.voids,
+ voids = _options$voids === void 0 ? false : _options$voids,
+ _options$mode = options.mode,
+ mode = _options$mode === void 0 ? 'lowest' : _options$mode,
+ _options$at = options.at,
+ at = _options$at === void 0 ? editor.selection : _options$at,
+ match = options.match;
+
+ if (!at) {
+ return;
+ }
+
+ var path = Editor.path(editor, at);
+ var reverse = mode === 'lowest';
+
+ var _iterator = _createForOfIteratorHelper$5(Editor.levels(editor, {
+ at: path,
+ voids: voids,
+ match: match,
+ reverse: reverse
+ })),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var _step$value = _slicedToArray(_step.value, 2),
+ n = _step$value[0],
+ p = _step$value[1];
+
+ if (!Text.isText(n) && !Path.equals(path, p)) {
+ return [n, p];
+ }
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+ },
+
+ /**
+ * Add a custom property to the leaf text nodes in the current selection.
+ *
+ * If the selection is currently collapsed, the marks will be added to the
+ * `editor.marks` property instead, and applied when text is inserted next.
+ */
+ addMark: function addMark(editor, key, value) {
+ editor.addMark(key, value);
+ },
+
+ /**
+ * Get the point after a location.
+ */
+ after: function after(editor, at) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var anchor = Editor.point(editor, at, {
+ edge: 'end'
+ });
+ var focus = Editor.end(editor, []);
+ var range = {
+ anchor: anchor,
+ focus: focus
+ };
+ var _options$distance = options.distance,
+ distance = _options$distance === void 0 ? 1 : _options$distance;
+ var d = 0;
+ var target;
+
+ var _iterator2 = _createForOfIteratorHelper$5(Editor.positions(editor, _objectSpread$8(_objectSpread$8({}, options), {}, {
+ at: range
+ }))),
+ _step2;
+
+ try {
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
+ var p = _step2.value;
+
+ if (d > distance) {
+ break;
+ }
+
+ if (d !== 0) {
+ target = p;
+ }
+
+ d++;
+ }
+ } catch (err) {
+ _iterator2.e(err);
+ } finally {
+ _iterator2.f();
+ }
+
+ return target;
+ },
+
+ /**
+ * Get the point before a location.
+ */
+ before: function before(editor, at) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var anchor = Editor.start(editor, []);
+ var focus = Editor.point(editor, at, {
+ edge: 'start'
+ });
+ var range = {
+ anchor: anchor,
+ focus: focus
+ };
+ var _options$distance2 = options.distance,
+ distance = _options$distance2 === void 0 ? 1 : _options$distance2;
+ var d = 0;
+ var target;
+
+ var _iterator3 = _createForOfIteratorHelper$5(Editor.positions(editor, _objectSpread$8(_objectSpread$8({}, options), {}, {
+ at: range,
+ reverse: true
+ }))),
+ _step3;
+
+ try {
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
+ var p = _step3.value;
+
+ if (d > distance) {
+ break;
+ }
+
+ if (d !== 0) {
+ target = p;
+ }
+
+ d++;
+ }
+ } catch (err) {
+ _iterator3.e(err);
+ } finally {
+ _iterator3.f();
+ }
+
+ return target;
+ },
+
+ /**
+ * Delete content in the editor backward from the current selection.
+ */
+ deleteBackward: function deleteBackward(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$unit = options.unit,
+ unit = _options$unit === void 0 ? 'character' : _options$unit;
+ editor.deleteBackward(unit);
+ },
+
+ /**
+ * Delete content in the editor forward from the current selection.
+ */
+ deleteForward: function deleteForward(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$unit2 = options.unit,
+ unit = _options$unit2 === void 0 ? 'character' : _options$unit2;
+ editor.deleteForward(unit);
+ },
+
+ /**
+ * Delete the content in the current selection.
+ */
+ deleteFragment: function deleteFragment(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$direction = options.direction,
+ direction = _options$direction === void 0 ? 'forward' : _options$direction;
+ editor.deleteFragment(direction);
+ },
+
+ /**
+ * Get the start and end points of a location.
+ */
+ edges: function edges(editor, at) {
+ return [Editor.start(editor, at), Editor.end(editor, at)];
+ },
+
+ /**
+ * Get the end point of a location.
+ */
+ end: function end(editor, at) {
+ return Editor.point(editor, at, {
+ edge: 'end'
+ });
+ },
+
+ /**
+ * Get the first node at a location.
+ */
+ first: function first(editor, at) {
+ var path = Editor.path(editor, at, {
+ edge: 'start'
+ });
+ return Editor.node(editor, path);
+ },
+
+ /**
+ * Get the fragment at a location.
+ */
+ fragment: function fragment(editor, at) {
+ var range = Editor.range(editor, at);
+ var fragment = Node$1.fragment(editor, range);
+ return fragment;
+ },
+
+ /**
+ * Check if a node has block children.
+ */
+ hasBlocks: function hasBlocks(editor, element) {
+ return element.children.some(function (n) {
+ return Editor.isBlock(editor, n);
+ });
+ },
+
+ /**
+ * Check if a node has inline and text children.
+ */
+ hasInlines: function hasInlines(editor, element) {
+ return element.children.some(function (n) {
+ return Text.isText(n) || Editor.isInline(editor, n);
+ });
+ },
+
+ /**
+ * Check if a node has text children.
+ */
+ hasTexts: function hasTexts(editor, element) {
+ return element.children.every(function (n) {
+ return Text.isText(n);
+ });
+ },
+
+ /**
+ * Insert a block break at the current selection.
+ *
+ * If the selection is currently expanded, it will be deleted first.
+ */
+ insertBreak: function insertBreak(editor) {
+ editor.insertBreak();
+ },
+
+ /**
+ * Insert a fragment at the current selection.
+ *
+ * If the selection is currently expanded, it will be deleted first.
+ */
+ insertFragment: function insertFragment(editor, fragment) {
+ editor.insertFragment(fragment);
+ },
+
+ /**
+ * Insert a node at the current selection.
+ *
+ * If the selection is currently expanded, it will be deleted first.
+ */
+ insertNode: function insertNode(editor, node) {
+ editor.insertNode(node);
+ },
+
+ /**
+ * Insert text at the current selection.
+ *
+ * If the selection is currently expanded, it will be deleted first.
+ */
+ insertText: function insertText(editor, text) {
+ editor.insertText(text);
+ },
+
+ /**
+ * Check if a value is a block `Element` object.
+ */
+ isBlock: function isBlock(editor, value) {
+ return Element$1.isElement(value) && !editor.isInline(value);
+ },
+
+ /**
+ * Check if a value is an `Editor` object.
+ */
+ isEditor: function isEditor(value) {
+ if (!isPlainObject.isPlainObject(value)) return false;
+ var cachedIsEditor = IS_EDITOR_CACHE.get(value);
+
+ if (cachedIsEditor !== undefined) {
+ return cachedIsEditor;
+ }
+
+ var isEditor = typeof value.addMark === 'function' && typeof value.apply === 'function' && typeof value.deleteBackward === 'function' && typeof value.deleteForward === 'function' && typeof value.deleteFragment === 'function' && typeof value.insertBreak === 'function' && typeof value.insertFragment === 'function' && typeof value.insertNode === 'function' && typeof value.insertText === 'function' && typeof value.isInline === 'function' && typeof value.isVoid === 'function' && typeof value.normalizeNode === 'function' && typeof value.onChange === 'function' && typeof value.removeMark === 'function' && (value.marks === null || isPlainObject.isPlainObject(value.marks)) && (value.selection === null || Range.isRange(value.selection)) && Node$1.isNodeList(value.children) && Operation.isOperationList(value.operations);
+ IS_EDITOR_CACHE.set(value, isEditor);
+ return isEditor;
+ },
+
+ /**
+ * Check if a point is the end point of a location.
+ */
+ isEnd: function isEnd(editor, point, at) {
+ var end = Editor.end(editor, at);
+ return Point.equals(point, end);
+ },
+
+ /**
+ * Check if a point is an edge of a location.
+ */
+ isEdge: function isEdge(editor, point, at) {
+ return Editor.isStart(editor, point, at) || Editor.isEnd(editor, point, at);
+ },
+
+ /**
+ * Check if an element is empty, accounting for void nodes.
+ */
+ isEmpty: function isEmpty(editor, element) {
+ var children = element.children;
+
+ var _children = _slicedToArray(children, 1),
+ first = _children[0];
+
+ return children.length === 0 || children.length === 1 && Text.isText(first) && first.text === '' && !editor.isVoid(element);
+ },
+
+ /**
+ * Check if a value is an inline `Element` object.
+ */
+ isInline: function isInline(editor, value) {
+ return Element$1.isElement(value) && editor.isInline(value);
+ },
+
+ /**
+ * Check if the editor is currently normalizing after each operation.
+ */
+ isNormalizing: function isNormalizing(editor) {
+ var isNormalizing = NORMALIZING.get(editor);
+ return isNormalizing === undefined ? true : isNormalizing;
+ },
+
+ /**
+ * Check if a point is the start point of a location.
+ */
+ isStart: function isStart(editor, point, at) {
+ // PERF: If the offset isn't `0` we know it's not the start.
+ if (point.offset !== 0) {
+ return false;
+ }
+
+ var start = Editor.start(editor, at);
+ return Point.equals(point, start);
+ },
+
+ /**
+ * Check if a value is a void `Element` object.
+ */
+ isVoid: function isVoid(editor, value) {
+ return Element$1.isElement(value) && editor.isVoid(value);
+ },
+
+ /**
+ * Get the last node at a location.
+ */
+ last: function last(editor, at) {
+ var path = Editor.path(editor, at, {
+ edge: 'end'
+ });
+ return Editor.node(editor, path);
+ },
+
+ /**
+ * Get the leaf text node at a location.
+ */
+ leaf: function leaf(editor, at) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var path = Editor.path(editor, at, options);
+ var node = Node$1.leaf(editor, path);
+ return [node, path];
+ },
+
+ /**
+ * Iterate through all of the levels at a location.
+ */
+ levels: function* levels(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$at2 = options.at,
+ at = _options$at2 === void 0 ? editor.selection : _options$at2,
+ _options$reverse = options.reverse,
+ reverse = _options$reverse === void 0 ? false : _options$reverse,
+ _options$voids2 = options.voids,
+ voids = _options$voids2 === void 0 ? false : _options$voids2;
+ var match = options.match;
+
+ if (match == null) {
+ match = function match() {
+ return true;
+ };
+ }
+
+ if (!at) {
+ return;
+ }
+
+ var levels = [];
+ var path = Editor.path(editor, at);
+
+ var _iterator4 = _createForOfIteratorHelper$5(Node$1.levels(editor, path)),
+ _step4;
+
+ try {
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
+ var _step4$value = _slicedToArray(_step4.value, 2),
+ n = _step4$value[0],
+ p = _step4$value[1];
+
+ if (!match(n, p)) {
+ continue;
+ }
+
+ levels.push([n, p]);
+
+ if (!voids && Editor.isVoid(editor, n)) {
+ break;
+ }
+ }
+ } catch (err) {
+ _iterator4.e(err);
+ } finally {
+ _iterator4.f();
+ }
+
+ if (reverse) {
+ levels.reverse();
+ }
+
+ yield* levels;
+ },
+
+ /**
+ * Get the marks that would be added to text at the current selection.
+ */
+ marks: function marks(editor) {
+ var marks = editor.marks,
+ selection = editor.selection;
+
+ if (!selection) {
+ return null;
+ }
+
+ if (marks) {
+ return marks;
+ }
+
+ if (Range.isExpanded(selection)) {
+ var _Editor$nodes = Editor.nodes(editor, {
+ match: Text.isText
+ }),
+ _Editor$nodes2 = _slicedToArray(_Editor$nodes, 1),
+ match = _Editor$nodes2[0];
+
+ if (match) {
+ var _match = _slicedToArray(match, 1),
+ _node = _match[0];
+
+ _node.text;
+ var _rest = _objectWithoutProperties(_node, _excluded$4);
+
+ return _rest;
+ } else {
+ return {};
+ }
+ }
+
+ var anchor = selection.anchor;
+ var path = anchor.path;
+
+ var _Editor$leaf = Editor.leaf(editor, path),
+ _Editor$leaf2 = _slicedToArray(_Editor$leaf, 1),
+ node = _Editor$leaf2[0];
+
+ if (anchor.offset === 0) {
+ var prev = Editor.previous(editor, {
+ at: path,
+ match: Text.isText
+ });
+ var block = Editor.above(editor, {
+ match: function match(n) {
+ return Editor.isBlock(editor, n);
+ }
+ });
+
+ if (prev && block) {
+ var _prev = _slicedToArray(prev, 2),
+ prevNode = _prev[0],
+ prevPath = _prev[1];
+
+ var _block = _slicedToArray(block, 2),
+ blockPath = _block[1];
+
+ if (Path.isAncestor(blockPath, prevPath)) {
+ node = prevNode;
+ }
+ }
+ }
+
+ var _node2 = node;
+ _node2.text;
+ var rest = _objectWithoutProperties(_node2, _excluded2$3);
+
+ return rest;
+ },
+
+ /**
+ * Get the matching node in the branch of the document after a location.
+ */
+ next: function next(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$mode2 = options.mode,
+ mode = _options$mode2 === void 0 ? 'lowest' : _options$mode2,
+ _options$voids3 = options.voids,
+ voids = _options$voids3 === void 0 ? false : _options$voids3;
+ var match = options.match,
+ _options$at3 = options.at,
+ at = _options$at3 === void 0 ? editor.selection : _options$at3;
+
+ if (!at) {
+ return;
+ }
+
+ var pointAfterLocation = Editor.after(editor, at, {
+ voids: voids
+ });
+ if (!pointAfterLocation) return;
+
+ var _Editor$last = Editor.last(editor, []),
+ _Editor$last2 = _slicedToArray(_Editor$last, 2),
+ to = _Editor$last2[1];
+
+ var span = [pointAfterLocation.path, to];
+
+ if (Path.isPath(at) && at.length === 0) {
+ throw new Error("Cannot get the next node from the root node!");
+ }
+
+ if (match == null) {
+ if (Path.isPath(at)) {
+ var _Editor$parent = Editor.parent(editor, at),
+ _Editor$parent2 = _slicedToArray(_Editor$parent, 1),
+ parent = _Editor$parent2[0];
+
+ match = function match(n) {
+ return parent.children.includes(n);
+ };
+ } else {
+ match = function match() {
+ return true;
+ };
+ }
+ }
+
+ var _Editor$nodes3 = Editor.nodes(editor, {
+ at: span,
+ match: match,
+ mode: mode,
+ voids: voids
+ }),
+ _Editor$nodes4 = _slicedToArray(_Editor$nodes3, 1),
+ next = _Editor$nodes4[0];
+
+ return next;
+ },
+
+ /**
+ * Get the node at a location.
+ */
+ node: function node(editor, at) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var path = Editor.path(editor, at, options);
+ var node = Node$1.get(editor, path);
+ return [node, path];
+ },
+
+ /**
+ * Iterate through all of the nodes in the Editor.
+ */
+ nodes: function* nodes(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$at4 = options.at,
+ at = _options$at4 === void 0 ? editor.selection : _options$at4,
+ _options$mode3 = options.mode,
+ mode = _options$mode3 === void 0 ? 'all' : _options$mode3,
+ _options$universal = options.universal,
+ universal = _options$universal === void 0 ? false : _options$universal,
+ _options$reverse2 = options.reverse,
+ reverse = _options$reverse2 === void 0 ? false : _options$reverse2,
+ _options$voids4 = options.voids,
+ voids = _options$voids4 === void 0 ? false : _options$voids4;
+ var match = options.match;
+
+ if (!match) {
+ match = function match() {
+ return true;
+ };
+ }
+
+ if (!at) {
+ return;
+ }
+
+ var from;
+ var to;
+
+ if (Span.isSpan(at)) {
+ from = at[0];
+ to = at[1];
+ } else {
+ var first = Editor.path(editor, at, {
+ edge: 'start'
+ });
+ var last = Editor.path(editor, at, {
+ edge: 'end'
+ });
+ from = reverse ? last : first;
+ to = reverse ? first : last;
+ }
+
+ var nodeEntries = Node$1.nodes(editor, {
+ reverse: reverse,
+ from: from,
+ to: to,
+ pass: function pass(_ref) {
+ var _ref2 = _slicedToArray(_ref, 1),
+ n = _ref2[0];
+
+ return voids ? false : Editor.isVoid(editor, n);
+ }
+ });
+ var matches = [];
+ var hit;
+
+ var _iterator5 = _createForOfIteratorHelper$5(nodeEntries),
+ _step5;
+
+ try {
+ for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
+ var _step5$value = _slicedToArray(_step5.value, 2),
+ node = _step5$value[0],
+ path = _step5$value[1];
+
+ var isLower = hit && Path.compare(path, hit[1]) === 0; // In highest mode any node lower than the last hit is not a match.
+
+ if (mode === 'highest' && isLower) {
+ continue;
+ }
+
+ if (!match(node, path)) {
+ // If we've arrived at a leaf text node that is not lower than the last
+ // hit, then we've found a branch that doesn't include a match, which
+ // means the match is not universal.
+ if (universal && !isLower && Text.isText(node)) {
+ return;
+ } else {
+ continue;
+ }
+ } // If there's a match and it's lower than the last, update the hit.
+
+
+ if (mode === 'lowest' && isLower) {
+ hit = [node, path];
+ continue;
+ } // In lowest mode we emit the last hit, once it's guaranteed lowest.
+
+
+ var emit = mode === 'lowest' ? hit : [node, path];
+
+ if (emit) {
+ if (universal) {
+ matches.push(emit);
+ } else {
+ yield emit;
+ }
+ }
+
+ hit = [node, path];
+ } // Since lowest is always emitting one behind, catch up at the end.
+
+ } catch (err) {
+ _iterator5.e(err);
+ } finally {
+ _iterator5.f();
+ }
+
+ if (mode === 'lowest' && hit) {
+ if (universal) {
+ matches.push(hit);
+ } else {
+ yield hit;
+ }
+ } // Universal defers to ensure that the match occurs in every branch, so we
+ // yield all of the matches after iterating.
+
+
+ if (universal) {
+ yield* matches;
+ }
+ },
+
+ /**
+ * Normalize any dirty objects in the editor.
+ */
+ normalize: function normalize(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$force = options.force,
+ force = _options$force === void 0 ? false : _options$force;
+
+ var getDirtyPaths = function getDirtyPaths(editor) {
+ return DIRTY_PATHS.get(editor) || [];
+ };
+
+ if (!Editor.isNormalizing(editor)) {
+ return;
+ }
+
+ if (force) {
+ var allPaths = Array.from(Node$1.nodes(editor), function (_ref3) {
+ var _ref4 = _slicedToArray(_ref3, 2),
+ p = _ref4[1];
+
+ return p;
+ });
+ DIRTY_PATHS.set(editor, allPaths);
+ }
+
+ if (getDirtyPaths(editor).length === 0) {
+ return;
+ }
+
+ Editor.withoutNormalizing(editor, function () {
+ /*
+ Fix dirty elements with no children.
+ editor.normalizeNode() does fix this, but some normalization fixes also require it to work.
+ Running an initial pass avoids the catch-22 race condition.
+ */
+ var _iterator6 = _createForOfIteratorHelper$5(getDirtyPaths(editor)),
+ _step6;
+
+ try {
+ for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) {
+ var _dirtyPath = _step6.value;
+
+ if (Node$1.has(editor, _dirtyPath)) {
+ var _entry = Editor.node(editor, _dirtyPath);
+
+ var _entry2 = _slicedToArray(_entry, 2),
+ node = _entry2[0],
+ _ = _entry2[1];
+ /*
+ The default normalizer inserts an empty text node in this scenario, but it can be customised.
+ So there is some risk here.
+ As long as the normalizer only inserts child nodes for this case it is safe to do in any order;
+ by definition adding children to an empty node can't cause other paths to change.
+ */
+
+
+ if (Element$1.isElement(node) && node.children.length === 0) {
+ editor.normalizeNode(_entry);
+ }
+ }
+ }
+ } catch (err) {
+ _iterator6.e(err);
+ } finally {
+ _iterator6.f();
+ }
+
+ var max = getDirtyPaths(editor).length * 42; // HACK: better way?
+
+ var m = 0;
+
+ while (getDirtyPaths(editor).length !== 0) {
+ if (m > max) {
+ throw new Error("\n Could not completely normalize the editor after ".concat(max, " iterations! This is usually due to incorrect normalization logic that leaves a node in an invalid state.\n "));
+ }
+
+ var dirtyPath = getDirtyPaths(editor).pop(); // If the node doesn't exist in the tree, it does not need to be normalized.
+
+ if (Node$1.has(editor, dirtyPath)) {
+ var entry = Editor.node(editor, dirtyPath);
+ editor.normalizeNode(entry);
+ }
+
+ m++;
+ }
+ });
+ },
+
+ /**
+ * Get the parent node of a location.
+ */
+ parent: function parent(editor, at) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var path = Editor.path(editor, at, options);
+ var parentPath = Path.parent(path);
+ var entry = Editor.node(editor, parentPath);
+ return entry;
+ },
+
+ /**
+ * Get the path of a location.
+ */
+ path: function path(editor, at) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var depth = options.depth,
+ edge = options.edge;
+
+ if (Path.isPath(at)) {
+ if (edge === 'start') {
+ var _Node$first = Node$1.first(editor, at),
+ _Node$first2 = _slicedToArray(_Node$first, 2),
+ firstPath = _Node$first2[1];
+
+ at = firstPath;
+ } else if (edge === 'end') {
+ var _Node$last = Node$1.last(editor, at),
+ _Node$last2 = _slicedToArray(_Node$last, 2),
+ lastPath = _Node$last2[1];
+
+ at = lastPath;
+ }
+ }
+
+ if (Range.isRange(at)) {
+ if (edge === 'start') {
+ at = Range.start(at);
+ } else if (edge === 'end') {
+ at = Range.end(at);
+ } else {
+ at = Path.common(at.anchor.path, at.focus.path);
+ }
+ }
+
+ if (Point.isPoint(at)) {
+ at = at.path;
+ }
+
+ if (depth != null) {
+ at = at.slice(0, depth);
+ }
+
+ return at;
+ },
+ hasPath: function hasPath(editor, path) {
+ return Node$1.has(editor, path);
+ },
+
+ /**
+ * Create a mutable ref for a `Path` object, which will stay in sync as new
+ * operations are applied to the editor.
+ */
+ pathRef: function pathRef(editor, path) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var _options$affinity = options.affinity,
+ affinity = _options$affinity === void 0 ? 'forward' : _options$affinity;
+ var ref = {
+ current: path,
+ affinity: affinity,
+ unref: function unref() {
+ var current = ref.current;
+ var pathRefs = Editor.pathRefs(editor);
+ pathRefs["delete"](ref);
+ ref.current = null;
+ return current;
+ }
+ };
+ var refs = Editor.pathRefs(editor);
+ refs.add(ref);
+ return ref;
+ },
+
+ /**
+ * Get the set of currently tracked path refs of the editor.
+ */
+ pathRefs: function pathRefs(editor) {
+ var refs = PATH_REFS.get(editor);
+
+ if (!refs) {
+ refs = new Set();
+ PATH_REFS.set(editor, refs);
+ }
+
+ return refs;
+ },
+
+ /**
+ * Get the start or end point of a location.
+ */
+ point: function point(editor, at) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var _options$edge = options.edge,
+ edge = _options$edge === void 0 ? 'start' : _options$edge;
+
+ if (Path.isPath(at)) {
+ var path;
+
+ if (edge === 'end') {
+ var _Node$last3 = Node$1.last(editor, at),
+ _Node$last4 = _slicedToArray(_Node$last3, 2),
+ lastPath = _Node$last4[1];
+
+ path = lastPath;
+ } else {
+ var _Node$first3 = Node$1.first(editor, at),
+ _Node$first4 = _slicedToArray(_Node$first3, 2),
+ firstPath = _Node$first4[1];
+
+ path = firstPath;
+ }
+
+ var node = Node$1.get(editor, path);
+
+ if (!Text.isText(node)) {
+ throw new Error("Cannot get the ".concat(edge, " point in the node at path [").concat(at, "] because it has no ").concat(edge, " text node."));
+ }
+
+ return {
+ path: path,
+ offset: edge === 'end' ? node.text.length : 0
+ };
+ }
+
+ if (Range.isRange(at)) {
+ var _Range$edges = Range.edges(at),
+ _Range$edges2 = _slicedToArray(_Range$edges, 2),
+ start = _Range$edges2[0],
+ end = _Range$edges2[1];
+
+ return edge === 'start' ? start : end;
+ }
+
+ return at;
+ },
+
+ /**
+ * Create a mutable ref for a `Point` object, which will stay in sync as new
+ * operations are applied to the editor.
+ */
+ pointRef: function pointRef(editor, point) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var _options$affinity2 = options.affinity,
+ affinity = _options$affinity2 === void 0 ? 'forward' : _options$affinity2;
+ var ref = {
+ current: point,
+ affinity: affinity,
+ unref: function unref() {
+ var current = ref.current;
+ var pointRefs = Editor.pointRefs(editor);
+ pointRefs["delete"](ref);
+ ref.current = null;
+ return current;
+ }
+ };
+ var refs = Editor.pointRefs(editor);
+ refs.add(ref);
+ return ref;
+ },
+
+ /**
+ * Get the set of currently tracked point refs of the editor.
+ */
+ pointRefs: function pointRefs(editor) {
+ var refs = POINT_REFS.get(editor);
+
+ if (!refs) {
+ refs = new Set();
+ POINT_REFS.set(editor, refs);
+ }
+
+ return refs;
+ },
+
+ /**
+ * Return all the positions in `at` range where a `Point` can be placed.
+ *
+ * By default, moves forward by individual offsets at a time, but
+ * the `unit` option can be used to to move by character, word, line, or block.
+ *
+ * The `reverse` option can be used to change iteration direction.
+ *
+ * Note: By default void nodes are treated as a single point and iteration
+ * will not happen inside their content unless you pass in true for the
+ * `voids` option, then iteration will occur.
+ */
+ positions: function* positions(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$at5 = options.at,
+ at = _options$at5 === void 0 ? editor.selection : _options$at5,
+ _options$unit3 = options.unit,
+ unit = _options$unit3 === void 0 ? 'offset' : _options$unit3,
+ _options$reverse3 = options.reverse,
+ reverse = _options$reverse3 === void 0 ? false : _options$reverse3,
+ _options$voids5 = options.voids,
+ voids = _options$voids5 === void 0 ? false : _options$voids5;
+
+ if (!at) {
+ return;
+ }
+ /**
+ * Algorithm notes:
+ *
+ * Each step `distance` is dynamic depending on the underlying text
+ * and the `unit` specified. Each step, e.g., a line or word, may
+ * span multiple text nodes, so we iterate through the text both on
+ * two levels in step-sync:
+ *
+ * `leafText` stores the text on a text leaf level, and is advanced
+ * through using the counters `leafTextOffset` and `leafTextRemaining`.
+ *
+ * `blockText` stores the text on a block level, and is shortened
+ * by `distance` every time it is advanced.
+ *
+ * We only maintain a window of one blockText and one leafText because
+ * a block node always appears before all of its leaf nodes.
+ */
+
+
+ var range = Editor.range(editor, at);
+
+ var _Range$edges3 = Range.edges(range),
+ _Range$edges4 = _slicedToArray(_Range$edges3, 2),
+ start = _Range$edges4[0],
+ end = _Range$edges4[1];
+
+ var first = reverse ? end : start;
+ var isNewBlock = false;
+ var blockText = '';
+ var distance = 0; // Distance for leafText to catch up to blockText.
+
+ var leafTextRemaining = 0;
+ var leafTextOffset = 0; // Iterate through all nodes in range, grabbing entire textual content
+ // of block nodes in blockText, and text nodes in leafText.
+ // Exploits the fact that nodes are sequenced in such a way that we first
+ // encounter the block node, then all of its text nodes, so when iterating
+ // through the blockText and leafText we just need to remember a window of
+ // one block node and leaf node, respectively.
+
+ var _iterator7 = _createForOfIteratorHelper$5(Editor.nodes(editor, {
+ at: at,
+ reverse: reverse,
+ voids: voids
+ })),
+ _step7;
+
+ try {
+ for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) {
+ var _step7$value = _slicedToArray(_step7.value, 2),
+ node = _step7$value[0],
+ path = _step7$value[1];
+
+ /*
+ * ELEMENT NODE - Yield position(s) for voids, collect blockText for blocks
+ */
+ if (Element$1.isElement(node)) {
+ // Void nodes are a special case, so by default we will always
+ // yield their first point. If the `voids` option is set to true,
+ // then we will iterate over their content.
+ if (!voids && editor.isVoid(node)) {
+ yield Editor.start(editor, path);
+ continue;
+ } // Inline element nodes are ignored as they don't themselves
+ // contribute to `blockText` or `leafText` - their parent and
+ // children do.
+
+
+ if (editor.isInline(node)) continue; // Block element node - set `blockText` to its text content.
+
+ if (Editor.hasInlines(editor, node)) {
+ // We always exhaust block nodes before encountering a new one:
+ // console.assert(blockText === '',
+ // `blockText='${blockText}' - `+
+ // `not exhausted before new block node`, path)
+ // Ensure range considered is capped to `range`, in the
+ // start/end edge cases where block extends beyond range.
+ // Equivalent to this, but presumably more performant:
+ // blockRange = Editor.range(editor, ...Editor.edges(editor, path))
+ // blockRange = Range.intersection(range, blockRange) // intersect
+ // blockText = Editor.string(editor, blockRange, { voids })
+ var e = Path.isAncestor(path, end.path) ? end : Editor.end(editor, path);
+ var s = Path.isAncestor(path, start.path) ? start : Editor.start(editor, path);
+ blockText = Editor.string(editor, {
+ anchor: s,
+ focus: e
+ }, {
+ voids: voids
+ });
+ isNewBlock = true;
+ }
+ }
+ /*
+ * TEXT LEAF NODE - Iterate through text content, yielding
+ * positions every `distance` offset according to `unit`.
+ */
+
+
+ if (Text.isText(node)) {
+ var isFirst = Path.equals(path, first.path); // Proof that we always exhaust text nodes before encountering a new one:
+ // console.assert(leafTextRemaining <= 0,
+ // `leafTextRemaining=${leafTextRemaining} - `+
+ // `not exhausted before new leaf text node`, path)
+ // Reset `leafText` counters for new text node.
+
+ if (isFirst) {
+ leafTextRemaining = reverse ? first.offset : node.text.length - first.offset;
+ leafTextOffset = first.offset; // Works for reverse too.
+ } else {
+ leafTextRemaining = node.text.length;
+ leafTextOffset = reverse ? leafTextRemaining : 0;
+ } // Yield position at the start of node (potentially).
+
+
+ if (isFirst || isNewBlock || unit === 'offset') {
+ yield {
+ path: path,
+ offset: leafTextOffset
+ };
+ isNewBlock = false;
+ } // Yield positions every (dynamically calculated) `distance` offset.
+
+
+ while (true) {
+ // If `leafText` has caught up with `blockText` (distance=0),
+ // and if blockText is exhausted, break to get another block node,
+ // otherwise advance blockText forward by the new `distance`.
+ if (distance === 0) {
+ if (blockText === '') break;
+ distance = calcDistance(blockText, unit, reverse); // Split the string at the previously found distance and use the
+ // remaining string for the next iteration.
+
+ blockText = splitByCharacterDistance(blockText, distance, reverse)[1];
+ } // Advance `leafText` by the current `distance`.
+
+
+ leafTextOffset = reverse ? leafTextOffset - distance : leafTextOffset + distance;
+ leafTextRemaining = leafTextRemaining - distance; // If `leafText` is exhausted, break to get a new leaf node
+ // and set distance to the overflow amount, so we'll (maybe)
+ // catch up to blockText in the next leaf text node.
+
+ if (leafTextRemaining < 0) {
+ distance = -leafTextRemaining;
+ break;
+ } // Successfully walked `distance` offsets through `leafText`
+ // to catch up with `blockText`, so we can reset `distance`
+ // and yield this position in this node.
+
+
+ distance = 0;
+ yield {
+ path: path,
+ offset: leafTextOffset
+ };
+ }
+ }
+ } // Proof that upon completion, we've exahusted both leaf and block text:
+ // console.assert(leafTextRemaining <= 0, "leafText wasn't exhausted")
+ // console.assert(blockText === '', "blockText wasn't exhausted")
+ // Helper:
+ // Return the distance in offsets for a step of size `unit` on given string.
+
+ } catch (err) {
+ _iterator7.e(err);
+ } finally {
+ _iterator7.f();
+ }
+
+ function calcDistance(text, unit, reverse) {
+ if (unit === 'character') {
+ return getCharacterDistance(text, reverse);
+ } else if (unit === 'word') {
+ return getWordDistance(text, reverse);
+ } else if (unit === 'line' || unit === 'block') {
+ return text.length;
+ }
+
+ return 1;
+ }
+ },
+
+ /**
+ * Get the matching node in the branch of the document before a location.
+ */
+ previous: function previous(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$mode4 = options.mode,
+ mode = _options$mode4 === void 0 ? 'lowest' : _options$mode4,
+ _options$voids6 = options.voids,
+ voids = _options$voids6 === void 0 ? false : _options$voids6;
+ var match = options.match,
+ _options$at6 = options.at,
+ at = _options$at6 === void 0 ? editor.selection : _options$at6;
+
+ if (!at) {
+ return;
+ }
+
+ var pointBeforeLocation = Editor.before(editor, at, {
+ voids: voids
+ });
+
+ if (!pointBeforeLocation) {
+ return;
+ }
+
+ var _Editor$first = Editor.first(editor, []),
+ _Editor$first2 = _slicedToArray(_Editor$first, 2),
+ to = _Editor$first2[1]; // The search location is from the start of the document to the path of
+ // the point before the location passed in
+
+
+ var span = [pointBeforeLocation.path, to];
+
+ if (Path.isPath(at) && at.length === 0) {
+ throw new Error("Cannot get the previous node from the root node!");
+ }
+
+ if (match == null) {
+ if (Path.isPath(at)) {
+ var _Editor$parent3 = Editor.parent(editor, at),
+ _Editor$parent4 = _slicedToArray(_Editor$parent3, 1),
+ parent = _Editor$parent4[0];
+
+ match = function match(n) {
+ return parent.children.includes(n);
+ };
+ } else {
+ match = function match() {
+ return true;
+ };
+ }
+ }
+
+ var _Editor$nodes5 = Editor.nodes(editor, {
+ reverse: true,
+ at: span,
+ match: match,
+ mode: mode,
+ voids: voids
+ }),
+ _Editor$nodes6 = _slicedToArray(_Editor$nodes5, 1),
+ previous = _Editor$nodes6[0];
+
+ return previous;
+ },
+
+ /**
+ * Get a range of a location.
+ */
+ range: function range(editor, at, to) {
+ if (Range.isRange(at) && !to) {
+ return at;
+ }
+
+ var start = Editor.start(editor, at);
+ var end = Editor.end(editor, to || at);
+ return {
+ anchor: start,
+ focus: end
+ };
+ },
+
+ /**
+ * Create a mutable ref for a `Range` object, which will stay in sync as new
+ * operations are applied to the editor.
+ */
+ rangeRef: function rangeRef(editor, range) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var _options$affinity3 = options.affinity,
+ affinity = _options$affinity3 === void 0 ? 'forward' : _options$affinity3;
+ var ref = {
+ current: range,
+ affinity: affinity,
+ unref: function unref() {
+ var current = ref.current;
+ var rangeRefs = Editor.rangeRefs(editor);
+ rangeRefs["delete"](ref);
+ ref.current = null;
+ return current;
+ }
+ };
+ var refs = Editor.rangeRefs(editor);
+ refs.add(ref);
+ return ref;
+ },
+
+ /**
+ * Get the set of currently tracked range refs of the editor.
+ */
+ rangeRefs: function rangeRefs(editor) {
+ var refs = RANGE_REFS.get(editor);
+
+ if (!refs) {
+ refs = new Set();
+ RANGE_REFS.set(editor, refs);
+ }
+
+ return refs;
+ },
+
+ /**
+ * Remove a custom property from all of the leaf text nodes in the current
+ * selection.
+ *
+ * If the selection is currently collapsed, the removal will be stored on
+ * `editor.marks` and applied to the text inserted next.
+ */
+ removeMark: function removeMark(editor, key) {
+ editor.removeMark(key);
+ },
+
+ /**
+ * Manually set if the editor should currently be normalizing.
+ *
+ * Note: Using this incorrectly can leave the editor in an invalid state.
+ *
+ */
+ setNormalizing: function setNormalizing(editor, isNormalizing) {
+ NORMALIZING.set(editor, isNormalizing);
+ },
+
+ /**
+ * Get the start point of a location.
+ */
+ start: function start(editor, at) {
+ return Editor.point(editor, at, {
+ edge: 'start'
+ });
+ },
+
+ /**
+ * Get the text string content of a location.
+ *
+ * Note: by default the text of void nodes is considered to be an empty
+ * string, regardless of content, unless you pass in true for the voids option
+ */
+ string: function string(editor, at) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var _options$voids7 = options.voids,
+ voids = _options$voids7 === void 0 ? false : _options$voids7;
+ var range = Editor.range(editor, at);
+
+ var _Range$edges5 = Range.edges(range),
+ _Range$edges6 = _slicedToArray(_Range$edges5, 2),
+ start = _Range$edges6[0],
+ end = _Range$edges6[1];
+
+ var text = '';
+
+ var _iterator8 = _createForOfIteratorHelper$5(Editor.nodes(editor, {
+ at: range,
+ match: Text.isText,
+ voids: voids
+ })),
+ _step8;
+
+ try {
+ for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) {
+ var _step8$value = _slicedToArray(_step8.value, 2),
+ node = _step8$value[0],
+ path = _step8$value[1];
+
+ var t = node.text;
+
+ if (Path.equals(path, end.path)) {
+ t = t.slice(0, end.offset);
+ }
+
+ if (Path.equals(path, start.path)) {
+ t = t.slice(start.offset);
+ }
+
+ text += t;
+ }
+ } catch (err) {
+ _iterator8.e(err);
+ } finally {
+ _iterator8.f();
+ }
+
+ return text;
+ },
+
+ /**
+ * Convert a range into a non-hanging one.
+ */
+ unhangRange: function unhangRange(editor, range) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var _options$voids8 = options.voids,
+ voids = _options$voids8 === void 0 ? false : _options$voids8;
+
+ var _Range$edges7 = Range.edges(range),
+ _Range$edges8 = _slicedToArray(_Range$edges7, 2),
+ start = _Range$edges8[0],
+ end = _Range$edges8[1]; // PERF: exit early if we can guarantee that the range isn't hanging.
+
+
+ if (start.offset !== 0 || end.offset !== 0 || Range.isCollapsed(range)) {
+ return range;
+ }
+
+ var endBlock = Editor.above(editor, {
+ at: end,
+ match: function match(n) {
+ return Editor.isBlock(editor, n);
+ }
+ });
+ var blockPath = endBlock ? endBlock[1] : [];
+ var first = Editor.start(editor, []);
+ var before = {
+ anchor: first,
+ focus: end
+ };
+ var skip = true;
+
+ var _iterator9 = _createForOfIteratorHelper$5(Editor.nodes(editor, {
+ at: before,
+ match: Text.isText,
+ reverse: true,
+ voids: voids
+ })),
+ _step9;
+
+ try {
+ for (_iterator9.s(); !(_step9 = _iterator9.n()).done;) {
+ var _step9$value = _slicedToArray(_step9.value, 2),
+ node = _step9$value[0],
+ path = _step9$value[1];
+
+ if (skip) {
+ skip = false;
+ continue;
+ }
+
+ if (node.text !== '' || Path.isBefore(path, blockPath)) {
+ end = {
+ path: path,
+ offset: node.text.length
+ };
+ break;
+ }
+ }
+ } catch (err) {
+ _iterator9.e(err);
+ } finally {
+ _iterator9.f();
+ }
+
+ return {
+ anchor: start,
+ focus: end
+ };
+ },
+
+ /**
+ * Match a void node in the current branch of the editor.
+ */
+ "void": function _void(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ return Editor.above(editor, _objectSpread$8(_objectSpread$8({}, options), {}, {
+ match: function match(n) {
+ return Editor.isVoid(editor, n);
+ }
+ }));
+ },
+
+ /**
+ * Call a function, deferring normalization until after it completes.
+ */
+ withoutNormalizing: function withoutNormalizing(editor, fn) {
+ var value = Editor.isNormalizing(editor);
+ Editor.setNormalizing(editor, false);
+
+ try {
+ fn();
+ } finally {
+ Editor.setNormalizing(editor, value);
+ }
+
+ Editor.normalize(editor);
+ }
+ };
+
+ var Location = {
+ /**
+ * Check if a value implements the `Location` interface.
+ */
+ isLocation: function isLocation(value) {
+ return Path.isPath(value) || Point.isPoint(value) || Range.isRange(value);
+ }
+ };
+ var Span = {
+ /**
+ * Check if a value implements the `Span` interface.
+ */
+ isSpan: function isSpan(value) {
+ return Array.isArray(value) && value.length === 2 && value.every(Path.isPath);
+ }
+ };
+
+ var _excluded$3 = ["children"],
+ _excluded2$2 = ["text"];
+
+ function _createForOfIteratorHelper$4(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray$4(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; } } }; }
+
+ function _unsupportedIterableToArray$4(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray$4(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$4(o, minLen); }
+
+ function _arrayLikeToArray$4(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; }
+ var IS_NODE_LIST_CACHE = new WeakMap();
+ var Node$1 = {
+ /**
+ * Get the node at a specific path, asserting that it's an ancestor node.
+ */
+ ancestor: function ancestor(root, path) {
+ var node = Node$1.get(root, path);
+
+ if (Text.isText(node)) {
+ throw new Error("Cannot get the ancestor node at path [".concat(path, "] because it refers to a text node instead: ").concat(node));
+ }
+
+ return node;
+ },
+
+ /**
+ * Return a generator of all the ancestor nodes above a specific path.
+ *
+ * By default the order is bottom-up, from lowest to highest ancestor in
+ * the tree, but you can pass the `reverse: true` option to go top-down.
+ */
+ ancestors: function* ancestors(root, path) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+
+ var _iterator = _createForOfIteratorHelper$4(Path.ancestors(path, options)),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var p = _step.value;
+ var n = Node$1.ancestor(root, p);
+ var entry = [n, p];
+ yield entry;
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+ },
+
+ /**
+ * Get the child of a node at a specific index.
+ */
+ child: function child(root, index) {
+ if (Text.isText(root)) {
+ throw new Error("Cannot get the child of a text node: ".concat(JSON.stringify(root)));
+ }
+
+ var c = root.children[index];
+
+ if (c == null) {
+ throw new Error("Cannot get child at index `".concat(index, "` in node: ").concat(JSON.stringify(root)));
+ }
+
+ return c;
+ },
+
+ /**
+ * Iterate over the children of a node at a specific path.
+ */
+ children: function* children(root, path) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var _options$reverse = options.reverse,
+ reverse = _options$reverse === void 0 ? false : _options$reverse;
+ var ancestor = Node$1.ancestor(root, path);
+ var children = ancestor.children;
+ var index = reverse ? children.length - 1 : 0;
+
+ while (reverse ? index >= 0 : index < children.length) {
+ var child = Node$1.child(ancestor, index);
+ var childPath = path.concat(index);
+ yield [child, childPath];
+ index = reverse ? index - 1 : index + 1;
+ }
+ },
+
+ /**
+ * Get an entry for the common ancesetor node of two paths.
+ */
+ common: function common(root, path, another) {
+ var p = Path.common(path, another);
+ var n = Node$1.get(root, p);
+ return [n, p];
+ },
+
+ /**
+ * Get the node at a specific path, asserting that it's a descendant node.
+ */
+ descendant: function descendant(root, path) {
+ var node = Node$1.get(root, path);
+
+ if (Editor.isEditor(node)) {
+ throw new Error("Cannot get the descendant node at path [".concat(path, "] because it refers to the root editor node instead: ").concat(node));
+ }
+
+ return node;
+ },
+
+ /**
+ * Return a generator of all the descendant node entries inside a root node.
+ */
+ descendants: function* descendants(root) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+
+ var _iterator2 = _createForOfIteratorHelper$4(Node$1.nodes(root, options)),
+ _step2;
+
+ try {
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
+ var _step2$value = _slicedToArray(_step2.value, 2),
+ node = _step2$value[0],
+ path = _step2$value[1];
+
+ if (path.length !== 0) {
+ // NOTE: we have to coerce here because checking the path's length does
+ // guarantee that `node` is not a `Editor`, but TypeScript doesn't know.
+ yield [node, path];
+ }
+ }
+ } catch (err) {
+ _iterator2.e(err);
+ } finally {
+ _iterator2.f();
+ }
+ },
+
+ /**
+ * Return a generator of all the element nodes inside a root node. Each iteration
+ * will return an `ElementEntry` tuple consisting of `[Element, Path]`. If the
+ * root node is an element it will be included in the iteration as well.
+ */
+ elements: function* elements(root) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+
+ var _iterator3 = _createForOfIteratorHelper$4(Node$1.nodes(root, options)),
+ _step3;
+
+ try {
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
+ var _step3$value = _slicedToArray(_step3.value, 2),
+ node = _step3$value[0],
+ path = _step3$value[1];
+
+ if (Element$1.isElement(node)) {
+ yield [node, path];
+ }
+ }
+ } catch (err) {
+ _iterator3.e(err);
+ } finally {
+ _iterator3.f();
+ }
+ },
+
+ /**
+ * Extract props from a Node.
+ */
+ extractProps: function extractProps(node) {
+ if (Element$1.isAncestor(node)) {
+ node.children;
+ var properties = _objectWithoutProperties(node, _excluded$3);
+
+ return properties;
+ } else {
+ node.text;
+ var _properties = _objectWithoutProperties(node, _excluded2$2);
+
+ return _properties;
+ }
+ },
+
+ /**
+ * Get the first node entry in a root node from a path.
+ */
+ first: function first(root, path) {
+ var p = path.slice();
+ var n = Node$1.get(root, p);
+
+ while (n) {
+ if (Text.isText(n) || n.children.length === 0) {
+ break;
+ } else {
+ n = n.children[0];
+ p.push(0);
+ }
+ }
+
+ return [n, p];
+ },
+
+ /**
+ * Get the sliced fragment represented by a range inside a root node.
+ */
+ fragment: function fragment(root, range) {
+ if (Text.isText(root)) {
+ throw new Error("Cannot get a fragment starting from a root text node: ".concat(JSON.stringify(root)));
+ }
+
+ var newRoot = immer.produce({
+ children: root.children
+ }, function (r) {
+ var _Range$edges = Range.edges(range),
+ _Range$edges2 = _slicedToArray(_Range$edges, 2),
+ start = _Range$edges2[0],
+ end = _Range$edges2[1];
+
+ var nodeEntries = Node$1.nodes(r, {
+ reverse: true,
+ pass: function pass(_ref) {
+ var _ref2 = _slicedToArray(_ref, 2),
+ path = _ref2[1];
+
+ return !Range.includes(range, path);
+ }
+ });
+
+ var _iterator4 = _createForOfIteratorHelper$4(nodeEntries),
+ _step4;
+
+ try {
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
+ var _step4$value = _slicedToArray(_step4.value, 2),
+ path = _step4$value[1];
+
+ if (!Range.includes(range, path)) {
+ var parent = Node$1.parent(r, path);
+ var index = path[path.length - 1];
+ parent.children.splice(index, 1);
+ }
+
+ if (Path.equals(path, end.path)) {
+ var leaf = Node$1.leaf(r, path);
+ leaf.text = leaf.text.slice(0, end.offset);
+ }
+
+ if (Path.equals(path, start.path)) {
+ var _leaf = Node$1.leaf(r, path);
+
+ _leaf.text = _leaf.text.slice(start.offset);
+ }
+ }
+ } catch (err) {
+ _iterator4.e(err);
+ } finally {
+ _iterator4.f();
+ }
+
+ if (Editor.isEditor(r)) {
+ r.selection = null;
+ }
+ });
+ return newRoot.children;
+ },
+
+ /**
+ * Get the descendant node referred to by a specific path. If the path is an
+ * empty array, it refers to the root node itself.
+ */
+ get: function get(root, path) {
+ var node = root;
+
+ for (var i = 0; i < path.length; i++) {
+ var p = path[i];
+
+ if (Text.isText(node) || !node.children[p]) {
+ throw new Error("Cannot find a descendant at path [".concat(path, "] in node: ").concat(JSON.stringify(root)));
+ }
+
+ node = node.children[p];
+ }
+
+ return node;
+ },
+
+ /**
+ * Check if a descendant node exists at a specific path.
+ */
+ has: function has(root, path) {
+ var node = root;
+
+ for (var i = 0; i < path.length; i++) {
+ var p = path[i];
+
+ if (Text.isText(node) || !node.children[p]) {
+ return false;
+ }
+
+ node = node.children[p];
+ }
+
+ return true;
+ },
+
+ /**
+ * Check if a value implements the `Node` interface.
+ */
+ isNode: function isNode(value) {
+ return Text.isText(value) || Element$1.isElement(value) || Editor.isEditor(value);
+ },
+
+ /**
+ * Check if a value is a list of `Node` objects.
+ */
+ isNodeList: function isNodeList(value) {
+ if (!Array.isArray(value)) {
+ return false;
+ }
+
+ var cachedResult = IS_NODE_LIST_CACHE.get(value);
+
+ if (cachedResult !== undefined) {
+ return cachedResult;
+ }
+
+ var isNodeList = value.every(function (val) {
+ return Node$1.isNode(val);
+ });
+ IS_NODE_LIST_CACHE.set(value, isNodeList);
+ return isNodeList;
+ },
+
+ /**
+ * Get the last node entry in a root node from a path.
+ */
+ last: function last(root, path) {
+ var p = path.slice();
+ var n = Node$1.get(root, p);
+
+ while (n) {
+ if (Text.isText(n) || n.children.length === 0) {
+ break;
+ } else {
+ var i = n.children.length - 1;
+ n = n.children[i];
+ p.push(i);
+ }
+ }
+
+ return [n, p];
+ },
+
+ /**
+ * Get the node at a specific path, ensuring it's a leaf text node.
+ */
+ leaf: function leaf(root, path) {
+ var node = Node$1.get(root, path);
+
+ if (!Text.isText(node)) {
+ throw new Error("Cannot get the leaf node at path [".concat(path, "] because it refers to a non-leaf node: ").concat(node));
+ }
+
+ return node;
+ },
+
+ /**
+ * Return a generator of the in a branch of the tree, from a specific path.
+ *
+ * By default the order is top-down, from lowest to highest node in the tree,
+ * but you can pass the `reverse: true` option to go bottom-up.
+ */
+ levels: function* levels(root, path) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+
+ var _iterator5 = _createForOfIteratorHelper$4(Path.levels(path, options)),
+ _step5;
+
+ try {
+ for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
+ var p = _step5.value;
+ var n = Node$1.get(root, p);
+ yield [n, p];
+ }
+ } catch (err) {
+ _iterator5.e(err);
+ } finally {
+ _iterator5.f();
+ }
+ },
+
+ /**
+ * Check if a node matches a set of props.
+ */
+ matches: function matches(node, props) {
+ return Element$1.isElement(node) && Element$1.isElementProps(props) && Element$1.matches(node, props) || Text.isText(node) && Text.isTextProps(props) && Text.matches(node, props);
+ },
+
+ /**
+ * Return a generator of all the node entries of a root node. Each entry is
+ * returned as a `[Node, Path]` tuple, with the path referring to the node's
+ * position inside the root node.
+ */
+ nodes: function* nodes(root) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var pass = options.pass,
+ _options$reverse2 = options.reverse,
+ reverse = _options$reverse2 === void 0 ? false : _options$reverse2;
+ var _options$from = options.from,
+ from = _options$from === void 0 ? [] : _options$from,
+ to = options.to;
+ var visited = new Set();
+ var p = [];
+ var n = root;
+
+ while (true) {
+ if (to && (reverse ? Path.isBefore(p, to) : Path.isAfter(p, to))) {
+ break;
+ }
+
+ if (!visited.has(n)) {
+ yield [n, p];
+ } // If we're allowed to go downward and we haven't descended yet, do.
+
+
+ if (!visited.has(n) && !Text.isText(n) && n.children.length !== 0 && (pass == null || pass([n, p]) === false)) {
+ visited.add(n);
+ var nextIndex = reverse ? n.children.length - 1 : 0;
+
+ if (Path.isAncestor(p, from)) {
+ nextIndex = from[p.length];
+ }
+
+ p = p.concat(nextIndex);
+ n = Node$1.get(root, p);
+ continue;
+ } // If we're at the root and we can't go down, we're done.
+
+
+ if (p.length === 0) {
+ break;
+ } // If we're going forward...
+
+
+ if (!reverse) {
+ var newPath = Path.next(p);
+
+ if (Node$1.has(root, newPath)) {
+ p = newPath;
+ n = Node$1.get(root, p);
+ continue;
+ }
+ } // If we're going backward...
+
+
+ if (reverse && p[p.length - 1] !== 0) {
+ var _newPath = Path.previous(p);
+
+ p = _newPath;
+ n = Node$1.get(root, p);
+ continue;
+ } // Otherwise we're going upward...
+
+
+ p = Path.parent(p);
+ n = Node$1.get(root, p);
+ visited.add(n);
+ }
+ },
+
+ /**
+ * Get the parent of a node at a specific path.
+ */
+ parent: function parent(root, path) {
+ var parentPath = Path.parent(path);
+ var p = Node$1.get(root, parentPath);
+
+ if (Text.isText(p)) {
+ throw new Error("Cannot get the parent of path [".concat(path, "] because it does not exist in the root."));
+ }
+
+ return p;
+ },
+
+ /**
+ * Get the concatenated text string of a node's content.
+ *
+ * Note that this will not include spaces or line breaks between block nodes.
+ * It is not a user-facing string, but a string for performing offset-related
+ * computations for a node.
+ */
+ string: function string(node) {
+ if (Text.isText(node)) {
+ return node.text;
+ } else {
+ return node.children.map(Node$1.string).join('');
+ }
+ },
+
+ /**
+ * Return a generator of all leaf text nodes in a root node.
+ */
+ texts: function* texts(root) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+
+ var _iterator6 = _createForOfIteratorHelper$4(Node$1.nodes(root, options)),
+ _step6;
+
+ try {
+ for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) {
+ var _step6$value = _slicedToArray(_step6.value, 2),
+ node = _step6$value[0],
+ path = _step6$value[1];
+
+ if (Text.isText(node)) {
+ yield [node, path];
+ }
+ }
+ } catch (err) {
+ _iterator6.e(err);
+ } finally {
+ _iterator6.f();
+ }
+ }
+ };
+
+ function ownKeys$7(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread$7(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$7(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$7(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+ var Operation = {
+ /**
+ * Check of a value is a `NodeOperation` object.
+ */
+ isNodeOperation: function isNodeOperation(value) {
+ return Operation.isOperation(value) && value.type.endsWith('_node');
+ },
+
+ /**
+ * Check of a value is an `Operation` object.
+ */
+ isOperation: function isOperation(value) {
+ if (!isPlainObject.isPlainObject(value)) {
+ return false;
+ }
+
+ switch (value.type) {
+ case 'insert_node':
+ return Path.isPath(value.path) && Node$1.isNode(value.node);
+
+ case 'insert_text':
+ return typeof value.offset === 'number' && typeof value.text === 'string' && Path.isPath(value.path);
+
+ case 'merge_node':
+ return typeof value.position === 'number' && Path.isPath(value.path) && isPlainObject.isPlainObject(value.properties);
+
+ case 'move_node':
+ return Path.isPath(value.path) && Path.isPath(value.newPath);
+
+ case 'remove_node':
+ return Path.isPath(value.path) && Node$1.isNode(value.node);
+
+ case 'remove_text':
+ return typeof value.offset === 'number' && typeof value.text === 'string' && Path.isPath(value.path);
+
+ case 'set_node':
+ return Path.isPath(value.path) && isPlainObject.isPlainObject(value.properties) && isPlainObject.isPlainObject(value.newProperties);
+
+ case 'set_selection':
+ return value.properties === null && Range.isRange(value.newProperties) || value.newProperties === null && Range.isRange(value.properties) || isPlainObject.isPlainObject(value.properties) && isPlainObject.isPlainObject(value.newProperties);
+
+ case 'split_node':
+ return Path.isPath(value.path) && typeof value.position === 'number' && isPlainObject.isPlainObject(value.properties);
+
+ default:
+ return false;
+ }
+ },
+
+ /**
+ * Check if a value is a list of `Operation` objects.
+ */
+ isOperationList: function isOperationList(value) {
+ return Array.isArray(value) && value.every(function (val) {
+ return Operation.isOperation(val);
+ });
+ },
+
+ /**
+ * Check of a value is a `SelectionOperation` object.
+ */
+ isSelectionOperation: function isSelectionOperation(value) {
+ return Operation.isOperation(value) && value.type.endsWith('_selection');
+ },
+
+ /**
+ * Check of a value is a `TextOperation` object.
+ */
+ isTextOperation: function isTextOperation(value) {
+ return Operation.isOperation(value) && value.type.endsWith('_text');
+ },
+
+ /**
+ * Invert an operation, returning a new operation that will exactly undo the
+ * original when applied.
+ */
+ inverse: function inverse(op) {
+ switch (op.type) {
+ case 'insert_node':
+ {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ type: 'remove_node'
+ });
+ }
+
+ case 'insert_text':
+ {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ type: 'remove_text'
+ });
+ }
+
+ case 'merge_node':
+ {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ type: 'split_node',
+ path: Path.previous(op.path)
+ });
+ }
+
+ case 'move_node':
+ {
+ var newPath = op.newPath,
+ path = op.path; // PERF: in this case the move operation is a no-op anyways.
+
+ if (Path.equals(newPath, path)) {
+ return op;
+ } // If the move happens completely within a single parent the path and
+ // newPath are stable with respect to each other.
+
+
+ if (Path.isSibling(path, newPath)) {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ path: newPath,
+ newPath: path
+ });
+ } // If the move does not happen within a single parent it is possible
+ // for the move to impact the true path to the location where the node
+ // was removed from and where it was inserted. We have to adjust for this
+ // and find the original path. We can accomplish this (only in non-sibling)
+ // moves by looking at the impact of the move operation on the node
+ // after the original move path.
+
+
+ var inversePath = Path.transform(path, op);
+ var inverseNewPath = Path.transform(Path.next(path), op);
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ path: inversePath,
+ newPath: inverseNewPath
+ });
+ }
+
+ case 'remove_node':
+ {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ type: 'insert_node'
+ });
+ }
+
+ case 'remove_text':
+ {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ type: 'insert_text'
+ });
+ }
+
+ case 'set_node':
+ {
+ var properties = op.properties,
+ newProperties = op.newProperties;
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ properties: newProperties,
+ newProperties: properties
+ });
+ }
+
+ case 'set_selection':
+ {
+ var _properties = op.properties,
+ _newProperties = op.newProperties;
+
+ if (_properties == null) {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ properties: _newProperties,
+ newProperties: null
+ });
+ } else if (_newProperties == null) {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ properties: null,
+ newProperties: _properties
+ });
+ } else {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ properties: _newProperties,
+ newProperties: _properties
+ });
+ }
+ }
+
+ case 'split_node':
+ {
+ return _objectSpread$7(_objectSpread$7({}, op), {}, {
+ type: 'merge_node',
+ path: Path.next(op.path)
+ });
+ }
+ }
+ }
+ };
+
+ var Path = {
+ /**
+ * Get a list of ancestor paths for a given path.
+ *
+ * The paths are sorted from deepest to shallowest ancestor. However, if the
+ * `reverse: true` option is passed, they are reversed.
+ */
+ ancestors: function ancestors(path) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$reverse = options.reverse,
+ reverse = _options$reverse === void 0 ? false : _options$reverse;
+ var paths = Path.levels(path, options);
+
+ if (reverse) {
+ paths = paths.slice(1);
+ } else {
+ paths = paths.slice(0, -1);
+ }
+
+ return paths;
+ },
+
+ /**
+ * Get the common ancestor path of two paths.
+ */
+ common: function common(path, another) {
+ var common = [];
+
+ for (var i = 0; i < path.length && i < another.length; i++) {
+ var av = path[i];
+ var bv = another[i];
+
+ if (av !== bv) {
+ break;
+ }
+
+ common.push(av);
+ }
+
+ return common;
+ },
+
+ /**
+ * Compare a path to another, returning an integer indicating whether the path
+ * was before, at, or after the other.
+ *
+ * Note: Two paths of unequal length can still receive a `0` result if one is
+ * directly above or below the other. If you want exact matching, use
+ * [[Path.equals]] instead.
+ */
+ compare: function compare(path, another) {
+ var min = Math.min(path.length, another.length);
+
+ for (var i = 0; i < min; i++) {
+ if (path[i] < another[i]) return -1;
+ if (path[i] > another[i]) return 1;
+ }
+
+ return 0;
+ },
+
+ /**
+ * Check if a path ends after one of the indexes in another.
+ */
+ endsAfter: function endsAfter(path, another) {
+ var i = path.length - 1;
+ var as = path.slice(0, i);
+ var bs = another.slice(0, i);
+ var av = path[i];
+ var bv = another[i];
+ return Path.equals(as, bs) && av > bv;
+ },
+
+ /**
+ * Check if a path ends at one of the indexes in another.
+ */
+ endsAt: function endsAt(path, another) {
+ var i = path.length;
+ var as = path.slice(0, i);
+ var bs = another.slice(0, i);
+ return Path.equals(as, bs);
+ },
+
+ /**
+ * Check if a path ends before one of the indexes in another.
+ */
+ endsBefore: function endsBefore(path, another) {
+ var i = path.length - 1;
+ var as = path.slice(0, i);
+ var bs = another.slice(0, i);
+ var av = path[i];
+ var bv = another[i];
+ return Path.equals(as, bs) && av < bv;
+ },
+
+ /**
+ * Check if a path is exactly equal to another.
+ */
+ equals: function equals(path, another) {
+ return path.length === another.length && path.every(function (n, i) {
+ return n === another[i];
+ });
+ },
+
+ /**
+ * Check if the path of previous sibling node exists
+ */
+ hasPrevious: function hasPrevious(path) {
+ return path[path.length - 1] > 0;
+ },
+
+ /**
+ * Check if a path is after another.
+ */
+ isAfter: function isAfter(path, another) {
+ return Path.compare(path, another) === 1;
+ },
+
+ /**
+ * Check if a path is an ancestor of another.
+ */
+ isAncestor: function isAncestor(path, another) {
+ return path.length < another.length && Path.compare(path, another) === 0;
+ },
+
+ /**
+ * Check if a path is before another.
+ */
+ isBefore: function isBefore(path, another) {
+ return Path.compare(path, another) === -1;
+ },
+
+ /**
+ * Check if a path is a child of another.
+ */
+ isChild: function isChild(path, another) {
+ return path.length === another.length + 1 && Path.compare(path, another) === 0;
+ },
+
+ /**
+ * Check if a path is equal to or an ancestor of another.
+ */
+ isCommon: function isCommon(path, another) {
+ return path.length <= another.length && Path.compare(path, another) === 0;
+ },
+
+ /**
+ * Check if a path is a descendant of another.
+ */
+ isDescendant: function isDescendant(path, another) {
+ return path.length > another.length && Path.compare(path, another) === 0;
+ },
+
+ /**
+ * Check if a path is the parent of another.
+ */
+ isParent: function isParent(path, another) {
+ return path.length + 1 === another.length && Path.compare(path, another) === 0;
+ },
+
+ /**
+ * Check is a value implements the `Path` interface.
+ */
+ isPath: function isPath(value) {
+ return Array.isArray(value) && (value.length === 0 || typeof value[0] === 'number');
+ },
+
+ /**
+ * Check if a path is a sibling of another.
+ */
+ isSibling: function isSibling(path, another) {
+ if (path.length !== another.length) {
+ return false;
+ }
+
+ var as = path.slice(0, -1);
+ var bs = another.slice(0, -1);
+ var al = path[path.length - 1];
+ var bl = another[another.length - 1];
+ return al !== bl && Path.equals(as, bs);
+ },
+
+ /**
+ * Get a list of paths at every level down to a path. Note: this is the same
+ * as `Path.ancestors`, but including the path itself.
+ *
+ * The paths are sorted from shallowest to deepest. However, if the `reverse:
+ * true` option is passed, they are reversed.
+ */
+ levels: function levels(path) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$reverse2 = options.reverse,
+ reverse = _options$reverse2 === void 0 ? false : _options$reverse2;
+ var list = [];
+
+ for (var i = 0; i <= path.length; i++) {
+ list.push(path.slice(0, i));
+ }
+
+ if (reverse) {
+ list.reverse();
+ }
+
+ return list;
+ },
+
+ /**
+ * Given a path, get the path to the next sibling node.
+ */
+ next: function next(path) {
+ if (path.length === 0) {
+ throw new Error("Cannot get the next path of a root path [".concat(path, "], because it has no next index."));
+ }
+
+ var last = path[path.length - 1];
+ return path.slice(0, -1).concat(last + 1);
+ },
+
+ /**
+ * Given a path, return a new path referring to the parent node above it.
+ */
+ parent: function parent(path) {
+ if (path.length === 0) {
+ throw new Error("Cannot get the parent path of the root path [".concat(path, "]."));
+ }
+
+ return path.slice(0, -1);
+ },
+
+ /**
+ * Given a path, get the path to the previous sibling node.
+ */
+ previous: function previous(path) {
+ if (path.length === 0) {
+ throw new Error("Cannot get the previous path of a root path [".concat(path, "], because it has no previous index."));
+ }
+
+ var last = path[path.length - 1];
+
+ if (last <= 0) {
+ throw new Error("Cannot get the previous path of a first child path [".concat(path, "] because it would result in a negative index."));
+ }
+
+ return path.slice(0, -1).concat(last - 1);
+ },
+
+ /**
+ * Get a path relative to an ancestor.
+ */
+ relative: function relative(path, ancestor) {
+ if (!Path.isAncestor(ancestor, path) && !Path.equals(path, ancestor)) {
+ throw new Error("Cannot get the relative path of [".concat(path, "] inside ancestor [").concat(ancestor, "], because it is not above or equal to the path."));
+ }
+
+ return path.slice(ancestor.length);
+ },
+
+ /**
+ * Transform a path by an operation.
+ */
+ transform: function transform(path, operation) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ return immer.produce(path, function (p) {
+ var _options$affinity = options.affinity,
+ affinity = _options$affinity === void 0 ? 'forward' : _options$affinity; // PERF: Exit early if the operation is guaranteed not to have an effect.
+
+ if (!path || (path === null || path === void 0 ? void 0 : path.length) === 0) {
+ return;
+ }
+
+ if (p === null) {
+ return null;
+ }
+
+ switch (operation.type) {
+ case 'insert_node':
+ {
+ var op = operation.path;
+
+ if (Path.equals(op, p) || Path.endsBefore(op, p) || Path.isAncestor(op, p)) {
+ p[op.length - 1] += 1;
+ }
+
+ break;
+ }
+
+ case 'remove_node':
+ {
+ var _op = operation.path;
+
+ if (Path.equals(_op, p) || Path.isAncestor(_op, p)) {
+ return null;
+ } else if (Path.endsBefore(_op, p)) {
+ p[_op.length - 1] -= 1;
+ }
+
+ break;
+ }
+
+ case 'merge_node':
+ {
+ var _op2 = operation.path,
+ position = operation.position;
+
+ if (Path.equals(_op2, p) || Path.endsBefore(_op2, p)) {
+ p[_op2.length - 1] -= 1;
+ } else if (Path.isAncestor(_op2, p)) {
+ p[_op2.length - 1] -= 1;
+ p[_op2.length] += position;
+ }
+
+ break;
+ }
+
+ case 'split_node':
+ {
+ var _op3 = operation.path,
+ _position = operation.position;
+
+ if (Path.equals(_op3, p)) {
+ if (affinity === 'forward') {
+ p[p.length - 1] += 1;
+ } else if (affinity === 'backward') ; else {
+ return null;
+ }
+ } else if (Path.endsBefore(_op3, p)) {
+ p[_op3.length - 1] += 1;
+ } else if (Path.isAncestor(_op3, p) && path[_op3.length] >= _position) {
+ p[_op3.length - 1] += 1;
+ p[_op3.length] -= _position;
+ }
+
+ break;
+ }
+
+ case 'move_node':
+ {
+ var _op4 = operation.path,
+ onp = operation.newPath; // If the old and new path are the same, it's a no-op.
+
+ if (Path.equals(_op4, onp)) {
+ return;
+ }
+
+ if (Path.isAncestor(_op4, p) || Path.equals(_op4, p)) {
+ var copy = onp.slice();
+
+ if (Path.endsBefore(_op4, onp) && _op4.length < onp.length) {
+ copy[_op4.length - 1] -= 1;
+ }
+
+ return copy.concat(p.slice(_op4.length));
+ } else if (Path.isSibling(_op4, onp) && (Path.isAncestor(onp, p) || Path.equals(onp, p))) {
+ if (Path.endsBefore(_op4, p)) {
+ p[_op4.length - 1] -= 1;
+ } else {
+ p[_op4.length - 1] += 1;
+ }
+ } else if (Path.endsBefore(onp, p) || Path.equals(onp, p) || Path.isAncestor(onp, p)) {
+ if (Path.endsBefore(_op4, p)) {
+ p[_op4.length - 1] -= 1;
+ }
+
+ p[onp.length - 1] += 1;
+ } else if (Path.endsBefore(_op4, p)) {
+ if (Path.equals(onp, p)) {
+ p[onp.length - 1] += 1;
+ }
+
+ p[_op4.length - 1] -= 1;
+ }
+
+ break;
+ }
+ }
+ });
+ }
+ };
+
+ var PathRef = {
+ /**
+ * Transform the path ref's current value by an operation.
+ */
+ transform: function transform(ref, op) {
+ var current = ref.current,
+ affinity = ref.affinity;
+
+ if (current == null) {
+ return;
+ }
+
+ var path = Path.transform(current, op, {
+ affinity: affinity
+ });
+ ref.current = path;
+
+ if (path == null) {
+ ref.unref();
+ }
+ }
+ };
+
+ function ownKeys$6(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread$6(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$6(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$6(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+ var Point = {
+ /**
+ * Compare a point to another, returning an integer indicating whether the
+ * point was before, at, or after the other.
+ */
+ compare: function compare(point, another) {
+ var result = Path.compare(point.path, another.path);
+
+ if (result === 0) {
+ if (point.offset < another.offset) return -1;
+ if (point.offset > another.offset) return 1;
+ return 0;
+ }
+
+ return result;
+ },
+
+ /**
+ * Check if a point is after another.
+ */
+ isAfter: function isAfter(point, another) {
+ return Point.compare(point, another) === 1;
+ },
+
+ /**
+ * Check if a point is before another.
+ */
+ isBefore: function isBefore(point, another) {
+ return Point.compare(point, another) === -1;
+ },
+
+ /**
+ * Check if a point is exactly equal to another.
+ */
+ equals: function equals(point, another) {
+ // PERF: ensure the offsets are equal first since they are cheaper to check.
+ return point.offset === another.offset && Path.equals(point.path, another.path);
+ },
+
+ /**
+ * Check if a value implements the `Point` interface.
+ */
+ isPoint: function isPoint(value) {
+ return isPlainObject.isPlainObject(value) && typeof value.offset === 'number' && Path.isPath(value.path);
+ },
+
+ /**
+ * Transform a point by an operation.
+ */
+ transform: function transform(point, op) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ return immer.produce(point, function (p) {
+ if (p === null) {
+ return null;
+ }
+
+ var _options$affinity = options.affinity,
+ affinity = _options$affinity === void 0 ? 'forward' : _options$affinity;
+ var path = p.path,
+ offset = p.offset;
+
+ switch (op.type) {
+ case 'insert_node':
+ case 'move_node':
+ {
+ p.path = Path.transform(path, op, options);
+ break;
+ }
+
+ case 'insert_text':
+ {
+ if (Path.equals(op.path, path) && op.offset <= offset) {
+ p.offset += op.text.length;
+ }
+
+ break;
+ }
+
+ case 'merge_node':
+ {
+ if (Path.equals(op.path, path)) {
+ p.offset += op.position;
+ }
+
+ p.path = Path.transform(path, op, options);
+ break;
+ }
+
+ case 'remove_text':
+ {
+ if (Path.equals(op.path, path) && op.offset <= offset) {
+ p.offset -= Math.min(offset - op.offset, op.text.length);
+ }
+
+ break;
+ }
+
+ case 'remove_node':
+ {
+ if (Path.equals(op.path, path) || Path.isAncestor(op.path, path)) {
+ return null;
+ }
+
+ p.path = Path.transform(path, op, options);
+ break;
+ }
+
+ case 'split_node':
+ {
+ if (Path.equals(op.path, path)) {
+ if (op.position === offset && affinity == null) {
+ return null;
+ } else if (op.position < offset || op.position === offset && affinity === 'forward') {
+ p.offset -= op.position;
+ p.path = Path.transform(path, op, _objectSpread$6(_objectSpread$6({}, options), {}, {
+ affinity: 'forward'
+ }));
+ }
+ } else {
+ p.path = Path.transform(path, op, options);
+ }
+
+ break;
+ }
+ }
+ });
+ }
+ };
+
+ var PointRef = {
+ /**
+ * Transform the point ref's current value by an operation.
+ */
+ transform: function transform(ref, op) {
+ var current = ref.current,
+ affinity = ref.affinity;
+
+ if (current == null) {
+ return;
+ }
+
+ var point = Point.transform(current, op, {
+ affinity: affinity
+ });
+ ref.current = point;
+
+ if (point == null) {
+ ref.unref();
+ }
+ }
+ };
+
+ var _excluded$2 = ["anchor", "focus"];
+
+ function ownKeys$5(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread$5(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$5(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$5(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+ var Range = {
+ /**
+ * Get the start and end points of a range, in the order in which they appear
+ * in the document.
+ */
+ edges: function edges(range) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$reverse = options.reverse,
+ reverse = _options$reverse === void 0 ? false : _options$reverse;
+ var anchor = range.anchor,
+ focus = range.focus;
+ return Range.isBackward(range) === reverse ? [anchor, focus] : [focus, anchor];
+ },
+
+ /**
+ * Get the end point of a range.
+ */
+ end: function end(range) {
+ var _Range$edges = Range.edges(range),
+ _Range$edges2 = _slicedToArray(_Range$edges, 2),
+ end = _Range$edges2[1];
+
+ return end;
+ },
+
+ /**
+ * Check if a range is exactly equal to another.
+ */
+ equals: function equals(range, another) {
+ return Point.equals(range.anchor, another.anchor) && Point.equals(range.focus, another.focus);
+ },
+
+ /**
+ * Check if a range includes a path, a point or part of another range.
+ */
+ includes: function includes(range, target) {
+ if (Range.isRange(target)) {
+ if (Range.includes(range, target.anchor) || Range.includes(range, target.focus)) {
+ return true;
+ }
+
+ var _Range$edges3 = Range.edges(range),
+ _Range$edges4 = _slicedToArray(_Range$edges3, 2),
+ rs = _Range$edges4[0],
+ re = _Range$edges4[1];
+
+ var _Range$edges5 = Range.edges(target),
+ _Range$edges6 = _slicedToArray(_Range$edges5, 2),
+ ts = _Range$edges6[0],
+ te = _Range$edges6[1];
+
+ return Point.isBefore(rs, ts) && Point.isAfter(re, te);
+ }
+
+ var _Range$edges7 = Range.edges(range),
+ _Range$edges8 = _slicedToArray(_Range$edges7, 2),
+ start = _Range$edges8[0],
+ end = _Range$edges8[1];
+
+ var isAfterStart = false;
+ var isBeforeEnd = false;
+
+ if (Point.isPoint(target)) {
+ isAfterStart = Point.compare(target, start) >= 0;
+ isBeforeEnd = Point.compare(target, end) <= 0;
+ } else {
+ isAfterStart = Path.compare(target, start.path) >= 0;
+ isBeforeEnd = Path.compare(target, end.path) <= 0;
+ }
+
+ return isAfterStart && isBeforeEnd;
+ },
+
+ /**
+ * Get the intersection of a range with another.
+ */
+ intersection: function intersection(range, another) {
+ range.anchor;
+ range.focus;
+ var rest = _objectWithoutProperties(range, _excluded$2);
+
+ var _Range$edges9 = Range.edges(range),
+ _Range$edges10 = _slicedToArray(_Range$edges9, 2),
+ s1 = _Range$edges10[0],
+ e1 = _Range$edges10[1];
+
+ var _Range$edges11 = Range.edges(another),
+ _Range$edges12 = _slicedToArray(_Range$edges11, 2),
+ s2 = _Range$edges12[0],
+ e2 = _Range$edges12[1];
+
+ var start = Point.isBefore(s1, s2) ? s2 : s1;
+ var end = Point.isBefore(e1, e2) ? e1 : e2;
+
+ if (Point.isBefore(end, start)) {
+ return null;
+ } else {
+ return _objectSpread$5({
+ anchor: start,
+ focus: end
+ }, rest);
+ }
+ },
+
+ /**
+ * Check if a range is backward, meaning that its anchor point appears in the
+ * document _after_ its focus point.
+ */
+ isBackward: function isBackward(range) {
+ var anchor = range.anchor,
+ focus = range.focus;
+ return Point.isAfter(anchor, focus);
+ },
+
+ /**
+ * Check if a range is collapsed, meaning that both its anchor and focus
+ * points refer to the exact same position in the document.
+ */
+ isCollapsed: function isCollapsed(range) {
+ var anchor = range.anchor,
+ focus = range.focus;
+ return Point.equals(anchor, focus);
+ },
+
+ /**
+ * Check if a range is expanded.
+ *
+ * This is the opposite of [[Range.isCollapsed]] and is provided for legibility.
+ */
+ isExpanded: function isExpanded(range) {
+ return !Range.isCollapsed(range);
+ },
+
+ /**
+ * Check if a range is forward.
+ *
+ * This is the opposite of [[Range.isBackward]] and is provided for legibility.
+ */
+ isForward: function isForward(range) {
+ return !Range.isBackward(range);
+ },
+
+ /**
+ * Check if a value implements the [[Range]] interface.
+ */
+ isRange: function isRange(value) {
+ return isPlainObject.isPlainObject(value) && Point.isPoint(value.anchor) && Point.isPoint(value.focus);
+ },
+
+ /**
+ * Iterate through all of the point entries in a range.
+ */
+ points: function* points(range) {
+ yield [range.anchor, 'anchor'];
+ yield [range.focus, 'focus'];
+ },
+
+ /**
+ * Get the start point of a range.
+ */
+ start: function start(range) {
+ var _Range$edges13 = Range.edges(range),
+ _Range$edges14 = _slicedToArray(_Range$edges13, 1),
+ start = _Range$edges14[0];
+
+ return start;
+ },
+
+ /**
+ * Transform a range by an operation.
+ */
+ transform: function transform(range, op) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ return immer.produce(range, function (r) {
+ if (r === null) {
+ return null;
+ }
+
+ var _options$affinity = options.affinity,
+ affinity = _options$affinity === void 0 ? 'inward' : _options$affinity;
+ var affinityAnchor;
+ var affinityFocus;
+
+ if (affinity === 'inward') {
+ // If the range is collapsed, make sure to use the same affinity to
+ // avoid the two points passing each other and expanding in the opposite
+ // direction
+ var isCollapsed = Range.isCollapsed(r);
+
+ if (Range.isForward(r)) {
+ affinityAnchor = 'forward';
+ affinityFocus = isCollapsed ? affinityAnchor : 'backward';
+ } else {
+ affinityAnchor = 'backward';
+ affinityFocus = isCollapsed ? affinityAnchor : 'forward';
+ }
+ } else if (affinity === 'outward') {
+ if (Range.isForward(r)) {
+ affinityAnchor = 'backward';
+ affinityFocus = 'forward';
+ } else {
+ affinityAnchor = 'forward';
+ affinityFocus = 'backward';
+ }
+ } else {
+ affinityAnchor = affinity;
+ affinityFocus = affinity;
+ }
+
+ var anchor = Point.transform(r.anchor, op, {
+ affinity: affinityAnchor
+ });
+ var focus = Point.transform(r.focus, op, {
+ affinity: affinityFocus
+ });
+
+ if (!anchor || !focus) {
+ return null;
+ }
+
+ r.anchor = anchor;
+ r.focus = focus;
+ });
+ }
+ };
+
+ var RangeRef = {
+ /**
+ * Transform the range ref's current value by an operation.
+ */
+ transform: function transform(ref, op) {
+ var current = ref.current,
+ affinity = ref.affinity;
+
+ if (current == null) {
+ return;
+ }
+
+ var path = Range.transform(current, op, {
+ affinity: affinity
+ });
+ ref.current = path;
+
+ if (path == null) {
+ ref.unref();
+ }
+ }
+ };
+
+ /*
+ Custom deep equal comparison for Slate nodes.
+
+ We don't need general purpose deep equality;
+ Slate only supports plain values, Arrays, and nested objects.
+ Complex values nested inside Arrays are not supported.
+
+ Slate objects are designed to be serialised, so
+ missing keys are deliberately normalised to undefined.
+ */
+
+ var isDeepEqual = function isDeepEqual(node, another) {
+ for (var key in node) {
+ var a = node[key];
+ var b = another[key];
+
+ if (isPlainObject.isPlainObject(a) && isPlainObject.isPlainObject(b)) {
+ if (!isDeepEqual(a, b)) return false;
+ } else if (Array.isArray(a) && Array.isArray(b)) {
+ if (a.length !== b.length) return false;
+
+ for (var i = 0; i < a.length; i++) {
+ if (a[i] !== b[i]) return false;
+ }
+ } else if (a !== b) {
+ return false;
+ }
+ }
+ /*
+ Deep object equality is only necessary in one direction; in the reverse direction
+ we are only looking for keys that are missing.
+ As above, undefined keys are normalised to missing.
+ */
+
+
+ for (var _key in another) {
+ if (node[_key] === undefined && another[_key] !== undefined) {
+ return false;
+ }
+ }
+
+ return true;
+ };
+
+ var _excluded$1 = ["text"],
+ _excluded2$1 = ["anchor", "focus"];
+
+ function _createForOfIteratorHelper$3(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray$3(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; } } }; }
+
+ function _unsupportedIterableToArray$3(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray$3(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$3(o, minLen); }
+
+ function _arrayLikeToArray$3(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; }
+
+ function ownKeys$4(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread$4(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$4(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$4(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+ var Text = {
+ /**
+ * Check if two text nodes are equal.
+ *
+ * When loose is set, the text is not compared. This is
+ * used to check whether sibling text nodes can be merged.
+ */
+ equals: function equals(text, another) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var _options$loose = options.loose,
+ loose = _options$loose === void 0 ? false : _options$loose;
+
+ function omitText(obj) {
+ obj.text;
+ var rest = _objectWithoutProperties(obj, _excluded$1);
+
+ return rest;
+ }
+
+ return isDeepEqual(loose ? omitText(text) : text, loose ? omitText(another) : another);
+ },
+
+ /**
+ * Check if a value implements the `Text` interface.
+ */
+ isText: function isText(value) {
+ return isPlainObject.isPlainObject(value) && typeof value.text === 'string';
+ },
+
+ /**
+ * Check if a value is a list of `Text` objects.
+ */
+ isTextList: function isTextList(value) {
+ return Array.isArray(value) && value.every(function (val) {
+ return Text.isText(val);
+ });
+ },
+
+ /**
+ * Check if some props are a partial of Text.
+ */
+ isTextProps: function isTextProps(props) {
+ return props.text !== undefined;
+ },
+
+ /**
+ * Check if an text matches set of properties.
+ *
+ * Note: this is for matching custom properties, and it does not ensure that
+ * the `text` property are two nodes equal.
+ */
+ matches: function matches(text, props) {
+ for (var key in props) {
+ if (key === 'text') {
+ continue;
+ }
+
+ if (!text.hasOwnProperty(key) || text[key] !== props[key]) {
+ return false;
+ }
+ }
+
+ return true;
+ },
+
+ /**
+ * Get the leaves for a text node given decorations.
+ */
+ decorations: function decorations(node, _decorations) {
+ var leaves = [_objectSpread$4({}, node)];
+
+ var _iterator = _createForOfIteratorHelper$3(_decorations),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var dec = _step.value;
+
+ var anchor = dec.anchor,
+ focus = dec.focus,
+ rest = _objectWithoutProperties(dec, _excluded2$1);
+
+ var _Range$edges = Range.edges(dec),
+ _Range$edges2 = _slicedToArray(_Range$edges, 2),
+ start = _Range$edges2[0],
+ end = _Range$edges2[1];
+
+ var next = [];
+ var o = 0;
+
+ var _iterator2 = _createForOfIteratorHelper$3(leaves),
+ _step2;
+
+ try {
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
+ var leaf = _step2.value;
+ var length = leaf.text.length;
+ var offset = o;
+ o += length; // If the range encompases the entire leaf, add the range.
+
+ if (start.offset <= offset && end.offset >= o) {
+ Object.assign(leaf, rest);
+ next.push(leaf);
+ continue;
+ } // If the range expanded and match the leaf, or starts after, or ends before it, continue.
+
+
+ if (start.offset !== end.offset && (start.offset === o || end.offset === offset) || start.offset > o || end.offset < offset || end.offset === offset && offset !== 0) {
+ next.push(leaf);
+ continue;
+ } // Otherwise we need to split the leaf, at the start, end, or both,
+ // and add the range to the middle intersecting section. Do the end
+ // split first since we don't need to update the offset that way.
+
+
+ var middle = leaf;
+ var before = void 0;
+ var after = void 0;
+
+ if (end.offset < o) {
+ var off = end.offset - offset;
+ after = _objectSpread$4(_objectSpread$4({}, middle), {}, {
+ text: middle.text.slice(off)
+ });
+ middle = _objectSpread$4(_objectSpread$4({}, middle), {}, {
+ text: middle.text.slice(0, off)
+ });
+ }
+
+ if (start.offset > offset) {
+ var _off = start.offset - offset;
+
+ before = _objectSpread$4(_objectSpread$4({}, middle), {}, {
+ text: middle.text.slice(0, _off)
+ });
+ middle = _objectSpread$4(_objectSpread$4({}, middle), {}, {
+ text: middle.text.slice(_off)
+ });
+ }
+
+ Object.assign(middle, rest);
+
+ if (before) {
+ next.push(before);
+ }
+
+ next.push(middle);
+
+ if (after) {
+ next.push(after);
+ }
+ }
+ } catch (err) {
+ _iterator2.e(err);
+ } finally {
+ _iterator2.f();
+ }
+
+ leaves = next;
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+
+ return leaves;
+ }
+ };
+
+ function ownKeys$3(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$3(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$3(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+
+ function _createForOfIteratorHelper$2(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray$2(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; } } }; }
+
+ function _unsupportedIterableToArray$2(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray$2(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$2(o, minLen); }
+
+ function _arrayLikeToArray$2(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; }
+
+ var applyToDraft = function applyToDraft(editor, selection, op) {
+ switch (op.type) {
+ case 'insert_node':
+ {
+ var path = op.path,
+ node = op.node;
+ var parent = Node$1.parent(editor, path);
+ var index = path[path.length - 1];
+
+ if (index > parent.children.length) {
+ throw new Error("Cannot apply an \"insert_node\" operation at path [".concat(path, "] because the destination is past the end of the node."));
+ }
+
+ parent.children.splice(index, 0, node);
+
+ if (selection) {
+ var _iterator = _createForOfIteratorHelper$2(Range.points(selection)),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var _step$value = _slicedToArray(_step.value, 2),
+ point = _step$value[0],
+ key = _step$value[1];
+
+ selection[key] = Point.transform(point, op);
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+ }
+
+ break;
+ }
+
+ case 'insert_text':
+ {
+ var _path = op.path,
+ offset = op.offset,
+ text = op.text;
+ if (text.length === 0) break;
+
+ var _node = Node$1.leaf(editor, _path);
+
+ var before = _node.text.slice(0, offset);
+
+ var after = _node.text.slice(offset);
+
+ _node.text = before + text + after;
+
+ if (selection) {
+ var _iterator2 = _createForOfIteratorHelper$2(Range.points(selection)),
+ _step2;
+
+ try {
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
+ var _step2$value = _slicedToArray(_step2.value, 2),
+ _point = _step2$value[0],
+ _key = _step2$value[1];
+
+ selection[_key] = Point.transform(_point, op);
+ }
+ } catch (err) {
+ _iterator2.e(err);
+ } finally {
+ _iterator2.f();
+ }
+ }
+
+ break;
+ }
+
+ case 'merge_node':
+ {
+ var _path2 = op.path;
+
+ var _node2 = Node$1.get(editor, _path2);
+
+ var prevPath = Path.previous(_path2);
+ var prev = Node$1.get(editor, prevPath);
+
+ var _parent = Node$1.parent(editor, _path2);
+
+ var _index = _path2[_path2.length - 1];
+
+ if (Text.isText(_node2) && Text.isText(prev)) {
+ prev.text += _node2.text;
+ } else if (!Text.isText(_node2) && !Text.isText(prev)) {
+ var _prev$children;
+
+ (_prev$children = prev.children).push.apply(_prev$children, _toConsumableArray(_node2.children));
+ } else {
+ throw new Error("Cannot apply a \"merge_node\" operation at path [".concat(_path2, "] to nodes of different interfaces: ").concat(_node2, " ").concat(prev));
+ }
+
+ _parent.children.splice(_index, 1);
+
+ if (selection) {
+ var _iterator3 = _createForOfIteratorHelper$2(Range.points(selection)),
+ _step3;
+
+ try {
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
+ var _step3$value = _slicedToArray(_step3.value, 2),
+ _point2 = _step3$value[0],
+ _key2 = _step3$value[1];
+
+ selection[_key2] = Point.transform(_point2, op);
+ }
+ } catch (err) {
+ _iterator3.e(err);
+ } finally {
+ _iterator3.f();
+ }
+ }
+
+ break;
+ }
+
+ case 'move_node':
+ {
+ var _path3 = op.path,
+ newPath = op.newPath;
+
+ if (Path.isAncestor(_path3, newPath)) {
+ throw new Error("Cannot move a path [".concat(_path3, "] to new path [").concat(newPath, "] because the destination is inside itself."));
+ }
+
+ var _node3 = Node$1.get(editor, _path3);
+
+ var _parent2 = Node$1.parent(editor, _path3);
+
+ var _index2 = _path3[_path3.length - 1]; // This is tricky, but since the `path` and `newPath` both refer to
+ // the same snapshot in time, there's a mismatch. After either
+ // removing the original position, the second step's path can be out
+ // of date. So instead of using the `op.newPath` directly, we
+ // transform `op.path` to ascertain what the `newPath` would be after
+ // the operation was applied.
+
+ _parent2.children.splice(_index2, 1);
+
+ var truePath = Path.transform(_path3, op);
+ var newParent = Node$1.get(editor, Path.parent(truePath));
+ var newIndex = truePath[truePath.length - 1];
+ newParent.children.splice(newIndex, 0, _node3);
+
+ if (selection) {
+ var _iterator4 = _createForOfIteratorHelper$2(Range.points(selection)),
+ _step4;
+
+ try {
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
+ var _step4$value = _slicedToArray(_step4.value, 2),
+ _point3 = _step4$value[0],
+ _key3 = _step4$value[1];
+
+ selection[_key3] = Point.transform(_point3, op);
+ }
+ } catch (err) {
+ _iterator4.e(err);
+ } finally {
+ _iterator4.f();
+ }
+ }
+
+ break;
+ }
+
+ case 'remove_node':
+ {
+ var _path4 = op.path;
+ var _index3 = _path4[_path4.length - 1];
+
+ var _parent3 = Node$1.parent(editor, _path4);
+
+ _parent3.children.splice(_index3, 1); // Transform all of the points in the value, but if the point was in the
+ // node that was removed we need to update the range or remove it.
+
+
+ if (selection) {
+ var _iterator5 = _createForOfIteratorHelper$2(Range.points(selection)),
+ _step5;
+
+ try {
+ for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
+ var _step5$value = _slicedToArray(_step5.value, 2),
+ _point4 = _step5$value[0],
+ _key4 = _step5$value[1];
+
+ var result = Point.transform(_point4, op);
+
+ if (selection != null && result != null) {
+ selection[_key4] = result;
+ } else {
+ var _prev = void 0;
+
+ var next = void 0;
+
+ var _iterator6 = _createForOfIteratorHelper$2(Node$1.texts(editor)),
+ _step6;
+
+ try {
+ for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) {
+ var _step6$value = _slicedToArray(_step6.value, 2),
+ n = _step6$value[0],
+ p = _step6$value[1];
+
+ if (Path.compare(p, _path4) === -1) {
+ _prev = [n, p];
+ } else {
+ next = [n, p];
+ break;
+ }
+ }
+ } catch (err) {
+ _iterator6.e(err);
+ } finally {
+ _iterator6.f();
+ }
+
+ var preferNext = false;
+
+ if (_prev && next) {
+ if (Path.equals(next[1], _path4)) {
+ preferNext = !Path.hasPrevious(next[1]);
+ } else {
+ preferNext = Path.common(_prev[1], _path4).length < Path.common(next[1], _path4).length;
+ }
+ }
+
+ if (_prev && !preferNext) {
+ _point4.path = _prev[1];
+ _point4.offset = _prev[0].text.length;
+ } else if (next) {
+ _point4.path = next[1];
+ _point4.offset = 0;
+ } else {
+ selection = null;
+ }
+ }
+ }
+ } catch (err) {
+ _iterator5.e(err);
+ } finally {
+ _iterator5.f();
+ }
+ }
+
+ break;
+ }
+
+ case 'remove_text':
+ {
+ var _path5 = op.path,
+ _offset = op.offset,
+ _text = op.text;
+ if (_text.length === 0) break;
+
+ var _node4 = Node$1.leaf(editor, _path5);
+
+ var _before = _node4.text.slice(0, _offset);
+
+ var _after = _node4.text.slice(_offset + _text.length);
+
+ _node4.text = _before + _after;
+
+ if (selection) {
+ var _iterator7 = _createForOfIteratorHelper$2(Range.points(selection)),
+ _step7;
+
+ try {
+ for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) {
+ var _step7$value = _slicedToArray(_step7.value, 2),
+ _point5 = _step7$value[0],
+ _key5 = _step7$value[1];
+
+ selection[_key5] = Point.transform(_point5, op);
+ }
+ } catch (err) {
+ _iterator7.e(err);
+ } finally {
+ _iterator7.f();
+ }
+ }
+
+ break;
+ }
+
+ case 'set_node':
+ {
+ var _path6 = op.path,
+ properties = op.properties,
+ newProperties = op.newProperties;
+
+ if (_path6.length === 0) {
+ throw new Error("Cannot set properties on the root node!");
+ }
+
+ var _node5 = Node$1.get(editor, _path6);
+
+ for (var _key6 in newProperties) {
+ if (_key6 === 'children' || _key6 === 'text') {
+ throw new Error("Cannot set the \"".concat(_key6, "\" property of nodes!"));
+ }
+
+ var value = newProperties[_key6];
+
+ if (value == null) {
+ delete _node5[_key6];
+ } else {
+ _node5[_key6] = value;
+ }
+ } // properties that were previously defined, but are now missing, must be deleted
+
+
+ for (var _key7 in properties) {
+ if (!newProperties.hasOwnProperty(_key7)) {
+ delete _node5[_key7];
+ }
+ }
+
+ break;
+ }
+
+ case 'set_selection':
+ {
+ var _newProperties = op.newProperties;
+
+ if (_newProperties == null) {
+ selection = _newProperties;
+ } else {
+ if (selection == null) {
+ if (!Range.isRange(_newProperties)) {
+ throw new Error("Cannot apply an incomplete \"set_selection\" operation properties ".concat(JSON.stringify(_newProperties), " when there is no current selection."));
+ }
+
+ selection = _objectSpread$3({}, _newProperties);
+ }
+
+ for (var _key8 in _newProperties) {
+ var _value = _newProperties[_key8];
+
+ if (_value == null) {
+ if (_key8 === 'anchor' || _key8 === 'focus') {
+ throw new Error("Cannot remove the \"".concat(_key8, "\" selection property"));
+ }
+
+ delete selection[_key8];
+ } else {
+ selection[_key8] = _value;
+ }
+ }
+ }
+
+ break;
+ }
+
+ case 'split_node':
+ {
+ var _path7 = op.path,
+ position = op.position,
+ _properties = op.properties;
+
+ if (_path7.length === 0) {
+ throw new Error("Cannot apply a \"split_node\" operation at path [".concat(_path7, "] because the root node cannot be split."));
+ }
+
+ var _node6 = Node$1.get(editor, _path7);
+
+ var _parent4 = Node$1.parent(editor, _path7);
+
+ var _index4 = _path7[_path7.length - 1];
+ var newNode;
+
+ if (Text.isText(_node6)) {
+ var _before2 = _node6.text.slice(0, position);
+
+ var _after2 = _node6.text.slice(position);
+
+ _node6.text = _before2;
+ newNode = _objectSpread$3(_objectSpread$3({}, _properties), {}, {
+ text: _after2
+ });
+ } else {
+ var _before3 = _node6.children.slice(0, position);
+
+ var _after3 = _node6.children.slice(position);
+
+ _node6.children = _before3;
+ newNode = _objectSpread$3(_objectSpread$3({}, _properties), {}, {
+ children: _after3
+ });
+ }
+
+ _parent4.children.splice(_index4 + 1, 0, newNode);
+
+ if (selection) {
+ var _iterator8 = _createForOfIteratorHelper$2(Range.points(selection)),
+ _step8;
+
+ try {
+ for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) {
+ var _step8$value = _slicedToArray(_step8.value, 2),
+ _point6 = _step8$value[0],
+ _key9 = _step8$value[1];
+
+ selection[_key9] = Point.transform(_point6, op);
+ }
+ } catch (err) {
+ _iterator8.e(err);
+ } finally {
+ _iterator8.f();
+ }
+ }
+
+ break;
+ }
+ }
+
+ return selection;
+ };
+
+ var GeneralTransforms = {
+ /**
+ * Transform the editor by an operation.
+ */
+ transform: function transform(editor, op) {
+ editor.children = immer.createDraft(editor.children);
+ var selection = editor.selection && immer.createDraft(editor.selection);
+
+ try {
+ selection = applyToDraft(editor, selection, op);
+ } finally {
+ editor.children = immer.finishDraft(editor.children);
+
+ if (selection) {
+ editor.selection = immer.isDraft(selection) ? immer.finishDraft(selection) : selection;
+ } else {
+ editor.selection = null;
+ }
+ }
+ }
+ };
+
+ var _excluded = ["text"],
+ _excluded2 = ["children"];
+
+ function ownKeys$2(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$2(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$2(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+
+ function _createForOfIteratorHelper$1(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray$1(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; } } }; }
+
+ function _unsupportedIterableToArray$1(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray$1(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$1(o, minLen); }
+
+ function _arrayLikeToArray$1(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; }
+ var NodeTransforms = {
+ /**
+ * Insert nodes at a specific location in the Editor.
+ */
+ insertNodes: function insertNodes(editor, nodes) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var _options$hanging = options.hanging,
+ hanging = _options$hanging === void 0 ? false : _options$hanging,
+ _options$voids = options.voids,
+ voids = _options$voids === void 0 ? false : _options$voids,
+ _options$mode = options.mode,
+ mode = _options$mode === void 0 ? 'lowest' : _options$mode;
+ var at = options.at,
+ match = options.match,
+ select = options.select;
+
+ if (Node$1.isNode(nodes)) {
+ nodes = [nodes];
+ }
+
+ if (nodes.length === 0) {
+ return;
+ }
+
+ var _nodes = nodes,
+ _nodes2 = _slicedToArray(_nodes, 1),
+ node = _nodes2[0]; // By default, use the selection as the target location. But if there is
+ // no selection, insert at the end of the document since that is such a
+ // common use case when inserting from a non-selected state.
+
+
+ if (!at) {
+ if (editor.selection) {
+ at = editor.selection;
+ } else if (editor.children.length > 0) {
+ at = Editor.end(editor, []);
+ } else {
+ at = [0];
+ }
+
+ select = true;
+ }
+
+ if (select == null) {
+ select = false;
+ }
+
+ if (Range.isRange(at)) {
+ if (!hanging) {
+ at = Editor.unhangRange(editor, at);
+ }
+
+ if (Range.isCollapsed(at)) {
+ at = at.anchor;
+ } else {
+ var _Range$edges = Range.edges(at),
+ _Range$edges2 = _slicedToArray(_Range$edges, 2),
+ end = _Range$edges2[1];
+
+ var pointRef = Editor.pointRef(editor, end);
+ Transforms["delete"](editor, {
+ at: at
+ });
+ at = pointRef.unref();
+ }
+ }
+
+ if (Point.isPoint(at)) {
+ if (match == null) {
+ if (Text.isText(node)) {
+ match = function match(n) {
+ return Text.isText(n);
+ };
+ } else if (editor.isInline(node)) {
+ match = function match(n) {
+ return Text.isText(n) || Editor.isInline(editor, n);
+ };
+ } else {
+ match = function match(n) {
+ return Editor.isBlock(editor, n);
+ };
+ }
+ }
+
+ var _Editor$nodes = Editor.nodes(editor, {
+ at: at.path,
+ match: match,
+ mode: mode,
+ voids: voids
+ }),
+ _Editor$nodes2 = _slicedToArray(_Editor$nodes, 1),
+ entry = _Editor$nodes2[0];
+
+ if (entry) {
+ var _entry = _slicedToArray(entry, 2),
+ _matchPath = _entry[1];
+
+ var pathRef = Editor.pathRef(editor, _matchPath);
+ var isAtEnd = Editor.isEnd(editor, at, _matchPath);
+ Transforms.splitNodes(editor, {
+ at: at,
+ match: match,
+ mode: mode,
+ voids: voids
+ });
+ var path = pathRef.unref();
+ at = isAtEnd ? Path.next(path) : path;
+ } else {
+ return;
+ }
+ }
+
+ var parentPath = Path.parent(at);
+ var index = at[at.length - 1];
+
+ if (!voids && Editor["void"](editor, {
+ at: parentPath
+ })) {
+ return;
+ }
+
+ var _iterator = _createForOfIteratorHelper$1(nodes),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var _node = _step.value;
+
+ var _path = parentPath.concat(index);
+
+ index++;
+ editor.apply({
+ type: 'insert_node',
+ path: _path,
+ node: _node
+ });
+ at = Path.next(at);
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+
+ at = Path.previous(at);
+
+ if (select) {
+ var point = Editor.end(editor, at);
+
+ if (point) {
+ Transforms.select(editor, point);
+ }
+ }
+ });
+ },
+
+ /**
+ * Lift nodes at a specific location upwards in the document tree, splitting
+ * their parent in two if necessary.
+ */
+ liftNodes: function liftNodes(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var _options$at = options.at,
+ at = _options$at === void 0 ? editor.selection : _options$at,
+ _options$mode2 = options.mode,
+ mode = _options$mode2 === void 0 ? 'lowest' : _options$mode2,
+ _options$voids2 = options.voids,
+ voids = _options$voids2 === void 0 ? false : _options$voids2;
+ var match = options.match;
+
+ if (match == null) {
+ match = Path.isPath(at) ? matchPath(editor, at) : function (n) {
+ return Editor.isBlock(editor, n);
+ };
+ }
+
+ if (!at) {
+ return;
+ }
+
+ var matches = Editor.nodes(editor, {
+ at: at,
+ match: match,
+ mode: mode,
+ voids: voids
+ });
+ var pathRefs = Array.from(matches, function (_ref) {
+ var _ref2 = _slicedToArray(_ref, 2),
+ p = _ref2[1];
+
+ return Editor.pathRef(editor, p);
+ });
+
+ for (var _i = 0, _pathRefs = pathRefs; _i < _pathRefs.length; _i++) {
+ var pathRef = _pathRefs[_i];
+ var path = pathRef.unref();
+
+ if (path.length < 2) {
+ throw new Error("Cannot lift node at a path [".concat(path, "] because it has a depth of less than `2`."));
+ }
+
+ var parentNodeEntry = Editor.node(editor, Path.parent(path));
+
+ var _parentNodeEntry = _slicedToArray(parentNodeEntry, 2),
+ parent = _parentNodeEntry[0],
+ parentPath = _parentNodeEntry[1];
+
+ var index = path[path.length - 1];
+ var length = parent.children.length;
+
+ if (length === 1) {
+ var toPath = Path.next(parentPath);
+ Transforms.moveNodes(editor, {
+ at: path,
+ to: toPath,
+ voids: voids
+ });
+ Transforms.removeNodes(editor, {
+ at: parentPath,
+ voids: voids
+ });
+ } else if (index === 0) {
+ Transforms.moveNodes(editor, {
+ at: path,
+ to: parentPath,
+ voids: voids
+ });
+ } else if (index === length - 1) {
+ var _toPath = Path.next(parentPath);
+
+ Transforms.moveNodes(editor, {
+ at: path,
+ to: _toPath,
+ voids: voids
+ });
+ } else {
+ var splitPath = Path.next(path);
+
+ var _toPath2 = Path.next(parentPath);
+
+ Transforms.splitNodes(editor, {
+ at: splitPath,
+ voids: voids
+ });
+ Transforms.moveNodes(editor, {
+ at: path,
+ to: _toPath2,
+ voids: voids
+ });
+ }
+ }
+ });
+ },
+
+ /**
+ * Merge a node at a location with the previous node of the same depth,
+ * removing any empty containing nodes after the merge if necessary.
+ */
+ mergeNodes: function mergeNodes(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var match = options.match,
+ _options$at2 = options.at,
+ at = _options$at2 === void 0 ? editor.selection : _options$at2;
+ var _options$hanging2 = options.hanging,
+ hanging = _options$hanging2 === void 0 ? false : _options$hanging2,
+ _options$voids3 = options.voids,
+ voids = _options$voids3 === void 0 ? false : _options$voids3,
+ _options$mode3 = options.mode,
+ mode = _options$mode3 === void 0 ? 'lowest' : _options$mode3;
+
+ if (!at) {
+ return;
+ }
+
+ if (match == null) {
+ if (Path.isPath(at)) {
+ var _Editor$parent = Editor.parent(editor, at),
+ _Editor$parent2 = _slicedToArray(_Editor$parent, 1),
+ parent = _Editor$parent2[0];
+
+ match = function match(n) {
+ return parent.children.includes(n);
+ };
+ } else {
+ match = function match(n) {
+ return Editor.isBlock(editor, n);
+ };
+ }
+ }
+
+ if (!hanging && Range.isRange(at)) {
+ at = Editor.unhangRange(editor, at);
+ }
+
+ if (Range.isRange(at)) {
+ if (Range.isCollapsed(at)) {
+ at = at.anchor;
+ } else {
+ var _Range$edges3 = Range.edges(at),
+ _Range$edges4 = _slicedToArray(_Range$edges3, 2),
+ end = _Range$edges4[1];
+
+ var pointRef = Editor.pointRef(editor, end);
+ Transforms["delete"](editor, {
+ at: at
+ });
+ at = pointRef.unref();
+
+ if (options.at == null) {
+ Transforms.select(editor, at);
+ }
+ }
+ }
+
+ var _Editor$nodes3 = Editor.nodes(editor, {
+ at: at,
+ match: match,
+ voids: voids,
+ mode: mode
+ }),
+ _Editor$nodes4 = _slicedToArray(_Editor$nodes3, 1),
+ current = _Editor$nodes4[0];
+
+ var prev = Editor.previous(editor, {
+ at: at,
+ match: match,
+ voids: voids,
+ mode: mode
+ });
+
+ if (!current || !prev) {
+ return;
+ }
+
+ var _current = _slicedToArray(current, 2),
+ node = _current[0],
+ path = _current[1];
+
+ var _prev = _slicedToArray(prev, 2),
+ prevNode = _prev[0],
+ prevPath = _prev[1];
+
+ if (path.length === 0 || prevPath.length === 0) {
+ return;
+ }
+
+ var newPath = Path.next(prevPath);
+ var commonPath = Path.common(path, prevPath);
+ var isPreviousSibling = Path.isSibling(path, prevPath);
+ var levels = Array.from(Editor.levels(editor, {
+ at: path
+ }), function (_ref3) {
+ var _ref4 = _slicedToArray(_ref3, 1),
+ n = _ref4[0];
+
+ return n;
+ }).slice(commonPath.length).slice(0, -1); // Determine if the merge will leave an ancestor of the path empty as a
+ // result, in which case we'll want to remove it after merging.
+
+ var emptyAncestor = Editor.above(editor, {
+ at: path,
+ mode: 'highest',
+ match: function match(n) {
+ return levels.includes(n) && hasSingleChildNest(editor, n);
+ }
+ });
+ var emptyRef = emptyAncestor && Editor.pathRef(editor, emptyAncestor[1]);
+ var properties;
+ var position; // Ensure that the nodes are equivalent, and figure out what the position
+ // and extra properties of the merge will be.
+
+ if (Text.isText(node) && Text.isText(prevNode)) {
+ node.text;
+ var rest = _objectWithoutProperties(node, _excluded);
+
+ position = prevNode.text.length;
+ properties = rest;
+ } else if (Element$1.isElement(node) && Element$1.isElement(prevNode)) {
+ node.children;
+ var _rest = _objectWithoutProperties(node, _excluded2);
+
+ position = prevNode.children.length;
+ properties = _rest;
+ } else {
+ throw new Error("Cannot merge the node at path [".concat(path, "] with the previous sibling because it is not the same kind: ").concat(JSON.stringify(node), " ").concat(JSON.stringify(prevNode)));
+ } // If the node isn't already the next sibling of the previous node, move
+ // it so that it is before merging.
+
+
+ if (!isPreviousSibling) {
+ Transforms.moveNodes(editor, {
+ at: path,
+ to: newPath,
+ voids: voids
+ });
+ } // If there was going to be an empty ancestor of the node that was merged,
+ // we remove it from the tree.
+
+
+ if (emptyRef) {
+ Transforms.removeNodes(editor, {
+ at: emptyRef.current,
+ voids: voids
+ });
+ } // If the target node that we're merging with is empty, remove it instead
+ // of merging the two. This is a common rich text editor behavior to
+ // prevent losing formatting when deleting entire nodes when you have a
+ // hanging selection.
+ // if prevNode is first child in parent,don't remove it.
+
+
+ if (Element$1.isElement(prevNode) && Editor.isEmpty(editor, prevNode) || Text.isText(prevNode) && prevNode.text === '' && prevPath[prevPath.length - 1] !== 0) {
+ Transforms.removeNodes(editor, {
+ at: prevPath,
+ voids: voids
+ });
+ } else {
+ editor.apply({
+ type: 'merge_node',
+ path: newPath,
+ position: position,
+ properties: properties
+ });
+ }
+
+ if (emptyRef) {
+ emptyRef.unref();
+ }
+ });
+ },
+
+ /**
+ * Move the nodes at a location to a new location.
+ */
+ moveNodes: function moveNodes(editor, options) {
+ Editor.withoutNormalizing(editor, function () {
+ var to = options.to,
+ _options$at3 = options.at,
+ at = _options$at3 === void 0 ? editor.selection : _options$at3,
+ _options$mode4 = options.mode,
+ mode = _options$mode4 === void 0 ? 'lowest' : _options$mode4,
+ _options$voids4 = options.voids,
+ voids = _options$voids4 === void 0 ? false : _options$voids4;
+ var match = options.match;
+
+ if (!at) {
+ return;
+ }
+
+ if (match == null) {
+ match = Path.isPath(at) ? matchPath(editor, at) : function (n) {
+ return Editor.isBlock(editor, n);
+ };
+ }
+
+ var toRef = Editor.pathRef(editor, to);
+ var targets = Editor.nodes(editor, {
+ at: at,
+ match: match,
+ mode: mode,
+ voids: voids
+ });
+ var pathRefs = Array.from(targets, function (_ref5) {
+ var _ref6 = _slicedToArray(_ref5, 2),
+ p = _ref6[1];
+
+ return Editor.pathRef(editor, p);
+ });
+
+ for (var _i2 = 0, _pathRefs2 = pathRefs; _i2 < _pathRefs2.length; _i2++) {
+ var pathRef = _pathRefs2[_i2];
+ var path = pathRef.unref();
+ var newPath = toRef.current;
+
+ if (path.length !== 0) {
+ editor.apply({
+ type: 'move_node',
+ path: path,
+ newPath: newPath
+ });
+ }
+
+ if (toRef.current && Path.isSibling(newPath, path) && Path.isAfter(newPath, path)) {
+ // When performing a sibling move to a later index, the path at the destination is shifted
+ // to before the insertion point instead of after. To ensure our group of nodes are inserted
+ // in the correct order we increment toRef to account for that
+ toRef.current = Path.next(toRef.current);
+ }
+ }
+
+ toRef.unref();
+ });
+ },
+
+ /**
+ * Remove the nodes at a specific location in the document.
+ */
+ removeNodes: function removeNodes(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var _options$hanging3 = options.hanging,
+ hanging = _options$hanging3 === void 0 ? false : _options$hanging3,
+ _options$voids5 = options.voids,
+ voids = _options$voids5 === void 0 ? false : _options$voids5,
+ _options$mode5 = options.mode,
+ mode = _options$mode5 === void 0 ? 'lowest' : _options$mode5;
+ var _options$at4 = options.at,
+ at = _options$at4 === void 0 ? editor.selection : _options$at4,
+ match = options.match;
+
+ if (!at) {
+ return;
+ }
+
+ if (match == null) {
+ match = Path.isPath(at) ? matchPath(editor, at) : function (n) {
+ return Editor.isBlock(editor, n);
+ };
+ }
+
+ if (!hanging && Range.isRange(at)) {
+ at = Editor.unhangRange(editor, at);
+ }
+
+ var depths = Editor.nodes(editor, {
+ at: at,
+ match: match,
+ mode: mode,
+ voids: voids
+ });
+ var pathRefs = Array.from(depths, function (_ref7) {
+ var _ref8 = _slicedToArray(_ref7, 2),
+ p = _ref8[1];
+
+ return Editor.pathRef(editor, p);
+ });
+
+ for (var _i3 = 0, _pathRefs3 = pathRefs; _i3 < _pathRefs3.length; _i3++) {
+ var pathRef = _pathRefs3[_i3];
+ var path = pathRef.unref();
+
+ if (path) {
+ var _Editor$node = Editor.node(editor, path),
+ _Editor$node2 = _slicedToArray(_Editor$node, 1),
+ node = _Editor$node2[0];
+
+ editor.apply({
+ type: 'remove_node',
+ path: path,
+ node: node
+ });
+ }
+ }
+ });
+ },
+
+ /**
+ * Set new properties on the nodes at a location.
+ */
+ setNodes: function setNodes(editor, props) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var match = options.match,
+ _options$at5 = options.at,
+ at = _options$at5 === void 0 ? editor.selection : _options$at5;
+ var _options$hanging4 = options.hanging,
+ hanging = _options$hanging4 === void 0 ? false : _options$hanging4,
+ _options$mode6 = options.mode,
+ mode = _options$mode6 === void 0 ? 'lowest' : _options$mode6,
+ _options$split = options.split,
+ split = _options$split === void 0 ? false : _options$split,
+ _options$voids6 = options.voids,
+ voids = _options$voids6 === void 0 ? false : _options$voids6;
+
+ if (!at) {
+ return;
+ }
+
+ if (match == null) {
+ match = Path.isPath(at) ? matchPath(editor, at) : function (n) {
+ return Editor.isBlock(editor, n);
+ };
+ }
+
+ if (!hanging && Range.isRange(at)) {
+ at = Editor.unhangRange(editor, at);
+ }
+
+ if (split && Range.isRange(at)) {
+ if (Range.isCollapsed(at) && Editor.leaf(editor, at.anchor)[0].text.length > 0) {
+ // If the range is collapsed in a non-empty node and 'split' is true, there's nothing to
+ // set that won't get normalized away
+ return;
+ }
+
+ var rangeRef = Editor.rangeRef(editor, at, {
+ affinity: 'inward'
+ });
+
+ var _Range$edges5 = Range.edges(at),
+ _Range$edges6 = _slicedToArray(_Range$edges5, 2),
+ start = _Range$edges6[0],
+ end = _Range$edges6[1];
+
+ var splitMode = mode === 'lowest' ? 'lowest' : 'highest';
+ var endAtEndOfNode = Editor.isEnd(editor, end, end.path);
+ Transforms.splitNodes(editor, {
+ at: end,
+ match: match,
+ mode: splitMode,
+ voids: voids,
+ always: !endAtEndOfNode
+ });
+ var startAtStartOfNode = Editor.isStart(editor, start, start.path);
+ Transforms.splitNodes(editor, {
+ at: start,
+ match: match,
+ mode: splitMode,
+ voids: voids,
+ always: !startAtStartOfNode
+ });
+ at = rangeRef.unref();
+
+ if (options.at == null) {
+ Transforms.select(editor, at);
+ }
+ }
+
+ var _iterator2 = _createForOfIteratorHelper$1(Editor.nodes(editor, {
+ at: at,
+ match: match,
+ mode: mode,
+ voids: voids
+ })),
+ _step2;
+
+ try {
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
+ var _step2$value = _slicedToArray(_step2.value, 2),
+ node = _step2$value[0],
+ path = _step2$value[1];
+
+ var properties = {};
+ var newProperties = {}; // You can't set properties on the editor node.
+
+ if (path.length === 0) {
+ continue;
+ }
+
+ var hasChanges = false;
+
+ for (var k in props) {
+ if (k === 'children' || k === 'text') {
+ continue;
+ }
+
+ if (props[k] !== node[k]) {
+ hasChanges = true; // Omit new properties from the old properties list
+
+ if (node.hasOwnProperty(k)) properties[k] = node[k]; // Omit properties that have been removed from the new properties list
+
+ if (props[k] != null) newProperties[k] = props[k];
+ }
+ }
+
+ if (hasChanges) {
+ editor.apply({
+ type: 'set_node',
+ path: path,
+ properties: properties,
+ newProperties: newProperties
+ });
+ }
+ }
+ } catch (err) {
+ _iterator2.e(err);
+ } finally {
+ _iterator2.f();
+ }
+ });
+ },
+
+ /**
+ * Split the nodes at a specific location.
+ */
+ splitNodes: function splitNodes(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var _options$mode7 = options.mode,
+ mode = _options$mode7 === void 0 ? 'lowest' : _options$mode7,
+ _options$voids7 = options.voids,
+ voids = _options$voids7 === void 0 ? false : _options$voids7;
+ var match = options.match,
+ _options$at6 = options.at,
+ at = _options$at6 === void 0 ? editor.selection : _options$at6,
+ _options$height = options.height,
+ height = _options$height === void 0 ? 0 : _options$height,
+ _options$always = options.always,
+ always = _options$always === void 0 ? false : _options$always;
+
+ if (match == null) {
+ match = function match(n) {
+ return Editor.isBlock(editor, n);
+ };
+ }
+
+ if (Range.isRange(at)) {
+ at = deleteRange(editor, at);
+ } // If the target is a path, the default height-skipping and position
+ // counters need to account for us potentially splitting at a non-leaf.
+
+
+ if (Path.isPath(at)) {
+ var path = at;
+ var point = Editor.point(editor, path);
+
+ var _Editor$parent3 = Editor.parent(editor, path),
+ _Editor$parent4 = _slicedToArray(_Editor$parent3, 1),
+ parent = _Editor$parent4[0];
+
+ match = function match(n) {
+ return n === parent;
+ };
+
+ height = point.path.length - path.length + 1;
+ at = point;
+ always = true;
+ }
+
+ if (!at) {
+ return;
+ }
+
+ var beforeRef = Editor.pointRef(editor, at, {
+ affinity: 'backward'
+ });
+
+ var _Editor$nodes5 = Editor.nodes(editor, {
+ at: at,
+ match: match,
+ mode: mode,
+ voids: voids
+ }),
+ _Editor$nodes6 = _slicedToArray(_Editor$nodes5, 1),
+ highest = _Editor$nodes6[0];
+
+ if (!highest) {
+ return;
+ }
+
+ var voidMatch = Editor["void"](editor, {
+ at: at,
+ mode: 'highest'
+ });
+ var nudge = 0;
+
+ if (!voids && voidMatch) {
+ var _voidMatch = _slicedToArray(voidMatch, 2),
+ voidNode = _voidMatch[0],
+ voidPath = _voidMatch[1];
+
+ if (Element$1.isElement(voidNode) && editor.isInline(voidNode)) {
+ var after = Editor.after(editor, voidPath);
+
+ if (!after) {
+ var text = {
+ text: ''
+ };
+ var afterPath = Path.next(voidPath);
+ Transforms.insertNodes(editor, text, {
+ at: afterPath,
+ voids: voids
+ });
+ after = Editor.point(editor, afterPath);
+ }
+
+ at = after;
+ always = true;
+ }
+
+ var siblingHeight = at.path.length - voidPath.length;
+ height = siblingHeight + 1;
+ always = true;
+ }
+
+ var afterRef = Editor.pointRef(editor, at);
+ var depth = at.path.length - height;
+
+ var _highest = _slicedToArray(highest, 2),
+ highestPath = _highest[1];
+
+ var lowestPath = at.path.slice(0, depth);
+ var position = height === 0 ? at.offset : at.path[depth] + nudge;
+
+ var _iterator3 = _createForOfIteratorHelper$1(Editor.levels(editor, {
+ at: lowestPath,
+ reverse: true,
+ voids: voids
+ })),
+ _step3;
+
+ try {
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
+ var _step3$value = _slicedToArray(_step3.value, 2),
+ node = _step3$value[0],
+ _path2 = _step3$value[1];
+
+ var split = false;
+
+ if (_path2.length < highestPath.length || _path2.length === 0 || !voids && Editor.isVoid(editor, node)) {
+ break;
+ }
+
+ var _point2 = beforeRef.current;
+ var isEnd = Editor.isEnd(editor, _point2, _path2);
+
+ if (always || !beforeRef || !Editor.isEdge(editor, _point2, _path2)) {
+ split = true;
+ var properties = Node$1.extractProps(node);
+ editor.apply({
+ type: 'split_node',
+ path: _path2,
+ position: position,
+ properties: properties
+ });
+ }
+
+ position = _path2[_path2.length - 1] + (split || isEnd ? 1 : 0);
+ }
+ } catch (err) {
+ _iterator3.e(err);
+ } finally {
+ _iterator3.f();
+ }
+
+ if (options.at == null) {
+ var _point = afterRef.current || Editor.end(editor, []);
+
+ Transforms.select(editor, _point);
+ }
+
+ beforeRef.unref();
+ afterRef.unref();
+ });
+ },
+
+ /**
+ * Unset properties on the nodes at a location.
+ */
+ unsetNodes: function unsetNodes(editor, props) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+
+ if (!Array.isArray(props)) {
+ props = [props];
+ }
+
+ var obj = {};
+
+ var _iterator4 = _createForOfIteratorHelper$1(props),
+ _step4;
+
+ try {
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
+ var key = _step4.value;
+ obj[key] = null;
+ }
+ } catch (err) {
+ _iterator4.e(err);
+ } finally {
+ _iterator4.f();
+ }
+
+ Transforms.setNodes(editor, obj, options);
+ },
+
+ /**
+ * Unwrap the nodes at a location from a parent node, splitting the parent if
+ * necessary to ensure that only the content in the range is unwrapped.
+ */
+ unwrapNodes: function unwrapNodes(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var _options$mode8 = options.mode,
+ mode = _options$mode8 === void 0 ? 'lowest' : _options$mode8,
+ _options$split2 = options.split,
+ split = _options$split2 === void 0 ? false : _options$split2,
+ _options$voids8 = options.voids,
+ voids = _options$voids8 === void 0 ? false : _options$voids8;
+ var _options$at7 = options.at,
+ at = _options$at7 === void 0 ? editor.selection : _options$at7,
+ match = options.match;
+
+ if (!at) {
+ return;
+ }
+
+ if (match == null) {
+ match = Path.isPath(at) ? matchPath(editor, at) : function (n) {
+ return Editor.isBlock(editor, n);
+ };
+ }
+
+ if (Path.isPath(at)) {
+ at = Editor.range(editor, at);
+ }
+
+ var rangeRef = Range.isRange(at) ? Editor.rangeRef(editor, at) : null;
+ var matches = Editor.nodes(editor, {
+ at: at,
+ match: match,
+ mode: mode,
+ voids: voids
+ });
+ var pathRefs = Array.from(matches, function (_ref9) {
+ var _ref10 = _slicedToArray(_ref9, 2),
+ p = _ref10[1];
+
+ return Editor.pathRef(editor, p);
+ } // unwrapNode will call liftNode which does not support splitting the node when nested.
+ // If we do not reverse the order and call it from top to the bottom, it will remove all blocks
+ // that wrap target node. So we reverse the order.
+ ).reverse();
+
+ var _iterator5 = _createForOfIteratorHelper$1(pathRefs),
+ _step5;
+
+ try {
+ var _loop = function _loop() {
+ var pathRef = _step5.value;
+ var path = pathRef.unref();
+
+ var _Editor$node3 = Editor.node(editor, path),
+ _Editor$node4 = _slicedToArray(_Editor$node3, 1),
+ node = _Editor$node4[0];
+
+ var range = Editor.range(editor, path);
+
+ if (split && rangeRef) {
+ range = Range.intersection(rangeRef.current, range);
+ }
+
+ Transforms.liftNodes(editor, {
+ at: range,
+ match: function match(n) {
+ return Element$1.isAncestor(node) && node.children.includes(n);
+ },
+ voids: voids
+ });
+ };
+
+ for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
+ _loop();
+ }
+ } catch (err) {
+ _iterator5.e(err);
+ } finally {
+ _iterator5.f();
+ }
+
+ if (rangeRef) {
+ rangeRef.unref();
+ }
+ });
+ },
+
+ /**
+ * Wrap the nodes at a location in a new container node, splitting the edges
+ * of the range first to ensure that only the content in the range is wrapped.
+ */
+ wrapNodes: function wrapNodes(editor, element) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var _options$mode9 = options.mode,
+ mode = _options$mode9 === void 0 ? 'lowest' : _options$mode9,
+ _options$split3 = options.split,
+ split = _options$split3 === void 0 ? false : _options$split3,
+ _options$voids9 = options.voids,
+ voids = _options$voids9 === void 0 ? false : _options$voids9;
+ var match = options.match,
+ _options$at8 = options.at,
+ at = _options$at8 === void 0 ? editor.selection : _options$at8;
+
+ if (!at) {
+ return;
+ }
+
+ if (match == null) {
+ if (Path.isPath(at)) {
+ match = matchPath(editor, at);
+ } else if (editor.isInline(element)) {
+ match = function match(n) {
+ return Editor.isInline(editor, n) || Text.isText(n);
+ };
+ } else {
+ match = function match(n) {
+ return Editor.isBlock(editor, n);
+ };
+ }
+ }
+
+ if (split && Range.isRange(at)) {
+ var _Range$edges7 = Range.edges(at),
+ _Range$edges8 = _slicedToArray(_Range$edges7, 2),
+ start = _Range$edges8[0],
+ end = _Range$edges8[1];
+
+ var rangeRef = Editor.rangeRef(editor, at, {
+ affinity: 'inward'
+ });
+ Transforms.splitNodes(editor, {
+ at: end,
+ match: match,
+ voids: voids
+ });
+ Transforms.splitNodes(editor, {
+ at: start,
+ match: match,
+ voids: voids
+ });
+ at = rangeRef.unref();
+
+ if (options.at == null) {
+ Transforms.select(editor, at);
+ }
+ }
+
+ var roots = Array.from(Editor.nodes(editor, {
+ at: at,
+ match: editor.isInline(element) ? function (n) {
+ return Editor.isBlock(editor, n);
+ } : function (n) {
+ return Editor.isEditor(n);
+ },
+ mode: 'lowest',
+ voids: voids
+ }));
+
+ for (var _i4 = 0, _roots = roots; _i4 < _roots.length; _i4++) {
+ var _roots$_i = _slicedToArray(_roots[_i4], 2),
+ rootPath = _roots$_i[1];
+
+ var a = Range.isRange(at) ? Range.intersection(at, Editor.range(editor, rootPath)) : at;
+
+ if (!a) {
+ continue;
+ }
+
+ var matches = Array.from(Editor.nodes(editor, {
+ at: a,
+ match: match,
+ mode: mode,
+ voids: voids
+ }));
+
+ if (matches.length > 0) {
+ var _ret = function () {
+ var _matches = _slicedToArray(matches, 1),
+ first = _matches[0];
+
+ var last = matches[matches.length - 1];
+
+ var _first = _slicedToArray(first, 2),
+ firstPath = _first[1];
+
+ var _last = _slicedToArray(last, 2),
+ lastPath = _last[1];
+
+ if (firstPath.length === 0 && lastPath.length === 0) {
+ // if there's no matching parent - usually means the node is an editor - don't do anything
+ return "continue";
+ }
+
+ var commonPath = Path.equals(firstPath, lastPath) ? Path.parent(firstPath) : Path.common(firstPath, lastPath);
+ var range = Editor.range(editor, firstPath, lastPath);
+ var commonNodeEntry = Editor.node(editor, commonPath);
+
+ var _commonNodeEntry = _slicedToArray(commonNodeEntry, 1),
+ commonNode = _commonNodeEntry[0];
+
+ var depth = commonPath.length + 1;
+ var wrapperPath = Path.next(lastPath.slice(0, depth));
+
+ var wrapper = _objectSpread$2(_objectSpread$2({}, element), {}, {
+ children: []
+ });
+
+ Transforms.insertNodes(editor, wrapper, {
+ at: wrapperPath,
+ voids: voids
+ });
+ Transforms.moveNodes(editor, {
+ at: range,
+ match: function match(n) {
+ return Element$1.isAncestor(commonNode) && commonNode.children.includes(n);
+ },
+ to: wrapperPath.concat(0),
+ voids: voids
+ });
+ }();
+
+ if (_ret === "continue") continue;
+ }
+ }
+ });
+ }
+ };
+
+ var hasSingleChildNest = function hasSingleChildNest(editor, node) {
+ if (Element$1.isElement(node)) {
+ var element = node;
+
+ if (Editor.isVoid(editor, node)) {
+ return true;
+ } else if (element.children.length === 1) {
+ return hasSingleChildNest(editor, element.children[0]);
+ } else {
+ return false;
+ }
+ } else if (Editor.isEditor(node)) {
+ return false;
+ } else {
+ return true;
+ }
+ };
+ /**
+ * Convert a range into a point by deleting it's content.
+ */
+
+
+ var deleteRange = function deleteRange(editor, range) {
+ if (Range.isCollapsed(range)) {
+ return range.anchor;
+ } else {
+ var _Range$edges9 = Range.edges(range),
+ _Range$edges10 = _slicedToArray(_Range$edges9, 2),
+ end = _Range$edges10[1];
+
+ var pointRef = Editor.pointRef(editor, end);
+ Transforms["delete"](editor, {
+ at: range
+ });
+ return pointRef.unref();
+ }
+ };
+
+ var matchPath = function matchPath(editor, path) {
+ var _Editor$node5 = Editor.node(editor, path),
+ _Editor$node6 = _slicedToArray(_Editor$node5, 1),
+ node = _Editor$node6[0];
+
+ return function (n) {
+ return n === node;
+ };
+ };
+
+ function ownKeys$1(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$1(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$1(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+ var SelectionTransforms = {
+ /**
+ * Collapse the selection.
+ */
+ collapse: function collapse(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var _options$edge = options.edge,
+ edge = _options$edge === void 0 ? 'anchor' : _options$edge;
+ var selection = editor.selection;
+
+ if (!selection) {
+ return;
+ } else if (edge === 'anchor') {
+ Transforms.select(editor, selection.anchor);
+ } else if (edge === 'focus') {
+ Transforms.select(editor, selection.focus);
+ } else if (edge === 'start') {
+ var _Range$edges = Range.edges(selection),
+ _Range$edges2 = _slicedToArray(_Range$edges, 1),
+ start = _Range$edges2[0];
+
+ Transforms.select(editor, start);
+ } else if (edge === 'end') {
+ var _Range$edges3 = Range.edges(selection),
+ _Range$edges4 = _slicedToArray(_Range$edges3, 2),
+ end = _Range$edges4[1];
+
+ Transforms.select(editor, end);
+ }
+ },
+
+ /**
+ * Unset the selection.
+ */
+ deselect: function deselect(editor) {
+ var selection = editor.selection;
+
+ if (selection) {
+ editor.apply({
+ type: 'set_selection',
+ properties: selection,
+ newProperties: null
+ });
+ }
+ },
+
+ /**
+ * Move the selection's point forward or backward.
+ */
+ move: function move(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ var selection = editor.selection;
+ var _options$distance = options.distance,
+ distance = _options$distance === void 0 ? 1 : _options$distance,
+ _options$unit = options.unit,
+ unit = _options$unit === void 0 ? 'character' : _options$unit,
+ _options$reverse = options.reverse,
+ reverse = _options$reverse === void 0 ? false : _options$reverse;
+ var _options$edge2 = options.edge,
+ edge = _options$edge2 === void 0 ? null : _options$edge2;
+
+ if (!selection) {
+ return;
+ }
+
+ if (edge === 'start') {
+ edge = Range.isBackward(selection) ? 'focus' : 'anchor';
+ }
+
+ if (edge === 'end') {
+ edge = Range.isBackward(selection) ? 'anchor' : 'focus';
+ }
+
+ var anchor = selection.anchor,
+ focus = selection.focus;
+ var opts = {
+ distance: distance,
+ unit: unit
+ };
+ var props = {};
+
+ if (edge == null || edge === 'anchor') {
+ var point = reverse ? Editor.before(editor, anchor, opts) : Editor.after(editor, anchor, opts);
+
+ if (point) {
+ props.anchor = point;
+ }
+ }
+
+ if (edge == null || edge === 'focus') {
+ var _point = reverse ? Editor.before(editor, focus, opts) : Editor.after(editor, focus, opts);
+
+ if (_point) {
+ props.focus = _point;
+ }
+ }
+
+ Transforms.setSelection(editor, props);
+ },
+
+ /**
+ * Set the selection to a new value.
+ */
+ select: function select(editor, target) {
+ var selection = editor.selection;
+ target = Editor.range(editor, target);
+
+ if (selection) {
+ Transforms.setSelection(editor, target);
+ return;
+ }
+
+ if (!Range.isRange(target)) {
+ throw new Error("When setting the selection and the current selection is `null` you must provide at least an `anchor` and `focus`, but you passed: ".concat(JSON.stringify(target)));
+ }
+
+ editor.apply({
+ type: 'set_selection',
+ properties: selection,
+ newProperties: target
+ });
+ },
+
+ /**
+ * Set new properties on one of the selection's points.
+ */
+ setPoint: function setPoint(editor, props) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ var selection = editor.selection;
+ var _options$edge3 = options.edge,
+ edge = _options$edge3 === void 0 ? 'both' : _options$edge3;
+
+ if (!selection) {
+ return;
+ }
+
+ if (edge === 'start') {
+ edge = Range.isBackward(selection) ? 'focus' : 'anchor';
+ }
+
+ if (edge === 'end') {
+ edge = Range.isBackward(selection) ? 'anchor' : 'focus';
+ }
+
+ var anchor = selection.anchor,
+ focus = selection.focus;
+ var point = edge === 'anchor' ? anchor : focus;
+ Transforms.setSelection(editor, _defineProperty({}, edge === 'anchor' ? 'anchor' : 'focus', _objectSpread$1(_objectSpread$1({}, point), props)));
+ },
+
+ /**
+ * Set new properties on the selection.
+ */
+ setSelection: function setSelection(editor, props) {
+ var selection = editor.selection;
+ var oldProps = {};
+ var newProps = {};
+
+ if (!selection) {
+ return;
+ }
+
+ for (var k in props) {
+ if (k === 'anchor' && props.anchor != null && !Point.equals(props.anchor, selection.anchor) || k === 'focus' && props.focus != null && !Point.equals(props.focus, selection.focus) || k !== 'anchor' && k !== 'focus' && props[k] !== selection[k]) {
+ oldProps[k] = selection[k];
+ newProps[k] = props[k];
+ }
+ }
+
+ if (Object.keys(oldProps).length > 0) {
+ editor.apply({
+ type: 'set_selection',
+ properties: oldProps,
+ newProperties: newProps
+ });
+ }
+ }
+ };
+
+ 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; } } }; }
+
+ 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); }
+
+ 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; }
+ var TextTransforms = {
+ /**
+ * Delete content in the editor.
+ */
+ "delete": function _delete(editor) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var _options$reverse = options.reverse,
+ reverse = _options$reverse === void 0 ? false : _options$reverse,
+ _options$unit = options.unit,
+ unit = _options$unit === void 0 ? 'character' : _options$unit,
+ _options$distance = options.distance,
+ distance = _options$distance === void 0 ? 1 : _options$distance,
+ _options$voids = options.voids,
+ voids = _options$voids === void 0 ? false : _options$voids;
+ var _options$at = options.at,
+ at = _options$at === void 0 ? editor.selection : _options$at,
+ _options$hanging = options.hanging,
+ hanging = _options$hanging === void 0 ? false : _options$hanging;
+
+ if (!at) {
+ return;
+ }
+
+ if (Range.isRange(at) && Range.isCollapsed(at)) {
+ at = at.anchor;
+ }
+
+ if (Point.isPoint(at)) {
+ var furthestVoid = Editor["void"](editor, {
+ at: at,
+ mode: 'highest'
+ });
+
+ if (!voids && furthestVoid) {
+ var _furthestVoid = _slicedToArray(furthestVoid, 2),
+ voidPath = _furthestVoid[1];
+
+ at = voidPath;
+ } else {
+ var opts = {
+ unit: unit,
+ distance: distance
+ };
+ var target = reverse ? Editor.before(editor, at, opts) || Editor.start(editor, []) : Editor.after(editor, at, opts) || Editor.end(editor, []);
+ at = {
+ anchor: at,
+ focus: target
+ };
+ hanging = true;
+ }
+ }
+
+ if (Path.isPath(at)) {
+ Transforms.removeNodes(editor, {
+ at: at,
+ voids: voids
+ });
+ return;
+ }
+
+ if (Range.isCollapsed(at)) {
+ return;
+ }
+
+ if (!hanging) {
+ var _Range$edges = Range.edges(at),
+ _Range$edges2 = _slicedToArray(_Range$edges, 2),
+ _end = _Range$edges2[1];
+
+ var endOfDoc = Editor.end(editor, []);
+
+ if (!Point.equals(_end, endOfDoc)) {
+ at = Editor.unhangRange(editor, at, {
+ voids: voids
+ });
+ }
+ }
+
+ var _Range$edges3 = Range.edges(at),
+ _Range$edges4 = _slicedToArray(_Range$edges3, 2),
+ start = _Range$edges4[0],
+ end = _Range$edges4[1];
+
+ var startBlock = Editor.above(editor, {
+ match: function match(n) {
+ return Editor.isBlock(editor, n);
+ },
+ at: start,
+ voids: voids
+ });
+ var endBlock = Editor.above(editor, {
+ match: function match(n) {
+ return Editor.isBlock(editor, n);
+ },
+ at: end,
+ voids: voids
+ });
+ var isAcrossBlocks = startBlock && endBlock && !Path.equals(startBlock[1], endBlock[1]);
+ var isSingleText = Path.equals(start.path, end.path);
+ var startVoid = voids ? null : Editor["void"](editor, {
+ at: start,
+ mode: 'highest'
+ });
+ var endVoid = voids ? null : Editor["void"](editor, {
+ at: end,
+ mode: 'highest'
+ }); // If the start or end points are inside an inline void, nudge them out.
+
+ if (startVoid) {
+ var before = Editor.before(editor, start);
+
+ if (before && startBlock && Path.isAncestor(startBlock[1], before.path)) {
+ start = before;
+ }
+ }
+
+ if (endVoid) {
+ var after = Editor.after(editor, end);
+
+ if (after && endBlock && Path.isAncestor(endBlock[1], after.path)) {
+ end = after;
+ }
+ } // Get the highest nodes that are completely inside the range, as well as
+ // the start and end nodes.
+
+
+ var matches = [];
+ var lastPath;
+
+ var _iterator = _createForOfIteratorHelper(Editor.nodes(editor, {
+ at: at,
+ voids: voids
+ })),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var entry = _step.value;
+
+ var _entry = _slicedToArray(entry, 2),
+ _node2 = _entry[0],
+ _path3 = _entry[1];
+
+ if (lastPath && Path.compare(_path3, lastPath) === 0) {
+ continue;
+ }
+
+ if (!voids && Editor.isVoid(editor, _node2) || !Path.isCommon(_path3, start.path) && !Path.isCommon(_path3, end.path)) {
+ matches.push(entry);
+ lastPath = _path3;
+ }
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+
+ var pathRefs = Array.from(matches, function (_ref) {
+ var _ref2 = _slicedToArray(_ref, 2),
+ p = _ref2[1];
+
+ return Editor.pathRef(editor, p);
+ });
+ var startRef = Editor.pointRef(editor, start);
+ var endRef = Editor.pointRef(editor, end);
+
+ if (!isSingleText && !startVoid) {
+ var _point = startRef.current;
+
+ var _Editor$leaf = Editor.leaf(editor, _point),
+ _Editor$leaf2 = _slicedToArray(_Editor$leaf, 1),
+ node = _Editor$leaf2[0];
+
+ var path = _point.path;
+ var _start = start,
+ offset = _start.offset;
+ var text = node.text.slice(offset);
+ if (text.length > 0) editor.apply({
+ type: 'remove_text',
+ path: path,
+ offset: offset,
+ text: text
+ });
+ }
+
+ for (var _i = 0, _pathRefs = pathRefs; _i < _pathRefs.length; _i++) {
+ var pathRef = _pathRefs[_i];
+
+ var _path = pathRef.unref();
+
+ Transforms.removeNodes(editor, {
+ at: _path,
+ voids: voids
+ });
+ }
+
+ if (!endVoid) {
+ var _point2 = endRef.current;
+
+ var _Editor$leaf3 = Editor.leaf(editor, _point2),
+ _Editor$leaf4 = _slicedToArray(_Editor$leaf3, 1),
+ _node = _Editor$leaf4[0];
+
+ var _path2 = _point2.path;
+
+ var _offset = isSingleText ? start.offset : 0;
+
+ var _text = _node.text.slice(_offset, end.offset);
+
+ if (_text.length > 0) editor.apply({
+ type: 'remove_text',
+ path: _path2,
+ offset: _offset,
+ text: _text
+ });
+ }
+
+ if (!isSingleText && isAcrossBlocks && endRef.current && startRef.current) {
+ Transforms.mergeNodes(editor, {
+ at: endRef.current,
+ hanging: true,
+ voids: voids
+ });
+ }
+
+ var point = reverse ? startRef.unref() || endRef.unref() : endRef.unref() || startRef.unref();
+
+ if (options.at == null && point) {
+ Transforms.select(editor, point);
+ }
+ });
+ },
+
+ /**
+ * Insert a fragment at a specific location in the editor.
+ */
+ insertFragment: function insertFragment(editor, fragment) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var _options$hanging2 = options.hanging,
+ hanging = _options$hanging2 === void 0 ? false : _options$hanging2,
+ _options$voids2 = options.voids,
+ voids = _options$voids2 === void 0 ? false : _options$voids2;
+ var _options$at2 = options.at,
+ at = _options$at2 === void 0 ? editor.selection : _options$at2;
+
+ if (!fragment.length) {
+ return;
+ }
+
+ if (!at) {
+ return;
+ } else if (Range.isRange(at)) {
+ if (!hanging) {
+ at = Editor.unhangRange(editor, at);
+ }
+
+ if (Range.isCollapsed(at)) {
+ at = at.anchor;
+ } else {
+ var _Range$edges5 = Range.edges(at),
+ _Range$edges6 = _slicedToArray(_Range$edges5, 2),
+ end = _Range$edges6[1];
+
+ if (!voids && Editor["void"](editor, {
+ at: end
+ })) {
+ return;
+ }
+
+ var pointRef = Editor.pointRef(editor, end);
+ Transforms["delete"](editor, {
+ at: at
+ });
+ at = pointRef.unref();
+ }
+ } else if (Path.isPath(at)) {
+ at = Editor.start(editor, at);
+ }
+
+ if (!voids && Editor["void"](editor, {
+ at: at
+ })) {
+ return;
+ } // If the insert point is at the edge of an inline node, move it outside
+ // instead since it will need to be split otherwise.
+
+
+ var inlineElementMatch = Editor.above(editor, {
+ at: at,
+ match: function match(n) {
+ return Editor.isInline(editor, n);
+ },
+ mode: 'highest',
+ voids: voids
+ });
+
+ if (inlineElementMatch) {
+ var _inlineElementMatch = _slicedToArray(inlineElementMatch, 2),
+ _inlinePath = _inlineElementMatch[1];
+
+ if (Editor.isEnd(editor, at, _inlinePath)) {
+ var after = Editor.after(editor, _inlinePath);
+ at = after;
+ } else if (Editor.isStart(editor, at, _inlinePath)) {
+ var before = Editor.before(editor, _inlinePath);
+ at = before;
+ }
+ }
+
+ var blockMatch = Editor.above(editor, {
+ match: function match(n) {
+ return Editor.isBlock(editor, n);
+ },
+ at: at,
+ voids: voids
+ });
+
+ var _blockMatch = _slicedToArray(blockMatch, 2),
+ blockPath = _blockMatch[1];
+
+ var isBlockStart = Editor.isStart(editor, at, blockPath);
+ var isBlockEnd = Editor.isEnd(editor, at, blockPath);
+ var isBlockEmpty = isBlockStart && isBlockEnd;
+ var mergeStart = !isBlockStart || isBlockStart && isBlockEnd;
+ var mergeEnd = !isBlockEnd;
+
+ var _Node$first = Node$1.first({
+ children: fragment
+ }, []),
+ _Node$first2 = _slicedToArray(_Node$first, 2),
+ firstPath = _Node$first2[1];
+
+ var _Node$last = Node$1.last({
+ children: fragment
+ }, []),
+ _Node$last2 = _slicedToArray(_Node$last, 2),
+ lastPath = _Node$last2[1];
+
+ var matches = [];
+
+ var matcher = function matcher(_ref3) {
+ var _ref4 = _slicedToArray(_ref3, 2),
+ n = _ref4[0],
+ p = _ref4[1];
+
+ var isRoot = p.length === 0;
+
+ if (isRoot) {
+ return false;
+ }
+
+ if (isBlockEmpty) {
+ return true;
+ }
+
+ if (mergeStart && Path.isAncestor(p, firstPath) && Element$1.isElement(n) && !editor.isVoid(n) && !editor.isInline(n)) {
+ return false;
+ }
+
+ if (mergeEnd && Path.isAncestor(p, lastPath) && Element$1.isElement(n) && !editor.isVoid(n) && !editor.isInline(n)) {
+ return false;
+ }
+
+ return true;
+ };
+
+ var _iterator2 = _createForOfIteratorHelper(Node$1.nodes({
+ children: fragment
+ }, {
+ pass: matcher
+ })),
+ _step2;
+
+ try {
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
+ var entry = _step2.value;
+
+ if (matcher(entry)) {
+ matches.push(entry);
+ }
+ }
+ } catch (err) {
+ _iterator2.e(err);
+ } finally {
+ _iterator2.f();
+ }
+
+ var starts = [];
+ var middles = [];
+ var ends = [];
+ var starting = true;
+ var hasBlocks = false;
+
+ for (var _i2 = 0, _matches = matches; _i2 < _matches.length; _i2++) {
+ var _matches$_i = _slicedToArray(_matches[_i2], 1),
+ node = _matches$_i[0];
+
+ if (Element$1.isElement(node) && !editor.isInline(node)) {
+ starting = false;
+ hasBlocks = true;
+ middles.push(node);
+ } else if (starting) {
+ starts.push(node);
+ } else {
+ ends.push(node);
+ }
+ }
+
+ var _Editor$nodes = Editor.nodes(editor, {
+ at: at,
+ match: function match(n) {
+ return Text.isText(n) || Editor.isInline(editor, n);
+ },
+ mode: 'highest',
+ voids: voids
+ }),
+ _Editor$nodes2 = _slicedToArray(_Editor$nodes, 1),
+ inlineMatch = _Editor$nodes2[0];
+
+ var _inlineMatch = _slicedToArray(inlineMatch, 2),
+ inlinePath = _inlineMatch[1];
+
+ var isInlineStart = Editor.isStart(editor, at, inlinePath);
+ var isInlineEnd = Editor.isEnd(editor, at, inlinePath);
+ var middleRef = Editor.pathRef(editor, isBlockEnd ? Path.next(blockPath) : blockPath);
+ var endRef = Editor.pathRef(editor, isInlineEnd ? Path.next(inlinePath) : inlinePath);
+ var blockPathRef = Editor.pathRef(editor, blockPath);
+ Transforms.splitNodes(editor, {
+ at: at,
+ match: function match(n) {
+ return hasBlocks ? Editor.isBlock(editor, n) : Text.isText(n) || Editor.isInline(editor, n);
+ },
+ mode: hasBlocks ? 'lowest' : 'highest',
+ voids: voids
+ });
+ var startRef = Editor.pathRef(editor, !isInlineStart || isInlineStart && isInlineEnd ? Path.next(inlinePath) : inlinePath);
+ Transforms.insertNodes(editor, starts, {
+ at: startRef.current,
+ match: function match(n) {
+ return Text.isText(n) || Editor.isInline(editor, n);
+ },
+ mode: 'highest',
+ voids: voids
+ });
+
+ if (isBlockEmpty && middles.length) {
+ Transforms["delete"](editor, {
+ at: blockPathRef.unref(),
+ voids: voids
+ });
+ }
+
+ Transforms.insertNodes(editor, middles, {
+ at: middleRef.current,
+ match: function match(n) {
+ return Editor.isBlock(editor, n);
+ },
+ mode: 'lowest',
+ voids: voids
+ });
+ Transforms.insertNodes(editor, ends, {
+ at: endRef.current,
+ match: function match(n) {
+ return Text.isText(n) || Editor.isInline(editor, n);
+ },
+ mode: 'highest',
+ voids: voids
+ });
+
+ if (!options.at) {
+ var path;
+
+ if (ends.length > 0) {
+ path = Path.previous(endRef.current);
+ } else if (middles.length > 0) {
+ path = Path.previous(middleRef.current);
+ } else {
+ path = Path.previous(startRef.current);
+ }
+
+ var _end2 = Editor.end(editor, path);
+
+ Transforms.select(editor, _end2);
+ }
+
+ startRef.unref();
+ middleRef.unref();
+ endRef.unref();
+ });
+ },
+
+ /**
+ * Insert a string of text in the Editor.
+ */
+ insertText: function insertText(editor, text) {
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ Editor.withoutNormalizing(editor, function () {
+ var _options$voids3 = options.voids,
+ voids = _options$voids3 === void 0 ? false : _options$voids3;
+ var _options$at3 = options.at,
+ at = _options$at3 === void 0 ? editor.selection : _options$at3;
+
+ if (!at) {
+ return;
+ }
+
+ if (Path.isPath(at)) {
+ at = Editor.range(editor, at);
+ }
+
+ if (Range.isRange(at)) {
+ if (Range.isCollapsed(at)) {
+ at = at.anchor;
+ } else {
+ var end = Range.end(at);
+
+ if (!voids && Editor["void"](editor, {
+ at: end
+ })) {
+ return;
+ }
+
+ var pointRef = Editor.pointRef(editor, end);
+ Transforms["delete"](editor, {
+ at: at,
+ voids: voids
+ });
+ at = pointRef.unref();
+ Transforms.setSelection(editor, {
+ anchor: at,
+ focus: at
+ });
+ }
+ }
+
+ if (!voids && Editor["void"](editor, {
+ at: at
+ })) {
+ return;
+ }
+
+ var _at = at,
+ path = _at.path,
+ offset = _at.offset;
+ if (text.length > 0) editor.apply({
+ type: 'insert_text',
+ path: path,
+ offset: offset,
+ text: text
+ });
+ });
+ }
+ };
+
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
+
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
+ var Transforms = _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, GeneralTransforms), NodeTransforms), SelectionTransforms), TextTransforms);
+
+ var Editor_1 = Editor;
+ var Element_1 = Element$1;
+ var Location_1 = Location;
+ var Node_1 = Node$1;
+ var Operation_1 = Operation;
+ var Path_1 = Path;
+ var PathRef_1 = PathRef;
+ var Point_1 = Point;
+ var PointRef_1 = PointRef;
+ var Range_1 = Range;
+ var RangeRef_1 = RangeRef;
+ var Span_1 = Span;
+ var Text_1 = Text;
+ var Transforms_1 = Transforms;
+ var createEditor_1 = createEditor$1;
+
+
+ var dist$7 = /*#__PURE__*/Object.defineProperty({
+ Editor: Editor_1,
+ Element: Element_1,
+ Location: Location_1,
+ Node: Node_1,
+ Operation: Operation_1,
+ Path: Path_1,
+ PathRef: PathRef_1,
+ Point: Point_1,
+ PointRef: PointRef_1,
+ Range: Range_1,
+ RangeRef: RangeRef_1,
+ Span: Span_1,
+ Text: Text_1,
+ Transforms: Transforms_1,
+ createEditor: createEditor_1
+ }, '__esModule', {value: true});
+
+ /**
+ * lodash (Custom Build)
+ * Build: `lodash modularize exports="npm" -o ./`
+ * Copyright jQuery Foundation and other contributors
+ * Released under MIT license
+ * Based on Underscore.js 1.8.3
+ * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
+ */
+
+ /** Used as references for various `Number` constants. */
+ var MAX_SAFE_INTEGER$1 = 9007199254740991;
+
+ /** `Object#toString` result references. */
+ var argsTag$1 = '[object Arguments]',
+ funcTag$1 = '[object Function]',
+ genTag$1 = '[object GeneratorFunction]',
+ mapTag = '[object Map]',
+ objectTag = '[object Object]',
+ promiseTag = '[object Promise]',
+ setTag = '[object Set]',
+ stringTag = '[object String]',
+ weakMapTag = '[object WeakMap]';
+
+ var dataViewTag = '[object DataView]';
+
+ /**
+ * Used to match `RegExp`
+ * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).
+ */
+ var reRegExpChar = /[\\^$.*+?()[\]{}|]/g;
+
+ /** Used to detect host constructors (Safari). */
+ var reIsHostCtor = /^\[object .+?Constructor\]$/;
+
+ /** Used to detect unsigned integer values. */
+ var reIsUint$1 = /^(?:0|[1-9]\d*)$/;
+
+ /** Used to compose unicode character classes. */
+ var rsAstralRange$1 = '\\ud800-\\udfff',
+ rsComboMarksRange$1 = '\\u0300-\\u036f\\ufe20-\\ufe23',
+ rsComboSymbolsRange$1 = '\\u20d0-\\u20f0',
+ rsVarRange$1 = '\\ufe0e\\ufe0f';
+
+ /** Used to compose unicode capture groups. */
+ var rsAstral$1 = '[' + rsAstralRange$1 + ']',
+ rsCombo$1 = '[' + rsComboMarksRange$1 + rsComboSymbolsRange$1 + ']',
+ rsFitz$1 = '\\ud83c[\\udffb-\\udfff]',
+ rsModifier$1 = '(?:' + rsCombo$1 + '|' + rsFitz$1 + ')',
+ rsNonAstral$1 = '[^' + rsAstralRange$1 + ']',
+ rsRegional$1 = '(?:\\ud83c[\\udde6-\\uddff]){2}',
+ rsSurrPair$1 = '[\\ud800-\\udbff][\\udc00-\\udfff]',
+ rsZWJ$1 = '\\u200d';
+
+ /** Used to compose unicode regexes. */
+ var reOptMod$1 = rsModifier$1 + '?',
+ rsOptVar$1 = '[' + rsVarRange$1 + ']?',
+ rsOptJoin$1 = '(?:' + rsZWJ$1 + '(?:' + [rsNonAstral$1, rsRegional$1, rsSurrPair$1].join('|') + ')' + rsOptVar$1 + reOptMod$1 + ')*',
+ rsSeq$1 = rsOptVar$1 + reOptMod$1 + rsOptJoin$1,
+ rsSymbol$1 = '(?:' + [rsNonAstral$1 + rsCombo$1 + '?', rsCombo$1, rsRegional$1, rsSurrPair$1, rsAstral$1].join('|') + ')';
+
+ /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */
+ var reUnicode$1 = RegExp(rsFitz$1 + '(?=' + rsFitz$1 + ')|' + rsSymbol$1 + rsSeq$1, 'g');
+
+ /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */
+ var reHasUnicode$1 = RegExp('[' + rsZWJ$1 + rsAstralRange$1 + rsComboMarksRange$1 + rsComboSymbolsRange$1 + rsVarRange$1 + ']');
+
+ /** Detect free variable `global` from Node.js. */
+ var freeGlobal$3 = typeof commonjsGlobal == 'object' && commonjsGlobal && commonjsGlobal.Object === Object && commonjsGlobal;
+
+ /** Detect free variable `self`. */
+ var freeSelf$3 = typeof self == 'object' && self && self.Object === Object && self;
+
+ /** Used as a reference to the global object. */
+ var root$3 = freeGlobal$3 || freeSelf$3 || Function('return this')();
+
+ /**
+ * A specialized version of `_.map` for arrays without support for iteratee
+ * shorthands.
+ *
+ * @private
+ * @param {Array} [array] The array to iterate over.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @returns {Array} Returns the new mapped array.
+ */
+ function arrayMap(array, iteratee) {
+ var index = -1,
+ length = array ? array.length : 0,
+ result = Array(length);
+
+ while (++index < length) {
+ result[index] = iteratee(array[index], index, array);
+ }
+ return result;
+ }
+
+ /**
+ * Converts an ASCII `string` to an array.
+ *
+ * @private
+ * @param {string} string The string to convert.
+ * @returns {Array} Returns the converted array.
+ */
+ function asciiToArray$1(string) {
+ return string.split('');
+ }
+
+ /**
+ * The base implementation of `_.times` without support for iteratee shorthands
+ * or max array length checks.
+ *
+ * @private
+ * @param {number} n The number of times to invoke `iteratee`.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @returns {Array} Returns the array of results.
+ */
+ function baseTimes$1(n, iteratee) {
+ var index = -1,
+ result = Array(n);
+
+ while (++index < n) {
+ result[index] = iteratee(index);
+ }
+ return result;
+ }
+
+ /**
+ * The base implementation of `_.values` and `_.valuesIn` which creates an
+ * array of `object` property values corresponding to the property names
+ * of `props`.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @param {Array} props The property names to get values for.
+ * @returns {Object} Returns the array of property values.
+ */
+ function baseValues(object, props) {
+ return arrayMap(props, function(key) {
+ return object[key];
+ });
+ }
+
+ /**
+ * Gets the value at `key` of `object`.
+ *
+ * @private
+ * @param {Object} [object] The object to query.
+ * @param {string} key The key of the property to get.
+ * @returns {*} Returns the property value.
+ */
+ function getValue(object, key) {
+ return object == null ? undefined : object[key];
+ }
+
+ /**
+ * Checks if `string` contains Unicode symbols.
+ *
+ * @private
+ * @param {string} string The string to inspect.
+ * @returns {boolean} Returns `true` if a symbol is found, else `false`.
+ */
+ function hasUnicode$1(string) {
+ return reHasUnicode$1.test(string);
+ }
+
+ /**
+ * Checks if `value` is a host object in IE < 9.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a host object, else `false`.
+ */
+ function isHostObject(value) {
+ // Many host objects are `Object` objects that can coerce to strings
+ // despite having improperly defined `toString` methods.
+ var result = false;
+ if (value != null && typeof value.toString != 'function') {
+ try {
+ result = !!(value + '');
+ } catch (e) {}
+ }
+ return result;
+ }
+
+ /**
+ * Converts `iterator` to an array.
+ *
+ * @private
+ * @param {Object} iterator The iterator to convert.
+ * @returns {Array} Returns the converted array.
+ */
+ function iteratorToArray(iterator) {
+ var data,
+ result = [];
+
+ while (!(data = iterator.next()).done) {
+ result.push(data.value);
+ }
+ return result;
+ }
+
+ /**
+ * Converts `map` to its key-value pairs.
+ *
+ * @private
+ * @param {Object} map The map to convert.
+ * @returns {Array} Returns the key-value pairs.
+ */
+ function mapToArray(map) {
+ var index = -1,
+ result = Array(map.size);
+
+ map.forEach(function(value, key) {
+ result[++index] = [key, value];
+ });
+ return result;
+ }
+
+ /**
+ * Creates a unary function that invokes `func` with its argument transformed.
+ *
+ * @private
+ * @param {Function} func The function to wrap.
+ * @param {Function} transform The argument transform.
+ * @returns {Function} Returns the new function.
+ */
+ function overArg$1(func, transform) {
+ return function(arg) {
+ return func(transform(arg));
+ };
+ }
+
+ /**
+ * Converts `set` to an array of its values.
+ *
+ * @private
+ * @param {Object} set The set to convert.
+ * @returns {Array} Returns the values.
+ */
+ function setToArray(set) {
+ var index = -1,
+ result = Array(set.size);
+
+ set.forEach(function(value) {
+ result[++index] = value;
+ });
+ return result;
+ }
+
+ /**
+ * Converts `string` to an array.
+ *
+ * @private
+ * @param {string} string The string to convert.
+ * @returns {Array} Returns the converted array.
+ */
+ function stringToArray$1(string) {
+ return hasUnicode$1(string)
+ ? unicodeToArray$1(string)
+ : asciiToArray$1(string);
+ }
+
+ /**
+ * Converts a Unicode `string` to an array.
+ *
+ * @private
+ * @param {string} string The string to convert.
+ * @returns {Array} Returns the converted array.
+ */
+ function unicodeToArray$1(string) {
+ return string.match(reUnicode$1) || [];
+ }
+
+ /** Used for built-in method references. */
+ var funcProto = Function.prototype,
+ objectProto$4 = Object.prototype;
+
+ /** Used to detect overreaching core-js shims. */
+ var coreJsData = root$3['__core-js_shared__'];
+
+ /** Used to detect methods masquerading as native. */
+ var maskSrcKey = (function() {
+ var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');
+ return uid ? ('Symbol(src)_1.' + uid) : '';
+ }());
+
+ /** Used to resolve the decompiled source of functions. */
+ var funcToString = funcProto.toString;
+
+ /** Used to check objects for own properties. */
+ var hasOwnProperty$2 = objectProto$4.hasOwnProperty;
+
+ /**
+ * Used to resolve the
+ * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
+ * of values.
+ */
+ var objectToString$4 = objectProto$4.toString;
+
+ /** Used to detect if a method is native. */
+ var reIsNative = RegExp('^' +
+ funcToString.call(hasOwnProperty$2).replace(reRegExpChar, '\\$&')
+ .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$'
+ );
+
+ /** Built-in value references. */
+ var Symbol$2 = root$3.Symbol,
+ iteratorSymbol = Symbol$2 ? Symbol$2.iterator : undefined,
+ propertyIsEnumerable$1 = objectProto$4.propertyIsEnumerable;
+
+ /* Built-in method references for those with the same name as other `lodash` methods. */
+ var nativeKeys$1 = overArg$1(Object.keys, Object);
+
+ /* Built-in method references that are verified to be native. */
+ var DataView = getNative(root$3, 'DataView'),
+ Map$1 = getNative(root$3, 'Map'),
+ Promise$1 = getNative(root$3, 'Promise'),
+ Set$1 = getNative(root$3, 'Set'),
+ WeakMap$1 = getNative(root$3, 'WeakMap');
+
+ /** Used to detect maps, sets, and weakmaps. */
+ var dataViewCtorString = toSource(DataView),
+ mapCtorString = toSource(Map$1),
+ promiseCtorString = toSource(Promise$1),
+ setCtorString = toSource(Set$1),
+ weakMapCtorString = toSource(WeakMap$1);
+
+ /**
+ * Creates an array of the enumerable property names of the array-like `value`.
+ *
+ * @private
+ * @param {*} value The value to query.
+ * @param {boolean} inherited Specify returning inherited property names.
+ * @returns {Array} Returns the array of property names.
+ */
+ function arrayLikeKeys$1(value, inherited) {
+ // Safari 8.1 makes `arguments.callee` enumerable in strict mode.
+ // Safari 9 makes `arguments.length` enumerable in strict mode.
+ var result = (isArray$1(value) || isArguments$1(value))
+ ? baseTimes$1(value.length, String)
+ : [];
+
+ var length = result.length,
+ skipIndexes = !!length;
+
+ for (var key in value) {
+ if ((inherited || hasOwnProperty$2.call(value, key)) &&
+ !(skipIndexes && (key == 'length' || isIndex$1(key, length)))) {
+ result.push(key);
+ }
+ }
+ return result;
+ }
+
+ /**
+ * The base implementation of `getTag`.
+ *
+ * @private
+ * @param {*} value The value to query.
+ * @returns {string} Returns the `toStringTag`.
+ */
+ function baseGetTag(value) {
+ return objectToString$4.call(value);
+ }
+
+ /**
+ * The base implementation of `_.isNative` without bad shim checks.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a native function,
+ * else `false`.
+ */
+ function baseIsNative(value) {
+ if (!isObject$3(value) || isMasked(value)) {
+ return false;
+ }
+ var pattern = (isFunction$1(value) || isHostObject(value)) ? reIsNative : reIsHostCtor;
+ return pattern.test(toSource(value));
+ }
+
+ /**
+ * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @returns {Array} Returns the array of property names.
+ */
+ function baseKeys$1(object) {
+ if (!isPrototype$1(object)) {
+ return nativeKeys$1(object);
+ }
+ var result = [];
+ for (var key in Object(object)) {
+ if (hasOwnProperty$2.call(object, key) && key != 'constructor') {
+ result.push(key);
+ }
+ }
+ return result;
+ }
+
+ /**
+ * Copies the values of `source` to `array`.
+ *
+ * @private
+ * @param {Array} source The array to copy values from.
+ * @param {Array} [array=[]] The array to copy values to.
+ * @returns {Array} Returns `array`.
+ */
+ function copyArray(source, array) {
+ var index = -1,
+ length = source.length;
+
+ array || (array = Array(length));
+ while (++index < length) {
+ array[index] = source[index];
+ }
+ return array;
+ }
+
+ /**
+ * Gets the native function at `key` of `object`.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @param {string} key The key of the method to get.
+ * @returns {*} Returns the function if it's native, else `undefined`.
+ */
+ function getNative(object, key) {
+ var value = getValue(object, key);
+ return baseIsNative(value) ? value : undefined;
+ }
+
+ /**
+ * Gets the `toStringTag` of `value`.
+ *
+ * @private
+ * @param {*} value The value to query.
+ * @returns {string} Returns the `toStringTag`.
+ */
+ var getTag = baseGetTag;
+
+ // Fallback for data views, maps, sets, and weak maps in IE 11,
+ // for data views in Edge < 14, and promises in Node.js.
+ if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||
+ (Map$1 && getTag(new Map$1) != mapTag) ||
+ (Promise$1 && getTag(Promise$1.resolve()) != promiseTag) ||
+ (Set$1 && getTag(new Set$1) != setTag) ||
+ (WeakMap$1 && getTag(new WeakMap$1) != weakMapTag)) {
+ getTag = function(value) {
+ var result = objectToString$4.call(value),
+ Ctor = result == objectTag ? value.constructor : undefined,
+ ctorString = Ctor ? toSource(Ctor) : undefined;
+
+ if (ctorString) {
+ switch (ctorString) {
+ case dataViewCtorString: return dataViewTag;
+ case mapCtorString: return mapTag;
+ case promiseCtorString: return promiseTag;
+ case setCtorString: return setTag;
+ case weakMapCtorString: return weakMapTag;
+ }
+ }
+ return result;
+ };
+ }
+
+ /**
+ * Checks if `value` is a valid array-like index.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.
+ * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.
+ */
+ function isIndex$1(value, length) {
+ length = length == null ? MAX_SAFE_INTEGER$1 : length;
+ return !!length &&
+ (typeof value == 'number' || reIsUint$1.test(value)) &&
+ (value > -1 && value % 1 == 0 && value < length);
+ }
+
+ /**
+ * Checks if `func` has its source masked.
+ *
+ * @private
+ * @param {Function} func The function to check.
+ * @returns {boolean} Returns `true` if `func` is masked, else `false`.
+ */
+ function isMasked(func) {
+ return !!maskSrcKey && (maskSrcKey in func);
+ }
+
+ /**
+ * Checks if `value` is likely a prototype object.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.
+ */
+ function isPrototype$1(value) {
+ var Ctor = value && value.constructor,
+ proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto$4;
+
+ return value === proto;
+ }
+
+ /**
+ * Converts `func` to its source code.
+ *
+ * @private
+ * @param {Function} func The function to process.
+ * @returns {string} Returns the source code.
+ */
+ function toSource(func) {
+ if (func != null) {
+ try {
+ return funcToString.call(func);
+ } catch (e) {}
+ try {
+ return (func + '');
+ } catch (e) {}
+ }
+ return '';
+ }
+
+ /**
+ * Checks if `value` is likely an `arguments` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an `arguments` object,
+ * else `false`.
+ * @example
+ *
+ * _.isArguments(function() { return arguments; }());
+ * // => true
+ *
+ * _.isArguments([1, 2, 3]);
+ * // => false
+ */
+ function isArguments$1(value) {
+ // Safari 8.1 makes `arguments.callee` enumerable in strict mode.
+ return isArrayLikeObject$1(value) && hasOwnProperty$2.call(value, 'callee') &&
+ (!propertyIsEnumerable$1.call(value, 'callee') || objectToString$4.call(value) == argsTag$1);
+ }
+
+ /**
+ * Checks if `value` is classified as an `Array` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an array, else `false`.
+ * @example
+ *
+ * _.isArray([1, 2, 3]);
+ * // => true
+ *
+ * _.isArray(document.body.children);
+ * // => false
+ *
+ * _.isArray('abc');
+ * // => false
+ *
+ * _.isArray(_.noop);
+ * // => false
+ */
+ var isArray$1 = Array.isArray;
+
+ /**
+ * Checks if `value` is array-like. A value is considered array-like if it's
+ * not a function and has a `value.length` that's an integer greater than or
+ * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is array-like, else `false`.
+ * @example
+ *
+ * _.isArrayLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isArrayLike(document.body.children);
+ * // => true
+ *
+ * _.isArrayLike('abc');
+ * // => true
+ *
+ * _.isArrayLike(_.noop);
+ * // => false
+ */
+ function isArrayLike$1(value) {
+ return value != null && isLength$1(value.length) && !isFunction$1(value);
+ }
+
+ /**
+ * This method is like `_.isArrayLike` except that it also checks if `value`
+ * is an object.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an array-like object,
+ * else `false`.
+ * @example
+ *
+ * _.isArrayLikeObject([1, 2, 3]);
+ * // => true
+ *
+ * _.isArrayLikeObject(document.body.children);
+ * // => true
+ *
+ * _.isArrayLikeObject('abc');
+ * // => false
+ *
+ * _.isArrayLikeObject(_.noop);
+ * // => false
+ */
+ function isArrayLikeObject$1(value) {
+ return isObjectLike$4(value) && isArrayLike$1(value);
+ }
+
+ /**
+ * Checks if `value` is classified as a `Function` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a function, else `false`.
+ * @example
+ *
+ * _.isFunction(_);
+ * // => true
+ *
+ * _.isFunction(/abc/);
+ * // => false
+ */
+ function isFunction$1(value) {
+ // The use of `Object#toString` avoids issues with the `typeof` operator
+ // in Safari 8-9 which returns 'object' for typed array and other constructors.
+ var tag = isObject$3(value) ? objectToString$4.call(value) : '';
+ return tag == funcTag$1 || tag == genTag$1;
+ }
+
+ /**
+ * Checks if `value` is a valid array-like length.
+ *
+ * **Note:** This method is loosely based on
+ * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.
+ * @example
+ *
+ * _.isLength(3);
+ * // => true
+ *
+ * _.isLength(Number.MIN_VALUE);
+ * // => false
+ *
+ * _.isLength(Infinity);
+ * // => false
+ *
+ * _.isLength('3');
+ * // => false
+ */
+ function isLength$1(value) {
+ return typeof value == 'number' &&
+ value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER$1;
+ }
+
+ /**
+ * Checks if `value` is the
+ * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
+ * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an object, else `false`.
+ * @example
+ *
+ * _.isObject({});
+ * // => true
+ *
+ * _.isObject([1, 2, 3]);
+ * // => true
+ *
+ * _.isObject(_.noop);
+ * // => true
+ *
+ * _.isObject(null);
+ * // => false
+ */
+ function isObject$3(value) {
+ var type = typeof value;
+ return !!value && (type == 'object' || type == 'function');
+ }
+
+ /**
+ * Checks if `value` is object-like. A value is object-like if it's not `null`
+ * and has a `typeof` result of "object".
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
+ * @example
+ *
+ * _.isObjectLike({});
+ * // => true
+ *
+ * _.isObjectLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isObjectLike(_.noop);
+ * // => false
+ *
+ * _.isObjectLike(null);
+ * // => false
+ */
+ function isObjectLike$4(value) {
+ return !!value && typeof value == 'object';
+ }
+
+ /**
+ * Checks if `value` is classified as a `String` primitive or object.
+ *
+ * @static
+ * @since 0.1.0
+ * @memberOf _
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a string, else `false`.
+ * @example
+ *
+ * _.isString('abc');
+ * // => true
+ *
+ * _.isString(1);
+ * // => false
+ */
+ function isString(value) {
+ return typeof value == 'string' ||
+ (!isArray$1(value) && isObjectLike$4(value) && objectToString$4.call(value) == stringTag);
+ }
+
+ /**
+ * Converts `value` to an array.
+ *
+ * @static
+ * @since 0.1.0
+ * @memberOf _
+ * @category Lang
+ * @param {*} value The value to convert.
+ * @returns {Array} Returns the converted array.
+ * @example
+ *
+ * _.toArray({ 'a': 1, 'b': 2 });
+ * // => [1, 2]
+ *
+ * _.toArray('abc');
+ * // => ['a', 'b', 'c']
+ *
+ * _.toArray(1);
+ * // => []
+ *
+ * _.toArray(null);
+ * // => []
+ */
+ function toArray(value) {
+ if (!value) {
+ return [];
+ }
+ if (isArrayLike$1(value)) {
+ return isString(value) ? stringToArray$1(value) : copyArray(value);
+ }
+ if (iteratorSymbol && value[iteratorSymbol]) {
+ return iteratorToArray(value[iteratorSymbol]());
+ }
+ var tag = getTag(value),
+ func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values);
+
+ return func(value);
+ }
+
+ /**
+ * Creates an array of the own enumerable property names of `object`.
+ *
+ * **Note:** Non-object values are coerced to objects. See the
+ * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
+ * for more details.
+ *
+ * @static
+ * @since 0.1.0
+ * @memberOf _
+ * @category Object
+ * @param {Object} object The object to query.
+ * @returns {Array} Returns the array of property names.
+ * @example
+ *
+ * function Foo() {
+ * this.a = 1;
+ * this.b = 2;
+ * }
+ *
+ * Foo.prototype.c = 3;
+ *
+ * _.keys(new Foo);
+ * // => ['a', 'b'] (iteration order is not guaranteed)
+ *
+ * _.keys('hi');
+ * // => ['0', '1']
+ */
+ function keys$1(object) {
+ return isArrayLike$1(object) ? arrayLikeKeys$1(object) : baseKeys$1(object);
+ }
+
+ /**
+ * Creates an array of the own enumerable string keyed property values of `object`.
+ *
+ * **Note:** Non-object values are coerced to objects.
+ *
+ * @static
+ * @since 0.1.0
+ * @memberOf _
+ * @category Object
+ * @param {Object} object The object to query.
+ * @returns {Array} Returns the array of property values.
+ * @example
+ *
+ * function Foo() {
+ * this.a = 1;
+ * this.b = 2;
+ * }
+ *
+ * Foo.prototype.c = 3;
+ *
+ * _.values(new Foo);
+ * // => [1, 2] (iteration order is not guaranteed)
+ *
+ * _.values('hi');
+ * // => ['h', 'i']
+ */
+ function values(object) {
+ return object ? baseValues(object, keys$1(object)) : [];
+ }
+
+ var lodash_toarray = toArray;
+
+ /**
+ * SSR Window 3.0.0
+ * Better handling for window object in SSR environment
+ * https://github.com/nolimits4web/ssr-window
+ *
+ * Copyright 2020, Vladimir Kharlampidi
+ *
+ * Licensed under MIT
+ *
+ * Released on: November 9, 2020
+ */
+
+ var ssrWindow_umd = createCommonjsModule$1(function (module, exports) {
+ (function (global, factory) {
+ factory(exports) ;
+ }(commonjsGlobal, (function (exports) {
+ /* eslint-disable no-param-reassign */
+ function isObject(obj) {
+ return (obj !== null &&
+ typeof obj === 'object' &&
+ 'constructor' in obj &&
+ obj.constructor === Object);
+ }
+ function extend(target, src) {
+ if (target === void 0) { target = {}; }
+ if (src === void 0) { src = {}; }
+ Object.keys(src).forEach(function (key) {
+ if (typeof target[key] === 'undefined')
+ target[key] = src[key];
+ else if (isObject(src[key]) &&
+ isObject(target[key]) &&
+ Object.keys(src[key]).length > 0) {
+ extend(target[key], src[key]);
+ }
+ });
+ }
+
+ var ssrDocument = {
+ body: {},
+ addEventListener: function () { },
+ removeEventListener: function () { },
+ activeElement: {
+ blur: function () { },
+ nodeName: '',
+ },
+ querySelector: function () {
+ return null;
+ },
+ querySelectorAll: function () {
+ return [];
+ },
+ getElementById: function () {
+ return null;
+ },
+ createEvent: function () {
+ return {
+ initEvent: function () { },
+ };
+ },
+ createElement: function () {
+ return {
+ children: [],
+ childNodes: [],
+ style: {},
+ setAttribute: function () { },
+ getElementsByTagName: function () {
+ return [];
+ },
+ };
+ },
+ createElementNS: function () {
+ return {};
+ },
+ importNode: function () {
+ return null;
+ },
+ location: {
+ hash: '',
+ host: '',
+ hostname: '',
+ href: '',
+ origin: '',
+ pathname: '',
+ protocol: '',
+ search: '',
+ },
+ };
+ function getDocument() {
+ var doc = typeof document !== 'undefined' ? document : {};
+ extend(doc, ssrDocument);
+ return doc;
+ }
+
+ var ssrWindow = {
+ document: ssrDocument,
+ navigator: {
+ userAgent: '',
+ },
+ location: {
+ hash: '',
+ host: '',
+ hostname: '',
+ href: '',
+ origin: '',
+ pathname: '',
+ protocol: '',
+ search: '',
+ },
+ history: {
+ replaceState: function () { },
+ pushState: function () { },
+ go: function () { },
+ back: function () { },
+ },
+ CustomEvent: function CustomEvent() {
+ return this;
+ },
+ addEventListener: function () { },
+ removeEventListener: function () { },
+ getComputedStyle: function () {
+ return {
+ getPropertyValue: function () {
+ return '';
+ },
+ };
+ },
+ Image: function () { },
+ Date: function () { },
+ screen: {},
+ setTimeout: function () { },
+ clearTimeout: function () { },
+ matchMedia: function () {
+ return {};
+ },
+ requestAnimationFrame: function (callback) {
+ if (typeof setTimeout === 'undefined') {
+ callback();
+ return null;
+ }
+ return setTimeout(callback, 0);
+ },
+ cancelAnimationFrame: function (id) {
+ if (typeof setTimeout === 'undefined') {
+ return;
+ }
+ clearTimeout(id);
+ },
+ };
+ function getWindow() {
+ var win = typeof window !== 'undefined' ? window : {};
+ extend(win, ssrWindow);
+ return win;
+ }
+
+ exports.extend = extend;
+ exports.getDocument = getDocument;
+ exports.getWindow = getWindow;
+ exports.ssrDocument = ssrDocument;
+ exports.ssrWindow = ssrWindow;
+
+ Object.defineProperty(exports, '__esModule', { value: true });
+
+ })));
+
+ });
+
+ /**
+ * Dom7 3.0.0
+ * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API
+ * https://framework7.io/docs/dom7.html
+ *
+ * Copyright 2020, Vladimir Kharlampidi
+ *
+ * Licensed under MIT
+ *
+ * Released on: November 9, 2020
+ */
+
+
+
+
+
+ function _inheritsLoose(subClass, superClass) {
+ subClass.prototype = Object.create(superClass.prototype);
+ subClass.prototype.constructor = subClass;
+ subClass.__proto__ = superClass;
+ }
+
+ function _getPrototypeOf(o) {
+ _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
+ return o.__proto__ || Object.getPrototypeOf(o);
+ };
+ return _getPrototypeOf(o);
+ }
+
+ function _setPrototypeOf(o, p) {
+ _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {
+ o.__proto__ = p;
+ return o;
+ };
+
+ return _setPrototypeOf(o, p);
+ }
+
+ function _isNativeReflectConstruct() {
+ if (typeof Reflect === "undefined" || !Reflect.construct) return false;
+ if (Reflect.construct.sham) return false;
+ if (typeof Proxy === "function") return true;
+
+ try {
+ Date.prototype.toString.call(Reflect.construct(Date, [], function () {}));
+ return true;
+ } catch (e) {
+ return false;
+ }
+ }
+
+ function _construct(Parent, args, Class) {
+ if (_isNativeReflectConstruct()) {
+ _construct = Reflect.construct;
+ } else {
+ _construct = function _construct(Parent, args, Class) {
+ var a = [null];
+ a.push.apply(a, args);
+ var Constructor = Function.bind.apply(Parent, a);
+ var instance = new Constructor();
+ if (Class) _setPrototypeOf(instance, Class.prototype);
+ return instance;
+ };
+ }
+
+ return _construct.apply(null, arguments);
+ }
+
+ function _isNativeFunction(fn) {
+ return Function.toString.call(fn).indexOf("[native code]") !== -1;
+ }
+
+ function _wrapNativeSuper(Class) {
+ var _cache = typeof Map === "function" ? new Map() : undefined;
+
+ _wrapNativeSuper = function _wrapNativeSuper(Class) {
+ if (Class === null || !_isNativeFunction(Class)) return Class;
+
+ if (typeof Class !== "function") {
+ throw new TypeError("Super expression must either be null or a function");
+ }
+
+ if (typeof _cache !== "undefined") {
+ if (_cache.has(Class)) return _cache.get(Class);
+
+ _cache.set(Class, Wrapper);
+ }
+
+ function Wrapper() {
+ return _construct(Class, arguments, _getPrototypeOf(this).constructor);
+ }
+
+ Wrapper.prototype = Object.create(Class.prototype, {
+ constructor: {
+ value: Wrapper,
+ enumerable: false,
+ writable: true,
+ configurable: true
+ }
+ });
+ return _setPrototypeOf(Wrapper, Class);
+ };
+
+ return _wrapNativeSuper(Class);
+ }
+
+ function _assertThisInitialized(self) {
+ if (self === void 0) {
+ throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
+ }
+
+ return self;
+ }
+
+ /* eslint-disable no-proto */
+ function makeReactive(obj) {
+ var proto = obj.__proto__;
+ Object.defineProperty(obj, '__proto__', {
+ get: function get() {
+ return proto;
+ },
+ set: function set(value) {
+ proto.__proto__ = value;
+ }
+ });
+ }
+
+ var Dom7 = /*#__PURE__*/function (_Array) {
+ _inheritsLoose(Dom7, _Array);
+
+ function Dom7(items) {
+ var _this;
+
+ _this = _Array.call.apply(_Array, [this].concat(items)) || this;
+ makeReactive(_assertThisInitialized(_this));
+ return _this;
+ }
+
+ return Dom7;
+ }( /*#__PURE__*/_wrapNativeSuper(Array));
+
+ function arrayFlat(arr) {
+ if (arr === void 0) {
+ arr = [];
+ }
+
+ var res = [];
+ arr.forEach(function (el) {
+ if (Array.isArray(el)) {
+ res.push.apply(res, arrayFlat(el));
+ } else {
+ res.push(el);
+ }
+ });
+ return res;
+ }
+ function arrayFilter(arr, callback) {
+ return Array.prototype.filter.call(arr, callback);
+ }
+ function arrayUnique(arr) {
+ var uniqueArray = [];
+
+ for (var i = 0; i < arr.length; i += 1) {
+ if (uniqueArray.indexOf(arr[i]) === -1) uniqueArray.push(arr[i]);
+ }
+
+ return uniqueArray;
+ }
+ function toCamelCase(string) {
+ return string.toLowerCase().replace(/-(.)/g, function (match, group) {
+ return group.toUpperCase();
+ });
+ }
+
+ function qsa(selector, context) {
+ if (typeof selector !== 'string') {
+ return [selector];
+ }
+
+ var a = [];
+ var res = context.querySelectorAll(selector);
+
+ for (var i = 0; i < res.length; i += 1) {
+ a.push(res[i]);
+ }
+
+ return a;
+ }
+
+ function $(selector, context) {
+ var window = ssrWindow_umd.getWindow();
+ var document = ssrWindow_umd.getDocument();
+ var arr = [];
+
+ if (!context && selector instanceof Dom7) {
+ return selector;
+ }
+
+ if (!selector) {
+ return new Dom7(arr);
+ }
+
+ if (typeof selector === 'string') {
+ var html = selector.trim();
+
+ if (html.indexOf('<') >= 0 && html.indexOf('>') >= 0) {
+ var toCreate = 'div';
+ if (html.indexOf(' 0;
+ }).length > 0;
+ }
+
+ function attr(attrs, value) {
+ if (arguments.length === 1 && typeof attrs === 'string') {
+ // Get attr
+ if (this[0]) return this[0].getAttribute(attrs);
+ return undefined;
+ } // Set attrs
+
+
+ for (var i = 0; i < this.length; i += 1) {
+ if (arguments.length === 2) {
+ // String
+ this[i].setAttribute(attrs, value);
+ } else {
+ // Object
+ for (var attrName in attrs) {
+ this[i][attrName] = attrs[attrName];
+ this[i].setAttribute(attrName, attrs[attrName]);
+ }
+ }
+ }
+
+ return this;
+ }
+
+ function removeAttr(attr) {
+ for (var i = 0; i < this.length; i += 1) {
+ this[i].removeAttribute(attr);
+ }
+
+ return this;
+ }
+
+ function prop(props, value) {
+ if (arguments.length === 1 && typeof props === 'string') {
+ // Get prop
+ if (this[0]) return this[0][props];
+ } else {
+ // Set props
+ for (var i = 0; i < this.length; i += 1) {
+ if (arguments.length === 2) {
+ // String
+ this[i][props] = value;
+ } else {
+ // Object
+ for (var propName in props) {
+ this[i][propName] = props[propName];
+ }
+ }
+ }
+
+ return this;
+ }
+
+ return this;
+ }
+
+ function data(key, value) {
+ var el;
+
+ if (typeof value === 'undefined') {
+ el = this[0];
+ if (!el) return undefined; // Get value
+
+ if (el.dom7ElementDataStorage && key in el.dom7ElementDataStorage) {
+ return el.dom7ElementDataStorage[key];
+ }
+
+ var dataKey = el.getAttribute("data-" + key);
+
+ if (dataKey) {
+ return dataKey;
+ }
+
+ return undefined;
+ } // Set value
+
+
+ for (var i = 0; i < this.length; i += 1) {
+ el = this[i];
+ if (!el.dom7ElementDataStorage) el.dom7ElementDataStorage = {};
+ el.dom7ElementDataStorage[key] = value;
+ }
+
+ return this;
+ }
+
+ function removeData(key) {
+ for (var i = 0; i < this.length; i += 1) {
+ var el = this[i];
+
+ if (el.dom7ElementDataStorage && el.dom7ElementDataStorage[key]) {
+ el.dom7ElementDataStorage[key] = null;
+ delete el.dom7ElementDataStorage[key];
+ }
+ }
+ }
+
+ function dataset() {
+ var el = this[0];
+ if (!el) return undefined;
+ var dataset = {}; // eslint-disable-line
+
+ if (el.dataset) {
+ for (var dataKey in el.dataset) {
+ dataset[dataKey] = el.dataset[dataKey];
+ }
+ } else {
+ for (var i = 0; i < el.attributes.length; i += 1) {
+ var _attr = el.attributes[i];
+
+ if (_attr.name.indexOf('data-') >= 0) {
+ dataset[toCamelCase(_attr.name.split('data-')[1])] = _attr.value;
+ }
+ }
+ }
+
+ for (var key in dataset) {
+ if (dataset[key] === 'false') dataset[key] = false;else if (dataset[key] === 'true') dataset[key] = true;else if (parseFloat(dataset[key]) === dataset[key] * 1) dataset[key] *= 1;
+ }
+
+ return dataset;
+ }
+
+ function val(value) {
+ if (typeof value === 'undefined') {
+ // get value
+ var el = this[0];
+ if (!el) return undefined;
+
+ if (el.multiple && el.nodeName.toLowerCase() === 'select') {
+ var values = [];
+
+ for (var i = 0; i < el.selectedOptions.length; i += 1) {
+ values.push(el.selectedOptions[i].value);
+ }
+
+ return values;
+ }
+
+ return el.value;
+ } // set value
+
+
+ for (var _i = 0; _i < this.length; _i += 1) {
+ var _el = this[_i];
+
+ if (Array.isArray(value) && _el.multiple && _el.nodeName.toLowerCase() === 'select') {
+ for (var j = 0; j < _el.options.length; j += 1) {
+ _el.options[j].selected = value.indexOf(_el.options[j].value) >= 0;
+ }
+ } else {
+ _el.value = value;
+ }
+ }
+
+ return this;
+ }
+
+ function value(value) {
+ return this.val(value);
+ }
+
+ function transform(transform) {
+ for (var i = 0; i < this.length; i += 1) {
+ this[i].style.transform = transform;
+ }
+
+ return this;
+ }
+
+ function transition(duration) {
+ for (var i = 0; i < this.length; i += 1) {
+ this[i].style.transitionDuration = typeof duration !== 'string' ? duration + "ms" : duration;
+ }
+
+ return this;
+ }
+
+ function on() {
+ for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {
+ args[_key5] = arguments[_key5];
+ }
+
+ var eventType = args[0],
+ targetSelector = args[1],
+ listener = args[2],
+ capture = args[3];
+
+ if (typeof args[1] === 'function') {
+ eventType = args[0];
+ listener = args[1];
+ capture = args[2];
+ targetSelector = undefined;
+ }
+
+ if (!capture) capture = false;
+
+ function handleLiveEvent(e) {
+ var target = e.target;
+ if (!target) return;
+ var eventData = e.target.dom7EventData || [];
+
+ if (eventData.indexOf(e) < 0) {
+ eventData.unshift(e);
+ }
+
+ if ($(target).is(targetSelector)) listener.apply(target, eventData);else {
+ var _parents = $(target).parents(); // eslint-disable-line
+
+
+ for (var k = 0; k < _parents.length; k += 1) {
+ if ($(_parents[k]).is(targetSelector)) listener.apply(_parents[k], eventData);
+ }
+ }
+ }
+
+ function handleEvent(e) {
+ var eventData = e && e.target ? e.target.dom7EventData || [] : [];
+
+ if (eventData.indexOf(e) < 0) {
+ eventData.unshift(e);
+ }
+
+ listener.apply(this, eventData);
+ }
+
+ var events = eventType.split(' ');
+ var j;
+
+ for (var i = 0; i < this.length; i += 1) {
+ var el = this[i];
+
+ if (!targetSelector) {
+ for (j = 0; j < events.length; j += 1) {
+ var event = events[j];
+ if (!el.dom7Listeners) el.dom7Listeners = {};
+ if (!el.dom7Listeners[event]) el.dom7Listeners[event] = [];
+ el.dom7Listeners[event].push({
+ listener: listener,
+ proxyListener: handleEvent
+ });
+ el.addEventListener(event, handleEvent, capture);
+ }
+ } else {
+ // Live events
+ for (j = 0; j < events.length; j += 1) {
+ var _event = events[j];
+ if (!el.dom7LiveListeners) el.dom7LiveListeners = {};
+ if (!el.dom7LiveListeners[_event]) el.dom7LiveListeners[_event] = [];
+
+ el.dom7LiveListeners[_event].push({
+ listener: listener,
+ proxyListener: handleLiveEvent
+ });
+
+ el.addEventListener(_event, handleLiveEvent, capture);
+ }
+ }
+ }
+
+ return this;
+ }
+
+ function off() {
+ for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {
+ args[_key6] = arguments[_key6];
+ }
+
+ var eventType = args[0],
+ targetSelector = args[1],
+ listener = args[2],
+ capture = args[3];
+
+ if (typeof args[1] === 'function') {
+ eventType = args[0];
+ listener = args[1];
+ capture = args[2];
+ targetSelector = undefined;
+ }
+
+ if (!capture) capture = false;
+ var events = eventType.split(' ');
+
+ for (var i = 0; i < events.length; i += 1) {
+ var event = events[i];
+
+ for (var j = 0; j < this.length; j += 1) {
+ var el = this[j];
+ var handlers = void 0;
+
+ if (!targetSelector && el.dom7Listeners) {
+ handlers = el.dom7Listeners[event];
+ } else if (targetSelector && el.dom7LiveListeners) {
+ handlers = el.dom7LiveListeners[event];
+ }
+
+ if (handlers && handlers.length) {
+ for (var k = handlers.length - 1; k >= 0; k -= 1) {
+ var handler = handlers[k];
+
+ if (listener && handler.listener === listener) {
+ el.removeEventListener(event, handler.proxyListener, capture);
+ handlers.splice(k, 1);
+ } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) {
+ el.removeEventListener(event, handler.proxyListener, capture);
+ handlers.splice(k, 1);
+ } else if (!listener) {
+ el.removeEventListener(event, handler.proxyListener, capture);
+ handlers.splice(k, 1);
+ }
+ }
+ }
+ }
+ }
+
+ return this;
+ }
+
+ function once() {
+ var dom = this;
+
+ for (var _len7 = arguments.length, args = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {
+ args[_key7] = arguments[_key7];
+ }
+
+ var eventName = args[0],
+ targetSelector = args[1],
+ listener = args[2],
+ capture = args[3];
+
+ if (typeof args[1] === 'function') {
+ eventName = args[0];
+ listener = args[1];
+ capture = args[2];
+ targetSelector = undefined;
+ }
+
+ function onceHandler() {
+ for (var _len8 = arguments.length, eventArgs = new Array(_len8), _key8 = 0; _key8 < _len8; _key8++) {
+ eventArgs[_key8] = arguments[_key8];
+ }
+
+ listener.apply(this, eventArgs);
+ dom.off(eventName, targetSelector, onceHandler, capture);
+
+ if (onceHandler.dom7proxy) {
+ delete onceHandler.dom7proxy;
+ }
+ }
+
+ onceHandler.dom7proxy = listener;
+ return dom.on(eventName, targetSelector, onceHandler, capture);
+ }
+
+ function trigger() {
+ var window = ssrWindow_umd.getWindow();
+
+ for (var _len9 = arguments.length, args = new Array(_len9), _key9 = 0; _key9 < _len9; _key9++) {
+ args[_key9] = arguments[_key9];
+ }
+
+ var events = args[0].split(' ');
+ var eventData = args[1];
+
+ for (var i = 0; i < events.length; i += 1) {
+ var event = events[i];
+
+ for (var j = 0; j < this.length; j += 1) {
+ var el = this[j];
+
+ if (window.CustomEvent) {
+ var evt = new window.CustomEvent(event, {
+ detail: eventData,
+ bubbles: true,
+ cancelable: true
+ });
+ el.dom7EventData = args.filter(function (data, dataIndex) {
+ return dataIndex > 0;
+ });
+ el.dispatchEvent(evt);
+ el.dom7EventData = [];
+ delete el.dom7EventData;
+ }
+ }
+ }
+
+ return this;
+ }
+
+ function transitionEnd(callback) {
+ var dom = this;
+
+ function fireCallBack(e) {
+ if (e.target !== this) return;
+ callback.call(this, e);
+ dom.off('transitionend', fireCallBack);
+ }
+
+ if (callback) {
+ dom.on('transitionend', fireCallBack);
+ }
+
+ return this;
+ }
+
+ function animationEnd(callback) {
+ var dom = this;
+
+ function fireCallBack(e) {
+ if (e.target !== this) return;
+ callback.call(this, e);
+ dom.off('animationend', fireCallBack);
+ }
+
+ if (callback) {
+ dom.on('animationend', fireCallBack);
+ }
+
+ return this;
+ }
+
+ function width() {
+ var window = ssrWindow_umd.getWindow();
+
+ if (this[0] === window) {
+ return window.innerWidth;
+ }
+
+ if (this.length > 0) {
+ return parseFloat(this.css('width'));
+ }
+
+ return null;
+ }
+
+ function outerWidth(includeMargins) {
+ if (this.length > 0) {
+ if (includeMargins) {
+ var _styles = this.styles();
+
+ return this[0].offsetWidth + parseFloat(_styles.getPropertyValue('margin-right')) + parseFloat(_styles.getPropertyValue('margin-left'));
+ }
+
+ return this[0].offsetWidth;
+ }
+
+ return null;
+ }
+
+ function height() {
+ var window = ssrWindow_umd.getWindow();
+
+ if (this[0] === window) {
+ return window.innerHeight;
+ }
+
+ if (this.length > 0) {
+ return parseFloat(this.css('height'));
+ }
+
+ return null;
+ }
+
+ function outerHeight(includeMargins) {
+ if (this.length > 0) {
+ if (includeMargins) {
+ var _styles2 = this.styles();
+
+ return this[0].offsetHeight + parseFloat(_styles2.getPropertyValue('margin-top')) + parseFloat(_styles2.getPropertyValue('margin-bottom'));
+ }
+
+ return this[0].offsetHeight;
+ }
+
+ return null;
+ }
+
+ function offset() {
+ if (this.length > 0) {
+ var window = ssrWindow_umd.getWindow();
+ var document = ssrWindow_umd.getDocument();
+ var el = this[0];
+ var box = el.getBoundingClientRect();
+ var body = document.body;
+ var clientTop = el.clientTop || body.clientTop || 0;
+ var clientLeft = el.clientLeft || body.clientLeft || 0;
+ var scrollTop = el === window ? window.scrollY : el.scrollTop;
+ var scrollLeft = el === window ? window.scrollX : el.scrollLeft;
+ return {
+ top: box.top + scrollTop - clientTop,
+ left: box.left + scrollLeft - clientLeft
+ };
+ }
+
+ return null;
+ }
+
+ function hide() {
+ for (var i = 0; i < this.length; i += 1) {
+ this[i].style.display = 'none';
+ }
+
+ return this;
+ }
+
+ function show() {
+ var window = ssrWindow_umd.getWindow();
+
+ for (var i = 0; i < this.length; i += 1) {
+ var el = this[i];
+
+ if (el.style.display === 'none') {
+ el.style.display = '';
+ }
+
+ if (window.getComputedStyle(el, null).getPropertyValue('display') === 'none') {
+ // Still not visible
+ el.style.display = 'block';
+ }
+ }
+
+ return this;
+ }
+
+ function styles() {
+ var window = ssrWindow_umd.getWindow();
+ if (this[0]) return window.getComputedStyle(this[0], null);
+ return {};
+ }
+
+ function css(props, value) {
+ var window = ssrWindow_umd.getWindow();
+ var i;
+
+ if (arguments.length === 1) {
+ if (typeof props === 'string') {
+ // .css('width')
+ if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(props);
+ } else {
+ // .css({ width: '100px' })
+ for (i = 0; i < this.length; i += 1) {
+ for (var _prop in props) {
+ this[i].style[_prop] = props[_prop];
+ }
+ }
+
+ return this;
+ }
+ }
+
+ if (arguments.length === 2 && typeof props === 'string') {
+ // .css('width', '100px')
+ for (i = 0; i < this.length; i += 1) {
+ this[i].style[props] = value;
+ }
+
+ return this;
+ }
+
+ return this;
+ }
+
+ function each(callback) {
+ if (!callback) return this;
+ this.forEach(function (el, index) {
+ callback.apply(el, [el, index]);
+ });
+ return this;
+ }
+
+ function filter(callback) {
+ var result = arrayFilter(this, callback);
+ return $(result);
+ }
+
+ function html(html) {
+ if (typeof html === 'undefined') {
+ return this[0] ? this[0].innerHTML : null;
+ }
+
+ for (var i = 0; i < this.length; i += 1) {
+ this[i].innerHTML = html;
+ }
+
+ return this;
+ }
+
+ function text(text) {
+ if (typeof text === 'undefined') {
+ return this[0] ? this[0].textContent.trim() : null;
+ }
+
+ for (var i = 0; i < this.length; i += 1) {
+ this[i].textContent = text;
+ }
+
+ return this;
+ }
+
+ function is(selector) {
+ var window = ssrWindow_umd.getWindow();
+ var document = ssrWindow_umd.getDocument();
+ var el = this[0];
+ var compareWith;
+ var i;
+ if (!el || typeof selector === 'undefined') return false;
+
+ if (typeof selector === 'string') {
+ if (el.matches) return el.matches(selector);
+ if (el.webkitMatchesSelector) return el.webkitMatchesSelector(selector);
+ if (el.msMatchesSelector) return el.msMatchesSelector(selector);
+ compareWith = $(selector);
+
+ for (i = 0; i < compareWith.length; i += 1) {
+ if (compareWith[i] === el) return true;
+ }
+
+ return false;
+ }
+
+ if (selector === document) {
+ return el === document;
+ }
+
+ if (selector === window) {
+ return el === window;
+ }
+
+ if (selector.nodeType || selector instanceof Dom7) {
+ compareWith = selector.nodeType ? [selector] : selector;
+
+ for (i = 0; i < compareWith.length; i += 1) {
+ if (compareWith[i] === el) return true;
+ }
+
+ return false;
+ }
+
+ return false;
+ }
+
+ function index$1() {
+ var child = this[0];
+ var i;
+
+ if (child) {
+ i = 0; // eslint-disable-next-line
+
+ while ((child = child.previousSibling) !== null) {
+ if (child.nodeType === 1) i += 1;
+ }
+
+ return i;
+ }
+
+ return undefined;
+ }
+
+ function eq(index) {
+ if (typeof index === 'undefined') return this;
+ var length = this.length;
+
+ if (index > length - 1) {
+ return $([]);
+ }
+
+ if (index < 0) {
+ var returnIndex = length + index;
+ if (returnIndex < 0) return $([]);
+ return $([this[returnIndex]]);
+ }
+
+ return $([this[index]]);
+ }
+
+ function append() {
+ var newChild;
+ var document = ssrWindow_umd.getDocument();
+
+ for (var k = 0; k < arguments.length; k += 1) {
+ newChild = k < 0 || arguments.length <= k ? undefined : arguments[k];
+
+ for (var i = 0; i < this.length; i += 1) {
+ if (typeof newChild === 'string') {
+ var tempDiv = document.createElement('div');
+ tempDiv.innerHTML = newChild;
+
+ while (tempDiv.firstChild) {
+ this[i].appendChild(tempDiv.firstChild);
+ }
+ } else if (newChild instanceof Dom7) {
+ for (var j = 0; j < newChild.length; j += 1) {
+ this[i].appendChild(newChild[j]);
+ }
+ } else {
+ this[i].appendChild(newChild);
+ }
+ }
+ }
+
+ return this;
+ }
+
+ function appendTo(parent) {
+ $(parent).append(this);
+ return this;
+ }
+
+ function prepend(newChild) {
+ var document = ssrWindow_umd.getDocument();
+ var i;
+ var j;
+
+ for (i = 0; i < this.length; i += 1) {
+ if (typeof newChild === 'string') {
+ var tempDiv = document.createElement('div');
+ tempDiv.innerHTML = newChild;
+
+ for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) {
+ this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]);
+ }
+ } else if (newChild instanceof Dom7) {
+ for (j = 0; j < newChild.length; j += 1) {
+ this[i].insertBefore(newChild[j], this[i].childNodes[0]);
+ }
+ } else {
+ this[i].insertBefore(newChild, this[i].childNodes[0]);
+ }
+ }
+
+ return this;
+ }
+
+ function prependTo(parent) {
+ $(parent).prepend(this);
+ return this;
+ }
+
+ function insertBefore(selector) {
+ var before = $(selector);
+
+ for (var i = 0; i < this.length; i += 1) {
+ if (before.length === 1) {
+ before[0].parentNode.insertBefore(this[i], before[0]);
+ } else if (before.length > 1) {
+ for (var j = 0; j < before.length; j += 1) {
+ before[j].parentNode.insertBefore(this[i].cloneNode(true), before[j]);
+ }
+ }
+ }
+ }
+
+ function insertAfter(selector) {
+ var after = $(selector);
+
+ for (var i = 0; i < this.length; i += 1) {
+ if (after.length === 1) {
+ after[0].parentNode.insertBefore(this[i], after[0].nextSibling);
+ } else if (after.length > 1) {
+ for (var j = 0; j < after.length; j += 1) {
+ after[j].parentNode.insertBefore(this[i].cloneNode(true), after[j].nextSibling);
+ }
+ }
+ }
+ }
+
+ function next(selector) {
+ if (this.length > 0) {
+ if (selector) {
+ if (this[0].nextElementSibling && $(this[0].nextElementSibling).is(selector)) {
+ return $([this[0].nextElementSibling]);
+ }
+
+ return $([]);
+ }
+
+ if (this[0].nextElementSibling) return $([this[0].nextElementSibling]);
+ return $([]);
+ }
+
+ return $([]);
+ }
+
+ function nextAll(selector) {
+ var nextEls = [];
+ var el = this[0];
+ if (!el) return $([]);
+
+ while (el.nextElementSibling) {
+ var _next = el.nextElementSibling; // eslint-disable-line
+
+ if (selector) {
+ if ($(_next).is(selector)) nextEls.push(_next);
+ } else nextEls.push(_next);
+
+ el = _next;
+ }
+
+ return $(nextEls);
+ }
+
+ function prev(selector) {
+ if (this.length > 0) {
+ var el = this[0];
+
+ if (selector) {
+ if (el.previousElementSibling && $(el.previousElementSibling).is(selector)) {
+ return $([el.previousElementSibling]);
+ }
+
+ return $([]);
+ }
+
+ if (el.previousElementSibling) return $([el.previousElementSibling]);
+ return $([]);
+ }
+
+ return $([]);
+ }
+
+ function prevAll(selector) {
+ var prevEls = [];
+ var el = this[0];
+ if (!el) return $([]);
+
+ while (el.previousElementSibling) {
+ var _prev = el.previousElementSibling; // eslint-disable-line
+
+ if (selector) {
+ if ($(_prev).is(selector)) prevEls.push(_prev);
+ } else prevEls.push(_prev);
+
+ el = _prev;
+ }
+
+ return $(prevEls);
+ }
+
+ function siblings(selector) {
+ return this.nextAll(selector).add(this.prevAll(selector));
+ }
+
+ function parent(selector) {
+ var parents = []; // eslint-disable-line
+
+ for (var i = 0; i < this.length; i += 1) {
+ if (this[i].parentNode !== null) {
+ if (selector) {
+ if ($(this[i].parentNode).is(selector)) parents.push(this[i].parentNode);
+ } else {
+ parents.push(this[i].parentNode);
+ }
+ }
+ }
+
+ return $(parents);
+ }
+
+ function parents(selector) {
+ var parents = []; // eslint-disable-line
+
+ for (var i = 0; i < this.length; i += 1) {
+ var _parent = this[i].parentNode; // eslint-disable-line
+
+ while (_parent) {
+ if (selector) {
+ if ($(_parent).is(selector)) parents.push(_parent);
+ } else {
+ parents.push(_parent);
+ }
+
+ _parent = _parent.parentNode;
+ }
+ }
+
+ return $(parents);
+ }
+
+ function closest(selector) {
+ var closest = this; // eslint-disable-line
+
+ if (typeof selector === 'undefined') {
+ return $([]);
+ }
+
+ if (!closest.is(selector)) {
+ closest = closest.parents(selector).eq(0);
+ }
+
+ return closest;
+ }
+
+ function find(selector) {
+ var foundElements = [];
+
+ for (var i = 0; i < this.length; i += 1) {
+ var found = this[i].querySelectorAll(selector);
+
+ for (var j = 0; j < found.length; j += 1) {
+ foundElements.push(found[j]);
+ }
+ }
+
+ return $(foundElements);
+ }
+
+ function children(selector) {
+ var children = []; // eslint-disable-line
+
+ for (var i = 0; i < this.length; i += 1) {
+ var childNodes = this[i].children;
+
+ for (var j = 0; j < childNodes.length; j += 1) {
+ if (!selector || $(childNodes[j]).is(selector)) {
+ children.push(childNodes[j]);
+ }
+ }
+ }
+
+ return $(children);
+ }
+
+ function remove() {
+ for (var i = 0; i < this.length; i += 1) {
+ if (this[i].parentNode) this[i].parentNode.removeChild(this[i]);
+ }
+
+ return this;
+ }
+
+ function detach() {
+ return this.remove();
+ }
+
+ function add() {
+ var dom = this;
+ var i;
+ var j;
+
+ for (var _len10 = arguments.length, els = new Array(_len10), _key10 = 0; _key10 < _len10; _key10++) {
+ els[_key10] = arguments[_key10];
+ }
+
+ for (i = 0; i < els.length; i += 1) {
+ var toAdd = $(els[i]);
+
+ for (j = 0; j < toAdd.length; j += 1) {
+ dom.push(toAdd[j]);
+ }
+ }
+
+ return dom;
+ }
+
+ function empty() {
+ for (var i = 0; i < this.length; i += 1) {
+ var el = this[i];
+
+ if (el.nodeType === 1) {
+ for (var j = 0; j < el.childNodes.length; j += 1) {
+ if (el.childNodes[j].parentNode) {
+ el.childNodes[j].parentNode.removeChild(el.childNodes[j]);
+ }
+ }
+
+ el.textContent = '';
+ }
+ }
+
+ return this;
+ }
+
+ function scrollTo() {
+ var window = ssrWindow_umd.getWindow();
+
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
+ args[_key] = arguments[_key];
+ }
+
+ var left = args[0],
+ top = args[1],
+ duration = args[2],
+ easing = args[3],
+ callback = args[4];
+
+ if (args.length === 4 && typeof easing === 'function') {
+ callback = easing;
+ left = args[0];
+ top = args[1];
+ duration = args[2];
+ callback = args[3];
+ easing = args[4];
+ }
+
+ if (typeof easing === 'undefined') easing = 'swing';
+ return this.each(function animate() {
+ var el = this;
+ var currentTop;
+ var currentLeft;
+ var maxTop;
+ var maxLeft;
+ var newTop;
+ var newLeft;
+ var scrollTop; // eslint-disable-line
+
+ var scrollLeft; // eslint-disable-line
+
+ var animateTop = top > 0 || top === 0;
+ var animateLeft = left > 0 || left === 0;
+
+ if (typeof easing === 'undefined') {
+ easing = 'swing';
+ }
+
+ if (animateTop) {
+ currentTop = el.scrollTop;
+
+ if (!duration) {
+ el.scrollTop = top;
+ }
+ }
+
+ if (animateLeft) {
+ currentLeft = el.scrollLeft;
+
+ if (!duration) {
+ el.scrollLeft = left;
+ }
+ }
+
+ if (!duration) return;
+
+ if (animateTop) {
+ maxTop = el.scrollHeight - el.offsetHeight;
+ newTop = Math.max(Math.min(top, maxTop), 0);
+ }
+
+ if (animateLeft) {
+ maxLeft = el.scrollWidth - el.offsetWidth;
+ newLeft = Math.max(Math.min(left, maxLeft), 0);
+ }
+
+ var startTime = null;
+ if (animateTop && newTop === currentTop) animateTop = false;
+ if (animateLeft && newLeft === currentLeft) animateLeft = false;
+
+ function render(time) {
+ if (time === void 0) {
+ time = new Date().getTime();
+ }
+
+ if (startTime === null) {
+ startTime = time;
+ }
+
+ var progress = Math.max(Math.min((time - startTime) / duration, 1), 0);
+ var easeProgress = easing === 'linear' ? progress : 0.5 - Math.cos(progress * Math.PI) / 2;
+ var done;
+ if (animateTop) scrollTop = currentTop + easeProgress * (newTop - currentTop);
+ if (animateLeft) scrollLeft = currentLeft + easeProgress * (newLeft - currentLeft);
+
+ if (animateTop && newTop > currentTop && scrollTop >= newTop) {
+ el.scrollTop = newTop;
+ done = true;
+ }
+
+ if (animateTop && newTop < currentTop && scrollTop <= newTop) {
+ el.scrollTop = newTop;
+ done = true;
+ }
+
+ if (animateLeft && newLeft > currentLeft && scrollLeft >= newLeft) {
+ el.scrollLeft = newLeft;
+ done = true;
+ }
+
+ if (animateLeft && newLeft < currentLeft && scrollLeft <= newLeft) {
+ el.scrollLeft = newLeft;
+ done = true;
+ }
+
+ if (done) {
+ if (callback) callback();
+ return;
+ }
+
+ if (animateTop) el.scrollTop = scrollTop;
+ if (animateLeft) el.scrollLeft = scrollLeft;
+ window.requestAnimationFrame(render);
+ }
+
+ window.requestAnimationFrame(render);
+ });
+ } // scrollTop(top, duration, easing, callback) {
+
+
+ function scrollTop() {
+ for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
+ args[_key2] = arguments[_key2];
+ }
+
+ var top = args[0],
+ duration = args[1],
+ easing = args[2],
+ callback = args[3];
+
+ if (args.length === 3 && typeof easing === 'function') {
+ top = args[0];
+ duration = args[1];
+ callback = args[2];
+ easing = args[3];
+ }
+
+ var dom = this;
+
+ if (typeof top === 'undefined') {
+ if (dom.length > 0) return dom[0].scrollTop;
+ return null;
+ }
+
+ return dom.scrollTo(undefined, top, duration, easing, callback);
+ }
+
+ function scrollLeft() {
+ for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
+ args[_key3] = arguments[_key3];
+ }
+
+ var left = args[0],
+ duration = args[1],
+ easing = args[2],
+ callback = args[3];
+
+ if (args.length === 3 && typeof easing === 'function') {
+ left = args[0];
+ duration = args[1];
+ callback = args[2];
+ easing = args[3];
+ }
+
+ var dom = this;
+
+ if (typeof left === 'undefined') {
+ if (dom.length > 0) return dom[0].scrollLeft;
+ return null;
+ }
+
+ return dom.scrollTo(left, undefined, duration, easing, callback);
+ }
+
+ function animate(initialProps, initialParams) {
+ var window = ssrWindow_umd.getWindow();
+ var els = this;
+ var a = {
+ props: Object.assign({}, initialProps),
+ params: Object.assign({
+ duration: 300,
+ easing: 'swing' // or 'linear'
+
+ /* Callbacks
+ begin(elements)
+ complete(elements)
+ progress(elements, complete, remaining, start, tweenValue)
+ */
+
+ }, initialParams),
+ elements: els,
+ animating: false,
+ que: [],
+ easingProgress: function easingProgress(easing, progress) {
+ if (easing === 'swing') {
+ return 0.5 - Math.cos(progress * Math.PI) / 2;
+ }
+
+ if (typeof easing === 'function') {
+ return easing(progress);
+ }
+
+ return progress;
+ },
+ stop: function stop() {
+ if (a.frameId) {
+ window.cancelAnimationFrame(a.frameId);
+ }
+
+ a.animating = false;
+ a.elements.each(function (el) {
+ var element = el;
+ delete element.dom7AnimateInstance;
+ });
+ a.que = [];
+ },
+ done: function done(complete) {
+ a.animating = false;
+ a.elements.each(function (el) {
+ var element = el;
+ delete element.dom7AnimateInstance;
+ });
+ if (complete) complete(els);
+
+ if (a.que.length > 0) {
+ var que = a.que.shift();
+ a.animate(que[0], que[1]);
+ }
+ },
+ animate: function animate(props, params) {
+ if (a.animating) {
+ a.que.push([props, params]);
+ return a;
+ }
+
+ var elements = []; // Define & Cache Initials & Units
+
+ a.elements.each(function (el, index) {
+ var initialFullValue;
+ var initialValue;
+ var unit;
+ var finalValue;
+ var finalFullValue;
+ if (!el.dom7AnimateInstance) a.elements[index].dom7AnimateInstance = a;
+ elements[index] = {
+ container: el
+ };
+ Object.keys(props).forEach(function (prop) {
+ initialFullValue = window.getComputedStyle(el, null).getPropertyValue(prop).replace(',', '.');
+ initialValue = parseFloat(initialFullValue);
+ unit = initialFullValue.replace(initialValue, '');
+ finalValue = parseFloat(props[prop]);
+ finalFullValue = props[prop] + unit;
+ elements[index][prop] = {
+ initialFullValue: initialFullValue,
+ initialValue: initialValue,
+ unit: unit,
+ finalValue: finalValue,
+ finalFullValue: finalFullValue,
+ currentValue: initialValue
+ };
+ });
+ });
+ var startTime = null;
+ var time;
+ var elementsDone = 0;
+ var propsDone = 0;
+ var done;
+ var began = false;
+ a.animating = true;
+
+ function render() {
+ time = new Date().getTime();
+ var progress;
+ var easeProgress; // let el;
+
+ if (!began) {
+ began = true;
+ if (params.begin) params.begin(els);
+ }
+
+ if (startTime === null) {
+ startTime = time;
+ }
+
+ if (params.progress) {
+ // eslint-disable-next-line
+ params.progress(els, Math.max(Math.min((time - startTime) / params.duration, 1), 0), startTime + params.duration - time < 0 ? 0 : startTime + params.duration - time, startTime);
+ }
+
+ elements.forEach(function (element) {
+ var el = element;
+ if (done || el.done) return;
+ Object.keys(props).forEach(function (prop) {
+ if (done || el.done) return;
+ progress = Math.max(Math.min((time - startTime) / params.duration, 1), 0);
+ easeProgress = a.easingProgress(params.easing, progress);
+ var _el$prop = el[prop],
+ initialValue = _el$prop.initialValue,
+ finalValue = _el$prop.finalValue,
+ unit = _el$prop.unit;
+ el[prop].currentValue = initialValue + easeProgress * (finalValue - initialValue);
+ var currentValue = el[prop].currentValue;
+
+ if (finalValue > initialValue && currentValue >= finalValue || finalValue < initialValue && currentValue <= finalValue) {
+ el.container.style[prop] = finalValue + unit;
+ propsDone += 1;
+
+ if (propsDone === Object.keys(props).length) {
+ el.done = true;
+ elementsDone += 1;
+ }
+
+ if (elementsDone === elements.length) {
+ done = true;
+ }
+ }
+
+ if (done) {
+ a.done(params.complete);
+ return;
+ }
+
+ el.container.style[prop] = currentValue + unit;
+ });
+ });
+ if (done) return; // Then call
+
+ a.frameId = window.requestAnimationFrame(render);
+ }
+
+ a.frameId = window.requestAnimationFrame(render);
+ return a;
+ }
+ };
+
+ if (a.elements.length === 0) {
+ return els;
+ }
+
+ var animateInstance;
+
+ for (var i = 0; i < a.elements.length; i += 1) {
+ if (a.elements[i].dom7AnimateInstance) {
+ animateInstance = a.elements[i].dom7AnimateInstance;
+ } else a.elements[i].dom7AnimateInstance = a;
+ }
+
+ if (!animateInstance) {
+ animateInstance = a;
+ }
+
+ if (initialProps === 'stop') {
+ animateInstance.stop();
+ } else {
+ animateInstance.animate(a.props, a.params);
+ }
+
+ return els;
+ }
+
+ function stop() {
+ var els = this;
+
+ for (var i = 0; i < els.length; i += 1) {
+ if (els[i].dom7AnimateInstance) {
+ els[i].dom7AnimateInstance.stop();
+ }
+ }
+ }
+
+ var noTrigger = 'resize scroll'.split(' ');
+
+ function shortcut(name) {
+ function eventHandler() {
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
+ args[_key] = arguments[_key];
+ }
+
+ if (typeof args[0] === 'undefined') {
+ for (var i = 0; i < this.length; i += 1) {
+ if (noTrigger.indexOf(name) < 0) {
+ if (name in this[i]) this[i][name]();else {
+ $(this[i]).trigger(name);
+ }
+ }
+ }
+
+ return this;
+ }
+
+ return this.on.apply(this, [name].concat(args));
+ }
+
+ return eventHandler;
+ }
+
+ var click = shortcut('click');
+ var blur = shortcut('blur');
+ var focus = shortcut('focus');
+ var focusin = shortcut('focusin');
+ var focusout = shortcut('focusout');
+ var keyup = shortcut('keyup');
+ var keydown = shortcut('keydown');
+ var keypress = shortcut('keypress');
+ var submit = shortcut('submit');
+ var change = shortcut('change');
+ var mousedown = shortcut('mousedown');
+ var mousemove = shortcut('mousemove');
+ var mouseup = shortcut('mouseup');
+ var mouseenter = shortcut('mouseenter');
+ var mouseleave = shortcut('mouseleave');
+ var mouseout = shortcut('mouseout');
+ var mouseover = shortcut('mouseover');
+ var touchstart = shortcut('touchstart');
+ var touchend = shortcut('touchend');
+ var touchmove = shortcut('touchmove');
+ var resize = shortcut('resize');
+ var scroll = shortcut('scroll');
+
+ var $_1 = $;
+ var add_1 = add;
+ var addClass_1 = addClass;
+ var animate_1 = animate;
+ var animationEnd_1 = animationEnd;
+ var append_1 = append;
+ var appendTo_1 = appendTo;
+ var attr_1 = attr;
+ var blur_1 = blur;
+ var change_1 = change;
+ var children_1 = children;
+ var click_1 = click;
+ var closest_1 = closest;
+ var css_1 = css;
+ var data_1 = data;
+ var dataset_1 = dataset;
+ var _default$1 = $;
+ var detach_1 = detach;
+ var each_1 = each;
+ var empty_1 = empty;
+ var eq_1 = eq;
+ var filter_1 = filter;
+ var find_1 = find;
+ var focus_1 = focus;
+ var focusin_1 = focusin;
+ var focusout_1 = focusout;
+ var hasClass_1 = hasClass;
+ var height_1 = height;
+ var hide_1 = hide;
+ var html_1 = html;
+ var index_1 = index$1;
+ var insertAfter_1 = insertAfter;
+ var insertBefore_1 = insertBefore;
+ var is_1 = is;
+ var keydown_1 = keydown;
+ var keypress_1 = keypress;
+ var keyup_1 = keyup;
+ var mousedown_1 = mousedown;
+ var mouseenter_1 = mouseenter;
+ var mouseleave_1 = mouseleave;
+ var mousemove_1 = mousemove;
+ var mouseout_1 = mouseout;
+ var mouseover_1 = mouseover;
+ var mouseup_1 = mouseup;
+ var next_1 = next;
+ var nextAll_1 = nextAll;
+ var off_1 = off;
+ var offset_1 = offset;
+ var on_1 = on;
+ var once_1 = once;
+ var outerHeight_1 = outerHeight;
+ var outerWidth_1 = outerWidth;
+ var parent_1 = parent;
+ var parents_1 = parents;
+ var prepend_1 = prepend;
+ var prependTo_1 = prependTo;
+ var prev_1 = prev;
+ var prevAll_1 = prevAll;
+ var prop_1 = prop;
+ var remove_1 = remove;
+ var removeAttr_1 = removeAttr;
+ var removeClass_1 = removeClass;
+ var removeData_1 = removeData;
+ var resize_1 = resize;
+ var scroll_1 = scroll;
+ var scrollLeft_1 = scrollLeft;
+ var scrollTo_1 = scrollTo;
+ var scrollTop_1 = scrollTop;
+ var show_1 = show;
+ var siblings_1 = siblings;
+ var stop_1 = stop;
+ var styles_1 = styles;
+ var submit_1 = submit;
+ var text_1 = text;
+ var toggleClass_1 = toggleClass;
+ var touchend_1 = touchend;
+ var touchmove_1 = touchmove;
+ var touchstart_1 = touchstart;
+ var transform_1 = transform;
+ var transition_1 = transition;
+ var transitionEnd_1 = transitionEnd;
+ var trigger_1 = trigger;
+ var val_1 = val;
+ var value_1 = value;
+ var width_1 = width;
+
+ var dom7_cjs = /*#__PURE__*/Object.defineProperty({
+ $: $_1,
+ add: add_1,
+ addClass: addClass_1,
+ animate: animate_1,
+ animationEnd: animationEnd_1,
+ append: append_1,
+ appendTo: appendTo_1,
+ attr: attr_1,
+ blur: blur_1,
+ change: change_1,
+ children: children_1,
+ click: click_1,
+ closest: closest_1,
+ css: css_1,
+ data: data_1,
+ dataset: dataset_1,
+ default: _default$1,
+ detach: detach_1,
+ each: each_1,
+ empty: empty_1,
+ eq: eq_1,
+ filter: filter_1,
+ find: find_1,
+ focus: focus_1,
+ focusin: focusin_1,
+ focusout: focusout_1,
+ hasClass: hasClass_1,
+ height: height_1,
+ hide: hide_1,
+ html: html_1,
+ index: index_1,
+ insertAfter: insertAfter_1,
+ insertBefore: insertBefore_1,
+ is: is_1,
+ keydown: keydown_1,
+ keypress: keypress_1,
+ keyup: keyup_1,
+ mousedown: mousedown_1,
+ mouseenter: mouseenter_1,
+ mouseleave: mouseleave_1,
+ mousemove: mousemove_1,
+ mouseout: mouseout_1,
+ mouseover: mouseover_1,
+ mouseup: mouseup_1,
+ next: next_1,
+ nextAll: nextAll_1,
+ off: off_1,
+ offset: offset_1,
+ on: on_1,
+ once: once_1,
+ outerHeight: outerHeight_1,
+ outerWidth: outerWidth_1,
+ parent: parent_1,
+ parents: parents_1,
+ prepend: prepend_1,
+ prependTo: prependTo_1,
+ prev: prev_1,
+ prevAll: prevAll_1,
+ prop: prop_1,
+ remove: remove_1,
+ removeAttr: removeAttr_1,
+ removeClass: removeClass_1,
+ removeData: removeData_1,
+ resize: resize_1,
+ scroll: scroll_1,
+ scrollLeft: scrollLeft_1,
+ scrollTo: scrollTo_1,
+ scrollTop: scrollTop_1,
+ show: show_1,
+ siblings: siblings_1,
+ stop: stop_1,
+ styles: styles_1,
+ submit: submit_1,
+ text: text_1,
+ toggleClass: toggleClass_1,
+ touchend: touchend_1,
+ touchmove: touchmove_1,
+ touchstart: touchstart_1,
+ transform: transform_1,
+ transition: transition_1,
+ transitionEnd: transitionEnd_1,
+ trigger: trigger_1,
+ val: val_1,
+ value: value_1,
+ width: width_1
+ }, '__esModule', {value: true});
+
+ /**
+ * lodash (Custom Build)
+ * Build: `lodash modularize exports="npm" -o ./`
+ * Copyright jQuery Foundation and other contributors
+ * Released under MIT license
+ * Based on Underscore.js 1.8.3
+ * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
+ */
+ /** Used as references for various `Number` constants. */
+ var MAX_SAFE_INTEGER = 9007199254740991;
+
+ /** `Object#toString` result references. */
+ var argsTag = '[object Arguments]',
+ funcTag = '[object Function]',
+ genTag = '[object GeneratorFunction]';
+
+ /** Used to detect unsigned integer values. */
+ var reIsUint = /^(?:0|[1-9]\d*)$/;
+
+ /**
+ * A specialized version of `_.forEach` for arrays without support for
+ * iteratee shorthands.
+ *
+ * @private
+ * @param {Array} [array] The array to iterate over.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @returns {Array} Returns `array`.
+ */
+ function arrayEach(array, iteratee) {
+ var index = -1,
+ length = array ? array.length : 0;
+
+ while (++index < length) {
+ if (iteratee(array[index], index, array) === false) {
+ break;
+ }
+ }
+ return array;
+ }
+
+ /**
+ * The base implementation of `_.times` without support for iteratee shorthands
+ * or max array length checks.
+ *
+ * @private
+ * @param {number} n The number of times to invoke `iteratee`.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @returns {Array} Returns the array of results.
+ */
+ function baseTimes(n, iteratee) {
+ var index = -1,
+ result = Array(n);
+
+ while (++index < n) {
+ result[index] = iteratee(index);
+ }
+ return result;
+ }
+
+ /**
+ * Creates a unary function that invokes `func` with its argument transformed.
+ *
+ * @private
+ * @param {Function} func The function to wrap.
+ * @param {Function} transform The argument transform.
+ * @returns {Function} Returns the new function.
+ */
+ function overArg(func, transform) {
+ return function(arg) {
+ return func(transform(arg));
+ };
+ }
+
+ /** Used for built-in method references. */
+ var objectProto$3 = Object.prototype;
+
+ /** Used to check objects for own properties. */
+ var hasOwnProperty$1 = objectProto$3.hasOwnProperty;
+
+ /**
+ * Used to resolve the
+ * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
+ * of values.
+ */
+ var objectToString$3 = objectProto$3.toString;
+
+ /** Built-in value references. */
+ var propertyIsEnumerable = objectProto$3.propertyIsEnumerable;
+
+ /* Built-in method references for those with the same name as other `lodash` methods. */
+ var nativeKeys = overArg(Object.keys, Object);
+
+ /**
+ * Creates an array of the enumerable property names of the array-like `value`.
+ *
+ * @private
+ * @param {*} value The value to query.
+ * @param {boolean} inherited Specify returning inherited property names.
+ * @returns {Array} Returns the array of property names.
+ */
+ function arrayLikeKeys(value, inherited) {
+ // Safari 8.1 makes `arguments.callee` enumerable in strict mode.
+ // Safari 9 makes `arguments.length` enumerable in strict mode.
+ var result = (isArray(value) || isArguments(value))
+ ? baseTimes(value.length, String)
+ : [];
+
+ var length = result.length,
+ skipIndexes = !!length;
+
+ for (var key in value) {
+ if ((inherited || hasOwnProperty$1.call(value, key)) &&
+ !(skipIndexes && (key == 'length' || isIndex(key, length)))) {
+ result.push(key);
+ }
+ }
+ return result;
+ }
+
+ /**
+ * The base implementation of `_.forEach` without support for iteratee shorthands.
+ *
+ * @private
+ * @param {Array|Object} collection The collection to iterate over.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @returns {Array|Object} Returns `collection`.
+ */
+ var baseEach = createBaseEach(baseForOwn);
+
+ /**
+ * The base implementation of `baseForOwn` which iterates over `object`
+ * properties returned by `keysFunc` and invokes `iteratee` for each property.
+ * Iteratee functions may exit iteration early by explicitly returning `false`.
+ *
+ * @private
+ * @param {Object} object The object to iterate over.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @param {Function} keysFunc The function to get the keys of `object`.
+ * @returns {Object} Returns `object`.
+ */
+ var baseFor = createBaseFor();
+
+ /**
+ * The base implementation of `_.forOwn` without support for iteratee shorthands.
+ *
+ * @private
+ * @param {Object} object The object to iterate over.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @returns {Object} Returns `object`.
+ */
+ function baseForOwn(object, iteratee) {
+ return object && baseFor(object, iteratee, keys);
+ }
+
+ /**
+ * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @returns {Array} Returns the array of property names.
+ */
+ function baseKeys(object) {
+ if (!isPrototype(object)) {
+ return nativeKeys(object);
+ }
+ var result = [];
+ for (var key in Object(object)) {
+ if (hasOwnProperty$1.call(object, key) && key != 'constructor') {
+ result.push(key);
+ }
+ }
+ return result;
+ }
+
+ /**
+ * Creates a `baseEach` or `baseEachRight` function.
+ *
+ * @private
+ * @param {Function} eachFunc The function to iterate over a collection.
+ * @param {boolean} [fromRight] Specify iterating from right to left.
+ * @returns {Function} Returns the new base function.
+ */
+ function createBaseEach(eachFunc, fromRight) {
+ return function(collection, iteratee) {
+ if (collection == null) {
+ return collection;
+ }
+ if (!isArrayLike(collection)) {
+ return eachFunc(collection, iteratee);
+ }
+ var length = collection.length,
+ index = fromRight ? length : -1,
+ iterable = Object(collection);
+
+ while ((fromRight ? index-- : ++index < length)) {
+ if (iteratee(iterable[index], index, iterable) === false) {
+ break;
+ }
+ }
+ return collection;
+ };
+ }
+
+ /**
+ * Creates a base function for methods like `_.forIn` and `_.forOwn`.
+ *
+ * @private
+ * @param {boolean} [fromRight] Specify iterating from right to left.
+ * @returns {Function} Returns the new base function.
+ */
+ function createBaseFor(fromRight) {
+ return function(object, iteratee, keysFunc) {
+ var index = -1,
+ iterable = Object(object),
+ props = keysFunc(object),
+ length = props.length;
+
+ while (length--) {
+ var key = props[fromRight ? length : ++index];
+ if (iteratee(iterable[key], key, iterable) === false) {
+ break;
+ }
+ }
+ return object;
+ };
+ }
+
+ /**
+ * Checks if `value` is a valid array-like index.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.
+ * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.
+ */
+ function isIndex(value, length) {
+ length = length == null ? MAX_SAFE_INTEGER : length;
+ return !!length &&
+ (typeof value == 'number' || reIsUint.test(value)) &&
+ (value > -1 && value % 1 == 0 && value < length);
+ }
+
+ /**
+ * Checks if `value` is likely a prototype object.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.
+ */
+ function isPrototype(value) {
+ var Ctor = value && value.constructor,
+ proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto$3;
+
+ return value === proto;
+ }
+
+ /**
+ * Iterates over elements of `collection` and invokes `iteratee` for each element.
+ * The iteratee is invoked with three arguments: (value, index|key, collection).
+ * Iteratee functions may exit iteration early by explicitly returning `false`.
+ *
+ * **Note:** As with other "Collections" methods, objects with a "length"
+ * property are iterated like arrays. To avoid this behavior use `_.forIn`
+ * or `_.forOwn` for object iteration.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @alias each
+ * @category Collection
+ * @param {Array|Object} collection The collection to iterate over.
+ * @param {Function} [iteratee=_.identity] The function invoked per iteration.
+ * @returns {Array|Object} Returns `collection`.
+ * @see _.forEachRight
+ * @example
+ *
+ * _([1, 2]).forEach(function(value) {
+ * console.log(value);
+ * });
+ * // => Logs `1` then `2`.
+ *
+ * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {
+ * console.log(key);
+ * });
+ * // => Logs 'a' then 'b' (iteration order is not guaranteed).
+ */
+ function forEach(collection, iteratee) {
+ var func = isArray(collection) ? arrayEach : baseEach;
+ return func(collection, typeof iteratee == 'function' ? iteratee : identity);
+ }
+
+ /**
+ * Checks if `value` is likely an `arguments` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an `arguments` object,
+ * else `false`.
+ * @example
+ *
+ * _.isArguments(function() { return arguments; }());
+ * // => true
+ *
+ * _.isArguments([1, 2, 3]);
+ * // => false
+ */
+ function isArguments(value) {
+ // Safari 8.1 makes `arguments.callee` enumerable in strict mode.
+ return isArrayLikeObject(value) && hasOwnProperty$1.call(value, 'callee') &&
+ (!propertyIsEnumerable.call(value, 'callee') || objectToString$3.call(value) == argsTag);
+ }
+
+ /**
+ * Checks if `value` is classified as an `Array` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an array, else `false`.
+ * @example
+ *
+ * _.isArray([1, 2, 3]);
+ * // => true
+ *
+ * _.isArray(document.body.children);
+ * // => false
+ *
+ * _.isArray('abc');
+ * // => false
+ *
+ * _.isArray(_.noop);
+ * // => false
+ */
+ var isArray = Array.isArray;
+
+ /**
+ * Checks if `value` is array-like. A value is considered array-like if it's
+ * not a function and has a `value.length` that's an integer greater than or
+ * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is array-like, else `false`.
+ * @example
+ *
+ * _.isArrayLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isArrayLike(document.body.children);
+ * // => true
+ *
+ * _.isArrayLike('abc');
+ * // => true
+ *
+ * _.isArrayLike(_.noop);
+ * // => false
+ */
+ function isArrayLike(value) {
+ return value != null && isLength(value.length) && !isFunction(value);
+ }
+
+ /**
+ * This method is like `_.isArrayLike` except that it also checks if `value`
+ * is an object.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an array-like object,
+ * else `false`.
+ * @example
+ *
+ * _.isArrayLikeObject([1, 2, 3]);
+ * // => true
+ *
+ * _.isArrayLikeObject(document.body.children);
+ * // => true
+ *
+ * _.isArrayLikeObject('abc');
+ * // => false
+ *
+ * _.isArrayLikeObject(_.noop);
+ * // => false
+ */
+ function isArrayLikeObject(value) {
+ return isObjectLike$3(value) && isArrayLike(value);
+ }
+
+ /**
+ * Checks if `value` is classified as a `Function` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a function, else `false`.
+ * @example
+ *
+ * _.isFunction(_);
+ * // => true
+ *
+ * _.isFunction(/abc/);
+ * // => false
+ */
+ function isFunction(value) {
+ // The use of `Object#toString` avoids issues with the `typeof` operator
+ // in Safari 8-9 which returns 'object' for typed array and other constructors.
+ var tag = isObject$2(value) ? objectToString$3.call(value) : '';
+ return tag == funcTag || tag == genTag;
+ }
+
+ /**
+ * Checks if `value` is a valid array-like length.
+ *
+ * **Note:** This method is loosely based on
+ * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.
+ * @example
+ *
+ * _.isLength(3);
+ * // => true
+ *
+ * _.isLength(Number.MIN_VALUE);
+ * // => false
+ *
+ * _.isLength(Infinity);
+ * // => false
+ *
+ * _.isLength('3');
+ * // => false
+ */
+ function isLength(value) {
+ return typeof value == 'number' &&
+ value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;
+ }
+
+ /**
+ * Checks if `value` is the
+ * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
+ * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an object, else `false`.
+ * @example
+ *
+ * _.isObject({});
+ * // => true
+ *
+ * _.isObject([1, 2, 3]);
+ * // => true
+ *
+ * _.isObject(_.noop);
+ * // => true
+ *
+ * _.isObject(null);
+ * // => false
+ */
+ function isObject$2(value) {
+ var type = typeof value;
+ return !!value && (type == 'object' || type == 'function');
+ }
+
+ /**
+ * Checks if `value` is object-like. A value is object-like if it's not `null`
+ * and has a `typeof` result of "object".
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
+ * @example
+ *
+ * _.isObjectLike({});
+ * // => true
+ *
+ * _.isObjectLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isObjectLike(_.noop);
+ * // => false
+ *
+ * _.isObjectLike(null);
+ * // => false
+ */
+ function isObjectLike$3(value) {
+ return !!value && typeof value == 'object';
+ }
+
+ /**
+ * Creates an array of the own enumerable property names of `object`.
+ *
+ * **Note:** Non-object values are coerced to objects. See the
+ * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
+ * for more details.
+ *
+ * @static
+ * @since 0.1.0
+ * @memberOf _
+ * @category Object
+ * @param {Object} object The object to query.
+ * @returns {Array} Returns the array of property names.
+ * @example
+ *
+ * function Foo() {
+ * this.a = 1;
+ * this.b = 2;
+ * }
+ *
+ * Foo.prototype.c = 3;
+ *
+ * _.keys(new Foo);
+ * // => ['a', 'b'] (iteration order is not guaranteed)
+ *
+ * _.keys('hi');
+ * // => ['0', '1']
+ */
+ function keys(object) {
+ return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);
+ }
+
+ /**
+ * This method returns the first argument it receives.
+ *
+ * @static
+ * @since 0.1.0
+ * @memberOf _
+ * @category Util
+ * @param {*} value Any value.
+ * @returns {*} Returns `value`.
+ * @example
+ *
+ * var object = { 'a': 1 };
+ *
+ * console.log(_.identity(object) === object);
+ * // => true
+ */
+ function identity(value) {
+ return value;
+ }
+
+ var lodash_foreach = forEach;
+
+ let urlAlphabet$1 =
+ 'useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict';
+ var urlAlphabet_1 = { urlAlphabet: urlAlphabet$1 };
+
+ let { urlAlphabet } = urlAlphabet_1;
+ {
+ if (
+ typeof navigator !== 'undefined' &&
+ navigator.product === 'ReactNative' &&
+ typeof crypto === 'undefined'
+ ) {
+ throw new Error(
+ 'React Native does not have a built-in secure random generator. ' +
+ 'If you don’t need unpredictable IDs use `nanoid/non-secure`. ' +
+ 'For secure IDs, import `react-native-get-random-values` ' +
+ 'before Nano ID.'
+ )
+ }
+ if (typeof msCrypto !== 'undefined' && typeof crypto === 'undefined') {
+ throw new Error(
+ 'Import file with `if (!window.crypto) window.crypto = window.msCrypto`' +
+ ' before importing Nano ID to fix IE 11 support'
+ )
+ }
+ if (typeof crypto === 'undefined') {
+ throw new Error(
+ 'Your browser does not have secure random generator. ' +
+ 'If you don’t need unpredictable IDs, you can use nanoid/non-secure.'
+ )
+ }
+ }
+ let random = bytes => crypto.getRandomValues(new Uint8Array(bytes));
+ let customRandom = (alphabet, size, getRandom) => {
+ let mask = (2 << (Math.log(alphabet.length - 1) / Math.LN2)) - 1;
+ let step = -~((1.6 * mask * size) / alphabet.length);
+ return () => {
+ let id = '';
+ while (true) {
+ let bytes = getRandom(step);
+ let j = step;
+ while (j--) {
+ id += alphabet[bytes[j] & mask] || '';
+ if (id.length === size) return id
+ }
+ }
+ }
+ };
+ let customAlphabet = (alphabet, size) => customRandom(alphabet, size, random);
+ let nanoid$2 = (size = 21) => {
+ let id = '';
+ let bytes = crypto.getRandomValues(new Uint8Array(size));
+ while (size--) {
+ let byte = bytes[size] & 63;
+ if (byte < 36) {
+ id += byte.toString(36);
+ } else if (byte < 62) {
+ id += (byte - 26).toString(36).toUpperCase();
+ } else if (byte < 63) {
+ id += '_';
+ } else {
+ id += '-';
+ }
+ }
+ return id
+ };
+ var index_browser = { nanoid: nanoid$2, customAlphabet, customRandom, urlAlphabet, random };
+
+ /**
+ * lodash (Custom Build)
+ * Build: `lodash modularize exports="npm" -o ./`
+ * Copyright jQuery Foundation and other contributors
+ * Released under MIT license
+ * Based on Underscore.js 1.8.3
+ * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
+ */
+
+ /** Used as the `TypeError` message for "Functions" methods. */
+ var FUNC_ERROR_TEXT$1 = 'Expected a function';
+
+ /** Used as references for various `Number` constants. */
+ var NAN$1 = 0 / 0;
+
+ /** `Object#toString` result references. */
+ var symbolTag$2 = '[object Symbol]';
+
+ /** Used to match leading and trailing whitespace. */
+ var reTrim$1 = /^\s+|\s+$/g;
+
+ /** Used to detect bad signed hexadecimal string values. */
+ var reIsBadHex$1 = /^[-+]0x[0-9a-f]+$/i;
+
+ /** Used to detect binary string values. */
+ var reIsBinary$1 = /^0b[01]+$/i;
+
+ /** Used to detect octal string values. */
+ var reIsOctal$1 = /^0o[0-7]+$/i;
+
+ /** Built-in method references without a dependency on `root`. */
+ var freeParseInt$1 = parseInt;
+
+ /** Detect free variable `global` from Node.js. */
+ var freeGlobal$2 = typeof commonjsGlobal == 'object' && commonjsGlobal && commonjsGlobal.Object === Object && commonjsGlobal;
+
+ /** Detect free variable `self`. */
+ var freeSelf$2 = typeof self == 'object' && self && self.Object === Object && self;
+
+ /** Used as a reference to the global object. */
+ var root$2 = freeGlobal$2 || freeSelf$2 || Function('return this')();
+
+ /** Used for built-in method references. */
+ var objectProto$2 = Object.prototype;
+
+ /**
+ * Used to resolve the
+ * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
+ * of values.
+ */
+ var objectToString$2 = objectProto$2.toString;
+
+ /* Built-in method references for those with the same name as other `lodash` methods. */
+ var nativeMax$1 = Math.max,
+ nativeMin$1 = Math.min;
+
+ /**
+ * Gets the timestamp of the number of milliseconds that have elapsed since
+ * the Unix epoch (1 January 1970 00:00:00 UTC).
+ *
+ * @static
+ * @memberOf _
+ * @since 2.4.0
+ * @category Date
+ * @returns {number} Returns the timestamp.
+ * @example
+ *
+ * _.defer(function(stamp) {
+ * console.log(_.now() - stamp);
+ * }, _.now());
+ * // => Logs the number of milliseconds it took for the deferred invocation.
+ */
+ var now$1 = function() {
+ return root$2.Date.now();
+ };
+
+ /**
+ * Creates a debounced function that delays invoking `func` until after `wait`
+ * milliseconds have elapsed since the last time the debounced function was
+ * invoked. The debounced function comes with a `cancel` method to cancel
+ * delayed `func` invocations and a `flush` method to immediately invoke them.
+ * Provide `options` to indicate whether `func` should be invoked on the
+ * leading and/or trailing edge of the `wait` timeout. The `func` is invoked
+ * with the last arguments provided to the debounced function. Subsequent
+ * calls to the debounced function return the result of the last `func`
+ * invocation.
+ *
+ * **Note:** If `leading` and `trailing` options are `true`, `func` is
+ * invoked on the trailing edge of the timeout only if the debounced function
+ * is invoked more than once during the `wait` timeout.
+ *
+ * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred
+ * until to the next tick, similar to `setTimeout` with a timeout of `0`.
+ *
+ * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)
+ * for details over the differences between `_.debounce` and `_.throttle`.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Function
+ * @param {Function} func The function to debounce.
+ * @param {number} [wait=0] The number of milliseconds to delay.
+ * @param {Object} [options={}] The options object.
+ * @param {boolean} [options.leading=false]
+ * Specify invoking on the leading edge of the timeout.
+ * @param {number} [options.maxWait]
+ * The maximum time `func` is allowed to be delayed before it's invoked.
+ * @param {boolean} [options.trailing=true]
+ * Specify invoking on the trailing edge of the timeout.
+ * @returns {Function} Returns the new debounced function.
+ * @example
+ *
+ * // Avoid costly calculations while the window size is in flux.
+ * jQuery(window).on('resize', _.debounce(calculateLayout, 150));
+ *
+ * // Invoke `sendMail` when clicked, debouncing subsequent calls.
+ * jQuery(element).on('click', _.debounce(sendMail, 300, {
+ * 'leading': true,
+ * 'trailing': false
+ * }));
+ *
+ * // Ensure `batchLog` is invoked once after 1 second of debounced calls.
+ * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });
+ * var source = new EventSource('/stream');
+ * jQuery(source).on('message', debounced);
+ *
+ * // Cancel the trailing debounced invocation.
+ * jQuery(window).on('popstate', debounced.cancel);
+ */
+ function debounce$2(func, wait, options) {
+ var lastArgs,
+ lastThis,
+ maxWait,
+ result,
+ timerId,
+ lastCallTime,
+ lastInvokeTime = 0,
+ leading = false,
+ maxing = false,
+ trailing = true;
+
+ if (typeof func != 'function') {
+ throw new TypeError(FUNC_ERROR_TEXT$1);
+ }
+ wait = toNumber$1(wait) || 0;
+ if (isObject$1(options)) {
+ leading = !!options.leading;
+ maxing = 'maxWait' in options;
+ maxWait = maxing ? nativeMax$1(toNumber$1(options.maxWait) || 0, wait) : maxWait;
+ trailing = 'trailing' in options ? !!options.trailing : trailing;
+ }
+
+ function invokeFunc(time) {
+ var args = lastArgs,
+ thisArg = lastThis;
+
+ lastArgs = lastThis = undefined;
+ lastInvokeTime = time;
+ result = func.apply(thisArg, args);
+ return result;
+ }
+
+ function leadingEdge(time) {
+ // Reset any `maxWait` timer.
+ lastInvokeTime = time;
+ // Start the timer for the trailing edge.
+ timerId = setTimeout(timerExpired, wait);
+ // Invoke the leading edge.
+ return leading ? invokeFunc(time) : result;
+ }
+
+ function remainingWait(time) {
+ var timeSinceLastCall = time - lastCallTime,
+ timeSinceLastInvoke = time - lastInvokeTime,
+ result = wait - timeSinceLastCall;
+
+ return maxing ? nativeMin$1(result, maxWait - timeSinceLastInvoke) : result;
+ }
+
+ function shouldInvoke(time) {
+ var timeSinceLastCall = time - lastCallTime,
+ timeSinceLastInvoke = time - lastInvokeTime;
+
+ // Either this is the first call, activity has stopped and we're at the
+ // trailing edge, the system time has gone backwards and we're treating
+ // it as the trailing edge, or we've hit the `maxWait` limit.
+ return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||
+ (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));
+ }
+
+ function timerExpired() {
+ var time = now$1();
+ if (shouldInvoke(time)) {
+ return trailingEdge(time);
+ }
+ // Restart the timer.
+ timerId = setTimeout(timerExpired, remainingWait(time));
+ }
+
+ function trailingEdge(time) {
+ timerId = undefined;
+
+ // Only invoke if we have `lastArgs` which means `func` has been
+ // debounced at least once.
+ if (trailing && lastArgs) {
+ return invokeFunc(time);
+ }
+ lastArgs = lastThis = undefined;
+ return result;
+ }
+
+ function cancel() {
+ if (timerId !== undefined) {
+ clearTimeout(timerId);
+ }
+ lastInvokeTime = 0;
+ lastArgs = lastCallTime = lastThis = timerId = undefined;
+ }
+
+ function flush() {
+ return timerId === undefined ? result : trailingEdge(now$1());
+ }
+
+ function debounced() {
+ var time = now$1(),
+ isInvoking = shouldInvoke(time);
+
+ lastArgs = arguments;
+ lastThis = this;
+ lastCallTime = time;
+
+ if (isInvoking) {
+ if (timerId === undefined) {
+ return leadingEdge(lastCallTime);
+ }
+ if (maxing) {
+ // Handle invocations in a tight loop.
+ timerId = setTimeout(timerExpired, wait);
+ return invokeFunc(lastCallTime);
+ }
+ }
+ if (timerId === undefined) {
+ timerId = setTimeout(timerExpired, wait);
+ }
+ return result;
+ }
+ debounced.cancel = cancel;
+ debounced.flush = flush;
+ return debounced;
+ }
+
+ /**
+ * Creates a throttled function that only invokes `func` at most once per
+ * every `wait` milliseconds. The throttled function comes with a `cancel`
+ * method to cancel delayed `func` invocations and a `flush` method to
+ * immediately invoke them. Provide `options` to indicate whether `func`
+ * should be invoked on the leading and/or trailing edge of the `wait`
+ * timeout. The `func` is invoked with the last arguments provided to the
+ * throttled function. Subsequent calls to the throttled function return the
+ * result of the last `func` invocation.
+ *
+ * **Note:** If `leading` and `trailing` options are `true`, `func` is
+ * invoked on the trailing edge of the timeout only if the throttled function
+ * is invoked more than once during the `wait` timeout.
+ *
+ * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred
+ * until to the next tick, similar to `setTimeout` with a timeout of `0`.
+ *
+ * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)
+ * for details over the differences between `_.throttle` and `_.debounce`.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Function
+ * @param {Function} func The function to throttle.
+ * @param {number} [wait=0] The number of milliseconds to throttle invocations to.
+ * @param {Object} [options={}] The options object.
+ * @param {boolean} [options.leading=true]
+ * Specify invoking on the leading edge of the timeout.
+ * @param {boolean} [options.trailing=true]
+ * Specify invoking on the trailing edge of the timeout.
+ * @returns {Function} Returns the new throttled function.
+ * @example
+ *
+ * // Avoid excessively updating the position while scrolling.
+ * jQuery(window).on('scroll', _.throttle(updatePosition, 100));
+ *
+ * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.
+ * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });
+ * jQuery(element).on('click', throttled);
+ *
+ * // Cancel the trailing throttled invocation.
+ * jQuery(window).on('popstate', throttled.cancel);
+ */
+ function throttle(func, wait, options) {
+ var leading = true,
+ trailing = true;
+
+ if (typeof func != 'function') {
+ throw new TypeError(FUNC_ERROR_TEXT$1);
+ }
+ if (isObject$1(options)) {
+ leading = 'leading' in options ? !!options.leading : leading;
+ trailing = 'trailing' in options ? !!options.trailing : trailing;
+ }
+ return debounce$2(func, wait, {
+ 'leading': leading,
+ 'maxWait': wait,
+ 'trailing': trailing
+ });
+ }
+
+ /**
+ * Checks if `value` is the
+ * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
+ * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an object, else `false`.
+ * @example
+ *
+ * _.isObject({});
+ * // => true
+ *
+ * _.isObject([1, 2, 3]);
+ * // => true
+ *
+ * _.isObject(_.noop);
+ * // => true
+ *
+ * _.isObject(null);
+ * // => false
+ */
+ function isObject$1(value) {
+ var type = typeof value;
+ return !!value && (type == 'object' || type == 'function');
+ }
+
+ /**
+ * Checks if `value` is object-like. A value is object-like if it's not `null`
+ * and has a `typeof` result of "object".
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
+ * @example
+ *
+ * _.isObjectLike({});
+ * // => true
+ *
+ * _.isObjectLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isObjectLike(_.noop);
+ * // => false
+ *
+ * _.isObjectLike(null);
+ * // => false
+ */
+ function isObjectLike$2(value) {
+ return !!value && typeof value == 'object';
+ }
+
+ /**
+ * Checks if `value` is classified as a `Symbol` primitive or object.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.
+ * @example
+ *
+ * _.isSymbol(Symbol.iterator);
+ * // => true
+ *
+ * _.isSymbol('abc');
+ * // => false
+ */
+ function isSymbol$2(value) {
+ return typeof value == 'symbol' ||
+ (isObjectLike$2(value) && objectToString$2.call(value) == symbolTag$2);
+ }
+
+ /**
+ * Converts `value` to a number.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to process.
+ * @returns {number} Returns the number.
+ * @example
+ *
+ * _.toNumber(3.2);
+ * // => 3.2
+ *
+ * _.toNumber(Number.MIN_VALUE);
+ * // => 5e-324
+ *
+ * _.toNumber(Infinity);
+ * // => Infinity
+ *
+ * _.toNumber('3.2');
+ * // => 3.2
+ */
+ function toNumber$1(value) {
+ if (typeof value == 'number') {
+ return value;
+ }
+ if (isSymbol$2(value)) {
+ return NAN$1;
+ }
+ if (isObject$1(value)) {
+ var other = typeof value.valueOf == 'function' ? value.valueOf() : value;
+ value = isObject$1(other) ? (other + '') : other;
+ }
+ if (typeof value != 'string') {
+ return value === 0 ? value : +value;
+ }
+ value = value.replace(reTrim$1, '');
+ var isBinary = reIsBinary$1.test(value);
+ return (isBinary || reIsOctal$1.test(value))
+ ? freeParseInt$1(value.slice(2), isBinary ? 2 : 8)
+ : (reIsBadHex$1.test(value) ? NAN$1 : +value);
+ }
+
+ var lodash_throttle = throttle;
+
+ var snabbdom_cjs = createCommonjsModule$1(function (module, exports) {
+
+ Object.defineProperty(exports, '__esModule', { value: true });
+
+ function createElement(tagName, options) {
+ return document.createElement(tagName, options);
+ }
+ function createElementNS(namespaceURI, qualifiedName, options) {
+ return document.createElementNS(namespaceURI, qualifiedName, options);
+ }
+ function createTextNode(text) {
+ return document.createTextNode(text);
+ }
+ function createComment(text) {
+ return document.createComment(text);
+ }
+ function insertBefore(parentNode, newNode, referenceNode) {
+ parentNode.insertBefore(newNode, referenceNode);
+ }
+ function removeChild(node, child) {
+ node.removeChild(child);
+ }
+ function appendChild(node, child) {
+ node.appendChild(child);
+ }
+ function parentNode(node) {
+ return node.parentNode;
+ }
+ function nextSibling(node) {
+ return node.nextSibling;
+ }
+ function tagName(elm) {
+ return elm.tagName;
+ }
+ function setTextContent(node, text) {
+ node.textContent = text;
+ }
+ function getTextContent(node) {
+ return node.textContent;
+ }
+ function isElement(node) {
+ return node.nodeType === 1;
+ }
+ function isText(node) {
+ return node.nodeType === 3;
+ }
+ function isComment(node) {
+ return node.nodeType === 8;
+ }
+ const htmlDomApi = {
+ createElement,
+ createElementNS,
+ createTextNode,
+ createComment,
+ insertBefore,
+ removeChild,
+ appendChild,
+ parentNode,
+ nextSibling,
+ tagName,
+ setTextContent,
+ getTextContent,
+ isElement,
+ isText,
+ isComment,
+ };
+
+ function vnode(sel, data, children, text, elm) {
+ const key = data === undefined ? undefined : data.key;
+ return { sel, data, children, text, elm, key };
+ }
+
+ const array = Array.isArray;
+ function primitive(s) {
+ return typeof s === "string" ||
+ typeof s === "number" ||
+ s instanceof String ||
+ s instanceof Number;
+ }
+
+ function isUndef(s) {
+ return s === undefined;
+ }
+ function isDef(s) {
+ return s !== undefined;
+ }
+ const emptyNode = vnode("", {}, [], undefined, undefined);
+ function sameVnode(vnode1, vnode2) {
+ var _a, _b;
+ const isSameKey = vnode1.key === vnode2.key;
+ const isSameIs = ((_a = vnode1.data) === null || _a === void 0 ? void 0 : _a.is) === ((_b = vnode2.data) === null || _b === void 0 ? void 0 : _b.is);
+ const isSameSel = vnode1.sel === vnode2.sel;
+ return isSameSel && isSameKey && isSameIs;
+ }
+ function isVnode(vnode) {
+ return vnode.sel !== undefined;
+ }
+ function createKeyToOldIdx(children, beginIdx, endIdx) {
+ var _a;
+ const map = {};
+ for (let i = beginIdx; i <= endIdx; ++i) {
+ const key = (_a = children[i]) === null || _a === void 0 ? void 0 : _a.key;
+ if (key !== undefined) {
+ map[key] = i;
+ }
+ }
+ return map;
+ }
+ const hooks = [
+ "create",
+ "update",
+ "remove",
+ "destroy",
+ "pre",
+ "post",
+ ];
+ function init$1(modules, domApi) {
+ const cbs = {
+ create: [],
+ update: [],
+ remove: [],
+ destroy: [],
+ pre: [],
+ post: [],
+ };
+ const api = domApi !== undefined ? domApi : htmlDomApi;
+ for (const hook of hooks) {
+ for (const module of modules) {
+ const currentHook = module[hook];
+ if (currentHook !== undefined) {
+ cbs[hook].push(currentHook);
+ }
+ }
+ }
+ function emptyNodeAt(elm) {
+ const id = elm.id ? "#" + elm.id : "";
+ // elm.className doesn't return a string when elm is an SVG element inside a shadowRoot.
+ // https://stackoverflow.com/questions/29454340/detecting-classname-of-svganimatedstring
+ const classes = elm.getAttribute("class");
+ const c = classes ? "." + classes.split(" ").join(".") : "";
+ return vnode(api.tagName(elm).toLowerCase() + id + c, {}, [], undefined, elm);
+ }
+ function createRmCb(childElm, listeners) {
+ return function rmCb() {
+ if (--listeners === 0) {
+ const parent = api.parentNode(childElm);
+ api.removeChild(parent, childElm);
+ }
+ };
+ }
+ function createElm(vnode, insertedVnodeQueue) {
+ var _a, _b;
+ let i;
+ let data = vnode.data;
+ if (data !== undefined) {
+ const init = (_a = data.hook) === null || _a === void 0 ? void 0 : _a.init;
+ if (isDef(init)) {
+ init(vnode);
+ data = vnode.data;
+ }
+ }
+ const children = vnode.children;
+ const sel = vnode.sel;
+ if (sel === "!") {
+ if (isUndef(vnode.text)) {
+ vnode.text = "";
+ }
+ vnode.elm = api.createComment(vnode.text);
+ }
+ else if (sel !== undefined) {
+ // Parse selector
+ const hashIdx = sel.indexOf("#");
+ const dotIdx = sel.indexOf(".", hashIdx);
+ const hash = hashIdx > 0 ? hashIdx : sel.length;
+ const dot = dotIdx > 0 ? dotIdx : sel.length;
+ const tag = hashIdx !== -1 || dotIdx !== -1
+ ? sel.slice(0, Math.min(hash, dot))
+ : sel;
+ const elm = (vnode.elm =
+ isDef(data) && isDef((i = data.ns))
+ ? api.createElementNS(i, tag, data)
+ : api.createElement(tag, data));
+ if (hash < dot)
+ elm.setAttribute("id", sel.slice(hash + 1, dot));
+ if (dotIdx > 0)
+ elm.setAttribute("class", sel.slice(dot + 1).replace(/\./g, " "));
+ for (i = 0; i < cbs.create.length; ++i)
+ cbs.create[i](emptyNode, vnode);
+ if (array(children)) {
+ for (i = 0; i < children.length; ++i) {
+ const ch = children[i];
+ if (ch != null) {
+ api.appendChild(elm, createElm(ch, insertedVnodeQueue));
+ }
+ }
+ }
+ else if (primitive(vnode.text)) {
+ api.appendChild(elm, api.createTextNode(vnode.text));
+ }
+ const hook = vnode.data.hook;
+ if (isDef(hook)) {
+ (_b = hook.create) === null || _b === void 0 ? void 0 : _b.call(hook, emptyNode, vnode);
+ if (hook.insert) {
+ insertedVnodeQueue.push(vnode);
+ }
+ }
+ }
+ else {
+ vnode.elm = api.createTextNode(vnode.text);
+ }
+ return vnode.elm;
+ }
+ function addVnodes(parentElm, before, vnodes, startIdx, endIdx, insertedVnodeQueue) {
+ for (; startIdx <= endIdx; ++startIdx) {
+ const ch = vnodes[startIdx];
+ if (ch != null) {
+ api.insertBefore(parentElm, createElm(ch, insertedVnodeQueue), before);
+ }
+ }
+ }
+ function invokeDestroyHook(vnode) {
+ var _a, _b;
+ const data = vnode.data;
+ if (data !== undefined) {
+ (_b = (_a = data === null || data === void 0 ? void 0 : data.hook) === null || _a === void 0 ? void 0 : _a.destroy) === null || _b === void 0 ? void 0 : _b.call(_a, vnode);
+ for (let i = 0; i < cbs.destroy.length; ++i)
+ cbs.destroy[i](vnode);
+ if (vnode.children !== undefined) {
+ for (let j = 0; j < vnode.children.length; ++j) {
+ const child = vnode.children[j];
+ if (child != null && typeof child !== "string") {
+ invokeDestroyHook(child);
+ }
+ }
+ }
+ }
+ }
+ function removeVnodes(parentElm, vnodes, startIdx, endIdx) {
+ var _a, _b;
+ for (; startIdx <= endIdx; ++startIdx) {
+ let listeners;
+ let rm;
+ const ch = vnodes[startIdx];
+ if (ch != null) {
+ if (isDef(ch.sel)) {
+ invokeDestroyHook(ch);
+ listeners = cbs.remove.length + 1;
+ rm = createRmCb(ch.elm, listeners);
+ for (let i = 0; i < cbs.remove.length; ++i)
+ cbs.remove[i](ch, rm);
+ const removeHook = (_b = (_a = ch === null || ch === void 0 ? void 0 : ch.data) === null || _a === void 0 ? void 0 : _a.hook) === null || _b === void 0 ? void 0 : _b.remove;
+ if (isDef(removeHook)) {
+ removeHook(ch, rm);
+ }
+ else {
+ rm();
+ }
+ }
+ else {
+ // Text node
+ api.removeChild(parentElm, ch.elm);
+ }
+ }
+ }
+ }
+ function updateChildren(parentElm, oldCh, newCh, insertedVnodeQueue) {
+ let oldStartIdx = 0;
+ let newStartIdx = 0;
+ let oldEndIdx = oldCh.length - 1;
+ let oldStartVnode = oldCh[0];
+ let oldEndVnode = oldCh[oldEndIdx];
+ let newEndIdx = newCh.length - 1;
+ let newStartVnode = newCh[0];
+ let newEndVnode = newCh[newEndIdx];
+ let oldKeyToIdx;
+ let idxInOld;
+ let elmToMove;
+ let before;
+ while (oldStartIdx <= oldEndIdx && newStartIdx <= newEndIdx) {
+ if (oldStartVnode == null) {
+ oldStartVnode = oldCh[++oldStartIdx]; // Vnode might have been moved left
+ }
+ else if (oldEndVnode == null) {
+ oldEndVnode = oldCh[--oldEndIdx];
+ }
+ else if (newStartVnode == null) {
+ newStartVnode = newCh[++newStartIdx];
+ }
+ else if (newEndVnode == null) {
+ newEndVnode = newCh[--newEndIdx];
+ }
+ else if (sameVnode(oldStartVnode, newStartVnode)) {
+ patchVnode(oldStartVnode, newStartVnode, insertedVnodeQueue);
+ oldStartVnode = oldCh[++oldStartIdx];
+ newStartVnode = newCh[++newStartIdx];
+ }
+ else if (sameVnode(oldEndVnode, newEndVnode)) {
+ patchVnode(oldEndVnode, newEndVnode, insertedVnodeQueue);
+ oldEndVnode = oldCh[--oldEndIdx];
+ newEndVnode = newCh[--newEndIdx];
+ }
+ else if (sameVnode(oldStartVnode, newEndVnode)) {
+ // Vnode moved right
+ patchVnode(oldStartVnode, newEndVnode, insertedVnodeQueue);
+ api.insertBefore(parentElm, oldStartVnode.elm, api.nextSibling(oldEndVnode.elm));
+ oldStartVnode = oldCh[++oldStartIdx];
+ newEndVnode = newCh[--newEndIdx];
+ }
+ else if (sameVnode(oldEndVnode, newStartVnode)) {
+ // Vnode moved left
+ patchVnode(oldEndVnode, newStartVnode, insertedVnodeQueue);
+ api.insertBefore(parentElm, oldEndVnode.elm, oldStartVnode.elm);
+ oldEndVnode = oldCh[--oldEndIdx];
+ newStartVnode = newCh[++newStartIdx];
+ }
+ else {
+ if (oldKeyToIdx === undefined) {
+ oldKeyToIdx = createKeyToOldIdx(oldCh, oldStartIdx, oldEndIdx);
+ }
+ idxInOld = oldKeyToIdx[newStartVnode.key];
+ if (isUndef(idxInOld)) {
+ // New element
+ api.insertBefore(parentElm, createElm(newStartVnode, insertedVnodeQueue), oldStartVnode.elm);
+ }
+ else {
+ elmToMove = oldCh[idxInOld];
+ if (elmToMove.sel !== newStartVnode.sel) {
+ api.insertBefore(parentElm, createElm(newStartVnode, insertedVnodeQueue), oldStartVnode.elm);
+ }
+ else {
+ patchVnode(elmToMove, newStartVnode, insertedVnodeQueue);
+ oldCh[idxInOld] = undefined;
+ api.insertBefore(parentElm, elmToMove.elm, oldStartVnode.elm);
+ }
+ }
+ newStartVnode = newCh[++newStartIdx];
+ }
+ }
+ if (oldStartIdx <= oldEndIdx || newStartIdx <= newEndIdx) {
+ if (oldStartIdx > oldEndIdx) {
+ before = newCh[newEndIdx + 1] == null ? null : newCh[newEndIdx + 1].elm;
+ addVnodes(parentElm, before, newCh, newStartIdx, newEndIdx, insertedVnodeQueue);
+ }
+ else {
+ removeVnodes(parentElm, oldCh, oldStartIdx, oldEndIdx);
+ }
+ }
+ }
+ function patchVnode(oldVnode, vnode, insertedVnodeQueue) {
+ var _a, _b, _c, _d, _e;
+ const hook = (_a = vnode.data) === null || _a === void 0 ? void 0 : _a.hook;
+ (_b = hook === null || hook === void 0 ? void 0 : hook.prepatch) === null || _b === void 0 ? void 0 : _b.call(hook, oldVnode, vnode);
+ const elm = (vnode.elm = oldVnode.elm);
+ const oldCh = oldVnode.children;
+ const ch = vnode.children;
+ if (oldVnode === vnode)
+ return;
+ if (vnode.data !== undefined) {
+ for (let i = 0; i < cbs.update.length; ++i)
+ cbs.update[i](oldVnode, vnode);
+ (_d = (_c = vnode.data.hook) === null || _c === void 0 ? void 0 : _c.update) === null || _d === void 0 ? void 0 : _d.call(_c, oldVnode, vnode);
+ }
+ if (isUndef(vnode.text)) {
+ if (isDef(oldCh) && isDef(ch)) {
+ if (oldCh !== ch)
+ updateChildren(elm, oldCh, ch, insertedVnodeQueue);
+ }
+ else if (isDef(ch)) {
+ if (isDef(oldVnode.text))
+ api.setTextContent(elm, "");
+ addVnodes(elm, null, ch, 0, ch.length - 1, insertedVnodeQueue);
+ }
+ else if (isDef(oldCh)) {
+ removeVnodes(elm, oldCh, 0, oldCh.length - 1);
+ }
+ else if (isDef(oldVnode.text)) {
+ api.setTextContent(elm, "");
+ }
+ }
+ else if (oldVnode.text !== vnode.text) {
+ if (isDef(oldCh)) {
+ removeVnodes(elm, oldCh, 0, oldCh.length - 1);
+ }
+ api.setTextContent(elm, vnode.text);
+ }
+ (_e = hook === null || hook === void 0 ? void 0 : hook.postpatch) === null || _e === void 0 ? void 0 : _e.call(hook, oldVnode, vnode);
+ }
+ return function patch(oldVnode, vnode) {
+ let i, elm, parent;
+ const insertedVnodeQueue = [];
+ for (i = 0; i < cbs.pre.length; ++i)
+ cbs.pre[i]();
+ if (!isVnode(oldVnode)) {
+ oldVnode = emptyNodeAt(oldVnode);
+ }
+ if (sameVnode(oldVnode, vnode)) {
+ patchVnode(oldVnode, vnode, insertedVnodeQueue);
+ }
+ else {
+ elm = oldVnode.elm;
+ parent = api.parentNode(elm);
+ createElm(vnode, insertedVnodeQueue);
+ if (parent !== null) {
+ api.insertBefore(parent, vnode.elm, api.nextSibling(elm));
+ removeVnodes(parent, [oldVnode], 0, 0);
+ }
+ }
+ for (i = 0; i < insertedVnodeQueue.length; ++i) {
+ insertedVnodeQueue[i].data.hook.insert(insertedVnodeQueue[i]);
+ }
+ for (i = 0; i < cbs.post.length; ++i)
+ cbs.post[i]();
+ return vnode;
+ };
+ }
+
+ function addNS(data, children, sel) {
+ data.ns = "http://www.w3.org/2000/svg";
+ if (sel !== "foreignObject" && children !== undefined) {
+ for (let i = 0; i < children.length; ++i) {
+ const childData = children[i].data;
+ if (childData !== undefined) {
+ addNS(childData, children[i].children, children[i].sel);
+ }
+ }
+ }
+ }
+ function h(sel, b, c) {
+ let data = {};
+ let children;
+ let text;
+ let i;
+ if (c !== undefined) {
+ if (b !== null) {
+ data = b;
+ }
+ if (array(c)) {
+ children = c;
+ }
+ else if (primitive(c)) {
+ text = c.toString();
+ }
+ else if (c && c.sel) {
+ children = [c];
+ }
+ }
+ else if (b !== undefined && b !== null) {
+ if (array(b)) {
+ children = b;
+ }
+ else if (primitive(b)) {
+ text = b.toString();
+ }
+ else if (b && b.sel) {
+ children = [b];
+ }
+ else {
+ data = b;
+ }
+ }
+ if (children !== undefined) {
+ for (i = 0; i < children.length; ++i) {
+ if (primitive(children[i]))
+ children[i] = vnode(undefined, undefined, undefined, children[i], undefined);
+ }
+ }
+ if (sel[0] === "s" &&
+ sel[1] === "v" &&
+ sel[2] === "g" &&
+ (sel.length === 3 || sel[3] === "." || sel[3] === "#")) {
+ addNS(data, children, sel);
+ }
+ return vnode(sel, data, children, text, undefined);
+ }
+
+ function copyToThunk(vnode, thunk) {
+ vnode.data.fn = thunk.data.fn;
+ vnode.data.args = thunk.data.args;
+ thunk.data = vnode.data;
+ thunk.children = vnode.children;
+ thunk.text = vnode.text;
+ thunk.elm = vnode.elm;
+ }
+ function init(thunk) {
+ const cur = thunk.data;
+ const vnode = cur.fn(...cur.args);
+ copyToThunk(vnode, thunk);
+ }
+ function prepatch(oldVnode, thunk) {
+ let i;
+ const old = oldVnode.data;
+ const cur = thunk.data;
+ const oldArgs = old.args;
+ const args = cur.args;
+ if (old.fn !== cur.fn || oldArgs.length !== args.length) {
+ copyToThunk(cur.fn(...args), thunk);
+ return;
+ }
+ for (i = 0; i < args.length; ++i) {
+ if (oldArgs[i] !== args[i]) {
+ copyToThunk(cur.fn(...args), thunk);
+ return;
+ }
+ }
+ copyToThunk(oldVnode, thunk);
+ }
+ const thunk = function thunk(sel, key, fn, args) {
+ if (args === undefined) {
+ args = fn;
+ fn = key;
+ key = undefined;
+ }
+ return h(sel, {
+ key: key,
+ hook: { init, prepatch },
+ fn: fn,
+ args: args,
+ });
+ };
+
+ function pre(vnode, newVnode) {
+ const attachData = vnode.data.attachData;
+ // Copy created placeholder and real element from old vnode
+ newVnode.data.attachData.placeholder = attachData.placeholder;
+ newVnode.data.attachData.real = attachData.real;
+ // Mount real element in vnode so the patch process operates on it
+ vnode.elm = vnode.data.attachData.real;
+ }
+ function post(_, vnode) {
+ // Mount dummy placeholder in vnode so potential reorders use it
+ vnode.elm = vnode.data.attachData.placeholder;
+ }
+ function destroy(vnode) {
+ // Remove placeholder
+ if (vnode.elm !== undefined) {
+ vnode.elm.parentNode.removeChild(vnode.elm);
+ }
+ // Remove real element from where it was inserted
+ vnode.elm = vnode.data.attachData.real;
+ }
+ function create(_, vnode) {
+ const real = vnode.elm;
+ const attachData = vnode.data.attachData;
+ const placeholder = document.createElement("span");
+ // Replace actual element with dummy placeholder
+ // Snabbdom will then insert placeholder instead
+ vnode.elm = placeholder;
+ attachData.target.appendChild(real);
+ attachData.real = real;
+ attachData.placeholder = placeholder;
+ }
+ function attachTo(target, vnode) {
+ if (vnode.data === undefined)
+ vnode.data = {};
+ if (vnode.data.hook === undefined)
+ vnode.data.hook = {};
+ const data = vnode.data;
+ const hook = vnode.data.hook;
+ data.attachData = { target: target, placeholder: undefined, real: undefined };
+ hook.create = create;
+ hook.prepatch = pre;
+ hook.postpatch = post;
+ hook.destroy = destroy;
+ return vnode;
+ }
+
+ function toVNode(node, domApi) {
+ const api = domApi !== undefined ? domApi : htmlDomApi;
+ let text;
+ if (api.isElement(node)) {
+ const id = node.id ? "#" + node.id : "";
+ const cn = node.getAttribute("class");
+ const c = cn ? "." + cn.split(" ").join(".") : "";
+ const sel = api.tagName(node).toLowerCase() + id + c;
+ const attrs = {};
+ const children = [];
+ let name;
+ let i, n;
+ const elmAttrs = node.attributes;
+ const elmChildren = node.childNodes;
+ for (i = 0, n = elmAttrs.length; i < n; i++) {
+ name = elmAttrs[i].nodeName;
+ if (name !== "id" && name !== "class") {
+ attrs[name] = elmAttrs[i].nodeValue;
+ }
+ }
+ for (i = 0, n = elmChildren.length; i < n; i++) {
+ children.push(toVNode(elmChildren[i], domApi));
+ }
+ return vnode(sel, { attrs }, children, undefined, node);
+ }
+ else if (api.isText(node)) {
+ text = api.getTextContent(node);
+ return vnode(undefined, undefined, undefined, text, node);
+ }
+ else if (api.isComment(node)) {
+ text = api.getTextContent(node);
+ return vnode("!", {}, [], text, node);
+ }
+ else {
+ return vnode("", {}, [], undefined, node);
+ }
+ }
+
+ const xlinkNS = "http://www.w3.org/1999/xlink";
+ const xmlNS = "http://www.w3.org/XML/1998/namespace";
+ const colonChar = 58;
+ const xChar = 120;
+ function updateAttrs(oldVnode, vnode) {
+ let key;
+ const elm = vnode.elm;
+ let oldAttrs = oldVnode.data.attrs;
+ let attrs = vnode.data.attrs;
+ if (!oldAttrs && !attrs)
+ return;
+ if (oldAttrs === attrs)
+ return;
+ oldAttrs = oldAttrs || {};
+ attrs = attrs || {};
+ // update modified attributes, add new attributes
+ for (key in attrs) {
+ const cur = attrs[key];
+ const old = oldAttrs[key];
+ if (old !== cur) {
+ if (cur === true) {
+ elm.setAttribute(key, "");
+ }
+ else if (cur === false) {
+ elm.removeAttribute(key);
+ }
+ else {
+ if (key.charCodeAt(0) !== xChar) {
+ elm.setAttribute(key, cur);
+ }
+ else if (key.charCodeAt(3) === colonChar) {
+ // Assume xml namespace
+ elm.setAttributeNS(xmlNS, key, cur);
+ }
+ else if (key.charCodeAt(5) === colonChar) {
+ // Assume xlink namespace
+ elm.setAttributeNS(xlinkNS, key, cur);
+ }
+ else {
+ elm.setAttribute(key, cur);
+ }
+ }
+ }
+ }
+ // remove removed attributes
+ // use `in` operator since the previous `for` iteration uses it (.i.e. add even attributes with undefined value)
+ // the other option is to remove all attributes with value == undefined
+ for (key in oldAttrs) {
+ if (!(key in attrs)) {
+ elm.removeAttribute(key);
+ }
+ }
+ }
+ const attributesModule = {
+ create: updateAttrs,
+ update: updateAttrs,
+ };
+
+ function updateClass(oldVnode, vnode) {
+ let cur;
+ let name;
+ const elm = vnode.elm;
+ let oldClass = oldVnode.data.class;
+ let klass = vnode.data.class;
+ if (!oldClass && !klass)
+ return;
+ if (oldClass === klass)
+ return;
+ oldClass = oldClass || {};
+ klass = klass || {};
+ for (name in oldClass) {
+ if (oldClass[name] && !Object.prototype.hasOwnProperty.call(klass, name)) {
+ // was `true` and now not provided
+ elm.classList.remove(name);
+ }
+ }
+ for (name in klass) {
+ cur = klass[name];
+ if (cur !== oldClass[name]) {
+ elm.classList[cur ? "add" : "remove"](name);
+ }
+ }
+ }
+ const classModule = { create: updateClass, update: updateClass };
+
+ const CAPS_REGEX = /[A-Z]/g;
+ function updateDataset(oldVnode, vnode) {
+ const elm = vnode.elm;
+ let oldDataset = oldVnode.data.dataset;
+ let dataset = vnode.data.dataset;
+ let key;
+ if (!oldDataset && !dataset)
+ return;
+ if (oldDataset === dataset)
+ return;
+ oldDataset = oldDataset || {};
+ dataset = dataset || {};
+ const d = elm.dataset;
+ for (key in oldDataset) {
+ if (!dataset[key]) {
+ if (d) {
+ if (key in d) {
+ delete d[key];
+ }
+ }
+ else {
+ elm.removeAttribute("data-" + key.replace(CAPS_REGEX, "-$&").toLowerCase());
+ }
+ }
+ }
+ for (key in dataset) {
+ if (oldDataset[key] !== dataset[key]) {
+ if (d) {
+ d[key] = dataset[key];
+ }
+ else {
+ elm.setAttribute("data-" + key.replace(CAPS_REGEX, "-$&").toLowerCase(), dataset[key]);
+ }
+ }
+ }
+ }
+ const datasetModule = {
+ create: updateDataset,
+ update: updateDataset,
+ };
+
+ function invokeHandler(handler, vnode, event) {
+ if (typeof handler === "function") {
+ // call function handler
+ handler.call(vnode, event, vnode);
+ }
+ else if (typeof handler === "object") {
+ // call multiple handlers
+ for (let i = 0; i < handler.length; i++) {
+ invokeHandler(handler[i], vnode, event);
+ }
+ }
+ }
+ function handleEvent(event, vnode) {
+ const name = event.type;
+ const on = vnode.data.on;
+ // call event handler(s) if exists
+ if (on && on[name]) {
+ invokeHandler(on[name], vnode, event);
+ }
+ }
+ function createListener() {
+ return function handler(event) {
+ handleEvent(event, handler.vnode);
+ };
+ }
+ function updateEventListeners(oldVnode, vnode) {
+ const oldOn = oldVnode.data.on;
+ const oldListener = oldVnode.listener;
+ const oldElm = oldVnode.elm;
+ const on = vnode && vnode.data.on;
+ const elm = (vnode && vnode.elm);
+ let name;
+ // optimization for reused immutable handlers
+ if (oldOn === on) {
+ return;
+ }
+ // remove existing listeners which no longer used
+ if (oldOn && oldListener) {
+ // if element changed or deleted we remove all existing listeners unconditionally
+ if (!on) {
+ for (name in oldOn) {
+ // remove listener if element was changed or existing listeners removed
+ oldElm.removeEventListener(name, oldListener, false);
+ }
+ }
+ else {
+ for (name in oldOn) {
+ // remove listener if existing listener removed
+ if (!on[name]) {
+ oldElm.removeEventListener(name, oldListener, false);
+ }
+ }
+ }
+ }
+ // add new listeners which has not already attached
+ if (on) {
+ // reuse existing listener or create new
+ const listener = (vnode.listener =
+ oldVnode.listener || createListener());
+ // update vnode for listener
+ listener.vnode = vnode;
+ // if element changed or added we add all needed listeners unconditionally
+ if (!oldOn) {
+ for (name in on) {
+ // add listener if element was changed or new listeners added
+ elm.addEventListener(name, listener, false);
+ }
+ }
+ else {
+ for (name in on) {
+ // add listener if new listener added
+ if (!oldOn[name]) {
+ elm.addEventListener(name, listener, false);
+ }
+ }
+ }
+ }
+ }
+ const eventListenersModule = {
+ create: updateEventListeners,
+ update: updateEventListeners,
+ destroy: updateEventListeners,
+ };
+
+ function updateProps(oldVnode, vnode) {
+ let key;
+ let cur;
+ let old;
+ const elm = vnode.elm;
+ let oldProps = oldVnode.data.props;
+ let props = vnode.data.props;
+ if (!oldProps && !props)
+ return;
+ if (oldProps === props)
+ return;
+ oldProps = oldProps || {};
+ props = props || {};
+ for (key in props) {
+ cur = props[key];
+ old = oldProps[key];
+ if (old !== cur && (key !== "value" || elm[key] !== cur)) {
+ elm[key] = cur;
+ }
+ }
+ }
+ const propsModule = { create: updateProps, update: updateProps };
+
+ // Bindig `requestAnimationFrame` like this fixes a bug in IE/Edge. See #360 and #409.
+ const raf = (typeof window !== "undefined" &&
+ window.requestAnimationFrame.bind(window)) ||
+ setTimeout;
+ const nextFrame = function (fn) {
+ raf(function () {
+ raf(fn);
+ });
+ };
+ let reflowForced = false;
+ function setNextFrame(obj, prop, val) {
+ nextFrame(function () {
+ obj[prop] = val;
+ });
+ }
+ function updateStyle(oldVnode, vnode) {
+ let cur;
+ let name;
+ const elm = vnode.elm;
+ let oldStyle = oldVnode.data.style;
+ let style = vnode.data.style;
+ if (!oldStyle && !style)
+ return;
+ if (oldStyle === style)
+ return;
+ oldStyle = oldStyle || {};
+ style = style || {};
+ const oldHasDel = "delayed" in oldStyle;
+ for (name in oldStyle) {
+ if (!style[name]) {
+ if (name[0] === "-" && name[1] === "-") {
+ elm.style.removeProperty(name);
+ }
+ else {
+ elm.style[name] = "";
+ }
+ }
+ }
+ for (name in style) {
+ cur = style[name];
+ if (name === "delayed" && style.delayed) {
+ for (const name2 in style.delayed) {
+ cur = style.delayed[name2];
+ if (!oldHasDel || cur !== oldStyle.delayed[name2]) {
+ setNextFrame(elm.style, name2, cur);
+ }
+ }
+ }
+ else if (name !== "remove" && cur !== oldStyle[name]) {
+ if (name[0] === "-" && name[1] === "-") {
+ elm.style.setProperty(name, cur);
+ }
+ else {
+ elm.style[name] = cur;
+ }
+ }
+ }
+ }
+ function applyDestroyStyle(vnode) {
+ let style;
+ let name;
+ const elm = vnode.elm;
+ const s = vnode.data.style;
+ if (!s || !(style = s.destroy))
+ return;
+ for (name in style) {
+ elm.style[name] = style[name];
+ }
+ }
+ function applyRemoveStyle(vnode, rm) {
+ const s = vnode.data.style;
+ if (!s || !s.remove) {
+ rm();
+ return;
+ }
+ if (!reflowForced) {
+ // eslint-disable-next-line @typescript-eslint/no-unused-expressions
+ vnode.elm.offsetLeft;
+ reflowForced = true;
+ }
+ let name;
+ const elm = vnode.elm;
+ let i = 0;
+ const style = s.remove;
+ let amount = 0;
+ const applied = [];
+ for (name in style) {
+ applied.push(name);
+ elm.style[name] = style[name];
+ }
+ const compStyle = getComputedStyle(elm);
+ const props = compStyle["transition-property"].split(", ");
+ for (; i < props.length; ++i) {
+ if (applied.indexOf(props[i]) !== -1)
+ amount++;
+ }
+ elm.addEventListener("transitionend", function (ev) {
+ if (ev.target === elm)
+ --amount;
+ if (amount === 0)
+ rm();
+ });
+ }
+ function forceReflow() {
+ reflowForced = false;
+ }
+ const styleModule = {
+ pre: forceReflow,
+ create: updateStyle,
+ update: updateStyle,
+ destroy: applyDestroyStyle,
+ remove: applyRemoveStyle,
+ };
+
+ /* eslint-disable @typescript-eslint/no-namespace, import/export */
+ function flattenAndFilter(children, flattened) {
+ for (const child of children) {
+ // filter out falsey children, except 0 since zero can be a valid value e.g inside a chart
+ if (child !== undefined &&
+ child !== null &&
+ child !== false &&
+ child !== "") {
+ if (Array.isArray(child)) {
+ flattenAndFilter(child, flattened);
+ }
+ else if (typeof child === "string" ||
+ typeof child === "number" ||
+ typeof child === "boolean") {
+ flattened.push(vnode(undefined, undefined, undefined, String(child), undefined));
+ }
+ else {
+ flattened.push(child);
+ }
+ }
+ }
+ return flattened;
+ }
+ /**
+ * jsx/tsx compatible factory function
+ * see: https://www.typescriptlang.org/docs/handbook/jsx.html#factory-functions
+ */
+ function jsx(tag, data, ...children) {
+ const flatChildren = flattenAndFilter(children, []);
+ if (typeof tag === "function") {
+ // tag is a function component
+ return tag(data, flatChildren);
+ }
+ else {
+ if (flatChildren.length === 1 &&
+ !flatChildren[0].sel &&
+ flatChildren[0].text) {
+ // only child is a simple text node, pass as text for a simpler vtree
+ return h(tag, data, flatChildren[0].text);
+ }
+ else {
+ return h(tag, data, flatChildren);
+ }
+ }
+ }
+ (function (jsx) {
+ })(jsx || (jsx = {}));
+
+ exports.array = array;
+ exports.attachTo = attachTo;
+ exports.attributesModule = attributesModule;
+ exports.classModule = classModule;
+ exports.datasetModule = datasetModule;
+ exports.eventListenersModule = eventListenersModule;
+ exports.h = h;
+ exports.htmlDomApi = htmlDomApi;
+ exports.init = init$1;
+ exports.jsx = jsx;
+ exports.primitive = primitive;
+ exports.propsModule = propsModule;
+ exports.styleModule = styleModule;
+ exports.thunk = thunk;
+ exports.toVNode = toVNode;
+ exports.vnode = vnode;
+ });
+
+ /**
+ * lodash (Custom Build)
+ * Build: `lodash modularize exports="npm" -o ./`
+ * Copyright jQuery Foundation and other contributors
+ * Released under MIT license
+ * Based on Underscore.js 1.8.3
+ * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
+ */
+
+ /** Used as references for various `Number` constants. */
+ var INFINITY = 1 / 0;
+
+ /** `Object#toString` result references. */
+ var symbolTag$1 = '[object Symbol]';
+
+ /** Used to match words composed of alphanumeric characters. */
+ var reAsciiWord = /[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g;
+
+ /** Used to match Latin Unicode letters (excluding mathematical operators). */
+ var reLatin = /[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g;
+
+ /** Used to compose unicode character classes. */
+ var rsAstralRange = '\\ud800-\\udfff',
+ rsComboMarksRange = '\\u0300-\\u036f\\ufe20-\\ufe23',
+ rsComboSymbolsRange = '\\u20d0-\\u20f0',
+ rsDingbatRange = '\\u2700-\\u27bf',
+ rsLowerRange = 'a-z\\xdf-\\xf6\\xf8-\\xff',
+ rsMathOpRange = '\\xac\\xb1\\xd7\\xf7',
+ rsNonCharRange = '\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf',
+ rsPunctuationRange = '\\u2000-\\u206f',
+ rsSpaceRange = ' \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000',
+ rsUpperRange = 'A-Z\\xc0-\\xd6\\xd8-\\xde',
+ rsVarRange = '\\ufe0e\\ufe0f',
+ rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange;
+
+ /** Used to compose unicode capture groups. */
+ var rsApos = "['\u2019]",
+ rsAstral = '[' + rsAstralRange + ']',
+ rsBreak = '[' + rsBreakRange + ']',
+ rsCombo = '[' + rsComboMarksRange + rsComboSymbolsRange + ']',
+ rsDigits = '\\d+',
+ rsDingbat = '[' + rsDingbatRange + ']',
+ rsLower = '[' + rsLowerRange + ']',
+ rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']',
+ rsFitz = '\\ud83c[\\udffb-\\udfff]',
+ rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',
+ rsNonAstral = '[^' + rsAstralRange + ']',
+ rsRegional = '(?:\\ud83c[\\udde6-\\uddff]){2}',
+ rsSurrPair = '[\\ud800-\\udbff][\\udc00-\\udfff]',
+ rsUpper = '[' + rsUpperRange + ']',
+ rsZWJ = '\\u200d';
+
+ /** Used to compose unicode regexes. */
+ var rsLowerMisc = '(?:' + rsLower + '|' + rsMisc + ')',
+ rsUpperMisc = '(?:' + rsUpper + '|' + rsMisc + ')',
+ rsOptLowerContr = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?',
+ rsOptUpperContr = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?',
+ reOptMod = rsModifier + '?',
+ rsOptVar = '[' + rsVarRange + ']?',
+ rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',
+ rsSeq = rsOptVar + reOptMod + rsOptJoin,
+ rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq,
+ rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';
+
+ /** Used to match apostrophes. */
+ var reApos = RegExp(rsApos, 'g');
+
+ /**
+ * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and
+ * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols).
+ */
+ var reComboMark = RegExp(rsCombo, 'g');
+
+ /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */
+ var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');
+
+ /** Used to match complex or compound words. */
+ var reUnicodeWord = RegExp([
+ rsUpper + '?' + rsLower + '+' + rsOptLowerContr + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')',
+ rsUpperMisc + '+' + rsOptUpperContr + '(?=' + [rsBreak, rsUpper + rsLowerMisc, '$'].join('|') + ')',
+ rsUpper + '?' + rsLowerMisc + '+' + rsOptLowerContr,
+ rsUpper + '+' + rsOptUpperContr,
+ rsDigits,
+ rsEmoji
+ ].join('|'), 'g');
+
+ /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */
+ var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboMarksRange + rsComboSymbolsRange + rsVarRange + ']');
+
+ /** Used to detect strings that need a more robust regexp to match words. */
+ var reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2,}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;
+
+ /** Used to map Latin Unicode letters to basic Latin letters. */
+ var deburredLetters = {
+ // Latin-1 Supplement block.
+ '\xc0': 'A', '\xc1': 'A', '\xc2': 'A', '\xc3': 'A', '\xc4': 'A', '\xc5': 'A',
+ '\xe0': 'a', '\xe1': 'a', '\xe2': 'a', '\xe3': 'a', '\xe4': 'a', '\xe5': 'a',
+ '\xc7': 'C', '\xe7': 'c',
+ '\xd0': 'D', '\xf0': 'd',
+ '\xc8': 'E', '\xc9': 'E', '\xca': 'E', '\xcb': 'E',
+ '\xe8': 'e', '\xe9': 'e', '\xea': 'e', '\xeb': 'e',
+ '\xcc': 'I', '\xcd': 'I', '\xce': 'I', '\xcf': 'I',
+ '\xec': 'i', '\xed': 'i', '\xee': 'i', '\xef': 'i',
+ '\xd1': 'N', '\xf1': 'n',
+ '\xd2': 'O', '\xd3': 'O', '\xd4': 'O', '\xd5': 'O', '\xd6': 'O', '\xd8': 'O',
+ '\xf2': 'o', '\xf3': 'o', '\xf4': 'o', '\xf5': 'o', '\xf6': 'o', '\xf8': 'o',
+ '\xd9': 'U', '\xda': 'U', '\xdb': 'U', '\xdc': 'U',
+ '\xf9': 'u', '\xfa': 'u', '\xfb': 'u', '\xfc': 'u',
+ '\xdd': 'Y', '\xfd': 'y', '\xff': 'y',
+ '\xc6': 'Ae', '\xe6': 'ae',
+ '\xde': 'Th', '\xfe': 'th',
+ '\xdf': 'ss',
+ // Latin Extended-A block.
+ '\u0100': 'A', '\u0102': 'A', '\u0104': 'A',
+ '\u0101': 'a', '\u0103': 'a', '\u0105': 'a',
+ '\u0106': 'C', '\u0108': 'C', '\u010a': 'C', '\u010c': 'C',
+ '\u0107': 'c', '\u0109': 'c', '\u010b': 'c', '\u010d': 'c',
+ '\u010e': 'D', '\u0110': 'D', '\u010f': 'd', '\u0111': 'd',
+ '\u0112': 'E', '\u0114': 'E', '\u0116': 'E', '\u0118': 'E', '\u011a': 'E',
+ '\u0113': 'e', '\u0115': 'e', '\u0117': 'e', '\u0119': 'e', '\u011b': 'e',
+ '\u011c': 'G', '\u011e': 'G', '\u0120': 'G', '\u0122': 'G',
+ '\u011d': 'g', '\u011f': 'g', '\u0121': 'g', '\u0123': 'g',
+ '\u0124': 'H', '\u0126': 'H', '\u0125': 'h', '\u0127': 'h',
+ '\u0128': 'I', '\u012a': 'I', '\u012c': 'I', '\u012e': 'I', '\u0130': 'I',
+ '\u0129': 'i', '\u012b': 'i', '\u012d': 'i', '\u012f': 'i', '\u0131': 'i',
+ '\u0134': 'J', '\u0135': 'j',
+ '\u0136': 'K', '\u0137': 'k', '\u0138': 'k',
+ '\u0139': 'L', '\u013b': 'L', '\u013d': 'L', '\u013f': 'L', '\u0141': 'L',
+ '\u013a': 'l', '\u013c': 'l', '\u013e': 'l', '\u0140': 'l', '\u0142': 'l',
+ '\u0143': 'N', '\u0145': 'N', '\u0147': 'N', '\u014a': 'N',
+ '\u0144': 'n', '\u0146': 'n', '\u0148': 'n', '\u014b': 'n',
+ '\u014c': 'O', '\u014e': 'O', '\u0150': 'O',
+ '\u014d': 'o', '\u014f': 'o', '\u0151': 'o',
+ '\u0154': 'R', '\u0156': 'R', '\u0158': 'R',
+ '\u0155': 'r', '\u0157': 'r', '\u0159': 'r',
+ '\u015a': 'S', '\u015c': 'S', '\u015e': 'S', '\u0160': 'S',
+ '\u015b': 's', '\u015d': 's', '\u015f': 's', '\u0161': 's',
+ '\u0162': 'T', '\u0164': 'T', '\u0166': 'T',
+ '\u0163': 't', '\u0165': 't', '\u0167': 't',
+ '\u0168': 'U', '\u016a': 'U', '\u016c': 'U', '\u016e': 'U', '\u0170': 'U', '\u0172': 'U',
+ '\u0169': 'u', '\u016b': 'u', '\u016d': 'u', '\u016f': 'u', '\u0171': 'u', '\u0173': 'u',
+ '\u0174': 'W', '\u0175': 'w',
+ '\u0176': 'Y', '\u0177': 'y', '\u0178': 'Y',
+ '\u0179': 'Z', '\u017b': 'Z', '\u017d': 'Z',
+ '\u017a': 'z', '\u017c': 'z', '\u017e': 'z',
+ '\u0132': 'IJ', '\u0133': 'ij',
+ '\u0152': 'Oe', '\u0153': 'oe',
+ '\u0149': "'n", '\u017f': 'ss'
+ };
+
+ /** Detect free variable `global` from Node.js. */
+ var freeGlobal$1 = typeof commonjsGlobal == 'object' && commonjsGlobal && commonjsGlobal.Object === Object && commonjsGlobal;
+
+ /** Detect free variable `self`. */
+ var freeSelf$1 = typeof self == 'object' && self && self.Object === Object && self;
+
+ /** Used as a reference to the global object. */
+ var root$1 = freeGlobal$1 || freeSelf$1 || Function('return this')();
+
+ /**
+ * A specialized version of `_.reduce` for arrays without support for
+ * iteratee shorthands.
+ *
+ * @private
+ * @param {Array} [array] The array to iterate over.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @param {*} [accumulator] The initial value.
+ * @param {boolean} [initAccum] Specify using the first element of `array` as
+ * the initial value.
+ * @returns {*} Returns the accumulated value.
+ */
+ function arrayReduce(array, iteratee, accumulator, initAccum) {
+ var index = -1,
+ length = array ? array.length : 0;
+
+ if (initAccum && length) {
+ accumulator = array[++index];
+ }
+ while (++index < length) {
+ accumulator = iteratee(accumulator, array[index], index, array);
+ }
+ return accumulator;
+ }
+
+ /**
+ * Converts an ASCII `string` to an array.
+ *
+ * @private
+ * @param {string} string The string to convert.
+ * @returns {Array} Returns the converted array.
+ */
+ function asciiToArray(string) {
+ return string.split('');
+ }
+
+ /**
+ * Splits an ASCII `string` into an array of its words.
+ *
+ * @private
+ * @param {string} The string to inspect.
+ * @returns {Array} Returns the words of `string`.
+ */
+ function asciiWords(string) {
+ return string.match(reAsciiWord) || [];
+ }
+
+ /**
+ * The base implementation of `_.propertyOf` without support for deep paths.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @returns {Function} Returns the new accessor function.
+ */
+ function basePropertyOf(object) {
+ return function(key) {
+ return object == null ? undefined : object[key];
+ };
+ }
+
+ /**
+ * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A
+ * letters to basic Latin letters.
+ *
+ * @private
+ * @param {string} letter The matched letter to deburr.
+ * @returns {string} Returns the deburred letter.
+ */
+ var deburrLetter = basePropertyOf(deburredLetters);
+
+ /**
+ * Checks if `string` contains Unicode symbols.
+ *
+ * @private
+ * @param {string} string The string to inspect.
+ * @returns {boolean} Returns `true` if a symbol is found, else `false`.
+ */
+ function hasUnicode(string) {
+ return reHasUnicode.test(string);
+ }
+
+ /**
+ * Checks if `string` contains a word composed of Unicode symbols.
+ *
+ * @private
+ * @param {string} string The string to inspect.
+ * @returns {boolean} Returns `true` if a word is found, else `false`.
+ */
+ function hasUnicodeWord(string) {
+ return reHasUnicodeWord.test(string);
+ }
+
+ /**
+ * Converts `string` to an array.
+ *
+ * @private
+ * @param {string} string The string to convert.
+ * @returns {Array} Returns the converted array.
+ */
+ function stringToArray(string) {
+ return hasUnicode(string)
+ ? unicodeToArray(string)
+ : asciiToArray(string);
+ }
+
+ /**
+ * Converts a Unicode `string` to an array.
+ *
+ * @private
+ * @param {string} string The string to convert.
+ * @returns {Array} Returns the converted array.
+ */
+ function unicodeToArray(string) {
+ return string.match(reUnicode) || [];
+ }
+
+ /**
+ * Splits a Unicode `string` into an array of its words.
+ *
+ * @private
+ * @param {string} The string to inspect.
+ * @returns {Array} Returns the words of `string`.
+ */
+ function unicodeWords(string) {
+ return string.match(reUnicodeWord) || [];
+ }
+
+ /** Used for built-in method references. */
+ var objectProto$1 = Object.prototype;
+
+ /**
+ * Used to resolve the
+ * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
+ * of values.
+ */
+ var objectToString$1 = objectProto$1.toString;
+
+ /** Built-in value references. */
+ var Symbol$1 = root$1.Symbol;
+
+ /** Used to convert symbols to primitives and strings. */
+ var symbolProto = Symbol$1 ? Symbol$1.prototype : undefined,
+ symbolToString = symbolProto ? symbolProto.toString : undefined;
+
+ /**
+ * The base implementation of `_.slice` without an iteratee call guard.
+ *
+ * @private
+ * @param {Array} array The array to slice.
+ * @param {number} [start=0] The start position.
+ * @param {number} [end=array.length] The end position.
+ * @returns {Array} Returns the slice of `array`.
+ */
+ function baseSlice(array, start, end) {
+ var index = -1,
+ length = array.length;
+
+ if (start < 0) {
+ start = -start > length ? 0 : (length + start);
+ }
+ end = end > length ? length : end;
+ if (end < 0) {
+ end += length;
+ }
+ length = start > end ? 0 : ((end - start) >>> 0);
+ start >>>= 0;
+
+ var result = Array(length);
+ while (++index < length) {
+ result[index] = array[index + start];
+ }
+ return result;
+ }
+
+ /**
+ * The base implementation of `_.toString` which doesn't convert nullish
+ * values to empty strings.
+ *
+ * @private
+ * @param {*} value The value to process.
+ * @returns {string} Returns the string.
+ */
+ function baseToString(value) {
+ // Exit early for strings to avoid a performance hit in some environments.
+ if (typeof value == 'string') {
+ return value;
+ }
+ if (isSymbol$1(value)) {
+ return symbolToString ? symbolToString.call(value) : '';
+ }
+ var result = (value + '');
+ return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;
+ }
+
+ /**
+ * Casts `array` to a slice if it's needed.
+ *
+ * @private
+ * @param {Array} array The array to inspect.
+ * @param {number} start The start position.
+ * @param {number} [end=array.length] The end position.
+ * @returns {Array} Returns the cast slice.
+ */
+ function castSlice(array, start, end) {
+ var length = array.length;
+ end = end === undefined ? length : end;
+ return (!start && end >= length) ? array : baseSlice(array, start, end);
+ }
+
+ /**
+ * Creates a function like `_.lowerFirst`.
+ *
+ * @private
+ * @param {string} methodName The name of the `String` case method to use.
+ * @returns {Function} Returns the new case function.
+ */
+ function createCaseFirst(methodName) {
+ return function(string) {
+ string = toString(string);
+
+ var strSymbols = hasUnicode(string)
+ ? stringToArray(string)
+ : undefined;
+
+ var chr = strSymbols
+ ? strSymbols[0]
+ : string.charAt(0);
+
+ var trailing = strSymbols
+ ? castSlice(strSymbols, 1).join('')
+ : string.slice(1);
+
+ return chr[methodName]() + trailing;
+ };
+ }
+
+ /**
+ * Creates a function like `_.camelCase`.
+ *
+ * @private
+ * @param {Function} callback The function to combine each word.
+ * @returns {Function} Returns the new compounder function.
+ */
+ function createCompounder(callback) {
+ return function(string) {
+ return arrayReduce(words(deburr(string).replace(reApos, '')), callback, '');
+ };
+ }
+
+ /**
+ * Checks if `value` is object-like. A value is object-like if it's not `null`
+ * and has a `typeof` result of "object".
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
+ * @example
+ *
+ * _.isObjectLike({});
+ * // => true
+ *
+ * _.isObjectLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isObjectLike(_.noop);
+ * // => false
+ *
+ * _.isObjectLike(null);
+ * // => false
+ */
+ function isObjectLike$1(value) {
+ return !!value && typeof value == 'object';
+ }
+
+ /**
+ * Checks if `value` is classified as a `Symbol` primitive or object.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.
+ * @example
+ *
+ * _.isSymbol(Symbol.iterator);
+ * // => true
+ *
+ * _.isSymbol('abc');
+ * // => false
+ */
+ function isSymbol$1(value) {
+ return typeof value == 'symbol' ||
+ (isObjectLike$1(value) && objectToString$1.call(value) == symbolTag$1);
+ }
+
+ /**
+ * Converts `value` to a string. An empty string is returned for `null`
+ * and `undefined` values. The sign of `-0` is preserved.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to process.
+ * @returns {string} Returns the string.
+ * @example
+ *
+ * _.toString(null);
+ * // => ''
+ *
+ * _.toString(-0);
+ * // => '-0'
+ *
+ * _.toString([1, 2, 3]);
+ * // => '1,2,3'
+ */
+ function toString(value) {
+ return value == null ? '' : baseToString(value);
+ }
+
+ /**
+ * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase).
+ *
+ * @static
+ * @memberOf _
+ * @since 3.0.0
+ * @category String
+ * @param {string} [string=''] The string to convert.
+ * @returns {string} Returns the camel cased string.
+ * @example
+ *
+ * _.camelCase('Foo Bar');
+ * // => 'fooBar'
+ *
+ * _.camelCase('--foo-bar--');
+ * // => 'fooBar'
+ *
+ * _.camelCase('__FOO_BAR__');
+ * // => 'fooBar'
+ */
+ var camelCase = createCompounder(function(result, word, index) {
+ word = word.toLowerCase();
+ return result + (index ? capitalize(word) : word);
+ });
+
+ /**
+ * Converts the first character of `string` to upper case and the remaining
+ * to lower case.
+ *
+ * @static
+ * @memberOf _
+ * @since 3.0.0
+ * @category String
+ * @param {string} [string=''] The string to capitalize.
+ * @returns {string} Returns the capitalized string.
+ * @example
+ *
+ * _.capitalize('FRED');
+ * // => 'Fred'
+ */
+ function capitalize(string) {
+ return upperFirst(toString(string).toLowerCase());
+ }
+
+ /**
+ * Deburrs `string` by converting
+ * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table)
+ * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A)
+ * letters to basic Latin letters and removing
+ * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks).
+ *
+ * @static
+ * @memberOf _
+ * @since 3.0.0
+ * @category String
+ * @param {string} [string=''] The string to deburr.
+ * @returns {string} Returns the deburred string.
+ * @example
+ *
+ * _.deburr('déjà vu');
+ * // => 'deja vu'
+ */
+ function deburr(string) {
+ string = toString(string);
+ return string && string.replace(reLatin, deburrLetter).replace(reComboMark, '');
+ }
+
+ /**
+ * Converts the first character of `string` to upper case.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category String
+ * @param {string} [string=''] The string to convert.
+ * @returns {string} Returns the converted string.
+ * @example
+ *
+ * _.upperFirst('fred');
+ * // => 'Fred'
+ *
+ * _.upperFirst('FRED');
+ * // => 'FRED'
+ */
+ var upperFirst = createCaseFirst('toUpperCase');
+
+ /**
+ * Splits `string` into an array of its words.
+ *
+ * @static
+ * @memberOf _
+ * @since 3.0.0
+ * @category String
+ * @param {string} [string=''] The string to inspect.
+ * @param {RegExp|string} [pattern] The pattern to match words.
+ * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.
+ * @returns {Array} Returns the words of `string`.
+ * @example
+ *
+ * _.words('fred, barney, & pebbles');
+ * // => ['fred', 'barney', 'pebbles']
+ *
+ * _.words('fred, barney, & pebbles', /[^, ]+/g);
+ * // => ['fred', 'barney', '&', 'pebbles']
+ */
+ function words(string, pattern, guard) {
+ string = toString(string);
+ pattern = guard ? undefined : pattern;
+
+ if (pattern === undefined) {
+ return hasUnicodeWord(string) ? unicodeWords(string) : asciiWords(string);
+ }
+ return string.match(pattern) || [];
+ }
+
+ var lodash_camelcase = camelCase;
+
+ /**
+ * Constants.
+ */
+
+ var IS_MAC = typeof window != 'undefined' && /Mac|iPod|iPhone|iPad/.test(window.navigator.platform);
+
+ var MODIFIERS = {
+ alt: 'altKey',
+ control: 'ctrlKey',
+ meta: 'metaKey',
+ shift: 'shiftKey'
+ };
+
+ var ALIASES = {
+ add: '+',
+ break: 'pause',
+ cmd: 'meta',
+ command: 'meta',
+ ctl: 'control',
+ ctrl: 'control',
+ del: 'delete',
+ down: 'arrowdown',
+ esc: 'escape',
+ ins: 'insert',
+ left: 'arrowleft',
+ mod: IS_MAC ? 'meta' : 'control',
+ opt: 'alt',
+ option: 'alt',
+ return: 'enter',
+ right: 'arrowright',
+ space: ' ',
+ spacebar: ' ',
+ up: 'arrowup',
+ win: 'meta',
+ windows: 'meta'
+ };
+
+ var CODES = {
+ backspace: 8,
+ tab: 9,
+ enter: 13,
+ shift: 16,
+ control: 17,
+ alt: 18,
+ pause: 19,
+ capslock: 20,
+ escape: 27,
+ ' ': 32,
+ pageup: 33,
+ pagedown: 34,
+ end: 35,
+ home: 36,
+ arrowleft: 37,
+ arrowup: 38,
+ arrowright: 39,
+ arrowdown: 40,
+ insert: 45,
+ delete: 46,
+ meta: 91,
+ numlock: 144,
+ scrolllock: 145,
+ ';': 186,
+ '=': 187,
+ ',': 188,
+ '-': 189,
+ '.': 190,
+ '/': 191,
+ '`': 192,
+ '[': 219,
+ '\\': 220,
+ ']': 221,
+ '\'': 222
+ };
+
+ for (var f = 1; f < 20; f++) {
+ CODES['f' + f] = 111 + f;
+ }
+
+ /**
+ * Is hotkey?
+ */
+
+ function isHotkey(hotkey, options, event) {
+ if (options && !('byKey' in options)) {
+ event = options;
+ options = null;
+ }
+
+ if (!Array.isArray(hotkey)) {
+ hotkey = [hotkey];
+ }
+
+ var array = hotkey.map(function (string) {
+ return parseHotkey(string, options);
+ });
+ var check = function check(e) {
+ return array.some(function (object) {
+ return compareHotkey(object, e);
+ });
+ };
+ var ret = event == null ? check : check(event);
+ return ret;
+ }
+
+ function isCodeHotkey(hotkey, event) {
+ return isHotkey(hotkey, event);
+ }
+
+ function isKeyHotkey(hotkey, event) {
+ return isHotkey(hotkey, { byKey: true }, event);
+ }
+
+ /**
+ * Parse.
+ */
+
+ function parseHotkey(hotkey, options) {
+ var byKey = options && options.byKey;
+ var ret = {};
+
+ // Special case to handle the `+` key since we use it as a separator.
+ hotkey = hotkey.replace('++', '+add');
+ var values = hotkey.split('+');
+ var length = values.length;
+
+ // Ensure that all the modifiers are set to false unless the hotkey has them.
+
+ for (var k in MODIFIERS) {
+ ret[MODIFIERS[k]] = false;
+ }
+
+ var _iteratorNormalCompletion = true;
+ var _didIteratorError = false;
+ var _iteratorError = undefined;
+
+ try {
+ for (var _iterator = values[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
+ var value = _step.value;
+
+ var optional = value.endsWith('?') && value.length > 1;
+
+ if (optional) {
+ value = value.slice(0, -1);
+ }
+
+ var name = toKeyName(value);
+ var modifier = MODIFIERS[name];
+
+ if (value.length > 1 && !modifier && !ALIASES[value] && !CODES[name]) {
+ throw new TypeError('Unknown modifier: "' + value + '"');
+ }
+
+ if (length === 1 || !modifier) {
+ if (byKey) {
+ ret.key = name;
+ } else {
+ ret.which = toKeyCode(value);
+ }
+ }
+
+ if (modifier) {
+ ret[modifier] = optional ? null : true;
+ }
+ }
+ } catch (err) {
+ _didIteratorError = true;
+ _iteratorError = err;
+ } finally {
+ try {
+ if (!_iteratorNormalCompletion && _iterator.return) {
+ _iterator.return();
+ }
+ } finally {
+ if (_didIteratorError) {
+ throw _iteratorError;
+ }
+ }
+ }
+
+ return ret;
+ }
+
+ /**
+ * Compare.
+ */
+
+ function compareHotkey(object, event) {
+ for (var key in object) {
+ var expected = object[key];
+ var actual = void 0;
+
+ if (expected == null) {
+ continue;
+ }
+
+ if (key === 'key' && event.key != null) {
+ actual = event.key.toLowerCase();
+ } else if (key === 'which') {
+ actual = expected === 91 && event.which === 93 ? 91 : event.which;
+ } else {
+ actual = event[key];
+ }
+
+ if (actual == null && expected === false) {
+ continue;
+ }
+
+ if (actual !== expected) {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ /**
+ * Utils.
+ */
+
+ function toKeyCode(name) {
+ name = toKeyName(name);
+ var code = CODES[name] || name.toUpperCase().charCodeAt(0);
+ return code;
+ }
+
+ function toKeyName(name) {
+ name = name.toLowerCase();
+ name = ALIASES[name] || name;
+ return name;
+ }
+
+ /**
+ * Export.
+ */
+
+ var _default = isHotkey;
+ var isHotkey_1 = isHotkey;
+ var isCodeHotkey_1 = isCodeHotkey;
+ var isKeyHotkey_1 = isKeyHotkey;
+ var parseHotkey_1 = parseHotkey;
+ var compareHotkey_1 = compareHotkey;
+ var toKeyCode_1 = toKeyCode;
+ var toKeyName_1 = toKeyName;
+
+ var lib$4 = /*#__PURE__*/Object.defineProperty({
+ default: _default,
+ isHotkey: isHotkey_1,
+ isCodeHotkey: isCodeHotkey_1,
+ isKeyHotkey: isKeyHotkey_1,
+ parseHotkey: parseHotkey_1,
+ compareHotkey: compareHotkey_1,
+ toKeyCode: toKeyCode_1,
+ toKeyName: toKeyName_1
+ }, '__esModule', {value: true});
+
+ /**
+ * lodash (Custom Build)
+ * Build: `lodash modularize exports="npm" -o ./`
+ * Copyright jQuery Foundation and other contributors
+ * Released under MIT license
+ * Based on Underscore.js 1.8.3
+ * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
+ */
+
+ /** Used as the `TypeError` message for "Functions" methods. */
+ var FUNC_ERROR_TEXT = 'Expected a function';
+
+ /** Used as references for various `Number` constants. */
+ var NAN = 0 / 0;
+
+ /** `Object#toString` result references. */
+ var symbolTag = '[object Symbol]';
+
+ /** Used to match leading and trailing whitespace. */
+ var reTrim = /^\s+|\s+$/g;
+
+ /** Used to detect bad signed hexadecimal string values. */
+ var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;
+
+ /** Used to detect binary string values. */
+ var reIsBinary = /^0b[01]+$/i;
+
+ /** Used to detect octal string values. */
+ var reIsOctal = /^0o[0-7]+$/i;
+
+ /** Built-in method references without a dependency on `root`. */
+ var freeParseInt = parseInt;
+
+ /** Detect free variable `global` from Node.js. */
+ var freeGlobal = typeof commonjsGlobal == 'object' && commonjsGlobal && commonjsGlobal.Object === Object && commonjsGlobal;
+
+ /** Detect free variable `self`. */
+ var freeSelf = typeof self == 'object' && self && self.Object === Object && self;
+
+ /** Used as a reference to the global object. */
+ var root = freeGlobal || freeSelf || Function('return this')();
+
+ /** Used for built-in method references. */
+ var objectProto = Object.prototype;
+
+ /**
+ * Used to resolve the
+ * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
+ * of values.
+ */
+ var objectToString = objectProto.toString;
+
+ /* Built-in method references for those with the same name as other `lodash` methods. */
+ var nativeMax = Math.max,
+ nativeMin = Math.min;
+
+ /**
+ * Gets the timestamp of the number of milliseconds that have elapsed since
+ * the Unix epoch (1 January 1970 00:00:00 UTC).
+ *
+ * @static
+ * @memberOf _
+ * @since 2.4.0
+ * @category Date
+ * @returns {number} Returns the timestamp.
+ * @example
+ *
+ * _.defer(function(stamp) {
+ * console.log(_.now() - stamp);
+ * }, _.now());
+ * // => Logs the number of milliseconds it took for the deferred invocation.
+ */
+ var now = function() {
+ return root.Date.now();
+ };
+
+ /**
+ * Creates a debounced function that delays invoking `func` until after `wait`
+ * milliseconds have elapsed since the last time the debounced function was
+ * invoked. The debounced function comes with a `cancel` method to cancel
+ * delayed `func` invocations and a `flush` method to immediately invoke them.
+ * Provide `options` to indicate whether `func` should be invoked on the
+ * leading and/or trailing edge of the `wait` timeout. The `func` is invoked
+ * with the last arguments provided to the debounced function. Subsequent
+ * calls to the debounced function return the result of the last `func`
+ * invocation.
+ *
+ * **Note:** If `leading` and `trailing` options are `true`, `func` is
+ * invoked on the trailing edge of the timeout only if the debounced function
+ * is invoked more than once during the `wait` timeout.
+ *
+ * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred
+ * until to the next tick, similar to `setTimeout` with a timeout of `0`.
+ *
+ * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)
+ * for details over the differences between `_.debounce` and `_.throttle`.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Function
+ * @param {Function} func The function to debounce.
+ * @param {number} [wait=0] The number of milliseconds to delay.
+ * @param {Object} [options={}] The options object.
+ * @param {boolean} [options.leading=false]
+ * Specify invoking on the leading edge of the timeout.
+ * @param {number} [options.maxWait]
+ * The maximum time `func` is allowed to be delayed before it's invoked.
+ * @param {boolean} [options.trailing=true]
+ * Specify invoking on the trailing edge of the timeout.
+ * @returns {Function} Returns the new debounced function.
+ * @example
+ *
+ * // Avoid costly calculations while the window size is in flux.
+ * jQuery(window).on('resize', _.debounce(calculateLayout, 150));
+ *
+ * // Invoke `sendMail` when clicked, debouncing subsequent calls.
+ * jQuery(element).on('click', _.debounce(sendMail, 300, {
+ * 'leading': true,
+ * 'trailing': false
+ * }));
+ *
+ * // Ensure `batchLog` is invoked once after 1 second of debounced calls.
+ * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });
+ * var source = new EventSource('/stream');
+ * jQuery(source).on('message', debounced);
+ *
+ * // Cancel the trailing debounced invocation.
+ * jQuery(window).on('popstate', debounced.cancel);
+ */
+ function debounce$1(func, wait, options) {
+ var lastArgs,
+ lastThis,
+ maxWait,
+ result,
+ timerId,
+ lastCallTime,
+ lastInvokeTime = 0,
+ leading = false,
+ maxing = false,
+ trailing = true;
+
+ if (typeof func != 'function') {
+ throw new TypeError(FUNC_ERROR_TEXT);
+ }
+ wait = toNumber(wait) || 0;
+ if (isObject(options)) {
+ leading = !!options.leading;
+ maxing = 'maxWait' in options;
+ maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;
+ trailing = 'trailing' in options ? !!options.trailing : trailing;
+ }
+
+ function invokeFunc(time) {
+ var args = lastArgs,
+ thisArg = lastThis;
+
+ lastArgs = lastThis = undefined;
+ lastInvokeTime = time;
+ result = func.apply(thisArg, args);
+ return result;
+ }
+
+ function leadingEdge(time) {
+ // Reset any `maxWait` timer.
+ lastInvokeTime = time;
+ // Start the timer for the trailing edge.
+ timerId = setTimeout(timerExpired, wait);
+ // Invoke the leading edge.
+ return leading ? invokeFunc(time) : result;
+ }
+
+ function remainingWait(time) {
+ var timeSinceLastCall = time - lastCallTime,
+ timeSinceLastInvoke = time - lastInvokeTime,
+ result = wait - timeSinceLastCall;
+
+ return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result;
+ }
+
+ function shouldInvoke(time) {
+ var timeSinceLastCall = time - lastCallTime,
+ timeSinceLastInvoke = time - lastInvokeTime;
+
+ // Either this is the first call, activity has stopped and we're at the
+ // trailing edge, the system time has gone backwards and we're treating
+ // it as the trailing edge, or we've hit the `maxWait` limit.
+ return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||
+ (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));
+ }
+
+ function timerExpired() {
+ var time = now();
+ if (shouldInvoke(time)) {
+ return trailingEdge(time);
+ }
+ // Restart the timer.
+ timerId = setTimeout(timerExpired, remainingWait(time));
+ }
+
+ function trailingEdge(time) {
+ timerId = undefined;
+
+ // Only invoke if we have `lastArgs` which means `func` has been
+ // debounced at least once.
+ if (trailing && lastArgs) {
+ return invokeFunc(time);
+ }
+ lastArgs = lastThis = undefined;
+ return result;
+ }
+
+ function cancel() {
+ if (timerId !== undefined) {
+ clearTimeout(timerId);
+ }
+ lastInvokeTime = 0;
+ lastArgs = lastCallTime = lastThis = timerId = undefined;
+ }
+
+ function flush() {
+ return timerId === undefined ? result : trailingEdge(now());
+ }
+
+ function debounced() {
+ var time = now(),
+ isInvoking = shouldInvoke(time);
+
+ lastArgs = arguments;
+ lastThis = this;
+ lastCallTime = time;
+
+ if (isInvoking) {
+ if (timerId === undefined) {
+ return leadingEdge(lastCallTime);
+ }
+ if (maxing) {
+ // Handle invocations in a tight loop.
+ timerId = setTimeout(timerExpired, wait);
+ return invokeFunc(lastCallTime);
+ }
+ }
+ if (timerId === undefined) {
+ timerId = setTimeout(timerExpired, wait);
+ }
+ return result;
+ }
+ debounced.cancel = cancel;
+ debounced.flush = flush;
+ return debounced;
+ }
+
+ /**
+ * Checks if `value` is the
+ * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
+ * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an object, else `false`.
+ * @example
+ *
+ * _.isObject({});
+ * // => true
+ *
+ * _.isObject([1, 2, 3]);
+ * // => true
+ *
+ * _.isObject(_.noop);
+ * // => true
+ *
+ * _.isObject(null);
+ * // => false
+ */
+ function isObject(value) {
+ var type = typeof value;
+ return !!value && (type == 'object' || type == 'function');
+ }
+
+ /**
+ * Checks if `value` is object-like. A value is object-like if it's not `null`
+ * and has a `typeof` result of "object".
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
+ * @example
+ *
+ * _.isObjectLike({});
+ * // => true
+ *
+ * _.isObjectLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isObjectLike(_.noop);
+ * // => false
+ *
+ * _.isObjectLike(null);
+ * // => false
+ */
+ function isObjectLike(value) {
+ return !!value && typeof value == 'object';
+ }
+
+ /**
+ * Checks if `value` is classified as a `Symbol` primitive or object.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.
+ * @example
+ *
+ * _.isSymbol(Symbol.iterator);
+ * // => true
+ *
+ * _.isSymbol('abc');
+ * // => false
+ */
+ function isSymbol(value) {
+ return typeof value == 'symbol' ||
+ (isObjectLike(value) && objectToString.call(value) == symbolTag);
+ }
+
+ /**
+ * Converts `value` to a number.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to process.
+ * @returns {number} Returns the number.
+ * @example
+ *
+ * _.toNumber(3.2);
+ * // => 3.2
+ *
+ * _.toNumber(Number.MIN_VALUE);
+ * // => 5e-324
+ *
+ * _.toNumber(Infinity);
+ * // => Infinity
+ *
+ * _.toNumber('3.2');
+ * // => 3.2
+ */
+ function toNumber(value) {
+ if (typeof value == 'number') {
+ return value;
+ }
+ if (isSymbol(value)) {
+ return NAN;
+ }
+ if (isObject(value)) {
+ var other = typeof value.valueOf == 'function' ? value.valueOf() : value;
+ value = isObject(other) ? (other + '') : other;
+ }
+ if (typeof value != 'string') {
+ return value === 0 ? value : +value;
+ }
+ value = value.replace(reTrim, '');
+ var isBinary = reIsBinary.test(value);
+ return (isBinary || reIsOctal.test(value))
+ ? freeParseInt(value.slice(2), isBinary ? 2 : 8)
+ : (reIsBadHex.test(value) ? NAN : +value);
+ }
+
+ var lodash_debounce = debounce$1;
+
+ /**
+ * lodash (Custom Build)
+ * Build: `lodash modularize exports="npm" -o ./`
+ * Copyright jQuery Foundation and other contributors
+ * Released under MIT license
+ * Based on Underscore.js 1.8.3
+ * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
+ */
+
+ var lodash_clonedeep = createCommonjsModule$1(function (module, exports) {
+ /** Used as the size to enable large array optimizations. */
+ var LARGE_ARRAY_SIZE = 200;
+
+ /** Used to stand-in for `undefined` hash values. */
+ var HASH_UNDEFINED = '__lodash_hash_undefined__';
+
+ /** Used as references for various `Number` constants. */
+ var MAX_SAFE_INTEGER = 9007199254740991;
+
+ /** `Object#toString` result references. */
+ var argsTag = '[object Arguments]',
+ arrayTag = '[object Array]',
+ boolTag = '[object Boolean]',
+ dateTag = '[object Date]',
+ errorTag = '[object Error]',
+ funcTag = '[object Function]',
+ genTag = '[object GeneratorFunction]',
+ mapTag = '[object Map]',
+ numberTag = '[object Number]',
+ objectTag = '[object Object]',
+ promiseTag = '[object Promise]',
+ regexpTag = '[object RegExp]',
+ setTag = '[object Set]',
+ stringTag = '[object String]',
+ symbolTag = '[object Symbol]',
+ weakMapTag = '[object WeakMap]';
+
+ var arrayBufferTag = '[object ArrayBuffer]',
+ dataViewTag = '[object DataView]',
+ float32Tag = '[object Float32Array]',
+ float64Tag = '[object Float64Array]',
+ int8Tag = '[object Int8Array]',
+ int16Tag = '[object Int16Array]',
+ int32Tag = '[object Int32Array]',
+ uint8Tag = '[object Uint8Array]',
+ uint8ClampedTag = '[object Uint8ClampedArray]',
+ uint16Tag = '[object Uint16Array]',
+ uint32Tag = '[object Uint32Array]';
+
+ /**
+ * Used to match `RegExp`
+ * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).
+ */
+ var reRegExpChar = /[\\^$.*+?()[\]{}|]/g;
+
+ /** Used to match `RegExp` flags from their coerced string values. */
+ var reFlags = /\w*$/;
+
+ /** Used to detect host constructors (Safari). */
+ var reIsHostCtor = /^\[object .+?Constructor\]$/;
+
+ /** Used to detect unsigned integer values. */
+ var reIsUint = /^(?:0|[1-9]\d*)$/;
+
+ /** Used to identify `toStringTag` values supported by `_.clone`. */
+ var cloneableTags = {};
+ cloneableTags[argsTag] = cloneableTags[arrayTag] =
+ cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =
+ cloneableTags[boolTag] = cloneableTags[dateTag] =
+ cloneableTags[float32Tag] = cloneableTags[float64Tag] =
+ cloneableTags[int8Tag] = cloneableTags[int16Tag] =
+ cloneableTags[int32Tag] = cloneableTags[mapTag] =
+ cloneableTags[numberTag] = cloneableTags[objectTag] =
+ cloneableTags[regexpTag] = cloneableTags[setTag] =
+ cloneableTags[stringTag] = cloneableTags[symbolTag] =
+ cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =
+ cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;
+ cloneableTags[errorTag] = cloneableTags[funcTag] =
+ cloneableTags[weakMapTag] = false;
+
+ /** Detect free variable `global` from Node.js. */
+ var freeGlobal = typeof commonjsGlobal == 'object' && commonjsGlobal && commonjsGlobal.Object === Object && commonjsGlobal;
+
+ /** Detect free variable `self`. */
+ var freeSelf = typeof self == 'object' && self && self.Object === Object && self;
+
+ /** Used as a reference to the global object. */
+ var root = freeGlobal || freeSelf || Function('return this')();
+
+ /** Detect free variable `exports`. */
+ var freeExports = exports && !exports.nodeType && exports;
+
+ /** Detect free variable `module`. */
+ var freeModule = freeExports && 'object' == 'object' && module && !module.nodeType && module;
+
+ /** Detect the popular CommonJS extension `module.exports`. */
+ var moduleExports = freeModule && freeModule.exports === freeExports;
+
+ /**
+ * Adds the key-value `pair` to `map`.
+ *
+ * @private
+ * @param {Object} map The map to modify.
+ * @param {Array} pair The key-value pair to add.
+ * @returns {Object} Returns `map`.
+ */
+ function addMapEntry(map, pair) {
+ // Don't return `map.set` because it's not chainable in IE 11.
+ map.set(pair[0], pair[1]);
+ return map;
+ }
+
+ /**
+ * Adds `value` to `set`.
+ *
+ * @private
+ * @param {Object} set The set to modify.
+ * @param {*} value The value to add.
+ * @returns {Object} Returns `set`.
+ */
+ function addSetEntry(set, value) {
+ // Don't return `set.add` because it's not chainable in IE 11.
+ set.add(value);
+ return set;
+ }
+
+ /**
+ * A specialized version of `_.forEach` for arrays without support for
+ * iteratee shorthands.
+ *
+ * @private
+ * @param {Array} [array] The array to iterate over.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @returns {Array} Returns `array`.
+ */
+ function arrayEach(array, iteratee) {
+ var index = -1,
+ length = array ? array.length : 0;
+
+ while (++index < length) {
+ if (iteratee(array[index], index, array) === false) {
+ break;
+ }
+ }
+ return array;
+ }
+
+ /**
+ * Appends the elements of `values` to `array`.
+ *
+ * @private
+ * @param {Array} array The array to modify.
+ * @param {Array} values The values to append.
+ * @returns {Array} Returns `array`.
+ */
+ function arrayPush(array, values) {
+ var index = -1,
+ length = values.length,
+ offset = array.length;
+
+ while (++index < length) {
+ array[offset + index] = values[index];
+ }
+ return array;
+ }
+
+ /**
+ * A specialized version of `_.reduce` for arrays without support for
+ * iteratee shorthands.
+ *
+ * @private
+ * @param {Array} [array] The array to iterate over.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @param {*} [accumulator] The initial value.
+ * @param {boolean} [initAccum] Specify using the first element of `array` as
+ * the initial value.
+ * @returns {*} Returns the accumulated value.
+ */
+ function arrayReduce(array, iteratee, accumulator, initAccum) {
+ var index = -1,
+ length = array ? array.length : 0;
+
+ if (initAccum && length) {
+ accumulator = array[++index];
+ }
+ while (++index < length) {
+ accumulator = iteratee(accumulator, array[index], index, array);
+ }
+ return accumulator;
+ }
+
+ /**
+ * The base implementation of `_.times` without support for iteratee shorthands
+ * or max array length checks.
+ *
+ * @private
+ * @param {number} n The number of times to invoke `iteratee`.
+ * @param {Function} iteratee The function invoked per iteration.
+ * @returns {Array} Returns the array of results.
+ */
+ function baseTimes(n, iteratee) {
+ var index = -1,
+ result = Array(n);
+
+ while (++index < n) {
+ result[index] = iteratee(index);
+ }
+ return result;
+ }
+
+ /**
+ * Gets the value at `key` of `object`.
+ *
+ * @private
+ * @param {Object} [object] The object to query.
+ * @param {string} key The key of the property to get.
+ * @returns {*} Returns the property value.
+ */
+ function getValue(object, key) {
+ return object == null ? undefined : object[key];
+ }
+
+ /**
+ * Checks if `value` is a host object in IE < 9.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a host object, else `false`.
+ */
+ function isHostObject(value) {
+ // Many host objects are `Object` objects that can coerce to strings
+ // despite having improperly defined `toString` methods.
+ var result = false;
+ if (value != null && typeof value.toString != 'function') {
+ try {
+ result = !!(value + '');
+ } catch (e) {}
+ }
+ return result;
+ }
+
+ /**
+ * Converts `map` to its key-value pairs.
+ *
+ * @private
+ * @param {Object} map The map to convert.
+ * @returns {Array} Returns the key-value pairs.
+ */
+ function mapToArray(map) {
+ var index = -1,
+ result = Array(map.size);
+
+ map.forEach(function(value, key) {
+ result[++index] = [key, value];
+ });
+ return result;
+ }
+
+ /**
+ * Creates a unary function that invokes `func` with its argument transformed.
+ *
+ * @private
+ * @param {Function} func The function to wrap.
+ * @param {Function} transform The argument transform.
+ * @returns {Function} Returns the new function.
+ */
+ function overArg(func, transform) {
+ return function(arg) {
+ return func(transform(arg));
+ };
+ }
+
+ /**
+ * Converts `set` to an array of its values.
+ *
+ * @private
+ * @param {Object} set The set to convert.
+ * @returns {Array} Returns the values.
+ */
+ function setToArray(set) {
+ var index = -1,
+ result = Array(set.size);
+
+ set.forEach(function(value) {
+ result[++index] = value;
+ });
+ return result;
+ }
+
+ /** Used for built-in method references. */
+ var arrayProto = Array.prototype,
+ funcProto = Function.prototype,
+ objectProto = Object.prototype;
+
+ /** Used to detect overreaching core-js shims. */
+ var coreJsData = root['__core-js_shared__'];
+
+ /** Used to detect methods masquerading as native. */
+ var maskSrcKey = (function() {
+ var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');
+ return uid ? ('Symbol(src)_1.' + uid) : '';
+ }());
+
+ /** Used to resolve the decompiled source of functions. */
+ var funcToString = funcProto.toString;
+
+ /** Used to check objects for own properties. */
+ var hasOwnProperty = objectProto.hasOwnProperty;
+
+ /**
+ * Used to resolve the
+ * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
+ * of values.
+ */
+ var objectToString = objectProto.toString;
+
+ /** Used to detect if a method is native. */
+ var reIsNative = RegExp('^' +
+ funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&')
+ .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$'
+ );
+
+ /** Built-in value references. */
+ var Buffer = moduleExports ? root.Buffer : undefined,
+ Symbol = root.Symbol,
+ Uint8Array = root.Uint8Array,
+ getPrototype = overArg(Object.getPrototypeOf, Object),
+ objectCreate = Object.create,
+ propertyIsEnumerable = objectProto.propertyIsEnumerable,
+ splice = arrayProto.splice;
+
+ /* Built-in method references for those with the same name as other `lodash` methods. */
+ var nativeGetSymbols = Object.getOwnPropertySymbols,
+ nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,
+ nativeKeys = overArg(Object.keys, Object);
+
+ /* Built-in method references that are verified to be native. */
+ var DataView = getNative(root, 'DataView'),
+ Map = getNative(root, 'Map'),
+ Promise = getNative(root, 'Promise'),
+ Set = getNative(root, 'Set'),
+ WeakMap = getNative(root, 'WeakMap'),
+ nativeCreate = getNative(Object, 'create');
+
+ /** Used to detect maps, sets, and weakmaps. */
+ var dataViewCtorString = toSource(DataView),
+ mapCtorString = toSource(Map),
+ promiseCtorString = toSource(Promise),
+ setCtorString = toSource(Set),
+ weakMapCtorString = toSource(WeakMap);
+
+ /** Used to convert symbols to primitives and strings. */
+ var symbolProto = Symbol ? Symbol.prototype : undefined,
+ symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;
+
+ /**
+ * Creates a hash object.
+ *
+ * @private
+ * @constructor
+ * @param {Array} [entries] The key-value pairs to cache.
+ */
+ function Hash(entries) {
+ var index = -1,
+ length = entries ? entries.length : 0;
+
+ this.clear();
+ while (++index < length) {
+ var entry = entries[index];
+ this.set(entry[0], entry[1]);
+ }
+ }
+
+ /**
+ * Removes all key-value entries from the hash.
+ *
+ * @private
+ * @name clear
+ * @memberOf Hash
+ */
+ function hashClear() {
+ this.__data__ = nativeCreate ? nativeCreate(null) : {};
+ }
+
+ /**
+ * Removes `key` and its value from the hash.
+ *
+ * @private
+ * @name delete
+ * @memberOf Hash
+ * @param {Object} hash The hash to modify.
+ * @param {string} key The key of the value to remove.
+ * @returns {boolean} Returns `true` if the entry was removed, else `false`.
+ */
+ function hashDelete(key) {
+ return this.has(key) && delete this.__data__[key];
+ }
+
+ /**
+ * Gets the hash value for `key`.
+ *
+ * @private
+ * @name get
+ * @memberOf Hash
+ * @param {string} key The key of the value to get.
+ * @returns {*} Returns the entry value.
+ */
+ function hashGet(key) {
+ var data = this.__data__;
+ if (nativeCreate) {
+ var result = data[key];
+ return result === HASH_UNDEFINED ? undefined : result;
+ }
+ return hasOwnProperty.call(data, key) ? data[key] : undefined;
+ }
+
+ /**
+ * Checks if a hash value for `key` exists.
+ *
+ * @private
+ * @name has
+ * @memberOf Hash
+ * @param {string} key The key of the entry to check.
+ * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
+ */
+ function hashHas(key) {
+ var data = this.__data__;
+ return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key);
+ }
+
+ /**
+ * Sets the hash `key` to `value`.
+ *
+ * @private
+ * @name set
+ * @memberOf Hash
+ * @param {string} key The key of the value to set.
+ * @param {*} value The value to set.
+ * @returns {Object} Returns the hash instance.
+ */
+ function hashSet(key, value) {
+ var data = this.__data__;
+ data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;
+ return this;
+ }
+
+ // Add methods to `Hash`.
+ Hash.prototype.clear = hashClear;
+ Hash.prototype['delete'] = hashDelete;
+ Hash.prototype.get = hashGet;
+ Hash.prototype.has = hashHas;
+ Hash.prototype.set = hashSet;
+
+ /**
+ * Creates an list cache object.
+ *
+ * @private
+ * @constructor
+ * @param {Array} [entries] The key-value pairs to cache.
+ */
+ function ListCache(entries) {
+ var index = -1,
+ length = entries ? entries.length : 0;
+
+ this.clear();
+ while (++index < length) {
+ var entry = entries[index];
+ this.set(entry[0], entry[1]);
+ }
+ }
+
+ /**
+ * Removes all key-value entries from the list cache.
+ *
+ * @private
+ * @name clear
+ * @memberOf ListCache
+ */
+ function listCacheClear() {
+ this.__data__ = [];
+ }
+
+ /**
+ * Removes `key` and its value from the list cache.
+ *
+ * @private
+ * @name delete
+ * @memberOf ListCache
+ * @param {string} key The key of the value to remove.
+ * @returns {boolean} Returns `true` if the entry was removed, else `false`.
+ */
+ function listCacheDelete(key) {
+ var data = this.__data__,
+ index = assocIndexOf(data, key);
+
+ if (index < 0) {
+ return false;
+ }
+ var lastIndex = data.length - 1;
+ if (index == lastIndex) {
+ data.pop();
+ } else {
+ splice.call(data, index, 1);
+ }
+ return true;
+ }
+
+ /**
+ * Gets the list cache value for `key`.
+ *
+ * @private
+ * @name get
+ * @memberOf ListCache
+ * @param {string} key The key of the value to get.
+ * @returns {*} Returns the entry value.
+ */
+ function listCacheGet(key) {
+ var data = this.__data__,
+ index = assocIndexOf(data, key);
+
+ return index < 0 ? undefined : data[index][1];
+ }
+
+ /**
+ * Checks if a list cache value for `key` exists.
+ *
+ * @private
+ * @name has
+ * @memberOf ListCache
+ * @param {string} key The key of the entry to check.
+ * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
+ */
+ function listCacheHas(key) {
+ return assocIndexOf(this.__data__, key) > -1;
+ }
+
+ /**
+ * Sets the list cache `key` to `value`.
+ *
+ * @private
+ * @name set
+ * @memberOf ListCache
+ * @param {string} key The key of the value to set.
+ * @param {*} value The value to set.
+ * @returns {Object} Returns the list cache instance.
+ */
+ function listCacheSet(key, value) {
+ var data = this.__data__,
+ index = assocIndexOf(data, key);
+
+ if (index < 0) {
+ data.push([key, value]);
+ } else {
+ data[index][1] = value;
+ }
+ return this;
+ }
+
+ // Add methods to `ListCache`.
+ ListCache.prototype.clear = listCacheClear;
+ ListCache.prototype['delete'] = listCacheDelete;
+ ListCache.prototype.get = listCacheGet;
+ ListCache.prototype.has = listCacheHas;
+ ListCache.prototype.set = listCacheSet;
+
+ /**
+ * Creates a map cache object to store key-value pairs.
+ *
+ * @private
+ * @constructor
+ * @param {Array} [entries] The key-value pairs to cache.
+ */
+ function MapCache(entries) {
+ var index = -1,
+ length = entries ? entries.length : 0;
+
+ this.clear();
+ while (++index < length) {
+ var entry = entries[index];
+ this.set(entry[0], entry[1]);
+ }
+ }
+
+ /**
+ * Removes all key-value entries from the map.
+ *
+ * @private
+ * @name clear
+ * @memberOf MapCache
+ */
+ function mapCacheClear() {
+ this.__data__ = {
+ 'hash': new Hash,
+ 'map': new (Map || ListCache),
+ 'string': new Hash
+ };
+ }
+
+ /**
+ * Removes `key` and its value from the map.
+ *
+ * @private
+ * @name delete
+ * @memberOf MapCache
+ * @param {string} key The key of the value to remove.
+ * @returns {boolean} Returns `true` if the entry was removed, else `false`.
+ */
+ function mapCacheDelete(key) {
+ return getMapData(this, key)['delete'](key);
+ }
+
+ /**
+ * Gets the map value for `key`.
+ *
+ * @private
+ * @name get
+ * @memberOf MapCache
+ * @param {string} key The key of the value to get.
+ * @returns {*} Returns the entry value.
+ */
+ function mapCacheGet(key) {
+ return getMapData(this, key).get(key);
+ }
+
+ /**
+ * Checks if a map value for `key` exists.
+ *
+ * @private
+ * @name has
+ * @memberOf MapCache
+ * @param {string} key The key of the entry to check.
+ * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
+ */
+ function mapCacheHas(key) {
+ return getMapData(this, key).has(key);
+ }
+
+ /**
+ * Sets the map `key` to `value`.
+ *
+ * @private
+ * @name set
+ * @memberOf MapCache
+ * @param {string} key The key of the value to set.
+ * @param {*} value The value to set.
+ * @returns {Object} Returns the map cache instance.
+ */
+ function mapCacheSet(key, value) {
+ getMapData(this, key).set(key, value);
+ return this;
+ }
+
+ // Add methods to `MapCache`.
+ MapCache.prototype.clear = mapCacheClear;
+ MapCache.prototype['delete'] = mapCacheDelete;
+ MapCache.prototype.get = mapCacheGet;
+ MapCache.prototype.has = mapCacheHas;
+ MapCache.prototype.set = mapCacheSet;
+
+ /**
+ * Creates a stack cache object to store key-value pairs.
+ *
+ * @private
+ * @constructor
+ * @param {Array} [entries] The key-value pairs to cache.
+ */
+ function Stack(entries) {
+ this.__data__ = new ListCache(entries);
+ }
+
+ /**
+ * Removes all key-value entries from the stack.
+ *
+ * @private
+ * @name clear
+ * @memberOf Stack
+ */
+ function stackClear() {
+ this.__data__ = new ListCache;
+ }
+
+ /**
+ * Removes `key` and its value from the stack.
+ *
+ * @private
+ * @name delete
+ * @memberOf Stack
+ * @param {string} key The key of the value to remove.
+ * @returns {boolean} Returns `true` if the entry was removed, else `false`.
+ */
+ function stackDelete(key) {
+ return this.__data__['delete'](key);
+ }
+
+ /**
+ * Gets the stack value for `key`.
+ *
+ * @private
+ * @name get
+ * @memberOf Stack
+ * @param {string} key The key of the value to get.
+ * @returns {*} Returns the entry value.
+ */
+ function stackGet(key) {
+ return this.__data__.get(key);
+ }
+
+ /**
+ * Checks if a stack value for `key` exists.
+ *
+ * @private
+ * @name has
+ * @memberOf Stack
+ * @param {string} key The key of the entry to check.
+ * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
+ */
+ function stackHas(key) {
+ return this.__data__.has(key);
+ }
+
+ /**
+ * Sets the stack `key` to `value`.
+ *
+ * @private
+ * @name set
+ * @memberOf Stack
+ * @param {string} key The key of the value to set.
+ * @param {*} value The value to set.
+ * @returns {Object} Returns the stack cache instance.
+ */
+ function stackSet(key, value) {
+ var cache = this.__data__;
+ if (cache instanceof ListCache) {
+ var pairs = cache.__data__;
+ if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {
+ pairs.push([key, value]);
+ return this;
+ }
+ cache = this.__data__ = new MapCache(pairs);
+ }
+ cache.set(key, value);
+ return this;
+ }
+
+ // Add methods to `Stack`.
+ Stack.prototype.clear = stackClear;
+ Stack.prototype['delete'] = stackDelete;
+ Stack.prototype.get = stackGet;
+ Stack.prototype.has = stackHas;
+ Stack.prototype.set = stackSet;
+
+ /**
+ * Creates an array of the enumerable property names of the array-like `value`.
+ *
+ * @private
+ * @param {*} value The value to query.
+ * @param {boolean} inherited Specify returning inherited property names.
+ * @returns {Array} Returns the array of property names.
+ */
+ function arrayLikeKeys(value, inherited) {
+ // Safari 8.1 makes `arguments.callee` enumerable in strict mode.
+ // Safari 9 makes `arguments.length` enumerable in strict mode.
+ var result = (isArray(value) || isArguments(value))
+ ? baseTimes(value.length, String)
+ : [];
+
+ var length = result.length,
+ skipIndexes = !!length;
+
+ for (var key in value) {
+ if ((inherited || hasOwnProperty.call(value, key)) &&
+ !(skipIndexes && (key == 'length' || isIndex(key, length)))) {
+ result.push(key);
+ }
+ }
+ return result;
+ }
+
+ /**
+ * Assigns `value` to `key` of `object` if the existing value is not equivalent
+ * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
+ * for equality comparisons.
+ *
+ * @private
+ * @param {Object} object The object to modify.
+ * @param {string} key The key of the property to assign.
+ * @param {*} value The value to assign.
+ */
+ function assignValue(object, key, value) {
+ var objValue = object[key];
+ if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||
+ (value === undefined && !(key in object))) {
+ object[key] = value;
+ }
+ }
+
+ /**
+ * Gets the index at which the `key` is found in `array` of key-value pairs.
+ *
+ * @private
+ * @param {Array} array The array to inspect.
+ * @param {*} key The key to search for.
+ * @returns {number} Returns the index of the matched value, else `-1`.
+ */
+ function assocIndexOf(array, key) {
+ var length = array.length;
+ while (length--) {
+ if (eq(array[length][0], key)) {
+ return length;
+ }
+ }
+ return -1;
+ }
+
+ /**
+ * The base implementation of `_.assign` without support for multiple sources
+ * or `customizer` functions.
+ *
+ * @private
+ * @param {Object} object The destination object.
+ * @param {Object} source The source object.
+ * @returns {Object} Returns `object`.
+ */
+ function baseAssign(object, source) {
+ return object && copyObject(source, keys(source), object);
+ }
+
+ /**
+ * The base implementation of `_.clone` and `_.cloneDeep` which tracks
+ * traversed objects.
+ *
+ * @private
+ * @param {*} value The value to clone.
+ * @param {boolean} [isDeep] Specify a deep clone.
+ * @param {boolean} [isFull] Specify a clone including symbols.
+ * @param {Function} [customizer] The function to customize cloning.
+ * @param {string} [key] The key of `value`.
+ * @param {Object} [object] The parent object of `value`.
+ * @param {Object} [stack] Tracks traversed objects and their clone counterparts.
+ * @returns {*} Returns the cloned value.
+ */
+ function baseClone(value, isDeep, isFull, customizer, key, object, stack) {
+ var result;
+ if (customizer) {
+ result = object ? customizer(value, key, object, stack) : customizer(value);
+ }
+ if (result !== undefined) {
+ return result;
+ }
+ if (!isObject(value)) {
+ return value;
+ }
+ var isArr = isArray(value);
+ if (isArr) {
+ result = initCloneArray(value);
+ if (!isDeep) {
+ return copyArray(value, result);
+ }
+ } else {
+ var tag = getTag(value),
+ isFunc = tag == funcTag || tag == genTag;
+
+ if (isBuffer(value)) {
+ return cloneBuffer(value, isDeep);
+ }
+ if (tag == objectTag || tag == argsTag || (isFunc && !object)) {
+ if (isHostObject(value)) {
+ return object ? value : {};
+ }
+ result = initCloneObject(isFunc ? {} : value);
+ if (!isDeep) {
+ return copySymbols(value, baseAssign(result, value));
+ }
+ } else {
+ if (!cloneableTags[tag]) {
+ return object ? value : {};
+ }
+ result = initCloneByTag(value, tag, baseClone, isDeep);
+ }
+ }
+ // Check for circular references and return its corresponding clone.
+ stack || (stack = new Stack);
+ var stacked = stack.get(value);
+ if (stacked) {
+ return stacked;
+ }
+ stack.set(value, result);
+
+ if (!isArr) {
+ var props = isFull ? getAllKeys(value) : keys(value);
+ }
+ arrayEach(props || value, function(subValue, key) {
+ if (props) {
+ key = subValue;
+ subValue = value[key];
+ }
+ // Recursively populate clone (susceptible to call stack limits).
+ assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack));
+ });
+ return result;
+ }
+
+ /**
+ * The base implementation of `_.create` without support for assigning
+ * properties to the created object.
+ *
+ * @private
+ * @param {Object} prototype The object to inherit from.
+ * @returns {Object} Returns the new object.
+ */
+ function baseCreate(proto) {
+ return isObject(proto) ? objectCreate(proto) : {};
+ }
+
+ /**
+ * The base implementation of `getAllKeys` and `getAllKeysIn` which uses
+ * `keysFunc` and `symbolsFunc` to get the enumerable property names and
+ * symbols of `object`.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @param {Function} keysFunc The function to get the keys of `object`.
+ * @param {Function} symbolsFunc The function to get the symbols of `object`.
+ * @returns {Array} Returns the array of property names and symbols.
+ */
+ function baseGetAllKeys(object, keysFunc, symbolsFunc) {
+ var result = keysFunc(object);
+ return isArray(object) ? result : arrayPush(result, symbolsFunc(object));
+ }
+
+ /**
+ * The base implementation of `getTag`.
+ *
+ * @private
+ * @param {*} value The value to query.
+ * @returns {string} Returns the `toStringTag`.
+ */
+ function baseGetTag(value) {
+ return objectToString.call(value);
+ }
+
+ /**
+ * The base implementation of `_.isNative` without bad shim checks.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a native function,
+ * else `false`.
+ */
+ function baseIsNative(value) {
+ if (!isObject(value) || isMasked(value)) {
+ return false;
+ }
+ var pattern = (isFunction(value) || isHostObject(value)) ? reIsNative : reIsHostCtor;
+ return pattern.test(toSource(value));
+ }
+
+ /**
+ * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @returns {Array} Returns the array of property names.
+ */
+ function baseKeys(object) {
+ if (!isPrototype(object)) {
+ return nativeKeys(object);
+ }
+ var result = [];
+ for (var key in Object(object)) {
+ if (hasOwnProperty.call(object, key) && key != 'constructor') {
+ result.push(key);
+ }
+ }
+ return result;
+ }
+
+ /**
+ * Creates a clone of `buffer`.
+ *
+ * @private
+ * @param {Buffer} buffer The buffer to clone.
+ * @param {boolean} [isDeep] Specify a deep clone.
+ * @returns {Buffer} Returns the cloned buffer.
+ */
+ function cloneBuffer(buffer, isDeep) {
+ if (isDeep) {
+ return buffer.slice();
+ }
+ var result = new buffer.constructor(buffer.length);
+ buffer.copy(result);
+ return result;
+ }
+
+ /**
+ * Creates a clone of `arrayBuffer`.
+ *
+ * @private
+ * @param {ArrayBuffer} arrayBuffer The array buffer to clone.
+ * @returns {ArrayBuffer} Returns the cloned array buffer.
+ */
+ function cloneArrayBuffer(arrayBuffer) {
+ var result = new arrayBuffer.constructor(arrayBuffer.byteLength);
+ new Uint8Array(result).set(new Uint8Array(arrayBuffer));
+ return result;
+ }
+
+ /**
+ * Creates a clone of `dataView`.
+ *
+ * @private
+ * @param {Object} dataView The data view to clone.
+ * @param {boolean} [isDeep] Specify a deep clone.
+ * @returns {Object} Returns the cloned data view.
+ */
+ function cloneDataView(dataView, isDeep) {
+ var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;
+ return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);
+ }
+
+ /**
+ * Creates a clone of `map`.
+ *
+ * @private
+ * @param {Object} map The map to clone.
+ * @param {Function} cloneFunc The function to clone values.
+ * @param {boolean} [isDeep] Specify a deep clone.
+ * @returns {Object} Returns the cloned map.
+ */
+ function cloneMap(map, isDeep, cloneFunc) {
+ var array = isDeep ? cloneFunc(mapToArray(map), true) : mapToArray(map);
+ return arrayReduce(array, addMapEntry, new map.constructor);
+ }
+
+ /**
+ * Creates a clone of `regexp`.
+ *
+ * @private
+ * @param {Object} regexp The regexp to clone.
+ * @returns {Object} Returns the cloned regexp.
+ */
+ function cloneRegExp(regexp) {
+ var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));
+ result.lastIndex = regexp.lastIndex;
+ return result;
+ }
+
+ /**
+ * Creates a clone of `set`.
+ *
+ * @private
+ * @param {Object} set The set to clone.
+ * @param {Function} cloneFunc The function to clone values.
+ * @param {boolean} [isDeep] Specify a deep clone.
+ * @returns {Object} Returns the cloned set.
+ */
+ function cloneSet(set, isDeep, cloneFunc) {
+ var array = isDeep ? cloneFunc(setToArray(set), true) : setToArray(set);
+ return arrayReduce(array, addSetEntry, new set.constructor);
+ }
+
+ /**
+ * Creates a clone of the `symbol` object.
+ *
+ * @private
+ * @param {Object} symbol The symbol object to clone.
+ * @returns {Object} Returns the cloned symbol object.
+ */
+ function cloneSymbol(symbol) {
+ return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};
+ }
+
+ /**
+ * Creates a clone of `typedArray`.
+ *
+ * @private
+ * @param {Object} typedArray The typed array to clone.
+ * @param {boolean} [isDeep] Specify a deep clone.
+ * @returns {Object} Returns the cloned typed array.
+ */
+ function cloneTypedArray(typedArray, isDeep) {
+ var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;
+ return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);
+ }
+
+ /**
+ * Copies the values of `source` to `array`.
+ *
+ * @private
+ * @param {Array} source The array to copy values from.
+ * @param {Array} [array=[]] The array to copy values to.
+ * @returns {Array} Returns `array`.
+ */
+ function copyArray(source, array) {
+ var index = -1,
+ length = source.length;
+
+ array || (array = Array(length));
+ while (++index < length) {
+ array[index] = source[index];
+ }
+ return array;
+ }
+
+ /**
+ * Copies properties of `source` to `object`.
+ *
+ * @private
+ * @param {Object} source The object to copy properties from.
+ * @param {Array} props The property identifiers to copy.
+ * @param {Object} [object={}] The object to copy properties to.
+ * @param {Function} [customizer] The function to customize copied values.
+ * @returns {Object} Returns `object`.
+ */
+ function copyObject(source, props, object, customizer) {
+ object || (object = {});
+
+ var index = -1,
+ length = props.length;
+
+ while (++index < length) {
+ var key = props[index];
+
+ var newValue = customizer
+ ? customizer(object[key], source[key], key, object, source)
+ : undefined;
+
+ assignValue(object, key, newValue === undefined ? source[key] : newValue);
+ }
+ return object;
+ }
+
+ /**
+ * Copies own symbol properties of `source` to `object`.
+ *
+ * @private
+ * @param {Object} source The object to copy symbols from.
+ * @param {Object} [object={}] The object to copy symbols to.
+ * @returns {Object} Returns `object`.
+ */
+ function copySymbols(source, object) {
+ return copyObject(source, getSymbols(source), object);
+ }
+
+ /**
+ * Creates an array of own enumerable property names and symbols of `object`.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @returns {Array} Returns the array of property names and symbols.
+ */
+ function getAllKeys(object) {
+ return baseGetAllKeys(object, keys, getSymbols);
+ }
+
+ /**
+ * Gets the data for `map`.
+ *
+ * @private
+ * @param {Object} map The map to query.
+ * @param {string} key The reference key.
+ * @returns {*} Returns the map data.
+ */
+ function getMapData(map, key) {
+ var data = map.__data__;
+ return isKeyable(key)
+ ? data[typeof key == 'string' ? 'string' : 'hash']
+ : data.map;
+ }
+
+ /**
+ * Gets the native function at `key` of `object`.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @param {string} key The key of the method to get.
+ * @returns {*} Returns the function if it's native, else `undefined`.
+ */
+ function getNative(object, key) {
+ var value = getValue(object, key);
+ return baseIsNative(value) ? value : undefined;
+ }
+
+ /**
+ * Creates an array of the own enumerable symbol properties of `object`.
+ *
+ * @private
+ * @param {Object} object The object to query.
+ * @returns {Array} Returns the array of symbols.
+ */
+ var getSymbols = nativeGetSymbols ? overArg(nativeGetSymbols, Object) : stubArray;
+
+ /**
+ * Gets the `toStringTag` of `value`.
+ *
+ * @private
+ * @param {*} value The value to query.
+ * @returns {string} Returns the `toStringTag`.
+ */
+ var getTag = baseGetTag;
+
+ // Fallback for data views, maps, sets, and weak maps in IE 11,
+ // for data views in Edge < 14, and promises in Node.js.
+ if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||
+ (Map && getTag(new Map) != mapTag) ||
+ (Promise && getTag(Promise.resolve()) != promiseTag) ||
+ (Set && getTag(new Set) != setTag) ||
+ (WeakMap && getTag(new WeakMap) != weakMapTag)) {
+ getTag = function(value) {
+ var result = objectToString.call(value),
+ Ctor = result == objectTag ? value.constructor : undefined,
+ ctorString = Ctor ? toSource(Ctor) : undefined;
+
+ if (ctorString) {
+ switch (ctorString) {
+ case dataViewCtorString: return dataViewTag;
+ case mapCtorString: return mapTag;
+ case promiseCtorString: return promiseTag;
+ case setCtorString: return setTag;
+ case weakMapCtorString: return weakMapTag;
+ }
+ }
+ return result;
+ };
+ }
+
+ /**
+ * Initializes an array clone.
+ *
+ * @private
+ * @param {Array} array The array to clone.
+ * @returns {Array} Returns the initialized clone.
+ */
+ function initCloneArray(array) {
+ var length = array.length,
+ result = array.constructor(length);
+
+ // Add properties assigned by `RegExp#exec`.
+ if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {
+ result.index = array.index;
+ result.input = array.input;
+ }
+ return result;
+ }
+
+ /**
+ * Initializes an object clone.
+ *
+ * @private
+ * @param {Object} object The object to clone.
+ * @returns {Object} Returns the initialized clone.
+ */
+ function initCloneObject(object) {
+ return (typeof object.constructor == 'function' && !isPrototype(object))
+ ? baseCreate(getPrototype(object))
+ : {};
+ }
+
+ /**
+ * Initializes an object clone based on its `toStringTag`.
+ *
+ * **Note:** This function only supports cloning values with tags of
+ * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.
+ *
+ * @private
+ * @param {Object} object The object to clone.
+ * @param {string} tag The `toStringTag` of the object to clone.
+ * @param {Function} cloneFunc The function to clone values.
+ * @param {boolean} [isDeep] Specify a deep clone.
+ * @returns {Object} Returns the initialized clone.
+ */
+ function initCloneByTag(object, tag, cloneFunc, isDeep) {
+ var Ctor = object.constructor;
+ switch (tag) {
+ case arrayBufferTag:
+ return cloneArrayBuffer(object);
+
+ case boolTag:
+ case dateTag:
+ return new Ctor(+object);
+
+ case dataViewTag:
+ return cloneDataView(object, isDeep);
+
+ case float32Tag: case float64Tag:
+ case int8Tag: case int16Tag: case int32Tag:
+ case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:
+ return cloneTypedArray(object, isDeep);
+
+ case mapTag:
+ return cloneMap(object, isDeep, cloneFunc);
+
+ case numberTag:
+ case stringTag:
+ return new Ctor(object);
+
+ case regexpTag:
+ return cloneRegExp(object);
+
+ case setTag:
+ return cloneSet(object, isDeep, cloneFunc);
+
+ case symbolTag:
+ return cloneSymbol(object);
+ }
+ }
+
+ /**
+ * Checks if `value` is a valid array-like index.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.
+ * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.
+ */
+ function isIndex(value, length) {
+ length = length == null ? MAX_SAFE_INTEGER : length;
+ return !!length &&
+ (typeof value == 'number' || reIsUint.test(value)) &&
+ (value > -1 && value % 1 == 0 && value < length);
+ }
+
+ /**
+ * Checks if `value` is suitable for use as unique object key.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is suitable, else `false`.
+ */
+ function isKeyable(value) {
+ var type = typeof value;
+ return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')
+ ? (value !== '__proto__')
+ : (value === null);
+ }
+
+ /**
+ * Checks if `func` has its source masked.
+ *
+ * @private
+ * @param {Function} func The function to check.
+ * @returns {boolean} Returns `true` if `func` is masked, else `false`.
+ */
+ function isMasked(func) {
+ return !!maskSrcKey && (maskSrcKey in func);
+ }
+
+ /**
+ * Checks if `value` is likely a prototype object.
+ *
+ * @private
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.
+ */
+ function isPrototype(value) {
+ var Ctor = value && value.constructor,
+ proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;
+
+ return value === proto;
+ }
+
+ /**
+ * Converts `func` to its source code.
+ *
+ * @private
+ * @param {Function} func The function to process.
+ * @returns {string} Returns the source code.
+ */
+ function toSource(func) {
+ if (func != null) {
+ try {
+ return funcToString.call(func);
+ } catch (e) {}
+ try {
+ return (func + '');
+ } catch (e) {}
+ }
+ return '';
+ }
+
+ /**
+ * This method is like `_.clone` except that it recursively clones `value`.
+ *
+ * @static
+ * @memberOf _
+ * @since 1.0.0
+ * @category Lang
+ * @param {*} value The value to recursively clone.
+ * @returns {*} Returns the deep cloned value.
+ * @see _.clone
+ * @example
+ *
+ * var objects = [{ 'a': 1 }, { 'b': 2 }];
+ *
+ * var deep = _.cloneDeep(objects);
+ * console.log(deep[0] === objects[0]);
+ * // => false
+ */
+ function cloneDeep(value) {
+ return baseClone(value, true, true);
+ }
+
+ /**
+ * Performs a
+ * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
+ * comparison between two values to determine if they are equivalent.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to compare.
+ * @param {*} other The other value to compare.
+ * @returns {boolean} Returns `true` if the values are equivalent, else `false`.
+ * @example
+ *
+ * var object = { 'a': 1 };
+ * var other = { 'a': 1 };
+ *
+ * _.eq(object, object);
+ * // => true
+ *
+ * _.eq(object, other);
+ * // => false
+ *
+ * _.eq('a', 'a');
+ * // => true
+ *
+ * _.eq('a', Object('a'));
+ * // => false
+ *
+ * _.eq(NaN, NaN);
+ * // => true
+ */
+ function eq(value, other) {
+ return value === other || (value !== value && other !== other);
+ }
+
+ /**
+ * Checks if `value` is likely an `arguments` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an `arguments` object,
+ * else `false`.
+ * @example
+ *
+ * _.isArguments(function() { return arguments; }());
+ * // => true
+ *
+ * _.isArguments([1, 2, 3]);
+ * // => false
+ */
+ function isArguments(value) {
+ // Safari 8.1 makes `arguments.callee` enumerable in strict mode.
+ return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&
+ (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);
+ }
+
+ /**
+ * Checks if `value` is classified as an `Array` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an array, else `false`.
+ * @example
+ *
+ * _.isArray([1, 2, 3]);
+ * // => true
+ *
+ * _.isArray(document.body.children);
+ * // => false
+ *
+ * _.isArray('abc');
+ * // => false
+ *
+ * _.isArray(_.noop);
+ * // => false
+ */
+ var isArray = Array.isArray;
+
+ /**
+ * Checks if `value` is array-like. A value is considered array-like if it's
+ * not a function and has a `value.length` that's an integer greater than or
+ * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is array-like, else `false`.
+ * @example
+ *
+ * _.isArrayLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isArrayLike(document.body.children);
+ * // => true
+ *
+ * _.isArrayLike('abc');
+ * // => true
+ *
+ * _.isArrayLike(_.noop);
+ * // => false
+ */
+ function isArrayLike(value) {
+ return value != null && isLength(value.length) && !isFunction(value);
+ }
+
+ /**
+ * This method is like `_.isArrayLike` except that it also checks if `value`
+ * is an object.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an array-like object,
+ * else `false`.
+ * @example
+ *
+ * _.isArrayLikeObject([1, 2, 3]);
+ * // => true
+ *
+ * _.isArrayLikeObject(document.body.children);
+ * // => true
+ *
+ * _.isArrayLikeObject('abc');
+ * // => false
+ *
+ * _.isArrayLikeObject(_.noop);
+ * // => false
+ */
+ function isArrayLikeObject(value) {
+ return isObjectLike(value) && isArrayLike(value);
+ }
+
+ /**
+ * Checks if `value` is a buffer.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.3.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.
+ * @example
+ *
+ * _.isBuffer(new Buffer(2));
+ * // => true
+ *
+ * _.isBuffer(new Uint8Array(2));
+ * // => false
+ */
+ var isBuffer = nativeIsBuffer || stubFalse;
+
+ /**
+ * Checks if `value` is classified as a `Function` object.
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a function, else `false`.
+ * @example
+ *
+ * _.isFunction(_);
+ * // => true
+ *
+ * _.isFunction(/abc/);
+ * // => false
+ */
+ function isFunction(value) {
+ // The use of `Object#toString` avoids issues with the `typeof` operator
+ // in Safari 8-9 which returns 'object' for typed array and other constructors.
+ var tag = isObject(value) ? objectToString.call(value) : '';
+ return tag == funcTag || tag == genTag;
+ }
+
+ /**
+ * Checks if `value` is a valid array-like length.
+ *
+ * **Note:** This method is loosely based on
+ * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.
+ * @example
+ *
+ * _.isLength(3);
+ * // => true
+ *
+ * _.isLength(Number.MIN_VALUE);
+ * // => false
+ *
+ * _.isLength(Infinity);
+ * // => false
+ *
+ * _.isLength('3');
+ * // => false
+ */
+ function isLength(value) {
+ return typeof value == 'number' &&
+ value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;
+ }
+
+ /**
+ * Checks if `value` is the
+ * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
+ * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
+ *
+ * @static
+ * @memberOf _
+ * @since 0.1.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is an object, else `false`.
+ * @example
+ *
+ * _.isObject({});
+ * // => true
+ *
+ * _.isObject([1, 2, 3]);
+ * // => true
+ *
+ * _.isObject(_.noop);
+ * // => true
+ *
+ * _.isObject(null);
+ * // => false
+ */
+ function isObject(value) {
+ var type = typeof value;
+ return !!value && (type == 'object' || type == 'function');
+ }
+
+ /**
+ * Checks if `value` is object-like. A value is object-like if it's not `null`
+ * and has a `typeof` result of "object".
+ *
+ * @static
+ * @memberOf _
+ * @since 4.0.0
+ * @category Lang
+ * @param {*} value The value to check.
+ * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
+ * @example
+ *
+ * _.isObjectLike({});
+ * // => true
+ *
+ * _.isObjectLike([1, 2, 3]);
+ * // => true
+ *
+ * _.isObjectLike(_.noop);
+ * // => false
+ *
+ * _.isObjectLike(null);
+ * // => false
+ */
+ function isObjectLike(value) {
+ return !!value && typeof value == 'object';
+ }
+
+ /**
+ * Creates an array of the own enumerable property names of `object`.
+ *
+ * **Note:** Non-object values are coerced to objects. See the
+ * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)
+ * for more details.
+ *
+ * @static
+ * @since 0.1.0
+ * @memberOf _
+ * @category Object
+ * @param {Object} object The object to query.
+ * @returns {Array} Returns the array of property names.
+ * @example
+ *
+ * function Foo() {
+ * this.a = 1;
+ * this.b = 2;
+ * }
+ *
+ * Foo.prototype.c = 3;
+ *
+ * _.keys(new Foo);
+ * // => ['a', 'b'] (iteration order is not guaranteed)
+ *
+ * _.keys('hi');
+ * // => ['0', '1']
+ */
+ function keys(object) {
+ return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);
+ }
+
+ /**
+ * This method returns a new empty array.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.13.0
+ * @category Util
+ * @returns {Array} Returns the new empty array.
+ * @example
+ *
+ * var arrays = _.times(2, _.stubArray);
+ *
+ * console.log(arrays);
+ * // => [[], []]
+ *
+ * console.log(arrays[0] === arrays[1]);
+ * // => false
+ */
+ function stubArray() {
+ return [];
+ }
+
+ /**
+ * This method returns `false`.
+ *
+ * @static
+ * @memberOf _
+ * @since 4.13.0
+ * @category Util
+ * @returns {boolean} Returns `false`.
+ * @example
+ *
+ * _.times(2, _.stubFalse);
+ * // => [false, false]
+ */
+ function stubFalse() {
+ return false;
+ }
+
+ module.exports = cloneDeep;
+ });
+
+ var hasProperty = function has(object, key) {
+ return Object.prototype.hasOwnProperty.call(object, key);
+ };
+
+ var _apply;
+
+ function _classPrivateFieldLooseBase$8(receiver, privateKey) { if (!Object.prototype.hasOwnProperty.call(receiver, privateKey)) { throw new TypeError("attempted to use private field on non-instance"); } return receiver; }
+
+ var id$8 = 0;
+
+ function _classPrivateFieldLooseKey$8(name) { return "__private_" + id$8++ + "_" + name; }
+
+
+
+ function insertReplacement(source, rx, replacement) {
+ const newParts = [];
+ source.forEach(chunk => {
+ // When the source contains multiple placeholders for interpolation,
+ // we should ignore chunks that are not strings, because those
+ // can be JSX objects and will be otherwise incorrectly turned into strings.
+ // Without this condition we’d get this: [object Object] hello [object Object] my