@mwater/visualization 5.1.0 → 5.3.0

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.
Files changed (305) hide show
  1. package/lib/ColorComponent.d.ts +10 -11
  2. package/lib/ColorComponent.js +78 -29
  3. package/lib/ColorSchemeFactory.d.ts +13 -2
  4. package/lib/ColorSchemeFactory.js +7 -5
  5. package/lib/CustomColorsContext.d.ts +6 -0
  6. package/lib/CustomColorsContext.js +6 -0
  7. package/lib/FiltersDesignerComponent.d.ts +1 -4
  8. package/lib/FiltersDesignerComponent.js +2 -3
  9. package/lib/GlobalFilter.d.ts +13 -0
  10. package/lib/GlobalFilter.js +2 -0
  11. package/lib/LocaleContextInjector.d.ts +5 -11
  12. package/lib/LocaleContextInjector.js +4 -12
  13. package/lib/MWaterAddRelatedFormComponent.js +3 -3
  14. package/lib/MWaterAddRelatedIndicatorComponent.d.ts +1 -4
  15. package/lib/MWaterAddRelatedIndicatorComponent.js +6 -6
  16. package/lib/MWaterCompleteTableSelectComponent.d.ts +7 -25
  17. package/lib/MWaterCompleteTableSelectComponent.js +36 -36
  18. package/lib/MWaterContextComponent.d.ts +19 -9
  19. package/lib/MWaterContextComponent.js +38 -22
  20. package/lib/MWaterCustomTablesetListComponent.js +9 -3
  21. package/lib/MWaterGlobalFiltersComponent.d.ts +6 -5
  22. package/lib/MWaterGlobalFiltersComponent.js +4 -4
  23. package/lib/MWaterLoaderComponent.d.ts +15 -3
  24. package/lib/MWaterLoaderComponent.js +11 -2
  25. package/lib/MWaterTableSelectComponent.d.ts +1 -4
  26. package/lib/MWaterTableSelectComponent.js +10 -12
  27. package/lib/UIComponents.d.ts +2 -2
  28. package/lib/UIComponents.js +4 -12
  29. package/lib/axes/Axis.d.ts +20 -25
  30. package/lib/axes/AxisBuilder.d.ts +7 -4
  31. package/lib/axes/AxisBuilder.js +12 -8
  32. package/lib/axes/AxisComponent.d.ts +6 -9
  33. package/lib/axes/AxisComponent.js +1 -2
  34. package/lib/axes/ColorPaletteCollectionComponent.d.ts +5 -12
  35. package/lib/axes/ColorPaletteCollectionComponent.js +67 -36
  36. package/lib/dashboards/DashboardComponent.d.ts +4 -17
  37. package/lib/dashboards/DashboardComponent.js +20 -67
  38. package/lib/dashboards/DashboardDesign.d.ts +5 -20
  39. package/lib/dashboards/DashboardUpgrader.js +36 -1
  40. package/lib/dashboards/DashboardViewComponent.d.ts +5 -34
  41. package/lib/dashboards/DashboardViewComponent.js +112 -136
  42. package/lib/dashboards/FontStyleEditor.d.ts +8 -0
  43. package/lib/dashboards/FontStyleEditor.js +130 -0
  44. package/lib/dashboards/LayoutOptionsComponent.d.ts +0 -1
  45. package/lib/dashboards/LayoutOptionsComponent.js +209 -39
  46. package/lib/dashboards/ServerDashboardDataSource.d.ts +1 -2
  47. package/lib/dashboards/ServerDashboardDataSource.js +52 -33
  48. package/lib/dashboards/SettingsModalComponent.d.ts +4 -15
  49. package/lib/dashboards/SettingsModalComponent.js +24 -38
  50. package/lib/dashboards/WidgetComponent.d.ts +3 -3
  51. package/lib/dashboards/WidgetComponent.js +3 -6
  52. package/lib/dashboards/WidgetDataSourcePrioritizer.d.ts +20 -0
  53. package/lib/dashboards/WidgetDataSourcePrioritizer.js +72 -0
  54. package/lib/dashboards/layoutOptions.d.ts +83 -0
  55. package/lib/dashboards/layoutOptions.js +436 -10
  56. package/lib/datagrids/DatagridComponent.d.ts +2 -9
  57. package/lib/datagrids/DatagridDataSource.d.ts +3 -3
  58. package/lib/datagrids/DatagridDataSource.js +0 -14
  59. package/lib/datagrids/DatagridDesign.d.ts +7 -6
  60. package/lib/datagrids/DatagridDesignerComponent.d.ts +2 -93
  61. package/lib/datagrids/DatagridDesignerComponent.js +8 -6
  62. package/lib/datagrids/DatagridViewComponent.js +1 -1
  63. package/lib/datagrids/FindReplaceModalComponent.d.ts +4 -20
  64. package/lib/datagrids/FindReplaceModalComponent.js +27 -13
  65. package/lib/datagrids/ServerDatagridDataSource.d.ts +8 -7
  66. package/lib/datagrids/ServerDatagridDataSource.js +88 -36
  67. package/lib/demo.js +4 -4
  68. package/lib/index.css +5 -0
  69. package/lib/index.d.ts +2 -1
  70. package/lib/index.js +0 -1
  71. package/lib/layouts/LayoutManager.d.ts +33 -29
  72. package/lib/layouts/LayoutManager.js +2 -8
  73. package/lib/layouts/blocks/BlocksDisplayComponent.d.ts +26 -56
  74. package/lib/layouts/blocks/BlocksDisplayComponent.js +122 -205
  75. package/lib/layouts/blocks/BlocksLayoutManager.d.ts +6 -22
  76. package/lib/layouts/blocks/BlocksLayoutManager.js +5 -14
  77. package/lib/layouts/blocks/HorizontalBlockComponent.d.ts +5 -4
  78. package/lib/layouts/blocks/HorizontalBlockComponent.js +5 -5
  79. package/lib/layouts/grid/GridLayoutManager.d.ts +2 -1
  80. package/lib/mWaterLoader.d.ts +2 -0
  81. package/lib/mWaterLoader.js +2 -1
  82. package/lib/maps/AddLayerComponent.d.ts +6 -8
  83. package/lib/maps/AddLayerComponent.js +6 -6
  84. package/lib/maps/BingLayer.js +10 -20
  85. package/lib/maps/BufferLayer.js +5 -2
  86. package/lib/maps/ChoroplethLayer.js +2 -1
  87. package/lib/maps/ClusterLayer.js +3 -1
  88. package/lib/maps/DirectMapDataSource.d.ts +5 -2
  89. package/lib/maps/DirectMapDataSource.js +2 -1
  90. package/lib/maps/EditPopupComponent.js +2 -1
  91. package/lib/maps/GridLayer.js +5 -3
  92. package/lib/maps/GridLayerDesigner.js +0 -1
  93. package/lib/maps/LayerSwitcherComponent.js +1 -1
  94. package/lib/maps/MapComponent.d.ts +3 -11
  95. package/lib/maps/MapComponent.js +3 -3
  96. package/lib/maps/MapDesign.d.ts +2 -13
  97. package/lib/maps/MapFiltersDesignerComponent.d.ts +0 -4
  98. package/lib/maps/MapFiltersDesignerComponent.js +4 -5
  99. package/lib/maps/MarkersLayer.js +30 -25
  100. package/lib/maps/RasterMapViewComponent.d.ts +3 -13
  101. package/lib/maps/RasterMapViewComponent.js +3 -3
  102. package/lib/maps/RegionSelectComponent.d.ts +2 -1
  103. package/lib/maps/ServerMapDataSource.d.ts +3 -4
  104. package/lib/maps/ServerMapDataSource.js +5 -5
  105. package/lib/maps/VectorMapViewComponent.js +2 -1
  106. package/lib/maps/mapSymbols.js +2 -0
  107. package/lib/maps/symbols/font-awesome/cloud-rain.png +0 -0
  108. package/lib/maps/vectorMaps.d.ts +1 -0
  109. package/lib/maps/vectorMaps.js +70 -56
  110. package/lib/quickfilter/QuickfilterCompiler.d.ts +1 -1
  111. package/lib/quickfilter/QuickfiltersComponent.d.ts +1 -4
  112. package/lib/quickfilter/QuickfiltersComponent.js +3 -3
  113. package/lib/richtext/DropdownPaletteItem.d.ts +32 -0
  114. package/lib/richtext/DropdownPaletteItem.js +82 -0
  115. package/lib/richtext/FontColorPaletteItem.d.ts +1 -5
  116. package/lib/richtext/FontColorPaletteItem.js +32 -27
  117. package/lib/richtext/ItemsHtmlConverter.js +12 -3
  118. package/lib/richtext/RichTextComponent.d.ts +26 -52
  119. package/lib/richtext/RichTextComponent.js +166 -128
  120. package/lib/valueFormatter.js +6 -1
  121. package/lib/wellknown.d.ts +5 -0
  122. package/lib/wellknown.js +288 -0
  123. package/lib/widgets/DropdownWidgetComponent.d.ts +8 -25
  124. package/lib/widgets/DropdownWidgetComponent.js +48 -25
  125. package/lib/widgets/IFrameWidgetComponent.d.ts +3 -11
  126. package/lib/widgets/ImageWidgetComponent.d.ts +8 -27
  127. package/lib/widgets/MapWidget.d.ts +4 -7
  128. package/lib/widgets/MapWidget.js +2 -1
  129. package/lib/widgets/MarkdownWidget.d.ts +2 -7
  130. package/lib/widgets/TOCWidget.d.ts +2 -9
  131. package/lib/widgets/TOCWidget.js +2 -1
  132. package/lib/widgets/Widget.d.ts +2 -0
  133. package/lib/widgets/WidgetDataSource.d.ts +3 -1
  134. package/lib/widgets/charts/Chart.d.ts +0 -1
  135. package/lib/widgets/charts/ChartViewComponent.d.ts +4 -0
  136. package/lib/widgets/charts/ChartViewComponent.js +11 -3
  137. package/lib/widgets/charts/ChartWidget.d.ts +1 -74
  138. package/lib/widgets/charts/ChartWidget.js +4 -183
  139. package/lib/widgets/charts/ChartWidgetComponent.d.ts +51 -0
  140. package/lib/widgets/charts/ChartWidgetComponent.js +167 -0
  141. package/lib/widgets/charts/calendar/CalendarChartViewComponent.d.ts +1 -4
  142. package/lib/widgets/charts/calendar/CalendarChartViewComponent.js +4 -4
  143. package/lib/widgets/charts/imagemosaic/ImagePopupComponent.d.ts +2 -7
  144. package/lib/widgets/charts/layered/LayeredChart.d.ts +5 -10
  145. package/lib/widgets/charts/layered/LayeredChart.js +6 -7
  146. package/lib/widgets/charts/layered/LayeredChartCompiler.d.ts +4 -2
  147. package/lib/widgets/charts/layered/LayeredChartCompiler.js +46 -32
  148. package/lib/widgets/charts/layered/LayeredChartDesign.d.ts +4 -0
  149. package/lib/widgets/charts/layered/LayeredChartDesignerComponent.d.ts +5 -31
  150. package/lib/widgets/charts/layered/LayeredChartDesignerComponent.js +21 -3
  151. package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.d.ts +1 -7
  152. package/lib/widgets/charts/layered/LayeredChartLayerDesignerComponent.js +2 -1
  153. package/lib/widgets/charts/layered/LayeredChartViewComponent.d.ts +1 -4
  154. package/lib/widgets/charts/layered/LayeredChartViewComponent.js +89 -38
  155. package/lib/widgets/charts/pivot/IntersectionDesignerComponent.d.ts +5 -105
  156. package/lib/widgets/charts/pivot/IntersectionDesignerComponent.js +122 -166
  157. package/lib/widgets/charts/pivot/PivotChart.d.ts +6 -0
  158. package/lib/widgets/charts/pivot/PivotChart.js +47 -17
  159. package/lib/widgets/charts/pivot/PivotChartDesign.d.ts +11 -0
  160. package/lib/widgets/charts/pivot/PivotChartDesignerComponent.d.ts +11 -7
  161. package/lib/widgets/charts/pivot/PivotChartDesignerComponent.js +1 -1
  162. package/lib/widgets/charts/pivot/PivotChartLayoutBuilder.d.ts +2 -2
  163. package/lib/widgets/charts/pivot/PivotChartLayoutBuilder.js +20 -36
  164. package/lib/widgets/charts/pivot/PivotChartLayoutComponent.js +0 -1
  165. package/lib/widgets/charts/pivot/PivotChartQueryBuilder.d.ts +23 -2
  166. package/lib/widgets/charts/pivot/PivotChartQueryBuilder.js +215 -181
  167. package/lib/widgets/charts/pivot/PivotChartUtils.d.ts +2 -2
  168. package/lib/widgets/charts/pivot/PivotChartViewComponent.d.ts +9 -47
  169. package/lib/widgets/charts/pivot/PivotChartViewComponent.js +20 -60
  170. package/lib/widgets/charts/pivot/SegmentDesignerComponent.d.ts +55 -58
  171. package/lib/widgets/charts/table/TableChart.js +8 -4
  172. package/lib/widgets/charts/table/TableChartDesignerComponent.js +3 -3
  173. package/lib/widgets/charts/table/TableChartViewComponent.js +30 -16
  174. package/lib/widgets/text/ExprInsertModalComponent.d.ts +2 -13
  175. package/lib/widgets/text/ExprUpdateModalComponent.d.ts +2 -13
  176. package/lib/widgets/text/TextComponent.d.ts +5 -12
  177. package/lib/widgets/text/TextComponent.js +19 -39
  178. package/lib/widgets/text/TextWidget.d.ts +2 -1
  179. package/lib/widgets/text/TextWidget.js +5 -1
  180. package/lib/widgets/text/TextWidgetComponent.d.ts +15 -3
  181. package/lib/widgets/text/TextWidgetComponent.js +76 -19
  182. package/lib/widgets/text/TextWidgetDesign.d.ts +16 -2
  183. package/lib/widgets/text/TextWidgetDesign.js +6 -0
  184. package/package.json +4 -4
  185. package/src/ColorComponent.tsx +177 -0
  186. package/src/ColorSchemeFactory.ts +12 -6
  187. package/src/CustomColorsContext.tsx +8 -0
  188. package/src/FiltersDesignerComponent.ts +3 -4
  189. package/src/GlobalFilter.ts +17 -0
  190. package/src/LocaleContextInjector.tsx +14 -13
  191. package/src/MWaterAddRelatedFormComponent.ts +3 -3
  192. package/src/MWaterAddRelatedIndicatorComponent.ts +6 -6
  193. package/src/MWaterCompleteTableSelectComponent.tsx +36 -36
  194. package/src/MWaterContextComponent.tsx +42 -33
  195. package/src/MWaterCustomTablesetListComponent.tsx +21 -3
  196. package/src/MWaterGlobalFiltersComponent.ts +8 -8
  197. package/src/MWaterLoaderComponent.ts +14 -4
  198. package/src/MWaterTableSelectComponent.tsx +11 -12
  199. package/src/{UIComponents.ts → UIComponents.tsx} +7 -15
  200. package/src/axes/Axis.ts +24 -25
  201. package/src/axes/AxisBuilder.ts +16 -13
  202. package/src/axes/AxisComponent.ts +3 -4
  203. package/src/axes/{ColorPaletteCollectionComponent.ts → ColorPaletteCollectionComponent.tsx} +87 -61
  204. package/src/dashboards/DashboardComponent.tsx +73 -147
  205. package/src/dashboards/DashboardDesign.ts +5 -25
  206. package/src/dashboards/DashboardUpgrader.ts +41 -1
  207. package/src/dashboards/DashboardViewComponent.tsx +313 -0
  208. package/src/dashboards/FontStyleEditor.tsx +166 -0
  209. package/src/dashboards/LayoutOptionsComponent.tsx +377 -71
  210. package/src/dashboards/ServerDashboardDataSource.ts +52 -33
  211. package/src/dashboards/SettingsModalComponent.tsx +170 -0
  212. package/src/dashboards/WidgetComponent.tsx +6 -12
  213. package/src/dashboards/WidgetDataSourcePrioritizer.ts +82 -0
  214. package/src/dashboards/layoutOptions.tsx +581 -0
  215. package/src/datagrids/DatagridDataSource.ts +6 -12
  216. package/src/datagrids/DatagridDesign.ts +8 -3
  217. package/src/datagrids/DatagridDesignerComponent.tsx +22 -18
  218. package/src/datagrids/DatagridViewComponent.ts +3 -3
  219. package/src/datagrids/ExprCellComponent.ts +0 -1
  220. package/src/datagrids/FindReplaceModalComponent.ts +39 -22
  221. package/src/datagrids/ServerDatagridDataSource.ts +107 -45
  222. package/src/demo.ts +4 -4
  223. package/src/index.css +5 -0
  224. package/src/index.ts +2 -1
  225. package/src/layouts/LayoutManager.ts +44 -42
  226. package/src/layouts/blocks/BlocksDisplayComponent.tsx +498 -0
  227. package/src/layouts/blocks/BlocksLayoutManager.ts +6 -15
  228. package/src/layouts/blocks/HorizontalBlockComponent.ts +9 -8
  229. package/src/mWaterLoader.ts +4 -1
  230. package/src/maps/AddLayerComponent.ts +9 -9
  231. package/src/maps/BingLayer.ts +16 -26
  232. package/src/maps/BufferLayer.ts +5 -2
  233. package/src/maps/ChoroplethLayer.ts +2 -1
  234. package/src/maps/ClusterLayer.ts +3 -1
  235. package/src/maps/DirectMapDataSource.ts +12 -3
  236. package/src/maps/EditPopupComponent.ts +2 -1
  237. package/src/maps/GridLayer.ts +5 -3
  238. package/src/maps/GridLayerDesigner.tsx +0 -1
  239. package/src/maps/LayerSwitcherComponent.tsx +1 -1
  240. package/src/maps/MapComponent.ts +3 -3
  241. package/src/maps/MapDesign.ts +2 -17
  242. package/src/maps/{MapFiltersDesignerComponent.ts → MapFiltersDesignerComponent.tsx} +25 -25
  243. package/src/maps/MarkersLayer.ts +38 -41
  244. package/src/maps/RasterMapViewComponent.ts +3 -3
  245. package/src/maps/ServerMapDataSource.ts +8 -8
  246. package/src/maps/VectorMapViewComponent.tsx +2 -2
  247. package/src/maps/mapSymbols.ts +2 -0
  248. package/src/maps/symbols/font-awesome/cloud-rain.png +0 -0
  249. package/src/maps/vectorMaps.tsx +88 -74
  250. package/src/quickfilter/QuickfilterCompiler.ts +1 -1
  251. package/src/quickfilter/QuickfiltersComponent.ts +3 -3
  252. package/src/richtext/DropdownPaletteItem.tsx +144 -0
  253. package/src/richtext/FontColorPaletteItem.tsx +160 -0
  254. package/src/richtext/ItemsHtmlConverter.ts +15 -5
  255. package/src/richtext/RichTextComponent.tsx +274 -232
  256. package/src/valueFormatter.ts +5 -1
  257. package/src/wellknown.ts +286 -0
  258. package/src/widgets/DropdownWidgetComponent.tsx +75 -0
  259. package/src/widgets/MapWidget.ts +5 -2
  260. package/src/widgets/TOCWidget.ts +2 -1
  261. package/src/widgets/Widget.ts +3 -0
  262. package/src/widgets/WidgetDataSource.ts +3 -1
  263. package/src/widgets/charts/Chart.ts +1 -1
  264. package/src/widgets/charts/ChartViewComponent.ts +16 -3
  265. package/src/widgets/charts/ChartWidget.ts +3 -275
  266. package/src/widgets/charts/ChartWidgetComponent.tsx +281 -0
  267. package/src/widgets/charts/calendar/CalendarChartViewComponent.tsx +4 -4
  268. package/src/widgets/charts/layered/LayeredChart.ts +4 -6
  269. package/src/widgets/charts/layered/LayeredChartCompiler.ts +80 -63
  270. package/src/widgets/charts/layered/LayeredChartDesign.ts +7 -1
  271. package/src/widgets/charts/layered/LayeredChartDesignerComponent.tsx +43 -10
  272. package/src/widgets/charts/layered/LayeredChartLayerDesignerComponent.tsx +6 -6
  273. package/src/widgets/charts/layered/LayeredChartViewComponent.ts +140 -88
  274. package/src/widgets/charts/pivot/IntersectionDesignerComponent.tsx +305 -221
  275. package/src/widgets/charts/pivot/PivotChart.ts +56 -18
  276. package/src/widgets/charts/pivot/PivotChartDesign.ts +12 -0
  277. package/src/widgets/charts/pivot/PivotChartDesignerComponent.tsx +4 -3
  278. package/src/widgets/charts/pivot/PivotChartLayoutBuilder.ts +39 -76
  279. package/src/widgets/charts/pivot/PivotChartLayoutComponent.tsx +0 -1
  280. package/src/widgets/charts/pivot/PivotChartQueryBuilder.ts +230 -189
  281. package/src/widgets/charts/pivot/PivotChartUtils.ts +4 -4
  282. package/src/widgets/charts/pivot/{PivotChartViewComponent.ts → PivotChartViewComponent.tsx} +86 -89
  283. package/src/widgets/charts/table/TableChart.ts +8 -4
  284. package/src/widgets/charts/table/TableChartDesignerComponent.ts +4 -4
  285. package/src/widgets/charts/table/TableChartViewComponent.ts +32 -19
  286. package/src/widgets/text/TextComponent.tsx +47 -49
  287. package/src/widgets/text/TextWidget.ts +8 -3
  288. package/src/widgets/text/TextWidgetComponent.tsx +249 -0
  289. package/src/widgets/text/TextWidgetDesign.ts +26 -2
  290. package/src/ColorComponent.ts +0 -117
  291. package/src/dashboards/DashboardViewComponent.ts +0 -304
  292. package/src/dashboards/SettingsModalComponent.ts +0 -169
  293. package/src/dashboards/layoutOptions.ts +0 -40
  294. package/src/layout-styles.css +0 -263
  295. package/src/layouts/blocks/BlocksDisplayComponent.ts +0 -461
  296. package/src/layouts/grid/GridLayoutComponent.ts +0 -67
  297. package/src/layouts/grid/GridLayoutManager.ts +0 -185
  298. package/src/layouts/grid/LegoLayoutEngine.ts +0 -142
  299. package/src/layouts/grid/PaletteItemComponent.ts +0 -28
  300. package/src/layouts/grid/README.md +0 -14
  301. package/src/layouts/grid/WidgetContainerComponent.ts +0 -420
  302. package/src/richtext/FontColorPaletteItem.ts +0 -172
  303. package/src/richtext/FontSizePaletteItem.ts +0 -110
  304. package/src/widgets/DropdownWidgetComponent.ts +0 -78
  305. package/src/widgets/text/TextWidgetComponent.ts +0 -120
