@mwater/visualization 5.2.0 → 5.3.1
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.
- package/lib/ColorComponent.d.ts +10 -11
- package/lib/ColorComponent.js +78 -29
- package/lib/ColorSchemeFactory.d.ts +13 -2
- package/lib/ColorSchemeFactory.js +7 -5
- package/lib/CustomColorsContext.d.ts +6 -0
- package/lib/CustomColorsContext.js +6 -0
- package/lib/FiltersDesignerComponent.d.ts +1 -4
- package/lib/FiltersDesignerComponent.js +2 -3
- package/lib/LocaleContextInjector.d.ts +5 -11
- package/lib/LocaleContextInjector.js +4 -12
- package/lib/MWaterAddRelatedFormComponent.js +3 -3
- package/lib/MWaterAddRelatedIndicatorComponent.d.ts +1 -4
- package/lib/MWaterAddRelatedIndicatorComponent.js +6 -6
- package/lib/MWaterCompleteTableSelectComponent.d.ts +5 -16
- package/lib/MWaterCompleteTableSelectComponent.js +36 -36
- package/lib/MWaterContextComponent.d.ts +4 -6
- package/lib/MWaterContextComponent.js +4 -13
- package/lib/MWaterLoaderComponent.d.ts +5 -3
- package/lib/MWaterLoaderComponent.js +2 -1
- package/lib/MWaterTableSelectComponent.d.ts +1 -4
- package/lib/MWaterTableSelectComponent.js +10 -12
- package/lib/UIComponents.d.ts +2 -2
- package/lib/UIComponents.js +4 -12
- package/lib/axes/AxisBuilder.d.ts +7 -4
- package/lib/axes/AxisBuilder.js +3 -1
- package/lib/axes/AxisComponent.d.ts +2 -5
- package/lib/axes/AxisComponent.js +1 -2
- package/lib/axes/ColorPaletteCollectionComponent.d.ts +5 -12
- package/lib/axes/ColorPaletteCollectionComponent.js +67 -36
- package/lib/dashboards/DashboardComponent.d.ts +4 -12
- package/lib/dashboards/DashboardComponent.js +18 -38
- package/lib/dashboards/DashboardDesign.d.ts +3 -3
- package/lib/dashboards/DashboardUpgrader.js +36 -1
- package/lib/dashboards/DashboardViewComponent.d.ts +5 -34
- package/lib/dashboards/DashboardViewComponent.js +109 -132
- package/lib/dashboards/FontStyleEditor.d.ts +8 -0
- package/lib/dashboards/FontStyleEditor.js +130 -0
- package/lib/dashboards/LayoutOptionsComponent.d.ts +0 -1
- package/lib/dashboards/LayoutOptionsComponent.js +211 -42
- package/lib/dashboards/ServerDashboardDataSource.d.ts +1 -2
- package/lib/dashboards/ServerDashboardDataSource.js +52 -33
- package/lib/dashboards/WidgetComponent.d.ts +3 -3
- package/lib/dashboards/WidgetComponent.js +3 -6
- package/lib/dashboards/WidgetDataSourcePrioritizer.d.ts +20 -0
- package/lib/dashboards/WidgetDataSourcePrioritizer.js +72 -0
- package/lib/dashboards/layoutOptions.d.ts +83 -0
- package/lib/dashboards/layoutOptions.js +436 -10
- package/lib/datagrids/DatagridDesign.d.ts +7 -6
- package/lib/datagrids/ServerDatagridDataSource.d.ts +7 -6
- package/lib/datagrids/ServerDatagridDataSource.js +87 -33
- package/lib/demo.js +3 -3
- package/lib/index.css +5 -0
- package/lib/index.d.ts +1 -1
- package/lib/index.js +0 -1
- package/lib/layouts/LayoutManager.d.ts +33 -29
- package/lib/layouts/LayoutManager.js +2 -8
- package/lib/layouts/blocks/BlocksDisplayComponent.d.ts +26 -57
- package/lib/layouts/blocks/BlocksDisplayComponent.js +122 -205
- package/lib/layouts/blocks/BlocksLayoutManager.d.ts +6 -22
- package/lib/layouts/blocks/BlocksLayoutManager.js +5 -14
- package/lib/layouts/blocks/HorizontalBlockComponent.d.ts +5 -4
- package/lib/layouts/blocks/HorizontalBlockComponent.js +5 -5
- package/lib/mWaterLoader.d.ts +2 -0
- package/lib/mWaterLoader.js +2 -1
- package/lib/maps/AddLayerComponent.d.ts +6 -8
- package/lib/maps/AddLayerComponent.js +6 -6
- package/lib/maps/BingLayer.js +10 -20
- package/lib/maps/BufferLayer.js +2 -1
- package/lib/maps/ChoroplethLayer.js +2 -1
- package/lib/maps/DirectMapDataSource.d.ts +5 -2
- package/lib/maps/DirectMapDataSource.js +2 -1
- package/lib/maps/EditPopupComponent.js +2 -1
- package/lib/maps/MapComponent.d.ts +1 -4
- package/lib/maps/MapComponent.js +3 -3
- package/lib/maps/MarkersLayer.js +30 -25
- package/lib/maps/RasterMapViewComponent.d.ts +1 -4
- package/lib/maps/RasterMapViewComponent.js +3 -3
- package/lib/maps/ServerMapDataSource.d.ts +2 -3
- package/lib/maps/ServerMapDataSource.js +5 -5
- package/lib/maps/VectorMapViewComponent.js +2 -1
- package/lib/maps/mapSymbols.js +2 -0
- package/lib/maps/symbols/font-awesome/cloud-rain.png +0 -0
- package/lib/maps/vectorMaps.js +61 -55
- package/lib/quickfilter/QuickfiltersComponent.d.ts +1 -4
- package/lib/quickfilter/QuickfiltersComponent.js +3 -3
- package/lib/richtext/DropdownPaletteItem.d.ts +32 -0
- package/lib/richtext/DropdownPaletteItem.js +82 -0
- package/lib/richtext/FontColorPaletteItem.d.ts +1 -5
- package/lib/richtext/FontColorPaletteItem.js +32 -27
- package/lib/richtext/ItemsHtmlConverter.js +12 -3
- package/lib/richtext/RichTextComponent.d.ts +26 -52
- package/lib/richtext/RichTextComponent.js +166 -128
- package/lib/valueFormatter.js +6 -1
- package/lib/wellknown.d.ts +5 -0
- package/lib/wellknown.js +288 -0
- package/lib/widgets/DropdownWidgetComponent.d.ts +8 -25
- package/lib/widgets/DropdownWidgetComponent.js +48 -25
- package/lib/widgets/IFrameWidgetComponent.d.ts +1 -2
- package/lib/widgets/ImageWidgetComponent.d.ts +2 -3
- package/lib/widgets/MapWidget.d.ts +2 -0
- package/lib/widgets/MapWidget.js +2 -1
- package/lib/widgets/TOCWidget.js +2 -1
- package/lib/widgets/Widget.d.ts +2 -0
- package/lib/widgets/WidgetDataSource.d.ts +3 -1
- package/lib/widgets/charts/Chart.d.ts +0 -1
- package/lib/widgets/charts/ChartViewComponent.d.ts +4 -0
- package/lib/widgets/charts/ChartViewComponent.js +11 -3
- package/lib/widgets/charts/ChartWidget.d.ts +1 -62
- package/lib/widgets/charts/ChartWidget.js +4 -183
- package/lib/widgets/charts/ChartWidgetComponent.d.ts +51 -0
- package/lib/widgets/charts/ChartWidgetComponent.js +167 -0
- package/lib/widgets/charts/calendar/CalendarChartViewComponent.d.ts +1 -4
- package/lib/widgets/charts/calendar/CalendarChartViewComponent.js +4 -4
- package/lib/widgets/charts/layered/LayeredChart.d.ts +5 -10
- package/lib/widgets/charts/layered/LayeredChart.js +6 -7
- package/lib/widgets/charts/layered/LayeredChartCompiler.d.ts +4 -2
- package/lib/widgets/charts/layered/LayeredChartCompiler.js +46 -32
- package/lib/widgets/charts/layered/LayeredChartDesign.d.ts +4 -0
- package/lib/widgets/charts/layered/LayeredChartDesignerComponent.d.ts +3 -0
- package/lib/widgets/charts/layered/LayeredChartDesignerComponent.js +21 -3
- package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.d.ts +1 -2
- package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.js +2 -1
- package/lib/widgets/charts/layered/LayeredChartViewComponent.d.ts +1 -4
- package/lib/widgets/charts/layered/LayeredChartViewComponent.js +89 -38
- package/lib/widgets/charts/pivot/IntersectionDesignerComponent.d.ts +5 -112
- package/lib/widgets/charts/pivot/IntersectionDesignerComponent.js +122 -166
- package/lib/widgets/charts/pivot/PivotChart.d.ts +6 -0
- package/lib/widgets/charts/pivot/PivotChart.js +47 -17
- package/lib/widgets/charts/pivot/PivotChartDesign.d.ts +11 -0
- package/lib/widgets/charts/pivot/PivotChartDesignerComponent.d.ts +1 -1
- package/lib/widgets/charts/pivot/PivotChartDesignerComponent.js +1 -1
- package/lib/widgets/charts/pivot/PivotChartLayoutBuilder.d.ts +2 -2
- package/lib/widgets/charts/pivot/PivotChartLayoutBuilder.js +20 -36
- package/lib/widgets/charts/pivot/PivotChartLayoutComponent.js +0 -1
- package/lib/widgets/charts/pivot/PivotChartQueryBuilder.d.ts +23 -2
- package/lib/widgets/charts/pivot/PivotChartQueryBuilder.js +215 -181
- package/lib/widgets/charts/pivot/PivotChartUtils.d.ts +2 -2
- package/lib/widgets/charts/pivot/PivotChartViewComponent.d.ts +9 -28
- package/lib/widgets/charts/pivot/PivotChartViewComponent.js +20 -60
- package/lib/widgets/charts/table/TableChart.js +8 -4
- package/lib/widgets/charts/table/TableChartDesignerComponent.js +3 -3
- package/lib/widgets/charts/table/TableChartViewComponent.js +11 -11
- package/lib/widgets/text/TextComponent.d.ts +5 -12
- package/lib/widgets/text/TextComponent.js +19 -39
- package/lib/widgets/text/TextWidget.d.ts +2 -1
- package/lib/widgets/text/TextWidget.js +5 -1
- package/lib/widgets/text/TextWidgetComponent.d.ts +15 -3
- package/lib/widgets/text/TextWidgetComponent.js +76 -19
- package/lib/widgets/text/TextWidgetDesign.d.ts +13 -1
- package/lib/widgets/text/TextWidgetDesign.js +6 -0
- package/package.json +4 -4
- package/src/ColorComponent.tsx +177 -0
- package/src/ColorSchemeFactory.ts +12 -6
- package/src/CustomColorsContext.tsx +9 -0
- package/src/FiltersDesignerComponent.ts +3 -4
- package/src/LocaleContextInjector.tsx +14 -13
- package/src/MWaterAddRelatedFormComponent.ts +3 -3
- package/src/MWaterAddRelatedIndicatorComponent.ts +6 -6
- package/src/MWaterCompleteTableSelectComponent.tsx +36 -36
- package/src/MWaterContextComponent.tsx +8 -17
- package/src/MWaterLoaderComponent.ts +6 -3
- package/src/MWaterTableSelectComponent.tsx +11 -12
- package/src/{UIComponents.ts → UIComponents.tsx} +7 -15
- package/src/axes/AxisBuilder.ts +7 -5
- package/src/axes/AxisComponent.ts +3 -4
- package/src/axes/{ColorPaletteCollectionComponent.ts → ColorPaletteCollectionComponent.tsx} +87 -61
- package/src/dashboards/DashboardComponent.tsx +71 -107
- package/src/dashboards/DashboardDesign.ts +3 -3
- package/src/dashboards/DashboardUpgrader.ts +41 -1
- package/src/dashboards/DashboardViewComponent.tsx +313 -0
- package/src/dashboards/FontStyleEditor.tsx +166 -0
- package/src/dashboards/LayoutOptionsComponent.tsx +380 -75
- package/src/dashboards/ServerDashboardDataSource.ts +52 -33
- package/src/dashboards/WidgetComponent.tsx +6 -12
- package/src/dashboards/WidgetDataSourcePrioritizer.ts +82 -0
- package/src/dashboards/layoutOptions.tsx +581 -0
- package/src/datagrids/DatagridDesign.ts +8 -3
- package/src/datagrids/ServerDatagridDataSource.ts +106 -43
- package/src/demo.ts +3 -3
- package/src/index.css +5 -0
- package/src/index.ts +1 -1
- package/src/layouts/LayoutManager.ts +44 -42
- package/src/layouts/blocks/BlocksDisplayComponent.tsx +498 -0
- package/src/layouts/blocks/BlocksLayoutManager.ts +6 -15
- package/src/layouts/blocks/HorizontalBlockComponent.ts +9 -8
- package/src/mWaterLoader.ts +4 -1
- package/src/maps/AddLayerComponent.ts +9 -9
- package/src/maps/BingLayer.ts +16 -26
- package/src/maps/BufferLayer.ts +2 -1
- package/src/maps/ChoroplethLayer.ts +2 -1
- package/src/maps/DirectMapDataSource.ts +12 -3
- package/src/maps/EditPopupComponent.ts +2 -1
- package/src/maps/MapComponent.ts +3 -3
- package/src/maps/MarkersLayer.ts +38 -41
- package/src/maps/RasterMapViewComponent.ts +3 -3
- package/src/maps/ServerMapDataSource.ts +7 -7
- package/src/maps/VectorMapViewComponent.tsx +2 -1
- package/src/maps/mapSymbols.ts +2 -0
- package/src/maps/symbols/font-awesome/cloud-rain.png +0 -0
- package/src/maps/vectorMaps.tsx +79 -74
- package/src/quickfilter/QuickfiltersComponent.ts +3 -3
- package/src/richtext/DropdownPaletteItem.tsx +144 -0
- package/src/richtext/FontColorPaletteItem.tsx +160 -0
- package/src/richtext/ItemsHtmlConverter.ts +15 -5
- package/src/richtext/RichTextComponent.tsx +274 -232
- package/src/valueFormatter.ts +5 -1
- package/src/wellknown.ts +286 -0
- package/src/widgets/DropdownWidgetComponent.tsx +75 -0
- package/src/widgets/MapWidget.ts +5 -2
- package/src/widgets/TOCWidget.ts +2 -1
- package/src/widgets/Widget.ts +3 -0
- package/src/widgets/WidgetDataSource.ts +3 -1
- package/src/widgets/charts/Chart.ts +1 -1
- package/src/widgets/charts/ChartViewComponent.ts +16 -3
- package/src/widgets/charts/ChartWidget.ts +3 -275
- package/src/widgets/charts/ChartWidgetComponent.tsx +281 -0
- package/src/widgets/charts/calendar/CalendarChartViewComponent.tsx +4 -4
- package/src/widgets/charts/layered/LayeredChart.ts +4 -6
- package/src/widgets/charts/layered/LayeredChartCompiler.ts +80 -63
- package/src/widgets/charts/layered/LayeredChartDesign.ts +7 -1
- package/src/widgets/charts/layered/LayeredChartDesignerComponent.tsx +43 -10
- package/src/widgets/charts/layered/LayeredChartLayerDesignerComponent.tsx +6 -6
- package/src/widgets/charts/layered/LayeredChartViewComponent.ts +140 -88
- package/src/widgets/charts/pivot/IntersectionDesignerComponent.tsx +305 -221
- package/src/widgets/charts/pivot/PivotChart.ts +56 -18
- package/src/widgets/charts/pivot/PivotChartDesign.ts +12 -0
- package/src/widgets/charts/pivot/PivotChartDesignerComponent.tsx +4 -3
- package/src/widgets/charts/pivot/PivotChartLayoutBuilder.ts +39 -76
- package/src/widgets/charts/pivot/PivotChartLayoutComponent.tsx +0 -1
- package/src/widgets/charts/pivot/PivotChartQueryBuilder.ts +230 -189
- package/src/widgets/charts/pivot/PivotChartUtils.ts +4 -4
- package/src/widgets/charts/pivot/{PivotChartViewComponent.ts → PivotChartViewComponent.tsx} +86 -89
- package/src/widgets/charts/table/TableChart.ts +8 -4
- package/src/widgets/charts/table/TableChartDesignerComponent.ts +4 -4
- package/src/widgets/charts/table/TableChartViewComponent.ts +13 -14
- package/src/widgets/text/TextComponent.tsx +47 -49
- package/src/widgets/text/TextWidget.ts +8 -3
- package/src/widgets/text/TextWidgetComponent.tsx +249 -0
- package/src/widgets/text/TextWidgetDesign.ts +22 -1
- package/src/ColorComponent.ts +0 -117
- package/src/dashboards/DashboardViewComponent.ts +0 -303
- package/src/dashboards/layoutOptions.ts +0 -40
- package/src/layout-styles.css +0 -263
- package/src/layouts/blocks/BlocksDisplayComponent.ts +0 -461
- package/src/layouts/grid/GridLayoutComponent.ts +0 -67
- package/src/layouts/grid/GridLayoutManager.ts +0 -185
- package/src/layouts/grid/LegoLayoutEngine.ts +0 -142
- package/src/layouts/grid/PaletteItemComponent.ts +0 -28
- package/src/layouts/grid/README.md +0 -14
- package/src/layouts/grid/WidgetContainerComponent.ts +0 -420
- package/src/richtext/FontColorPaletteItem.ts +0 -172
- package/src/richtext/FontSizePaletteItem.ts +0 -110
- package/src/widgets/DropdownWidgetComponent.ts +0 -78
- package/src/widgets/text/TextWidgetComponent.ts +0 -120
|
@@ -4,7 +4,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
const lodash_1 = __importDefault(require("lodash"));
|
|
7
|
-
const prop_types_1 = __importDefault(require("prop-types"));
|
|
8
7
|
const react_1 = __importDefault(require("react"));
|
|
9
8
|
const R = react_1.default.createElement;
|
|
10
9
|
const react_select_1 = __importDefault(require("react-select"));
|
|
@@ -14,6 +13,7 @@ const TextLiteralComponent_1 = __importDefault(require("./TextLiteralComponent")
|
|
|
14
13
|
const DateExprComponent_1 = __importDefault(require("./DateExprComponent"));
|
|
15
14
|
const QuickfilterCompiler_1 = __importDefault(require("./QuickfilterCompiler"));
|
|
16
15
|
const IdArrayQuickfilterComponent_1 = __importDefault(require("./IdArrayQuickfilterComponent"));
|
|
16
|
+
const contexts_1 = require("@mwater/expressions-ui/lib/contexts");
|
|
17
17
|
/** Displays quick filters and allows their value to be modified */
|
|
18
18
|
class QuickfiltersComponent extends react_1.default.Component {
|
|
19
19
|
renderQuickfilter(item, index) {
|
|
@@ -153,7 +153,7 @@ class QuickfiltersComponent extends react_1.default.Component {
|
|
|
153
153
|
exports.default = QuickfiltersComponent;
|
|
154
154
|
/** Quickfilter for an enum */
|
|
155
155
|
class EnumQuickfilterComponent extends react_1.default.Component {
|
|
156
|
-
static
|
|
156
|
+
static contextType = contexts_1.LocaleContext;
|
|
157
157
|
handleSingleChange = (val) => {
|
|
158
158
|
if (val) {
|
|
159
159
|
return this.props.onValueChange(val);
|
|
@@ -206,7 +206,7 @@ class EnumQuickfilterComponent extends react_1.default.Component {
|
|
|
206
206
|
render() {
|
|
207
207
|
const options = lodash_1.default.map(this.props.options, (opt) => ({
|
|
208
208
|
value: opt.id,
|
|
209
|
-
label: expressions_1.ExprUtils.localizeString(opt.name, this.context
|
|
209
|
+
label: expressions_1.ExprUtils.localizeString(opt.name, this.context)
|
|
210
210
|
}));
|
|
211
211
|
// Determine width, estimating about 8 px per letter with 120px padding
|
|
212
212
|
let width = lodash_1.default.max(options, (o) => o.label.length)?.label?.length;
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import React, { ReactNode } from "react";
|
|
2
|
+
export interface DropdownItem {
|
|
3
|
+
label: ReactNode;
|
|
4
|
+
value: string;
|
|
5
|
+
/** If true, this item will be rendered only when "More..." is clicked. */
|
|
6
|
+
more?: boolean;
|
|
7
|
+
}
|
|
8
|
+
export interface DropdownPaletteItemProps {
|
|
9
|
+
label: ReactNode;
|
|
10
|
+
items: DropdownItem[];
|
|
11
|
+
/** Called with clicked item */
|
|
12
|
+
onSelect: (value: string) => void;
|
|
13
|
+
/** should the popup be under or over? */
|
|
14
|
+
position?: "under" | "over";
|
|
15
|
+
}
|
|
16
|
+
interface DropdownPaletteItemState {
|
|
17
|
+
open: boolean;
|
|
18
|
+
moreOpen: boolean;
|
|
19
|
+
}
|
|
20
|
+
/** Palette item that allows picking from dropdown */
|
|
21
|
+
export default class DropdownPaletteItem extends React.Component<DropdownPaletteItemProps, DropdownPaletteItemState> {
|
|
22
|
+
static defaultProps: {
|
|
23
|
+
position: string;
|
|
24
|
+
};
|
|
25
|
+
constructor(props: DropdownPaletteItemProps);
|
|
26
|
+
handleMouseDown: (ev: React.MouseEvent) => void;
|
|
27
|
+
handleMoreClick: (ev: React.MouseEvent) => void;
|
|
28
|
+
renderItem(item: DropdownItem): React.JSX.Element;
|
|
29
|
+
renderItems(): React.JSX.Element;
|
|
30
|
+
render(): React.JSX.Element;
|
|
31
|
+
}
|
|
32
|
+
export {};
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const react_1 = __importDefault(require("react"));
|
|
7
|
+
const react_onclickout_1 = __importDefault(require("react-onclickout"));
|
|
8
|
+
/** Palette item that allows picking from dropdown */
|
|
9
|
+
class DropdownPaletteItem extends react_1.default.Component {
|
|
10
|
+
static defaultProps = { position: "under" };
|
|
11
|
+
constructor(props) {
|
|
12
|
+
super(props);
|
|
13
|
+
this.state = {
|
|
14
|
+
open: false,
|
|
15
|
+
moreOpen: false
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
handleMouseDown = (ev) => {
|
|
19
|
+
// Ignore if clicking on menu
|
|
20
|
+
if (ev.target.className === "dropdown-palette-menu-item") {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
// Don't lose focus from editor
|
|
24
|
+
ev.preventDefault();
|
|
25
|
+
this.setState({ open: !this.state.open });
|
|
26
|
+
};
|
|
27
|
+
handleMoreClick = (ev) => {
|
|
28
|
+
ev.preventDefault();
|
|
29
|
+
this.setState({ moreOpen: true });
|
|
30
|
+
};
|
|
31
|
+
renderItem(item) {
|
|
32
|
+
return (react_1.default.createElement("div", { className: "dropdown-palette-menu-item", onMouseDown: (ev) => {
|
|
33
|
+
ev.preventDefault();
|
|
34
|
+
this.props.onSelect(item.value);
|
|
35
|
+
this.setState({ open: false });
|
|
36
|
+
}, key: item.value }, item.label));
|
|
37
|
+
}
|
|
38
|
+
renderItems() {
|
|
39
|
+
const visibleItems = this.state.moreOpen ? this.props.items : this.props.items.filter(item => !item.more);
|
|
40
|
+
const halfLength = Math.ceil(visibleItems.length / 2);
|
|
41
|
+
const leftColumn = visibleItems.slice(0, halfLength);
|
|
42
|
+
const rightColumn = visibleItems.slice(halfLength);
|
|
43
|
+
return (react_1.default.createElement("div", { className: "dropdown-palette-menu" },
|
|
44
|
+
react_1.default.createElement("div", { style: { display: 'flex' } },
|
|
45
|
+
react_1.default.createElement("div", { style: { flex: 1 } }, leftColumn.map(item => this.renderItem(item))),
|
|
46
|
+
react_1.default.createElement("div", { style: { flex: 1 } }, rightColumn.map(item => this.renderItem(item)))),
|
|
47
|
+
this.props.items.some(item => item.more) && !this.state.moreOpen && (react_1.default.createElement("div", { className: "dropdown-palette-menu-item", onMouseDown: this.handleMoreClick }, "More..."))));
|
|
48
|
+
}
|
|
49
|
+
render() {
|
|
50
|
+
const popupPosition = {
|
|
51
|
+
position: "absolute",
|
|
52
|
+
left: 0,
|
|
53
|
+
zIndex: 1000,
|
|
54
|
+
backgroundColor: "white",
|
|
55
|
+
border: "solid 1px #AAA",
|
|
56
|
+
borderRadius: 3
|
|
57
|
+
};
|
|
58
|
+
if (this.props.position === "under") {
|
|
59
|
+
popupPosition.top = 26;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
popupPosition.bottom = 26;
|
|
63
|
+
}
|
|
64
|
+
return (react_1.default.createElement(react_onclickout_1.default, { onClickOut: () => this.setState({ open: false, moreOpen: false }) },
|
|
65
|
+
react_1.default.createElement("div", { className: "mwater-visualization-text-palette-item", style: { position: "relative" }, onMouseDown: this.handleMouseDown },
|
|
66
|
+
react_1.default.createElement("style", null, `
|
|
67
|
+
.dropdown-palette-menu-item {
|
|
68
|
+
color: black;
|
|
69
|
+
background-color: white;
|
|
70
|
+
text-align: left;
|
|
71
|
+
padding: 5px 15px 5px 15px;
|
|
72
|
+
cursor: pointer;
|
|
73
|
+
}
|
|
74
|
+
.dropdown-palette-menu-item:hover {
|
|
75
|
+
background-color: #DDD;
|
|
76
|
+
}
|
|
77
|
+
`),
|
|
78
|
+
this.state.open ? react_1.default.createElement("div", { style: popupPosition }, this.renderItems()) : undefined,
|
|
79
|
+
this.props.label)));
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
exports.default = DropdownPaletteItem;
|
|
@@ -14,10 +14,6 @@ export default class FontColorPaletteItem extends React.Component<FontColorPalet
|
|
|
14
14
|
};
|
|
15
15
|
constructor(props: any);
|
|
16
16
|
handleMouseDown: (ev: any) => void;
|
|
17
|
-
render(): React.
|
|
18
|
-
onClickOut: () => void;
|
|
19
|
-
}, React.Component<{
|
|
20
|
-
onClickOut: () => void;
|
|
21
|
-
}, any, any>>;
|
|
17
|
+
render(): React.JSX.Element;
|
|
22
18
|
}
|
|
23
19
|
export {};
|
|
@@ -4,10 +4,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
const react_1 = __importDefault(require("react"));
|
|
7
|
-
const R = react_1.default.createElement;
|
|
8
7
|
const lodash_1 = __importDefault(require("lodash"));
|
|
9
8
|
const react_onclickout_1 = __importDefault(require("react-onclickout"));
|
|
10
9
|
const color_1 = __importDefault(require("color"));
|
|
10
|
+
const CustomColorsContext_1 = require("../CustomColorsContext");
|
|
11
11
|
// Palette item that allows picking a color
|
|
12
12
|
class FontColorPaletteItem extends react_1.default.Component {
|
|
13
13
|
static defaultProps = { position: "under" };
|
|
@@ -37,30 +37,25 @@ class FontColorPaletteItem extends react_1.default.Component {
|
|
|
37
37
|
else {
|
|
38
38
|
popupPosition["bottom"] = 26;
|
|
39
39
|
}
|
|
40
|
-
return
|
|
41
|
-
className: "mwater-visualization-text-palette-item",
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
return this.setState({ open: false });
|
|
49
|
-
}
|
|
50
|
-
}))
|
|
51
|
-
: undefined, R("i", { className: "fa fa-tint" })));
|
|
40
|
+
return (react_1.default.createElement(react_onclickout_1.default, { onClickOut: () => this.setState({ open: false }) },
|
|
41
|
+
react_1.default.createElement("div", { className: "mwater-visualization-text-palette-item", onMouseDown: this.handleMouseDown, style: { position: "relative" } },
|
|
42
|
+
this.state.open ? (react_1.default.createElement("div", { style: popupPosition },
|
|
43
|
+
react_1.default.createElement(ColorPaletteComponent, { onSetColor: (color) => {
|
|
44
|
+
this.props.onSetColor(color);
|
|
45
|
+
return this.setState({ open: false });
|
|
46
|
+
} }))) : undefined,
|
|
47
|
+
react_1.default.createElement("i", { className: "fas fa-palette" }))));
|
|
52
48
|
}
|
|
53
49
|
}
|
|
54
50
|
exports.default = FontColorPaletteItem;
|
|
55
51
|
class ColorPaletteComponent extends react_1.default.Component {
|
|
52
|
+
static contextType = CustomColorsContext_1.CustomColorsContext;
|
|
56
53
|
renderColor(color) {
|
|
57
|
-
return
|
|
58
|
-
style: { width: 16, height: 15, backgroundColor: color, margin: 1 },
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
}
|
|
63
|
-
}));
|
|
54
|
+
return (react_1.default.createElement("td", null,
|
|
55
|
+
react_1.default.createElement("div", { style: { width: 16, height: 15, backgroundColor: color, margin: 1 }, onMouseDown: (ev) => {
|
|
56
|
+
ev.preventDefault();
|
|
57
|
+
this.props.onSetColor(color);
|
|
58
|
+
} })));
|
|
64
59
|
}
|
|
65
60
|
render() {
|
|
66
61
|
const baseColors = [
|
|
@@ -73,12 +68,22 @@ class ColorPaletteComponent extends react_1.default.Component {
|
|
|
73
68
|
"#9900FF",
|
|
74
69
|
"#FF00FF" // magenta
|
|
75
70
|
];
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
71
|
+
const customColors = this.context?.customColors || [];
|
|
72
|
+
return (react_1.default.createElement("div", { style: { padding: 5 } },
|
|
73
|
+
react_1.default.createElement("table", null,
|
|
74
|
+
react_1.default.createElement("tbody", null,
|
|
75
|
+
lodash_1.default.chunk(customColors.filter(color => color != null), 8).map((colorGroup, index) => (react_1.default.createElement("tr", { key: index }, colorGroup.map((color) => this.renderColor(color))))),
|
|
76
|
+
react_1.default.createElement("tr", null, lodash_1.default.map(lodash_1.default.range(0, 8), (i) => {
|
|
77
|
+
return this.renderColor((0, color_1.default)({ r: (i * 255) / 7, g: (i * 255) / 7, b: (i * 255) / 7 }).hex());
|
|
78
|
+
})),
|
|
79
|
+
react_1.default.createElement("tr", { style: { height: 5 } }),
|
|
80
|
+
react_1.default.createElement("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor(c))),
|
|
81
|
+
react_1.default.createElement("tr", { style: { height: 5 } }),
|
|
82
|
+
react_1.default.createElement("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).lighten(0.7).hex()))),
|
|
83
|
+
react_1.default.createElement("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).lighten(0.5).hex()))),
|
|
84
|
+
react_1.default.createElement("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).lighten(0.3).hex()))),
|
|
85
|
+
react_1.default.createElement("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).darken(0.3).hex()))),
|
|
86
|
+
react_1.default.createElement("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).darken(0.5).hex()))),
|
|
87
|
+
react_1.default.createElement("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).darken(0.7).hex())))))));
|
|
83
88
|
}
|
|
84
89
|
}
|
|
@@ -65,6 +65,9 @@ class ItemsHtmlConverter {
|
|
|
65
65
|
if (!allowedStyles[key]) {
|
|
66
66
|
continue;
|
|
67
67
|
}
|
|
68
|
+
if (value == null || value === "") {
|
|
69
|
+
continue;
|
|
70
|
+
}
|
|
68
71
|
if (!first) {
|
|
69
72
|
attrs += " ";
|
|
70
73
|
}
|
|
@@ -133,13 +136,19 @@ class ItemsHtmlConverter {
|
|
|
133
136
|
}
|
|
134
137
|
const item = { type: "element", tag, items: this.convertElemToItems(node) };
|
|
135
138
|
// Add style
|
|
136
|
-
|
|
137
|
-
|
|
139
|
+
const nodeElement = node;
|
|
140
|
+
if (nodeElement.style != null) {
|
|
141
|
+
const styleDeclaration = nodeElement.style;
|
|
142
|
+
for (const style of styleDeclaration) {
|
|
138
143
|
if (!allowedStyles[style]) {
|
|
139
144
|
continue;
|
|
140
145
|
}
|
|
146
|
+
const value = styleDeclaration[style];
|
|
147
|
+
if (value == null || value === "") {
|
|
148
|
+
continue;
|
|
149
|
+
}
|
|
141
150
|
item.style = item.style || {};
|
|
142
|
-
item.style[style] =
|
|
151
|
+
item.style[style] = value;
|
|
143
152
|
}
|
|
144
153
|
}
|
|
145
154
|
// Convert align (Firefox)
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import React, { ReactNode } from "react";
|
|
1
|
+
import React, { ReactNode, CSSProperties, MouseEvent } from "react";
|
|
2
2
|
import { ContentEditableComponent } from "@mwater/expressions-ui";
|
|
3
3
|
import ItemsHtmlConverter, { HtmlItem } from "./ItemsHtmlConverter";
|
|
4
4
|
export interface RichTextComponentProps {
|
|
5
5
|
items?: HtmlItem[];
|
|
6
|
-
onItemsChange
|
|
6
|
+
onItemsChange?: (items: HtmlItem[]) => void;
|
|
7
7
|
onItemClick?: (item: HtmlItem) => void;
|
|
8
8
|
/** Optional className of editor wrapper */
|
|
9
9
|
className?: string;
|
|
10
10
|
/** Optional style of editor wrapper */
|
|
11
|
-
style?:
|
|
11
|
+
style?: CSSProperties;
|
|
12
12
|
/** Converter to use for editing */
|
|
13
13
|
itemsHtmlConverter?: ItemsHtmlConverter;
|
|
14
14
|
/** True (default) to include heading h1, h2 in palette */
|
|
@@ -16,9 +16,10 @@ export interface RichTextComponentProps {
|
|
|
16
16
|
/** Extra buttons to put in palette */
|
|
17
17
|
extraPaletteButtons?: ReactNode;
|
|
18
18
|
}
|
|
19
|
-
|
|
19
|
+
interface RichTextComponentState {
|
|
20
20
|
focused: boolean;
|
|
21
|
-
}
|
|
21
|
+
}
|
|
22
|
+
export default class RichTextComponent extends React.Component<RichTextComponentProps, RichTextComponentState> {
|
|
22
23
|
static defaultProps: {
|
|
23
24
|
includeHeadings: boolean;
|
|
24
25
|
items: never[];
|
|
@@ -27,58 +28,31 @@ export default class RichTextComponent extends React.Component<RichTextComponent
|
|
|
27
28
|
entireComponent: HTMLElement | null;
|
|
28
29
|
contentEditable: ContentEditableComponent | null;
|
|
29
30
|
paletteComponent: HTMLElement | null;
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
31
|
+
/** Number of changes in progress. Used with beginChanges and endChanges
|
|
32
|
+
* to prevent onChange being called during a change */
|
|
33
|
+
changesInProgress: number;
|
|
34
|
+
constructor(props: RichTextComponentProps);
|
|
35
|
+
handleClick: (ev: MouseEvent) => void;
|
|
36
|
+
pasteHTML(html: string): void;
|
|
33
37
|
focus(): void;
|
|
38
|
+
beginChanges(): void;
|
|
39
|
+
endChanges(): void;
|
|
34
40
|
handleInsertExpr: (item: any) => void;
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
handleChange: (elem:
|
|
41
|
+
handleSetFontColor: (color: string) => void;
|
|
42
|
+
handleSetFontSize: (tag: string, size: string | null) => void;
|
|
43
|
+
handleChange: (elem: HTMLElement) => void;
|
|
38
44
|
handleFocus: () => void;
|
|
39
45
|
handleBlur: () => void;
|
|
40
|
-
handleCommand: (command:
|
|
41
|
-
handleCreateLink: (ev:
|
|
42
|
-
handleEditorClick: (ev:
|
|
46
|
+
handleCommand: (command: string, param: any, ev?: MouseEvent) => void;
|
|
47
|
+
handleCreateLink: (ev: MouseEvent) => void;
|
|
48
|
+
handleEditorClick: (ev: MouseEvent) => void;
|
|
43
49
|
createHtml(): string;
|
|
44
|
-
renderPalette(): React.
|
|
45
|
-
|
|
46
|
-
zIndex: number | null;
|
|
47
|
-
};
|
|
48
|
-
edges: string;
|
|
49
|
-
align: string;
|
|
50
|
-
render: (schemeName: any, { edges }: any) => React.DetailedReactHTMLElement<{
|
|
51
|
-
key: string;
|
|
52
|
-
className: string;
|
|
53
|
-
ref: (c: HTMLElement | null) => void;
|
|
54
|
-
}, HTMLElement>;
|
|
55
|
-
}, React.Component<{
|
|
56
|
-
style: {
|
|
57
|
-
zIndex: number | null;
|
|
58
|
-
};
|
|
50
|
+
renderPalette(): React.JSX.Element;
|
|
51
|
+
renderPaletteContent: (schemeName: string, { edges }: {
|
|
59
52
|
edges: string;
|
|
60
|
-
|
|
61
|
-
render: (schemeName: any, { edges }: any) => React.DetailedReactHTMLElement<{
|
|
62
|
-
key: string;
|
|
63
|
-
className: string;
|
|
64
|
-
ref: (c: HTMLElement | null) => void;
|
|
65
|
-
}, HTMLElement>;
|
|
66
|
-
}, any, any>>;
|
|
67
|
-
renderPaletteContent: (schemeName: any, { edges }: any) => React.DetailedReactHTMLElement<{
|
|
68
|
-
key: string;
|
|
69
|
-
className: string;
|
|
70
|
-
ref: (c: HTMLElement | null) => void;
|
|
71
|
-
}, HTMLElement>;
|
|
53
|
+
}) => React.JSX.Element;
|
|
72
54
|
refContentEditable: (c: ContentEditableComponent | null) => void;
|
|
73
|
-
renderHtml(): React.
|
|
74
|
-
|
|
75
|
-
style: any;
|
|
76
|
-
className: string | undefined;
|
|
77
|
-
}, HTMLElement>;
|
|
78
|
-
render(): React.DetailedReactHTMLElement<{
|
|
79
|
-
style: {
|
|
80
|
-
position: "relative";
|
|
81
|
-
};
|
|
82
|
-
ref: (c: HTMLElement | null) => void;
|
|
83
|
-
}, HTMLElement>;
|
|
55
|
+
renderHtml(): React.JSX.Element;
|
|
56
|
+
render(): React.JSX.Element;
|
|
84
57
|
}
|
|
58
|
+
export {};
|