mirror of
https://github.com/gristlabs/grist-core.git
synced 2024-10-27 20:44:07 +00:00
(core) Fix for layout editor when fields are removed
Summary: Fix for layout editor when fields are removed using the creator panel. Layout editor wasn't updated properly when "layoutSpecs" were changed. Test Plan: Updated Reviewers: georgegevoian Reviewed By: georgegevoian Differential Revision: https://phab.getgrist.com/D3700
This commit is contained in:
parent
2248053b09
commit
46148aa125
@ -326,7 +326,7 @@ RecordLayout.prototype.buildLayoutDom = function(row, optCreateEditor) {
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
const sub = this.layoutSpec.subscribe((spec) => { layout.buildLayout(spec); });
|
const sub = this.layoutSpec.subscribe((spec) => { layout.buildLayout(spec, createEditor); });
|
||||||
|
|
||||||
if (createEditor) {
|
if (createEditor) {
|
||||||
this.layoutEditor(RecordLayoutEditor.create(this, layout));
|
this.layoutEditor(RecordLayoutEditor.create(this, layout));
|
||||||
|
@ -1041,43 +1041,46 @@ export async function openAddWidgetToPage() {
|
|||||||
// must be already opened when calling this function.
|
// must be already opened when calling this function.
|
||||||
export async function selectWidget(
|
export async function selectWidget(
|
||||||
typeRe: RegExp|string,
|
typeRe: RegExp|string,
|
||||||
tableRe: RegExp|string,
|
tableRe: RegExp|string = '',
|
||||||
options: PageWidgetPickerOptions = {}) {
|
options: PageWidgetPickerOptions = {}) {
|
||||||
|
|
||||||
const tableEl = driver.findContent('.test-wselect-table', tableRe);
|
|
||||||
|
|
||||||
// unselect all selected columns
|
|
||||||
for (const col of (await driver.findAll('.test-wselect-column[class*=-selected]'))) {
|
|
||||||
await col.click();
|
|
||||||
}
|
|
||||||
|
|
||||||
// let's select table
|
|
||||||
await tableEl.click();
|
|
||||||
|
|
||||||
const pivotEl = tableEl.find('.test-wselect-pivot');
|
|
||||||
if (await pivotEl.isPresent()) {
|
|
||||||
await toggleSelectable(pivotEl, Boolean(options.summarize));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (options.summarize) {
|
|
||||||
for (const columnEl of await driver.findAll('.test-wselect-column')) {
|
|
||||||
const label = await columnEl.getText();
|
|
||||||
// TODO: Matching cols with regexp calls for trouble and adds no value. I think function should be
|
|
||||||
// rewritten using string matching only.
|
|
||||||
const goal = Boolean(options.summarize.find(r => label.match(r)));
|
|
||||||
await toggleSelectable(columnEl, goal);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (options.selectBy) {
|
|
||||||
// select link
|
|
||||||
await driver.find('.test-wselect-selectby').doClick();
|
|
||||||
await driver.findContent('.test-wselect-selectby option', options.selectBy).doClick();
|
|
||||||
}
|
|
||||||
|
|
||||||
// select right type
|
// select right type
|
||||||
await driver.findContent('.test-wselect-type', typeRe).doClick();
|
await driver.findContent('.test-wselect-type', typeRe).doClick();
|
||||||
|
|
||||||
|
if (tableRe) {
|
||||||
|
const tableEl = driver.findContent('.test-wselect-table', tableRe);
|
||||||
|
|
||||||
|
// unselect all selected columns
|
||||||
|
for (const col of (await driver.findAll('.test-wselect-column[class*=-selected]'))) {
|
||||||
|
await col.click();
|
||||||
|
}
|
||||||
|
|
||||||
|
// let's select table
|
||||||
|
await tableEl.click();
|
||||||
|
|
||||||
|
const pivotEl = tableEl.find('.test-wselect-pivot');
|
||||||
|
if (await pivotEl.isPresent()) {
|
||||||
|
await toggleSelectable(pivotEl, Boolean(options.summarize));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options.summarize) {
|
||||||
|
for (const columnEl of await driver.findAll('.test-wselect-column')) {
|
||||||
|
const label = await columnEl.getText();
|
||||||
|
// TODO: Matching cols with regexp calls for trouble and adds no value. I think function should be
|
||||||
|
// rewritten using string matching only.
|
||||||
|
const goal = Boolean(options.summarize.find(r => label.match(r)));
|
||||||
|
await toggleSelectable(columnEl, goal);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (options.selectBy) {
|
||||||
|
// select link
|
||||||
|
await driver.find('.test-wselect-selectby').doClick();
|
||||||
|
await driver.findContent('.test-wselect-selectby option', options.selectBy).doClick();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (options.dontAdd) {
|
if (options.dontAdd) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1985,7 +1988,8 @@ export class Session {
|
|||||||
return doc;
|
return doc;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async tempNewDoc(cleanup: Cleanup, docName: string, {load} = {load: true}) {
|
public async tempNewDoc(cleanup: Cleanup, docName: string = '', {load} = {load: true}) {
|
||||||
|
docName ||= `Test${Date.now()}`;
|
||||||
const docId = await createNewDoc(this.settings.name, this.settings.orgDomain, this.settings.workspace,
|
const docId = await createNewDoc(this.settings.name, this.settings.orgDomain, this.settings.workspace,
|
||||||
docName, {email: this.settings.email});
|
docName, {email: this.settings.email});
|
||||||
if (load) {
|
if (load) {
|
||||||
|
Loading…
Reference in New Issue
Block a user