(core) Fixing selectby error on the creator panel.

Summary: [Select By] in the creator panel was bugged. It wasn't refreshed in some cases as the observable array that needed to be created seemed too complicated. This Diff recomputes this array when the user wants to change the selection.

Test Plan: added tests

Reviewers: georgegevoian

Reviewed By: georgegevoian

Differential Revision: https://phab.getgrist.com/D3541
This commit is contained in:
Jarosław Sadziński 2022-07-21 16:46:26 +02:00
parent 938928f1b9
commit 5c8211c61d
3 changed files with 21 additions and 13 deletions

View File

@ -396,18 +396,21 @@ export class RightPanel extends Disposable {
}); });
}); });
// TODO: this computed is not enough to make sure that the linkOptions are up to date. Indeed // This computed is not enough to make sure that the linkOptions are up to date. Indeed
// the selectBy function depends on a much greater number of observables. Creating that many // the selectBy function depends on a much greater number of observables. Creating that many
// dependencies does not seem a better approach. Instead, we could refresh the list of // dependencies does not seem a better approach. Instead, we refresh the list of
// linkOptions only when the user clicks the dropdown. Such behaviour is not supported by the // linkOptions only when the user clicks on the dropdown. Such behavior is not supported by the
// weasel select function as of writing and would require a custom implementation. // weasel select function as of writing and would require a custom implementation, so we will simulate
const linkOptions = Computed.create(owner, (use) => // this behavior by using temporary observable that will be changed when the user clicks on the dropdown.
selectBy( const refreshTrigger = Observable.create(owner, false);
const linkOptions = Computed.create(owner, (use) => {
void use(refreshTrigger);
return selectBy(
this._gristDoc.docModel, this._gristDoc.docModel,
use(viewModel.viewSections).peek(), viewModel.viewSections().all(),
activeSection, activeSection,
) );
); });
link.onWrite((val) => this._gristDoc.saveLink(val)); link.onWrite((val) => this._gristDoc.saveLink(val));
return [ return [
@ -456,7 +459,12 @@ export class RightPanel extends Disposable {
dom.maybe((use) => !use(activeSection.isRaw), () => [ dom.maybe((use) => !use(activeSection.isRaw), () => [
cssLabel('SELECT BY'), cssLabel('SELECT BY'),
cssRow( cssRow(
select(link, linkOptions, {defaultLabel: 'Select Widget'}), dom.update(
select(link, linkOptions, {defaultLabel: 'Select Widget'}),
dom.on('click', () => {
refreshTrigger.set(!refreshTrigger.get());
})
),
testId('right-select-by') testId('right-select-by')
), ),
]), ]),

View File

@ -189,7 +189,7 @@ export function fromTableDataAction(tableData: TableDataAction): TableColValues
* Convert a list of rows into an object with columns of values, used for * Convert a list of rows into an object with columns of values, used for
* BulkAddRecord/BulkUpdateRecord actions. * BulkAddRecord/BulkUpdateRecord actions.
*/ */
export function getColValues(records: RowRecord[]): BulkColValues { export function getColValues(records: Partial<RowRecord>[]): BulkColValues {
const colIdSet = new Set<string>(); const colIdSet = new Set<string>();
for (const r of records) { for (const r of records) {
for (const c of Object.keys(r)) { for (const c of Object.keys(r)) {
@ -200,7 +200,7 @@ export function getColValues(records: RowRecord[]): BulkColValues {
} }
const result: BulkColValues = {}; const result: BulkColValues = {};
for (const colId of colIdSet) { for (const colId of colIdSet) {
result[colId] = records.map(r => r[colId]); result[colId] = records.map(r => r[colId]!);
} }
return result; return result;
} }

View File

@ -1157,7 +1157,7 @@ export function isSidePanelOpen(which: 'right'|'left'): Promise<boolean> {
} }
/* /*
* Toggles (opens or closes) the right panel and wait for the transition to complete. An optional * Toggles (opens or closes) the right or left panel and wait for the transition to complete. An optional
* argument can specify the desired state. * argument can specify the desired state.
*/ */
export async function toggleSidePanel(which: 'right'|'left', goal: 'open'|'close'|'toggle' = 'toggle') { export async function toggleSidePanel(which: 'right'|'left', goal: 'open'|'close'|'toggle' = 'toggle') {