@innovastudio/contentbox 1.6.21 → 1.6.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2433,7 +2433,7 @@ class SideBar {
|
|
2433
2433
|
|
2434
2434
|
numberCount++;
|
2435
2435
|
|
2436
|
-
let html = '<button tabindex="0" class="active" data-id="' + item.id + '" data-cat="
|
2436
|
+
let html = '<button tabindex="0" class="active" data-id="' + item.id + '" data-cat="' + item.category + '">' +
|
2437
2437
|
'<img class="lzy-img" src="" data-src="' + gallery.path + item.thumbnail + '">' +
|
2438
2438
|
'<span class="is-overlay"></span>' +
|
2439
2439
|
(numbering? (showNumberOnHover?'<div class="is-number">'+(numberCount+'').padStart(3, '0')+'</div>':'<div class="is-number show">'+(numberCount+'').padStart(3, '0')+'</div>') :'') +
|
@@ -14307,7 +14307,7 @@ class PanelBlock {
|
|
14307
14307
|
${out('Ungroup')}
|
14308
14308
|
</button>
|
14309
14309
|
</div>
|
14310
|
-
<div class="group flex mt-4 div-shape" style="width: 217px;display:none">
|
14310
|
+
<div class="group flex mt-4 div-shape" style="width: 217px;display:none;">
|
14311
14311
|
<button title="${out('Enable Shape')}" class="btn-shape" style="width: 100%">
|
14312
14312
|
${out('Enable Shape')}
|
14313
14313
|
</button>
|
@@ -14317,9 +14317,10 @@ class PanelBlock {
|
|
14317
14317
|
</div>
|
14318
14318
|
|
14319
14319
|
<div class="group editspacing mt-4">
|
14320
|
-
<button title="${out('Spacing')}" class="btn-spacing"
|
14320
|
+
<button title="${out('Spacing')}" class="btn-spacing">${out('Spacing')}</button>
|
14321
14321
|
</div>
|
14322
14322
|
|
14323
|
+
|
14323
14324
|
<!--
|
14324
14325
|
<div class="label flex flex-row">${out('Viewport')}: <span class="val-viewport"></span></div>
|
14325
14326
|
|
@@ -14387,12 +14388,14 @@ class PanelBlock {
|
|
14387
14388
|
this.builder.onChange();
|
14388
14389
|
});
|
14389
14390
|
const btnShape = panel.querySelector('.btn-shape');
|
14391
|
+
const btnRemoveShape = panel.querySelector('.btn-unshape');
|
14390
14392
|
if (btnShape) btnShape.addEventListener('click', () => {
|
14391
14393
|
this.builder.editor.saveForUndo();
|
14392
14394
|
this.builder.eb.enableShape();
|
14393
14395
|
this.builder.onChange();
|
14396
|
+
btnShape.style.display = 'none';
|
14397
|
+
btnRemoveShape.style.display = '';
|
14394
14398
|
});
|
14395
|
-
const btnRemoveShape = panel.querySelector('.btn-unshape');
|
14396
14399
|
if (btnRemoveShape) btnRemoveShape.addEventListener('click', () => {
|
14397
14400
|
this.builder.editor.saveForUndo();
|
14398
14401
|
this.builder.eb.removeShape();
|
@@ -14740,6 +14743,17 @@ class PanelBlock {
|
|
14740
14743
|
this.divUngroup.style.display = 'none';
|
14741
14744
|
}
|
14742
14745
|
|
14746
|
+
const btnShape = panel.querySelector('.btn-shape');
|
14747
|
+
const btnRemoveShape = panel.querySelector('.btn-unshape');
|
14748
|
+
|
14749
|
+
if (block.classList.contains('is-shape')) {
|
14750
|
+
btnShape.style.display = 'none';
|
14751
|
+
btnRemoveShape.style.display = '';
|
14752
|
+
} else {
|
14753
|
+
btnShape.style.display = '';
|
14754
|
+
btnRemoveShape.style.display = 'none';
|
14755
|
+
}
|
14756
|
+
|
14743
14757
|
if (block) {
|
14744
14758
|
if (block.closest('.autolayout')) {
|
14745
14759
|
this.divArrange.style.display = 'none';
|
@@ -16607,6 +16621,22 @@ class PanelRow {
|
|
16607
16621
|
<input type="checkbox" class="chk-reverse" /> <!-- chkReverseColumns -->
|
16608
16622
|
<span>${out('Reverse Columns')}</span>
|
16609
16623
|
</label>
|
16624
|
+
|
16625
|
+
<div class="label mt-4 changedevice">
|
16626
|
+
<span>${out('Column Gap')}:</span>
|
16627
|
+
</div>
|
16628
|
+
<div class="group colsperline mt-2" style="width:217px;">
|
16629
|
+
<button title="10" data-columngap="10">10</button>
|
16630
|
+
<button title="20" data-columngap="20">20</button>
|
16631
|
+
<button title="30" data-columngap="30">30</button>
|
16632
|
+
<button title="40" data-columngap="40">40</button>
|
16633
|
+
<button title="50" data-columngap="50">50</button>
|
16634
|
+
<button title="60" data-columngap="60">60</button>
|
16635
|
+
<button title="70" data-columngap="70">70</button>
|
16636
|
+
<button title="80" data-columngap="80">80</button>
|
16637
|
+
<button title="90" data-columngap="90">90</button>
|
16638
|
+
<button title="${out('Clear')}" data-columngap="" class="btn-clear"><svg><use xlink:href="#icon-eraser"></use></svg></button>
|
16639
|
+
</div>
|
16610
16640
|
</div>
|
16611
16641
|
|
16612
16642
|
</div>
|
@@ -16787,6 +16817,28 @@ class PanelRow {
|
|
16787
16817
|
activeRow.classList.remove(prefix + j);
|
16788
16818
|
}
|
16789
16819
|
|
16820
|
+
if (val !== '') activeRow.classList.add(prefix + val);
|
16821
|
+
this.builder.onChange();
|
16822
|
+
});
|
16823
|
+
});
|
16824
|
+
const btnColumnGap = panel.querySelectorAll('[data-columngap]');
|
16825
|
+
btnColumnGap.forEach(btn => {
|
16826
|
+
btn.addEventListener('click', () => {
|
16827
|
+
let activeRow = this.builder.controlpanel.activeRow;
|
16828
|
+
this.builder.editor.saveForUndo();
|
16829
|
+
let val = btn.getAttribute('data-columngap');
|
16830
|
+
panel.querySelectorAll('[data-columngap]').forEach(elm => elm.classList.remove('on'));
|
16831
|
+
if (val !== '') btn.classList.add('on');
|
16832
|
+
let prefix = 'gap-'; // let screenMode = this.builder.screenMode;
|
16833
|
+
// if(screenMode==='desktop') prefix = 'gap-';
|
16834
|
+
// else if (screenMode==='tablet-landscape') prefix = 'md-gap-';
|
16835
|
+
// else if (screenMode==='tablet') prefix = 'sm-gap-';
|
16836
|
+
// else if (screenMode==='mobile') prefix = 'xs-gap-';
|
16837
|
+
|
16838
|
+
for (let j = 1; j <= 9; j++) {
|
16839
|
+
activeRow.classList.remove(prefix + j * 10);
|
16840
|
+
}
|
16841
|
+
|
16790
16842
|
if (val !== '') activeRow.classList.add(prefix + val);
|
16791
16843
|
this.builder.onChange();
|
16792
16844
|
});
|
@@ -16975,7 +17027,9 @@ class PanelRow {
|
|
16975
17027
|
|
16976
17028
|
let valReverse = activeRow.classList.contains(prefix + 'column-reverse');
|
16977
17029
|
const chkReverseColumns = panel.querySelector('.chk-reverse');
|
16978
|
-
chkReverseColumns.checked = valReverse;
|
17030
|
+
chkReverseColumns.checked = valReverse;
|
17031
|
+
panel.querySelectorAll('[data-columngap]').forEach(elm => elm.classList.remove('on'));
|
17032
|
+
if (activeRow.classList.contains('gap-10')) panel.querySelector('[data-columngap="10"]').classList.add('on');else if (activeRow.classList.contains('gap-20')) panel.querySelector('[data-columngap="20"]').classList.add('on');else if (activeRow.classList.contains('gap-30')) panel.querySelector('[data-columngap="30"]').classList.add('on');else if (activeRow.classList.contains('gap-40')) panel.querySelector('[data-columngap="40"]').classList.add('on');else if (activeRow.classList.contains('gap-50')) panel.querySelector('[data-columngap="50"]').classList.add('on');else if (activeRow.classList.contains('gap-60')) panel.querySelector('[data-columngap="60"]').classList.add('on');else if (activeRow.classList.contains('gap-70')) panel.querySelector('[data-columngap="70"]').classList.add('on');else if (activeRow.classList.contains('gap-80')) panel.querySelector('[data-columngap="80"]').classList.add('on');else if (activeRow.classList.contains('gap-90')) panel.querySelector('[data-columngap="90"]').classList.add('on'); // Responsive
|
16979
17033
|
|
16980
17034
|
this.realtimeVisibility(activeRow); // More
|
16981
17035
|
|
@@ -25137,6 +25191,7 @@ class Dom {
|
|
25137
25191
|
}
|
25138
25192
|
getScale(container) {
|
25139
25193
|
let matrix = window.getComputedStyle(container).transform;
|
25194
|
+
if (matrix === 'none') return 1;
|
25140
25195
|
let values = matrix.split('(')[1];
|
25141
25196
|
values = values.split(')')[0];
|
25142
25197
|
values = values.split(',');
|
@@ -33352,6 +33407,9 @@ class UndoRedo {
|
|
33352
33407
|
let wrapper = this.builder.doc.querySelector(this.builder.opts.page);
|
33353
33408
|
// return htmlutil.readHtml(wrapper, false);
|
33354
33409
|
return wrapper.innerHTML;
|
33410
|
+
} else if (this.builder.docContainer) {
|
33411
|
+
let docContainer = this.builder.doc.querySelector(this.builder.docContainer);
|
33412
|
+
return docContainer.innerHTML;
|
33355
33413
|
} else {
|
33356
33414
|
const builders = this.builder.doc.querySelectorAll(this.builder.opts.container);
|
33357
33415
|
let html = '';
|
@@ -33412,12 +33470,18 @@ class UndoRedo {
|
|
33412
33470
|
|
33413
33471
|
// Use createContextualFragment() to make embedded script executable
|
33414
33472
|
// https://ghinda.net/article/script-tags/
|
33415
|
-
|
33473
|
+
let range = document.createRange();
|
33416
33474
|
wrapper.innerHTML = '';
|
33417
33475
|
wrapper.appendChild(range.createContextualFragment(html));
|
33418
33476
|
|
33419
33477
|
// applyBehavior (in ContentBox, unUndo will call pageSetup/applyBehavior)
|
33420
33478
|
this.cleaning(wrapper);
|
33479
|
+
} else if (this.builder.docContainer) {
|
33480
|
+
let docContainer = this.builder.doc.querySelector(this.builder.docContainer);
|
33481
|
+
let range = document.createRange();
|
33482
|
+
docContainer.innerHTML = '';
|
33483
|
+
docContainer.appendChild(range.createContextualFragment(html));
|
33484
|
+
this.cleaning(docContainer);
|
33421
33485
|
} else {
|
33422
33486
|
const builders = this.builder.doc.querySelectorAll(this.builder.opts.container);
|
33423
33487
|
let n = 0;
|
@@ -40351,12 +40415,16 @@ const renderSnippetPanel = (builder, snippetOpen) => {
|
|
40351
40415
|
}
|
40352
40416
|
|
40353
40417
|
// destroy
|
40354
|
-
if (builder.sortableOnCanvas)
|
40355
|
-
|
40356
|
-
obj
|
40357
|
-
|
40358
|
-
|
40418
|
+
if (builder.sortableOnCanvas) {
|
40419
|
+
builder.sortableOnCanvas.forEach(obj => {
|
40420
|
+
if (obj) {
|
40421
|
+
obj.destroy();
|
40422
|
+
}
|
40423
|
+
});
|
40424
|
+
}
|
40359
40425
|
if (builder.sortableOnPage) builder.sortableOnPage.destroy();
|
40426
|
+
let dummies = builder.doc.querySelectorAll('.block-dummy');
|
40427
|
+
dummies.forEach(elm => elm.parentNode.removeChild(elm));
|
40360
40428
|
}
|
40361
40429
|
});
|
40362
40430
|
if (builder.opts.snippetList === '#divSnippetList') {
|
@@ -40437,6 +40505,22 @@ const renderSnippetPanel = (builder, snippetOpen) => {
|
|
40437
40505
|
*/
|
40438
40506
|
};
|
40439
40507
|
|
40508
|
+
function openSnippets(builder) {
|
40509
|
+
const snippetPanel = document.querySelector('#divSnippetList');
|
40510
|
+
const snippethandle = snippetPanel.querySelector('#divSnippetHandle');
|
40511
|
+
snippetPanel.style.cssText = 'transition: all ease 0.8s;';
|
40512
|
+
snippetPanel.querySelector('.selectsnippet').style.display = 'block';
|
40513
|
+
snippetPanel.querySelector('.is-design-list').style.display = 'block';
|
40514
|
+
snippetPanel.classList.add('active');
|
40515
|
+
if (builder.opts.sidePanel === 'right') {
|
40516
|
+
snippethandle.innerHTML = '<svg class="is-icon-flex" style="width:17px;height:17px;"><use xlink:href="#ion-ios-arrow-right"></use></svg>';
|
40517
|
+
} else {
|
40518
|
+
snippethandle.innerHTML = '<svg class="is-icon-flex" style="width:17px;height:17px;"><use xlink:href="#ion-ios-arrow-left"></use></svg>';
|
40519
|
+
}
|
40520
|
+
setTimeout(function () {
|
40521
|
+
snippetPanel.style.cssText = '';
|
40522
|
+
}, 800);
|
40523
|
+
}
|
40440
40524
|
function toggleSnippets(builder) {
|
40441
40525
|
const dom = builder.dom;
|
40442
40526
|
let snippetPanel = document.querySelector('#divSnippetList');
|
@@ -68842,7 +68926,7 @@ class Image$1 {
|
|
68842
68926
|
}
|
68843
68927
|
imageTool.style.top = top + 'px';
|
68844
68928
|
imageTool.style.left = toolLeft + 'px';
|
68845
|
-
if (!this.builder.activeImage.hasAttribute('data-noresize')) {
|
68929
|
+
if (!this.builder.activeImage.hasAttribute('data-noresize') && (this.builder.imageResizeOnBlock || !this.builder.activeImage.closest('.is-block'))) {
|
68846
68930
|
let imageResizer = this.imageResizer;
|
68847
68931
|
imageResizer.style.top = top + 'px';
|
68848
68932
|
imageResizer.style.left = left + 'px';
|
@@ -68926,7 +69010,7 @@ class Image$1 {
|
|
68926
69010
|
imageTool.style.left = toolLeft + 'px';
|
68927
69011
|
|
68928
69012
|
// Image Resizer
|
68929
|
-
if (!elm.hasAttribute('data-noresize')) {
|
69013
|
+
if (!elm.hasAttribute('data-noresize') && (this.builder.imageResizeOnBlock || !elm.closest('.is-block'))) {
|
68930
69014
|
let imageResizer = this.imageResizer;
|
68931
69015
|
|
68932
69016
|
/*
|
@@ -92960,7 +93044,7 @@ class Resizeable {
|
|
92960
93044
|
let scale = this.getScale(container);
|
92961
93045
|
if (!scale) {
|
92962
93046
|
const wrapper = container.closest('.is-wrapper');
|
92963
|
-
scale = this.getScale(wrapper);
|
93047
|
+
if (wrapper) scale = this.getScale(wrapper);else scale = 1;
|
92964
93048
|
}
|
92965
93049
|
|
92966
93050
|
// Minimum resize
|
@@ -97575,6 +97659,7 @@ class ContentBuilder {
|
|
97575
97659
|
toolbar: 'top',
|
97576
97660
|
toolbarDisplay: 'auto',
|
97577
97661
|
shortenHTML: true,
|
97662
|
+
imageResizeOnBlock: true,
|
97578
97663
|
simpleEditingBreakpoint: '970px',
|
97579
97664
|
// iframe only
|
97580
97665
|
|
@@ -99244,6 +99329,7 @@ class ContentBuilder {
|
|
99244
99329
|
} else {
|
99245
99330
|
const area = this.doc.querySelector('.is-builder'); // get one of the builder area
|
99246
99331
|
scale = this.dom.getScale(area);
|
99332
|
+
if (!scale) scale = 1;
|
99247
99333
|
}
|
99248
99334
|
|
99249
99335
|
// Make moving draggable item scaled & positioned correctly (due to zoom value)
|
@@ -99404,11 +99490,17 @@ class ContentBuilder {
|
|
99404
99490
|
|
99405
99491
|
// Hide element tool
|
99406
99492
|
this.elmTool.hide();
|
99407
|
-
|
99408
|
-
|
99409
|
-
|
99410
|
-
|
99411
|
-
|
99493
|
+
|
99494
|
+
// // destroy
|
99495
|
+
// if(this.sortableOnCanvas) {
|
99496
|
+
// this.sortableOnCanvas.forEach(obj=>{
|
99497
|
+
// if(obj) {
|
99498
|
+
// obj.destroy();
|
99499
|
+
// }
|
99500
|
+
// });
|
99501
|
+
// let dummies = this.doc.querySelectorAll('.block-dummy');
|
99502
|
+
// dummies.forEach(elm=>elm.parentNode.removeChild(elm));
|
99503
|
+
// }
|
99412
99504
|
|
99413
99505
|
// if(this.sortableOnPage) this.sortableOnPage.destroy();
|
99414
99506
|
}
|
@@ -100508,7 +100600,10 @@ class ContentBuilder {
|
|
100508
100600
|
if (this.preview) return;
|
100509
100601
|
if (this.opts.snippetList === '#divSnippetList') {
|
100510
100602
|
let snippetPanel = document.querySelector(this.opts.snippetList);
|
100511
|
-
if (snippetPanel)
|
100603
|
+
if (snippetPanel) {
|
100604
|
+
if (snippetOpen) openSnippets(this);
|
100605
|
+
return; // do not render if already rendered (just protection)
|
100606
|
+
}
|
100512
100607
|
}
|
100513
100608
|
|
100514
100609
|
if (this.isScriptAlreadyIncluded(snippetFile)) return;
|
@@ -102052,13 +102147,21 @@ class ContentBuilder {
|
|
102052
102147
|
}
|
102053
102148
|
|
102054
102149
|
sectionDropSetup() {
|
102055
|
-
if (this.
|
102056
|
-
if (this.page !== '.is-wrapper') return; // only for ContentBox
|
102057
|
-
const wrapper = this.doc.querySelector(this.page);
|
102150
|
+
if (this.blockContainer) {
|
102058
102151
|
this.sortableOnCanvas = [];
|
102059
|
-
|
102060
|
-
|
102061
|
-
|
102152
|
+
let wrapper;
|
102153
|
+
let boxes;
|
102154
|
+
if (this.page && this.page === '.is-wrapper') {
|
102155
|
+
wrapper = this.doc.querySelector(this.page);
|
102156
|
+
boxes = wrapper.querySelectorAll('.is-box.box-canvas');
|
102157
|
+
} else {
|
102158
|
+
boxes = this.doc.querySelectorAll(this.blockContainer);
|
102159
|
+
}
|
102160
|
+
boxes.forEach(box => {
|
102161
|
+
box.insertAdjacentHTML('afterbegin', `
|
102162
|
+
<div class="is-block block-dummy" style="top: calc(97.2707% - 149.797px); left: calc(50% - 222px); width: 444px; height: 154px;z-index:-1000;visibility:hidden">
|
102163
|
+
</div>`);
|
102164
|
+
const obj = new Sortable(box, {
|
102062
102165
|
scroll: true,
|
102063
102166
|
group: 'shared',
|
102064
102167
|
direction: 'horizontal',
|
@@ -102071,7 +102174,7 @@ class ContentBuilder {
|
|
102071
102174
|
|
102072
102175
|
let snippetid = itemEl.getAttribute('data-id');
|
102073
102176
|
let lastBlock;
|
102074
|
-
let elements = Array.from(
|
102177
|
+
let elements = Array.from(box.querySelectorAll('.is-block')).filter(elm => !elm.parentNode.classList.contains('is-block')); // exclude child blocks
|
102075
102178
|
if (elements.length > 0) {
|
102076
102179
|
lastBlock = elements[elements.length - 1];
|
102077
102180
|
}
|
@@ -102183,14 +102286,14 @@ class ContentBuilder {
|
|
102183
102286
|
itemEl.outerHTML = blockTemplate.replace('[%CONTENT%]', itemEl.innerHTML);
|
102184
102287
|
}
|
102185
102288
|
this.activeCol = null;
|
102186
|
-
const builders =
|
102289
|
+
const builders = box.querySelectorAll('.is-container.container-new');
|
102187
102290
|
builders.forEach(builder => {
|
102188
102291
|
const block = builder.parentNode;
|
102189
102292
|
if (lastBlock) {
|
102190
102293
|
lastBlock.insertAdjacentElement('afterend', block);
|
102191
102294
|
} else {
|
102192
|
-
const ovarlay =
|
102193
|
-
ovarlay.insertAdjacentElement('afterend', block);
|
102295
|
+
const ovarlay = box.querySelector('.is-overlay');
|
102296
|
+
if (ovarlay) ovarlay.insertAdjacentElement('afterend', block);else box.insertAdjacentElement('afterbegin', block);
|
102194
102297
|
}
|
102195
102298
|
|
102196
102299
|
// After snippet has been added, re-apply behavior on builder areas
|
@@ -102203,16 +102306,24 @@ class ContentBuilder {
|
|
102203
102306
|
}
|
102204
102307
|
|
102205
102308
|
// destroy
|
102206
|
-
if (this.sortableOnCanvas)
|
102207
|
-
|
102208
|
-
obj
|
102209
|
-
|
102210
|
-
|
102309
|
+
if (this.sortableOnCanvas) {
|
102310
|
+
this.sortableOnCanvas.forEach(obj => {
|
102311
|
+
if (obj) {
|
102312
|
+
obj.destroy();
|
102313
|
+
}
|
102314
|
+
});
|
102315
|
+
let dummies = this.doc.querySelectorAll('.block-dummy');
|
102316
|
+
dummies.forEach(elm => elm.parentNode.removeChild(elm));
|
102317
|
+
}
|
102211
102318
|
if (this.sortableOnPage) this.sortableOnPage.destroy();
|
102212
102319
|
}
|
102213
102320
|
});
|
102214
102321
|
this.sortableOnCanvas.push(obj);
|
102215
102322
|
});
|
102323
|
+
}
|
102324
|
+
if (this.page) {
|
102325
|
+
if (this.page !== '.is-wrapper') return; // only for ContentBox
|
102326
|
+
const wrapper = this.doc.querySelector(this.page);
|
102216
102327
|
this.sortableOnPage = new Sortable(wrapper, {
|
102217
102328
|
scroll: true,
|
102218
102329
|
group: 'shared',
|
@@ -102412,11 +102523,15 @@ class ContentBuilder {
|
|
102412
102523
|
// this.sortableOnPage.option('draggable', '.dummy');
|
102413
102524
|
|
102414
102525
|
// destroy
|
102415
|
-
if (this.sortableOnCanvas)
|
102416
|
-
|
102417
|
-
obj
|
102418
|
-
|
102419
|
-
|
102526
|
+
if (this.sortableOnCanvas) {
|
102527
|
+
this.sortableOnCanvas.forEach(obj => {
|
102528
|
+
if (obj) {
|
102529
|
+
obj.destroy();
|
102530
|
+
}
|
102531
|
+
});
|
102532
|
+
let dummies = this.doc.querySelectorAll('.block-dummy');
|
102533
|
+
dummies.forEach(elm => elm.parentNode.removeChild(elm));
|
102534
|
+
}
|
102420
102535
|
if (this.sortableOnPage) this.sortableOnPage.destroy();
|
102421
102536
|
}
|
102422
102537
|
});
|
@@ -127658,7 +127773,7 @@ class Common {
|
|
127658
127773
|
for (let i = 0; i < attributes.length; i++) {
|
127659
127774
|
const attributeName = attributes[i].name;
|
127660
127775
|
|
127661
|
-
if (attributeName.includes('data--y-') || attributeName.includes('data--x-') || attributeName.includes('data--w-') || attributeName.includes('data--h-')) {
|
127776
|
+
if (attributeName.includes('data--y-') || attributeName.includes('data--x-') || attributeName.includes('data--w-') || attributeName.includes('data--h-') || attributeName.includes('data--transform-') || attributeName.includes('data--matrix-')) {
|
127662
127777
|
attributesToRemove.push(attributeName);
|
127663
127778
|
}
|
127664
127779
|
}
|
@@ -127688,7 +127803,7 @@ class Common {
|
|
127688
127803
|
for (let i = 0; i < attributes.length; i++) {
|
127689
127804
|
const attributeName = attributes[i].name;
|
127690
127805
|
|
127691
|
-
if (attributeName.includes('data--y-') || attributeName.includes('data--x-') || attributeName.includes('data--w-') || attributeName.includes('data--h-')) {
|
127806
|
+
if (attributeName.includes('data--y-') || attributeName.includes('data--x-') || attributeName.includes('data--w-') || attributeName.includes('data--h-') || attributeName.includes('data--transform-') || attributeName.includes('data--matrix-')) {
|
127692
127807
|
attributesToRemove.push(attributeName);
|
127693
127808
|
}
|
127694
127809
|
}
|
@@ -128362,7 +128477,17 @@ class Shape {
|
|
128362
128477
|
target.addEventListener('touchstart', this.handleTouchStart, {
|
128363
128478
|
passive: false
|
128364
128479
|
});
|
128365
|
-
this.repositionHandles(target);
|
128480
|
+
this.repositionHandles(target); // Like directly call selectBlock (below):
|
128481
|
+
|
128482
|
+
this.currentTarget = target;
|
128483
|
+
this.doc.addEventListener('mousemove', this.handleDragMove);
|
128484
|
+
this.doc.addEventListener('touchmove', this.handleDragMove, {
|
128485
|
+
passive: false
|
128486
|
+
});
|
128487
|
+
this.doc.addEventListener('mousedown', this.unSelectBlock);
|
128488
|
+
this.doc.addEventListener('touchstart', this.unSelectBlock, {
|
128489
|
+
passive: false
|
128490
|
+
});
|
128366
128491
|
}
|
128367
128492
|
}
|
128368
128493
|
|
@@ -128370,7 +128495,8 @@ class Shape {
|
|
128370
128495
|
if (target.classList.contains('is-shape')) {
|
128371
128496
|
target.classList.remove('is-shape');
|
128372
128497
|
target.style.transform = '';
|
128373
|
-
target.removeAttribute('data
|
128498
|
+
target.removeAttribute('data--matrix');
|
128499
|
+
target.removeAttribute('data--transform');
|
128374
128500
|
target.removeEventListener('mousedown', this.selectBlock);
|
128375
128501
|
target.removeEventListener('touchstart', this.selectBlock);
|
128376
128502
|
target.removeEventListener('dblclick', this.handleEditStart);
|
@@ -128387,6 +128513,11 @@ class Shape {
|
|
128387
128513
|
this.line5.style.display = '';
|
128388
128514
|
this.line6.style.display = '';
|
128389
128515
|
}
|
128516
|
+
|
128517
|
+
this.doc.removeEventListener('mousedown', this.unSelectBlock);
|
128518
|
+
this.doc.removeEventListener('touchstart', this.unSelectBlock);
|
128519
|
+
this.doc.removeEventListener('mousemove', this.handleDragMove);
|
128520
|
+
this.doc.removeEventListener('touchmove', this.handleDragMove);
|
128390
128521
|
}
|
128391
128522
|
|
128392
128523
|
destroy(element) {
|
@@ -128467,7 +128598,15 @@ class Shape {
|
|
128467
128598
|
}; // Current Matrix
|
128468
128599
|
|
128469
128600
|
let cm;
|
128470
|
-
|
128601
|
+
let m = JSON.parse(target.getAttribute('data--matrix')); // Adaptif
|
128602
|
+
|
128603
|
+
const breakpoint = target.getAttribute('data--transform-val');
|
128604
|
+
|
128605
|
+
if (breakpoint && breakpoint < 1920) {
|
128606
|
+
if (target.getAttribute('data--matrix-' + breakpoint)) {
|
128607
|
+
m = JSON.parse(target.getAttribute('data--matrix-' + breakpoint));
|
128608
|
+
}
|
128609
|
+
}
|
128471
128610
|
|
128472
128611
|
if (m) {
|
128473
128612
|
cm = {
|
@@ -128674,7 +128813,12 @@ class Shape {
|
|
128674
128813
|
}
|
128675
128814
|
}
|
128676
128815
|
|
128677
|
-
this.repositionHandles(currentTarget);
|
128816
|
+
this.repositionHandles(currentTarget); // Clear previous (if any. because when enable() is called, the events are also added)
|
128817
|
+
|
128818
|
+
this.doc.removeEventListener('mousemove', this.handleDragMove);
|
128819
|
+
this.doc.removeEventListener('touchmove', this.handleDragMove);
|
128820
|
+
this.doc.removeEventListener('mousedown', this.unSelectBlock);
|
128821
|
+
this.doc.removeEventListener('touchstart', this.unSelectBlock);
|
128678
128822
|
this.currentTarget = currentTarget;
|
128679
128823
|
this.doc.addEventListener('mousemove', this.handleDragMove);
|
128680
128824
|
this.doc.addEventListener('touchmove', this.handleDragMove, {
|
@@ -128766,8 +128910,17 @@ class Shape {
|
|
128766
128910
|
this.target.setAttribute('data-starty', y);
|
128767
128911
|
this.common.applyPixels(target); //Initial
|
128768
128912
|
|
128769
|
-
if (this.block.hasAttribute('data
|
128770
|
-
|
128913
|
+
if (this.block.hasAttribute('data--matrix')) {
|
128914
|
+
let s = this.block.getAttribute('data--matrix'); // Adaptif
|
128915
|
+
|
128916
|
+
const breakpoint = this.block.getAttribute('data--transform-val');
|
128917
|
+
|
128918
|
+
if (breakpoint && breakpoint < 1920) {
|
128919
|
+
if (this.block.getAttribute('data--matrix-' + breakpoint)) {
|
128920
|
+
s = this.block.getAttribute('data--matrix-' + breakpoint);
|
128921
|
+
}
|
128922
|
+
}
|
128923
|
+
|
128771
128924
|
this.initialCorners = JSON.parse(s);
|
128772
128925
|
this.corners = JSON.parse(s);
|
128773
128926
|
} else {
|
@@ -128868,14 +129021,50 @@ class Shape {
|
|
128868
129021
|
updateBlockStyle(target) {
|
128869
129022
|
this.common.applyPercentage(target);
|
128870
129023
|
this.doc.querySelectorAll('[data-startx]').forEach(elm => elm.removeAttribute('data-startx'));
|
128871
|
-
this.doc.querySelectorAll('[data-starty]').forEach(elm => elm.removeAttribute('data-starty'));
|
129024
|
+
this.doc.querySelectorAll('[data-starty]').forEach(elm => elm.removeAttribute('data-starty')); // Adaptif
|
129025
|
+
|
129026
|
+
const breakpoint = this.doc.body.getAttribute('data-breakpoint');
|
129027
|
+
|
129028
|
+
if (breakpoint && breakpoint < 1920) {
|
129029
|
+
target.setAttribute('data--y-' + breakpoint, target.style.top);
|
129030
|
+
target.setAttribute('data--x-' + breakpoint, target.style.left);
|
129031
|
+
target.setAttribute('data--w-' + breakpoint, target.style.width);
|
129032
|
+
target.setAttribute('data--h-' + breakpoint, target.style.height);
|
129033
|
+
} else {
|
129034
|
+
target.setAttribute('data--y', target.style.top);
|
129035
|
+
target.setAttribute('data--x', target.style.left);
|
129036
|
+
target.setAttribute('data--w', target.style.width);
|
129037
|
+
target.setAttribute('data--h', target.style.height);
|
129038
|
+
}
|
129039
|
+
|
129040
|
+
target.removeAttribute('data-prev'); // reset
|
129041
|
+
|
129042
|
+
target.removeAttribute('data-fluid'); //---
|
129043
|
+
|
128872
129044
|
if (this.onChange) this.onChange();
|
128873
129045
|
}
|
128874
129046
|
|
128875
129047
|
setTransform(block) {
|
128876
129048
|
let transform = this.common.transform2d(block, this.corners[0], this.corners[1], this.corners[2], this.corners[3], this.corners[4], this.corners[5], this.corners[6], this.corners[7]);
|
128877
129049
|
block.style.transform = transform;
|
128878
|
-
this.block.setAttribute('data
|
129050
|
+
let matrix = JSON.stringify(this.corners); // this.block.setAttribute('data--matrix', matrix);
|
129051
|
+
// Adaptif
|
129052
|
+
|
129053
|
+
const breakpoint = this.doc.body.getAttribute('data-breakpoint');
|
129054
|
+
|
129055
|
+
if (breakpoint && breakpoint < 1920) {
|
129056
|
+
this.block.setAttribute('data--transform-' + breakpoint, transform);
|
129057
|
+
this.block.setAttribute('data--transform-val', breakpoint);
|
129058
|
+
this.block.setAttribute('data--matrix-' + breakpoint, matrix);
|
129059
|
+
} else {
|
129060
|
+
this.block.setAttribute('data--transform', transform);
|
129061
|
+
this.block.setAttribute('data--transform-val', '');
|
129062
|
+
this.block.setAttribute('data--matrix', matrix);
|
129063
|
+
}
|
129064
|
+
|
129065
|
+
this.block.removeAttribute('data-prev'); // reset
|
129066
|
+
|
129067
|
+
this.block.removeAttribute('data-fluid'); //---
|
128879
129068
|
}
|
128880
129069
|
|
128881
129070
|
resizeTopLeft(deltaX, deltaY) {
|
@@ -129297,10 +129486,11 @@ class Draggable {
|
|
129297
129486
|
this.onDelete = options && options.onDelete || null;
|
129298
129487
|
this.onBeforeChange = options && options.onBeforeChange || null;
|
129299
129488
|
this.onChange = options && options.onChange || null;
|
129300
|
-
this.
|
129301
|
-
this.
|
129489
|
+
this.onSelectStart = options && options.onSelectStart || null;
|
129490
|
+
this.onSelectClear = options && options.onSelectClear || null;
|
129302
129491
|
this.disableOnMobile = options && options.disableOnMobile || 0;
|
129303
129492
|
this.onMultipleSelect = options && options.onMultipleSelect || null;
|
129493
|
+
this.onSelectBlock = options && options.onSelectBlock || null;
|
129304
129494
|
this.isDragging = false;
|
129305
129495
|
this.startX = 0;
|
129306
129496
|
this.startY = 0;
|
@@ -129494,7 +129684,7 @@ class Draggable {
|
|
129494
129684
|
|
129495
129685
|
if (blocks.length === 1) {
|
129496
129686
|
const block = blocks[0];
|
129497
|
-
if (this.
|
129687
|
+
if (this.onSelectStart) this.onSelectStart(block); // on first block select (before clone)
|
129498
129688
|
}
|
129499
129689
|
}
|
129500
129690
|
|
@@ -129550,8 +129740,13 @@ class Draggable {
|
|
129550
129740
|
const block = element.closest(this.selector);
|
129551
129741
|
|
129552
129742
|
if (block) {
|
129553
|
-
if (block.classList.contains('active'))
|
129554
|
-
|
129743
|
+
if (block.classList.contains('active')) {
|
129744
|
+
let actualBlock = block.classList.contains('clone') ? this.doc.querySelector(this.selector + '.cloned') : null;
|
129745
|
+
if (!actualBlock) actualBlock = block;
|
129746
|
+
if (this.onSelectBlock) this.onSelectBlock(actualBlock);
|
129747
|
+
return; // if clicked block is active
|
129748
|
+
} // if(block.parentNode.classList.contains('active')) return; // if group is active
|
129749
|
+
|
129555
129750
|
|
129556
129751
|
if (block.matches(this.selector) && block.querySelector(this.selector)) {
|
129557
129752
|
// if group is clicked, remove active childe's blocks
|
@@ -129563,11 +129758,16 @@ class Draggable {
|
|
129563
129758
|
block.classList.add('active');
|
129564
129759
|
if (this.onMultipleSelect) this.onMultipleSelect();
|
129565
129760
|
} else {
|
129566
|
-
if (this.
|
129761
|
+
if (this.onSelectClear) this.onSelectClear();
|
129567
129762
|
this.doc.querySelectorAll(this.selector + '.active').forEach(elm => elm.classList.remove('active'));
|
129568
129763
|
block.classList.add('active');
|
129569
|
-
|
129764
|
+
let actualBlock = block.classList.contains('clone') ? this.doc.querySelector(this.selector + '.cloned') : null;
|
129765
|
+
if (!actualBlock) actualBlock = block;
|
129766
|
+
if (this.onSelectBlock) this.onSelectBlock(actualBlock);
|
129767
|
+
}
|
129570
129768
|
|
129769
|
+
if (!block.parentNode) return; // just in case
|
129770
|
+
// Higlight parent group if current child block is clicked
|
129571
129771
|
|
129572
129772
|
if (block.parentNode.matches(this.selector)) {
|
129573
129773
|
block.parentNode.classList.add('block-active');
|
@@ -129585,7 +129785,7 @@ class Draggable {
|
|
129585
129785
|
|
129586
129786
|
this.doc.querySelectorAll(this.selector + '.active').forEach(elm => elm.classList.remove('active'));
|
129587
129787
|
this.doc.querySelectorAll('.block-active').forEach(elm => elm.classList.remove('block-active'));
|
129588
|
-
if (this.
|
129788
|
+
if (this.onSelectClear) this.onSelectClear();
|
129589
129789
|
} // Check if multiple selection occurs. If so, add 'multi' class to hide all the handles
|
129590
129790
|
|
129591
129791
|
|
@@ -129970,12 +130170,8 @@ class EditableBlocks {
|
|
129970
130170
|
// onEditStart: () => {},
|
129971
130171
|
// onEditEnd: () => {},
|
129972
130172
|
// onDuplicate: () => {},
|
129973
|
-
onSelectBlock:
|
129974
|
-
|
129975
|
-
},
|
129976
|
-
onUnSelectBlock: () => {
|
129977
|
-
this.unSelectBlock();
|
129978
|
-
},
|
130173
|
+
// onSelectBlock: (block) => {},
|
130174
|
+
// onUnSelectBlock: () => {},
|
129979
130175
|
// onMultipleSelect: () => {},
|
129980
130176
|
disableOnMobile: 0,
|
129981
130177
|
rotate: true,
|
@@ -130014,7 +130210,9 @@ class EditableBlocks {
|
|
130014
130210
|
target.style.zIndex = newZIndex;
|
130015
130211
|
}
|
130016
130212
|
|
130017
|
-
|
130213
|
+
selectStart(block) {
|
130214
|
+
if (block.classList.contains('is-shape')) return; // do not clone if block is shape
|
130215
|
+
|
130018
130216
|
if (!this.clone) return;
|
130019
130217
|
const viewportWidth = this.win.innerWidth;
|
130020
130218
|
|
@@ -130022,7 +130220,7 @@ class EditableBlocks {
|
|
130022
130220
|
return;
|
130023
130221
|
}
|
130024
130222
|
|
130025
|
-
if (block.classList.contains('is-group')) return;
|
130223
|
+
if (block.classList.contains('is-group')) return; // do not clone if block is shape
|
130026
130224
|
|
130027
130225
|
if (!block.classList.contains('clone')) {
|
130028
130226
|
let clonedDiv = block.cloneNode(true);
|
@@ -130033,7 +130231,7 @@ class EditableBlocks {
|
|
130033
130231
|
}
|
130034
130232
|
}
|
130035
130233
|
|
130036
|
-
|
130234
|
+
selectClear() {
|
130037
130235
|
this.doc.querySelectorAll('.clone').forEach(elm => elm.parentNode.removeChild(elm));
|
130038
130236
|
this.doc.querySelectorAll('.cloned').forEach(elm => elm.classList.remove('cloned'));
|
130039
130237
|
}
|
@@ -130063,8 +130261,14 @@ class EditableBlocks {
|
|
130063
130261
|
if (this.onChange) this.onChange();
|
130064
130262
|
},
|
130065
130263
|
onMultipleSelect: this.onMultipleSelect,
|
130066
|
-
|
130067
|
-
|
130264
|
+
onSelectStart: block => {
|
130265
|
+
this.selectStart(block);
|
130266
|
+
},
|
130267
|
+
onSelectClear: () => {
|
130268
|
+
this.selectClear();
|
130269
|
+
if (this.onUnselectBlock) this.onUnselectBlock();
|
130270
|
+
},
|
130271
|
+
onSelectBlock: this.onSelectBlock
|
130068
130272
|
});
|
130069
130273
|
this.resizable = new Resizable({
|
130070
130274
|
selector: this.selector,
|
@@ -130116,7 +130320,7 @@ class EditableBlocks {
|
|
130116
130320
|
if (block.classList.contains('clone')) {
|
130117
130321
|
const clonedTarget = this.doc.querySelector(this.selector + '.cloned');
|
130118
130322
|
this.onEditStart(clonedTarget);
|
130119
|
-
this.
|
130323
|
+
this.selectClear(); // Disable drag during editing
|
130120
130324
|
|
130121
130325
|
if (!this.draggable) return;
|
130122
130326
|
this.draggable.disableDrag(clonedTarget);
|
@@ -130194,8 +130398,24 @@ class EditableBlocks {
|
|
130194
130398
|
}
|
130195
130399
|
|
130196
130400
|
addBlock(html, container) {
|
130197
|
-
this.
|
130401
|
+
this.selectClear(); // clear clones
|
130402
|
+
|
130403
|
+
this.blockSelector.unSelect(); // clear active
|
130404
|
+
|
130405
|
+
const parser = new DOMParser();
|
130406
|
+
let doc = parser.parseFromString(html, 'text/html');
|
130407
|
+
const block = doc.querySelector('.is-block');
|
130408
|
+
block.classList.add('block-dummy');
|
130409
|
+
html = doc.body.innerHTML;
|
130198
130410
|
container.insertAdjacentHTML('beforeend', html);
|
130411
|
+
const newBlock = document.querySelector('.block-dummy');
|
130412
|
+
|
130413
|
+
if (newBlock) {
|
130414
|
+
newBlock.classList.remove('block-dummy');
|
130415
|
+
if (this.onAddBlock) this.onAddBlock(newBlock);
|
130416
|
+
newBlock.classList.add('active');
|
130417
|
+
}
|
130418
|
+
|
130199
130419
|
this.refresh();
|
130200
130420
|
}
|
130201
130421
|
|
@@ -130210,6 +130430,7 @@ class EditableBlocks {
|
|
130210
130430
|
}
|
130211
130431
|
|
130212
130432
|
enableShape() {
|
130433
|
+
this.selectClear();
|
130213
130434
|
let blocks = Array.from(this.doc.querySelectorAll(this.selector)).filter(elm => elm.classList.contains('active'));
|
130214
130435
|
blocks.forEach(block => {
|
130215
130436
|
this.shape.enable(block);
|
@@ -130240,6 +130461,13 @@ class EditableBlocks {
|
|
130240
130461
|
this.common.clearAllBreakpoints(container);
|
130241
130462
|
}
|
130242
130463
|
|
130464
|
+
isMultiSelect() {
|
130465
|
+
// Check if multiple selection occurs. If so, add 'multi' class to hide all the handles
|
130466
|
+
let blocks = Array.from(this.doc.querySelectorAll(this.selector)).filter(elm => elm.classList.contains('active') && !elm.classList.contains('clone'));
|
130467
|
+
if (blocks.length > 1) return true;
|
130468
|
+
return false;
|
130469
|
+
}
|
130470
|
+
|
130243
130471
|
}
|
130244
130472
|
|
130245
130473
|
const dom = new Dom$1();
|
@@ -130287,6 +130515,7 @@ class ContentBox {
|
|
130287
130515
|
disableStaticSection: false,
|
130288
130516
|
framework: '',
|
130289
130517
|
imageRenameOnEdit: true,
|
130518
|
+
imageResizeOnBlock: false,
|
130290
130519
|
htmlButton: true,
|
130291
130520
|
// HTML button on left sidebar
|
130292
130521
|
undoRedoButtons: true,
|
@@ -133544,10 +133773,10 @@ Add an image for each feature.`, 'Revise the headline, paragraph, and all the te
|
|
133544
133773
|
onChange: () => {
|
133545
133774
|
this.onChange();
|
133546
133775
|
},
|
133547
|
-
onContentClick: e => {
|
133548
|
-
|
133549
|
-
|
133550
|
-
},
|
133776
|
+
// onContentClick: (e) => { // click during editing with ContentBuilder in a block
|
133777
|
+
// const block = e.target.closest('.is-block');
|
133778
|
+
// this.editor.elmTool.click(block, e);
|
133779
|
+
// },
|
133551
133780
|
onEditStart: block => {
|
133552
133781
|
block.classList.add('editable');
|
133553
133782
|
const cols = block.querySelectorAll('[data-click="true"]'); // or [contentEditable="true"]
|
@@ -133674,6 +133903,7 @@ Add an image for each feature.`, 'Revise the headline, paragraph, and all the te
|
|
133674
133903
|
useMediaRecorder: this.settings.useMediaRecorder,
|
133675
133904
|
encoderPath: this.settings.encoderPath,
|
133676
133905
|
hideImageGeneration: this.settings.hideImageGeneration,
|
133906
|
+
imageResizeOnBlock: this.settings.imageResizeOnBlock,
|
133677
133907
|
listFilesUrl: this.settings.listFilesUrl,
|
133678
133908
|
listFoldersUrl: this.settings.listFoldersUrl,
|
133679
133909
|
deleteFilesUrl: this.settings.deleteFilesUrl,
|
@@ -133759,6 +133989,7 @@ Add an image for each feature.`, 'Revise the headline, paragraph, and all the te
|
|
133759
133989
|
onBlockCanvasAdd: () => {
|
133760
133990
|
this.eb.refresh();
|
133761
133991
|
},
|
133992
|
+
blockContainer: '.is-box',
|
133762
133993
|
slider: this.settings.slider,
|
133763
133994
|
onRender: () => {
|
133764
133995
|
this.settings.onRender();
|