@@ -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.CElement<{
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 R(react_onclickout_1.default, { onClickOut: () => this.setState({ open: false }) }, R("div", {
41
- className: "mwater-visualization-text-palette-item",
42
- onMouseDown: this.handleMouseDown,
43
- style: { position: "relative" }
44
- }, this.state.open
45
- ? R("div", { style: popupPosition }, R(ColorPaletteComponent, {
46
- onSetColor: (color) => {
47
- this.props.onSetColor(color);
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 R("td", null, R("div", {
58
- style: { width: 16, height: 15, backgroundColor: color, margin: 1 },
59
- onMouseDown: (ev) => {
60
- ev.preventDefault();
61
- return this.props.onSetColor(color);
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
- return R("div", { style: { padding: 5 } }, R("table", null, R("tbody", null,
77
- // Grey shades
78
- R("tr", null, lodash_1.default.map(lodash_1.default.range(0, 8), (i) => {
79
- return this.renderColor((0, color_1.default)({ r: (i * 255) / 7, g: (i * 255) / 7, b: (i * 255) / 7 }).hex());
80
- })), R("tr", { style: { height: 5 } }),
81
- // Base colors
82
- R("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor(c))), R("tr", { style: { height: 5 } }), R("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).lighten(0.7).hex()))), R("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).lighten(0.5).hex()))), R("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).lighten(0.3).hex()))), R("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).darken(0.3).hex()))), R("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).darken(0.5).hex()))), R("tr", null, lodash_1.default.map(baseColors, (c) => this.renderColor((0, color_1.default)(c).darken(0.7).hex()))))));
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
- if (node.style != null) {
137
- for (style of node.style) {
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] = node.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: (items: HtmlItem[]) => void;
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?: any;
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
- export default class RichTextComponent extends React.Component<RichTextComponentProps, {
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
- constructor(props: any);
31
- handleClick: (ev: any) => void;
32
- pasteHTML(html: any): void;
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
- handleSetFontSize: (size: any) => any;
36
- handleSetFontColor: (color: any) => void;
37
- handleChange: (elem: any) => void;
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: any, param: any, ev?: any) => boolean;
41
- handleCreateLink: (ev: any) => void;
42
- handleEditorClick: (ev: any) => void;
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.CElement<{
45
- style: {
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
- align: string;
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.DetailedReactHTMLElement<{
74
- key: string;
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 {};