@adaptabletools/adaptable-plugin-ipushpull 18.0.0-canary.4 → 18.0.0-canary.6
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/package.json
    CHANGED
    
    | @@ -1,6 +1,6 @@ | |
| 1 1 | 
             
            {
         | 
| 2 2 | 
             
              "name": "@adaptabletools/adaptable-plugin-ipushpull",
         | 
| 3 | 
            -
              "version": "18.0.0-canary. | 
| 3 | 
            +
              "version": "18.0.0-canary.6",
         | 
| 4 4 | 
             
              "description": "",
         | 
| 5 5 | 
             
              "homepage": "http://www.adaptabletools.com/",
         | 
| 6 6 | 
             
              "author": {
         | 
| @@ -17,8 +17,9 @@ | |
| 17 17 | 
             
                "rebass": "^3.2.2",
         | 
| 18 18 | 
             
                "redux": "4.0.5",
         | 
| 19 19 | 
             
                "styled-components": "^4.4.1",
         | 
| 20 | 
            +
                "tinycolor2": "^1.4.2",
         | 
| 20 21 | 
             
                "tslib": "^2.3.0",
         | 
| 21 | 
            -
                "@adaptabletools/adaptable": "18.0.0-canary. | 
| 22 | 
            +
                "@adaptabletools/adaptable": "18.0.0-canary.6"
         | 
| 22 23 | 
             
              },
         | 
| 23 24 | 
             
              "type": "module",
         | 
| 24 25 | 
             
              "module": "src/index.js"
         | 
| @@ -1,4 +1,5 @@ | |
| 1 1 | 
             
            import { IAdaptable } from '@adaptabletools/adaptable/src/AdaptableInterfaces/IAdaptable';
         | 
| 2 | 
            +
            import { IPPStyle } from '@adaptabletools/adaptable/src/Utilities/Interface/IPPStyle';
         | 
| 2 3 | 
             
            import { IPushPullService } from './Interface/IPushPullService';
         | 
| 3 4 | 
             
            import { IPushPullDomain } from '@adaptabletools/adaptable/src/PredefinedConfig/SystemState';
         | 
| 4 5 | 
             
            export declare enum ServiceStatus {
         | 
| @@ -20,4 +21,6 @@ export declare class PushPullService implements IPushPullService { | |
| 20 21 | 
             
                unloadPage(page: string): void;
         | 
| 21 22 | 
             
                addNewPage(folderId: number, page: string): Promise<any>;
         | 
| 22 23 | 
             
                pushData(page: string, data: any[]): Promise<void>;
         | 
| 24 | 
            +
                getCurrentIPPStyle(): IPPStyle;
         | 
| 25 | 
            +
                getDefaultIPPStyle(): IPPStyle;
         | 
| 23 26 | 
             
            }
         | 
| @@ -1,4 +1,5 @@ | |
| 1 1 | 
             
            import StringExtensions from '@adaptabletools/adaptable/src/Utilities/Extensions/StringExtensions';
         | 
| 2 | 
            +
            import tinycolor from 'tinycolor2';
         | 
| 2 3 | 
             
            export var ServiceStatus;
         | 
| 3 4 | 
             
            (function (ServiceStatus) {
         | 
| 4 5 | 
             
                ServiceStatus["Unknown"] = "Unknown";
         | 
| @@ -135,9 +136,7 @@ export class PushPullService { | |
| 135 136 | 
             
                pushData(page, data) {
         | 
| 136 137 | 
             
                    return new Promise((resolve, reject) => {
         | 
| 137 138 | 
             
                        let newData = [];
         | 
| 138 | 
            -
                        const style = data && data.length > 1
         | 
| 139 | 
            -
                            ? this.adaptable.getCurrentIPPStyle()
         | 
| 140 | 
            -
                            : this.adaptable.getDefaultIPPStyle();
         | 
| 139 | 
            +
                        const style = data && data.length > 1 ? this.getCurrentIPPStyle() : this.getDefaultIPPStyle();
         | 
| 141 140 | 
             
                        newData = data.map((row, i) => row.map((cell, y) => {
         | 
| 142 141 | 
             
                            const col = i == 0
         | 
| 143 142 | 
             
                                ? style.Header.Columns.find((x) => x.columnFriendlyName == data[0][y])
         | 
| @@ -206,4 +205,95 @@ export class PushPullService { | |
| 206 205 | 
             
                        });
         | 
| 207 206 | 
             
                    });
         | 
| 208 207 | 
             
                }
         | 
| 208 | 
            +
                getCurrentIPPStyle() {
         | 
| 209 | 
            +
                    const headerFirstCol = document
         | 
| 210 | 
            +
                        .querySelectorAll('.ag-header-cell')
         | 
| 211 | 
            +
                        .item(0);
         | 
| 212 | 
            +
                    const header = document.querySelector('.ag-header');
         | 
| 213 | 
            +
                    const headerColStyle = header ? window.getComputedStyle(header, null) : null;
         | 
| 214 | 
            +
                    const firstRow = document.querySelector('.ag-row-even');
         | 
| 215 | 
            +
                    const firstRowStyle = firstRow ? window.getComputedStyle(firstRow, null) : null;
         | 
| 216 | 
            +
                    const secondRow = document.querySelector('.ag-row-odd');
         | 
| 217 | 
            +
                    const secondRowStyle = secondRow
         | 
| 218 | 
            +
                        ? window.getComputedStyle(secondRow, null)
         | 
| 219 | 
            +
                        : {
         | 
| 220 | 
            +
                            backgroundColor: '#fff',
         | 
| 221 | 
            +
                        };
         | 
| 222 | 
            +
                    return {
         | 
| 223 | 
            +
                        Header: {
         | 
| 224 | 
            +
                            headerColor: tinycolor(headerColStyle.color).toHexString(),
         | 
| 225 | 
            +
                            headerBackColor: tinycolor(headerColStyle.backgroundColor).toHexString(),
         | 
| 226 | 
            +
                            headerFontFamily: headerColStyle.fontFamily,
         | 
| 227 | 
            +
                            headerFontSize: headerColStyle.fontSize,
         | 
| 228 | 
            +
                            headerFontStyle: headerColStyle.fontStyle,
         | 
| 229 | 
            +
                            headerFontWeight: headerColStyle.fontWeight,
         | 
| 230 | 
            +
                            height: Number(headerColStyle.height.replace('px', '')),
         | 
| 231 | 
            +
                            Columns: this.adaptable.api.columnApi.getColumns().map((col) => {
         | 
| 232 | 
            +
                                const headerColumn = document.querySelector(`.ag-header-cell[col-id='${col.columnId}']`);
         | 
| 233 | 
            +
                                const headerColumnStyle = window.getComputedStyle(headerColumn || headerFirstCol, null);
         | 
| 234 | 
            +
                                return {
         | 
| 235 | 
            +
                                    columnFriendlyName: col.friendlyName,
         | 
| 236 | 
            +
                                    width: Number(headerColumnStyle.width.replace('px', '')),
         | 
| 237 | 
            +
                                    textAlign: headerColumnStyle.textAlign,
         | 
| 238 | 
            +
                                };
         | 
| 239 | 
            +
                            }),
         | 
| 240 | 
            +
                        },
         | 
| 241 | 
            +
                        Row: {
         | 
| 242 | 
            +
                            color: tinycolor(firstRowStyle.color).toHexString(),
         | 
| 243 | 
            +
                            backColor: tinycolor(firstRowStyle.backgroundColor).toHexString(),
         | 
| 244 | 
            +
                            altBackColor: tinycolor(secondRowStyle.backgroundColor).toHexString(),
         | 
| 245 | 
            +
                            fontFamily: firstRowStyle.fontFamily,
         | 
| 246 | 
            +
                            fontSize: firstRowStyle.fontSize,
         | 
| 247 | 
            +
                            fontStyle: firstRowStyle.fontStyle,
         | 
| 248 | 
            +
                            fontWeight: firstRowStyle.fontWeight,
         | 
| 249 | 
            +
                            height: Number(firstRowStyle.height.replace('px', '')),
         | 
| 250 | 
            +
                            Columns: this.adaptable.api.columnApi.getColumns().map((col) => {
         | 
| 251 | 
            +
                                const cellElement = document.querySelector(`.ag-cell[col-id='${col.columnId}']`);
         | 
| 252 | 
            +
                                const headerColumnStyle = window.getComputedStyle(cellElement || firstRow, null);
         | 
| 253 | 
            +
                                return {
         | 
| 254 | 
            +
                                    columnFriendlyName: col.friendlyName,
         | 
| 255 | 
            +
                                    width: Number(headerColumnStyle.width.replace('px', '')),
         | 
| 256 | 
            +
                                    textAlign: headerColumnStyle.textAlign,
         | 
| 257 | 
            +
                                };
         | 
| 258 | 
            +
                            }),
         | 
| 259 | 
            +
                        },
         | 
| 260 | 
            +
                    };
         | 
| 261 | 
            +
                }
         | 
| 262 | 
            +
                getDefaultIPPStyle() {
         | 
| 263 | 
            +
                    return {
         | 
| 264 | 
            +
                        Header: {
         | 
| 265 | 
            +
                            headerColor: '#000000',
         | 
| 266 | 
            +
                            headerBackColor: '#f5f7f7',
         | 
| 267 | 
            +
                            headerFontFamily: 'sans-serif',
         | 
| 268 | 
            +
                            headerFontSize: '12px',
         | 
| 269 | 
            +
                            headerFontStyle: 'normal',
         | 
| 270 | 
            +
                            headerFontWeight: '400',
         | 
| 271 | 
            +
                            height: 65,
         | 
| 272 | 
            +
                            Columns: this.adaptable.api.columnApi.getColumns().map((col) => {
         | 
| 273 | 
            +
                                return {
         | 
| 274 | 
            +
                                    columnFriendlyName: col.friendlyName,
         | 
| 275 | 
            +
                                    width: 200,
         | 
| 276 | 
            +
                                    textAlign: 'start',
         | 
| 277 | 
            +
                                };
         | 
| 278 | 
            +
                            }),
         | 
| 279 | 
            +
                        },
         | 
| 280 | 
            +
                        Row: {
         | 
| 281 | 
            +
                            color: '#000000',
         | 
| 282 | 
            +
                            backColor: '#ffffff',
         | 
| 283 | 
            +
                            altBackColor: '#fcfdfe',
         | 
| 284 | 
            +
                            fontFamily: 'sans-serif',
         | 
| 285 | 
            +
                            fontSize: '12px',
         | 
| 286 | 
            +
                            fontStyle: 'normal',
         | 
| 287 | 
            +
                            fontWeight: '400',
         | 
| 288 | 
            +
                            height: 30,
         | 
| 289 | 
            +
                            Columns: this.adaptable.api.columnApi.getColumns().map((col) => {
         | 
| 290 | 
            +
                                return {
         | 
| 291 | 
            +
                                    columnFriendlyName: col.friendlyName,
         | 
| 292 | 
            +
                                    width: 200,
         | 
| 293 | 
            +
                                    textAlign: 'start',
         | 
| 294 | 
            +
                                };
         | 
| 295 | 
            +
                            }),
         | 
| 296 | 
            +
                        },
         | 
| 297 | 
            +
                    };
         | 
| 298 | 
            +
                }
         | 
| 209 299 | 
             
            }
         |