(core) Update grainjs, fix some code affected by stronger types.

Summary: Also clean up dom-ownership in Charts using the new grainjs maybeOwned() method.

Test Plan: Should be no behaviour changes; existing tests should pass

Reviewers: georgegevoian

Reviewed By: georgegevoian

Differential Revision: https://phab.getgrist.com/D3166
This commit is contained in:
Dmitry S 2021-12-05 00:14:38 -05:00
parent 7a6d726daa
commit e4314f9def
4 changed files with 26 additions and 30 deletions

View File

@ -22,8 +22,8 @@ import {nativeCompare} from 'app/common/gutil';
import {BaseFormatter} from 'app/common/ValueFormatter'; import {BaseFormatter} from 'app/common/ValueFormatter';
import {decodeObject} from 'app/plugin/objtypes'; import {decodeObject} from 'app/plugin/objtypes';
import {Events as BackboneEvents} from 'backbone'; import {Events as BackboneEvents} from 'backbone';
import {Computed, dom, DomElementArg, fromKo, Disposable as GrainJSDisposable, IOption, import {Computed, dom, DomContents, DomElementArg, fromKo, Disposable as GrainJSDisposable, IOption,
makeTestId, MultiHolder, Observable, styled} from 'grainjs'; makeTestId, Observable, styled} from 'grainjs';
import * as ko from 'knockout'; import * as ko from 'knockout';
import clamp = require('lodash/clamp'); import clamp = require('lodash/clamp');
import debounce = require('lodash/debounce'); import debounce = require('lodash/debounce');
@ -477,13 +477,11 @@ export class ChartConfig extends GrainJSDisposable {
private get _optionsObj() { return this._section.optionsObj; } private get _optionsObj() { return this._section.optionsObj; }
public buildDom() { public buildDom(): DomContents {
if (this._section.parentKey() !== 'chart') { return null; } if (this._section.parentKey() !== 'chart') { return null; }
const owner = new MultiHolder();
return [ return [
dom.autoDispose(owner),
cssRow( cssRow(
select(this._chartType, [ select(this._chartType, [
{value: 'bar', label: 'Bar Chart', icon: 'ChartBar' }, {value: 'bar', label: 'Bar Chart', icon: 'ChartBar' },
@ -502,7 +500,7 @@ export class ChartConfig extends GrainJSDisposable {
cssCheckboxRow('Invert Y-axis', this._optionsObj.prop('invertYAxis')), cssCheckboxRow('Invert Y-axis', this._optionsObj.prop('invertYAxis')),
cssCheckboxRow('Log scale Y-axis', this._optionsObj.prop('logYAxis')), cssCheckboxRow('Log scale Y-axis', this._optionsObj.prop('logYAxis')),
]), ]),
dom.maybe((use) => use(this._section.chartTypeDef) === 'donut', () => [ dom.maybeOwned((use) => use(this._section.chartTypeDef) === 'donut', (owner) => [
cssSlideRow( cssSlideRow(
'Hole Size', 'Hole Size',
Computed.create(owner, (use) => use(this._optionsObj.prop('donutHoleSize')) ?? DONUT_DEFAULT_HOLE_SIZE), Computed.create(owner, (use) => use(this._optionsObj.prop('donutHoleSize')) ?? DONUT_DEFAULT_HOLE_SIZE),
@ -658,7 +656,7 @@ export class ChartConfig extends GrainJSDisposable {
); );
} }
private _buildYAxis() { private _buildYAxis(): Element {
// The y-axis are all visible fields that comes after the x-axis and maybe the group data // The y-axis are all visible fields that comes after the x-axis and maybe the group data
// column. Hence the draggable list of y-axis needs to skip either one or two visible fields. // column. Hence the draggable list of y-axis needs to skip either one or two visible fields.

View File

@ -101,7 +101,7 @@ declare module "app/client/components/ViewConfigTab" {
import {Disposable} from 'app/client/lib/dispose'; import {Disposable} from 'app/client/lib/dispose';
import {KoArray} from "app/client/lib/koArray"; import {KoArray} from "app/client/lib/koArray";
import {ColumnRec, ViewRec, ViewSectionRec} from "app/client/models/DocModel"; import {ColumnRec, ViewRec, ViewSectionRec} from "app/client/models/DocModel";
import {DomArg} from 'grainjs'; import {DomArg, DomContents} from 'grainjs';
namespace ViewConfigTab { namespace ViewConfigTab {
interface ViewSectionData { interface ViewSectionData {
@ -113,7 +113,7 @@ declare module "app/client/components/ViewConfigTab" {
class ViewConfigTab extends Disposable { class ViewConfigTab extends Disposable {
constructor(options: {gristDoc: GristDoc, viewModel: ViewRec, skipDomBuild?: boolean}); constructor(options: {gristDoc: GristDoc, viewModel: ViewRec, skipDomBuild?: boolean});
public buildConfigDomObj(): TabContent[]; public buildConfigDomObj(): TabContent[];
public buildSortDom(): DomArg; public buildSortDom(): DomContents;
// TODO: these should be made private or renamed. // TODO: these should be made private or renamed.
public _buildSectionFieldsConfig(): DomArg; public _buildSectionFieldsConfig(): DomArg;
public _buildNameDom(): DomArg; public _buildNameDom(): DomArg;
@ -123,7 +123,7 @@ declare module "app/client/components/ViewConfigTab" {
public _buildFilterDom(): DomArg; public _buildFilterDom(): DomArg;
public _buildThemeDom(): DomArg; public _buildThemeDom(): DomArg;
public _buildGridStyleDom(): DomArg; public _buildGridStyleDom(): DomArg;
public _buildChartConfigDom(): DomArg; public _buildChartConfigDom(): DomContents;
public _buildLayoutDom(): DomArg; public _buildLayoutDom(): DomArg;
public _buildLinkDom(): DomArg; public _buildLinkDom(): DomArg;
public _buildCustomTypeItems(): DomArg; public _buildCustomTypeItems(): DomArg;

View File

@ -50,7 +50,7 @@ function createLoadedDocMenu(home: HomeModel) {
return css.docList( return css.docList(
dom.maybe(!home.app.currentFeatures.workspaces, () => [ dom.maybe(!home.app.currentFeatures.workspaces, () => [
css.docListHeader('This service is not available right now'), css.docListHeader('This service is not available right now'),
dom.text('(The organization needs a paid plan)') dom('span', '(The organization needs a paid plan)')
]), ]),
// currentWS and showIntro observables change together. We capture both in one domComputed call. // currentWS and showIntro observables change together. We capture both in one domComputed call.

View File

@ -323,25 +323,23 @@ export class RightPanel extends Disposable {
vct._buildChartConfigDom(), vct._buildChartConfigDom(),
]), ]),
dom.maybe((use) => use(this._pageWidgetType) === 'custom', () => [ dom.maybe((use) => use(this._pageWidgetType) === 'custom', () => {
cssLabel('CUSTOM'), const parts = vct._buildCustomTypeItems() as any[];
() => { return [
const parts = vct._buildCustomTypeItems() as any[]; cssLabel('CUSTOM'),
return [ // If 'customViewPlugin' feature is on, show the toggle that allows switching to
// If 'customViewPlugin' feature is on, show the toggle that allows switching to // plugin mode. Note that the default mode for a new 'custom' view is 'url', so that's
// plugin mode. Note that the default mode for a new 'custom' view is 'url', so that's // the only one that will be shown without the feature flag.
// the only one that will be shown without the feature flag. dom.maybe((use) => use(this._gristDoc.app.features).customViewPlugin,
dom.maybe((use) => use(this._gristDoc.app.features).customViewPlugin, () => dom('div', parts[0].buildDom())),
() => dom('div', parts[0].buildDom())), dom.maybe(use => use(activeSection.customDef.mode) === 'plugin',
dom.maybe(use => use(activeSection.customDef.mode) === 'plugin', () => dom('div', parts[2].buildDom())),
() => dom('div', parts[2].buildDom())), // In the default url mode, allow picking a url and granting/forbidding
// In the default url mode, allow picking a url and granting/forbidding // access to data.
// access to data. dom.maybe(use => use(activeSection.customDef.mode) === 'url',
dom.maybe(use => use(activeSection.customDef.mode) === 'url', () => dom.create(CustomSectionConfig, activeSection, this._gristDoc.app.topAppModel.api)),
() => dom.create(CustomSectionConfig, activeSection, this._gristDoc.app.topAppModel.api)), ];
]; }),
}
]),
dom.maybe((use) => use(this._pageWidgetType) !== 'chart', () => [ dom.maybe((use) => use(this._pageWidgetType) !== 'chart', () => [
cssSeparator(), cssSeparator(),