@adaptabletools/adaptable-cjs 20.0.0 → 20.0.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/README.md +1 -1
- package/base.css +37 -24
- package/base.css.map +1 -1
- package/index.css +34 -23
- package/index.css.map +1 -1
- package/package.json +1 -1
- package/src/AdaptableOptions/ColumnMenuOptions.d.ts +3 -0
- package/src/AdaptableOptions/ContextMenuOptions.d.ts +9 -0
- package/src/AdaptableOptions/ExportOptions.d.ts +6 -0
- package/src/AdaptableOptions/RowFormOptions.d.ts +7 -1
- package/src/AdaptableState/Common/AdaptableColumn.d.ts +3 -0
- package/src/AdaptableState/Common/AdaptableObject.d.ts +6 -0
- package/src/AdaptableState/Common/AggregationColumns.d.ts +6 -0
- package/src/AdaptableState/Common/Menu.d.ts +6 -0
- package/src/AdaptableState/ExportState.d.ts +9 -0
- package/src/AdaptableState/FlashingCellState.d.ts +5 -2
- package/src/AdaptableState/InitialState.d.ts +4 -3
- package/src/AdaptableState/LayoutState.d.ts +2 -2
- package/src/AdaptableState/ThemeState.d.ts +14 -2
- package/src/Api/StateApi.d.ts +2 -2
- package/src/Redux/ActionsReducers/PluginsRedux.d.ts +0 -93
- package/src/Redux/ActionsReducers/PluginsRedux.js +0 -93
- package/src/Redux/ActionsReducers/ScheduleRedux.d.ts +0 -42
- package/src/Redux/ActionsReducers/ScheduleRedux.js +0 -42
- package/src/Utilities/Defaults/DefaultSettingsPanel.js +1 -1
- package/src/Utilities/Services/ThemeService.js +3 -3
- package/src/View/ColumnInfo/ColumnInfo.js +5 -4
- package/src/View/Components/ColumnFilter/components/FloatingFilterValues.js +7 -0
- package/src/View/Theme/ThemeEditor.js +9 -7
- package/src/View/Theme/VariantSelector.d.ts +1 -0
- package/src/View/Theme/VariantSelector.js +6 -3
- package/src/agGrid/AdaptableAgGrid.js +4 -2
- package/src/agGrid/AgGridAdapter.js +5 -0
- package/src/agGrid/AgGridColumnAdapter.js +0 -7
- package/src/agGrid/AgGridThemeAdapter.js +2 -2
- package/src/agGrid/FloatingFilterWrapper.js +1 -0
- package/src/components/ExpressionEditor/BaseEditorInput.js +1 -1
- package/src/env.js +2 -2
- package/src/layout-manager/src/LayoutManagerModel.d.ts +1 -1
- package/src/metamodel/adaptable.metamodel.d.ts +104 -2
- package/src/metamodel/adaptable.metamodel.js +1 -1
- package/src/migration/AdaptableUpgradeHelper.d.ts +3 -3
- package/tsconfig.cjs.tsbuildinfo +1 -1
|
@@ -3,129 +3,36 @@ import * as Redux from 'redux';
|
|
|
3
3
|
* @ReduxAction Plugins have been instantiated
|
|
4
4
|
*/
|
|
5
5
|
export declare const PLUGINS_SET_PLUGIN_STATE = "PLUGINS_SET_PLUGIN_STATE";
|
|
6
|
-
/**
|
|
7
|
-
* @ReduxAction Throttle time for live reports has been set
|
|
8
|
-
*/
|
|
9
6
|
export declare const IPUSHPULL_SET_THROTTLE_TIME = "IPUSHPULL_SET_THROTTLE_TIME";
|
|
10
|
-
/**
|
|
11
|
-
* @ReduxAction A snapshot report has been sent
|
|
12
|
-
*/
|
|
13
7
|
export declare const IPUSHPULL_SEND_SNAPSHOT = "IPUSHPULL_SEND_SNAPSHOT";
|
|
14
|
-
/**
|
|
15
|
-
* @ReduxAction An ipushpull report has been selected
|
|
16
|
-
*/
|
|
17
8
|
export declare const IPUSHPULL_REPORT_SELECT = "IPUSHPULL_REPORT_SELECT";
|
|
18
|
-
/**
|
|
19
|
-
* @ReduxAction Live data has been sent to ipushpull
|
|
20
|
-
*/
|
|
21
9
|
export declare const IPUSHPULL_START_LIVE_DATA = "IPUSHPULL_START_LIVE_DATA";
|
|
22
|
-
/**
|
|
23
|
-
* @ReduxAction Live data to ipushpull has been stopped
|
|
24
|
-
*/
|
|
25
10
|
export declare const IPUSHPULL_STOP_LIVE_DATA = "IPUSHPULL_STOP_LIVE_DATA";
|
|
26
|
-
/**
|
|
27
|
-
* @ReduxAction A new ipushpull page has been added
|
|
28
|
-
*/
|
|
29
11
|
export declare const IPUSHPULL_ADD_PAGE = "IPUSHPULL_ADD_PAGE";
|
|
30
|
-
/**
|
|
31
|
-
* @ReduxAction Logged in to ipushpull
|
|
32
|
-
*/
|
|
33
12
|
export declare const IPUSHPULL_LOGIN = "IPUSHPULL_LOGIN";
|
|
34
|
-
/**
|
|
35
|
-
* @ReduxAction Logged out from ipushpull
|
|
36
|
-
*/
|
|
37
13
|
export declare const IPUSHPULL_LOGOUT = "IPUSHPULL_LOGOUT";
|
|
38
|
-
/**
|
|
39
|
-
* @ReduxAction Error message set from failed login
|
|
40
|
-
*/
|
|
41
14
|
export declare const IPUSHPULL_SET_LOGIN_ERROR_MESSAGE = "IPUSHPULL_SET_LOGIN_ERROR_MESSAGE";
|
|
42
|
-
/**
|
|
43
|
-
* @ReduxAction Login details to ipushpull have been set
|
|
44
|
-
*/
|
|
45
15
|
export declare const IPUSHPULL_SET_LOGIN_DETAILS = "IPUSHPULL_SET_LOGIN_DETAILS";
|
|
46
|
-
/**
|
|
47
|
-
* @ReduxAction ipushpull has been made available
|
|
48
|
-
*/
|
|
49
16
|
export declare const IPUSHPULL_SET_AVAILABLE_ON = "IPUSHPULL_SET_AVAILABLE_ON";
|
|
50
|
-
/**
|
|
51
|
-
* @ReduxAction ipushpull has been made unavailable
|
|
52
|
-
*/
|
|
53
17
|
export declare const IPUSHPULL_SET_AVAILABLE_OFF = "SET_IPUSHPULL_AVAILABLE_OFF";
|
|
54
|
-
/**
|
|
55
|
-
* @ReduxAction ipushpull is now running
|
|
56
|
-
*/
|
|
57
18
|
export declare const IPUSHPULL_SET_RUNNING_ON = "IPUSHPULL_SET_RUNNING_ON";
|
|
58
|
-
/**
|
|
59
|
-
* @ReduxAction ipushpull is no longer running
|
|
60
|
-
*/
|
|
61
19
|
export declare const IPUSHPULL_SET_RUNNING_OFF = "IPUSHPULL_SET_RUNNING_OFF";
|
|
62
|
-
/**
|
|
63
|
-
* @ReduxAction A live report to ipuspull has been set
|
|
64
|
-
*/
|
|
65
20
|
export declare const IPUSHPULL_LIVE_REPORT_SET = "IPUSHPULL_LIVE_REPORT_SET";
|
|
66
|
-
/**
|
|
67
|
-
* @ReduxAction The live report to ipuspull has been cleared
|
|
68
|
-
*/
|
|
69
21
|
export declare const IPUSHPULL_LIVE_REPORT_CLEAR = "IPUSHPULL_LIVE_REPORT_CLEAR";
|
|
70
|
-
/**
|
|
71
|
-
* @ReduxAction ipushpull domain pages have been set
|
|
72
|
-
*/
|
|
73
22
|
export declare const IPUSHPULL_DOMAIN_PAGES_SET = "IPUSHPULL_DOMAIN_PAGES_SET";
|
|
74
|
-
/**
|
|
75
|
-
* @ReduxAction ipushpull domain pages have been cleared
|
|
76
|
-
*/
|
|
77
23
|
export declare const IPUSHPULL_DOMAIN_PAGES_CLEAR = "IPUSHPULL_DOMAIN_PAGES_CLEAR";
|
|
78
|
-
/**
|
|
79
|
-
* @ReduxAction ipushpull set current(selected) report name
|
|
80
|
-
*/
|
|
81
24
|
export declare const IPUSHPULL_SET_CURRENT_REPORTNAME = "IPUSHPULL_SET_CURRENT_REPORTNAME";
|
|
82
|
-
/**
|
|
83
|
-
* @ReduxAction ipushpull set current(selected) folder
|
|
84
|
-
*/
|
|
85
25
|
export declare const IPUSHPULL_SET_CURRENT_FOLDER = "IPUSHPULL_SET_CURRENT_FOLDER";
|
|
86
|
-
/**
|
|
87
|
-
* @ReduxAction ipushpull set current(selected) page
|
|
88
|
-
*/
|
|
89
26
|
export declare const IPUSHPULL_SET_CURRENT_PAGE = "IPUSHPULL_SET_CURRENT_PAGE";
|
|
90
|
-
/**
|
|
91
|
-
* @ReduxAction ipushpull set available pages (depending on current folder)
|
|
92
|
-
*/
|
|
93
27
|
export declare const IPUSHPULL_SET_AVAILABLE_PAGES = "IPUSHPULL_SET_AVAILABLE_PAGES";
|
|
94
|
-
/**
|
|
95
|
-
* @ReduxAction Live data has been sent to OpenFin
|
|
96
|
-
*/
|
|
97
28
|
export declare const OPENFIN_START_LIVE_DATA = "OPENFIN_START_LIVE_DATA";
|
|
98
|
-
/**
|
|
99
|
-
* @ReduxAction Live data is not longer sent to OpenFin
|
|
100
|
-
*/
|
|
101
29
|
export declare const OPENFIN_STOP_LIVE_DATA = "OPENFIN_STOP_LIVE_DATA";
|
|
102
|
-
/**
|
|
103
|
-
* @ReduxAction An OpenFin live report has started
|
|
104
|
-
*/
|
|
105
30
|
export declare const OPENFIN_LIVE_REPORT_SET = "OPENFIN_LIVE_REPORT_SET";
|
|
106
|
-
/**
|
|
107
|
-
* @ReduxAction An OpenFin live report has stopped
|
|
108
|
-
*/
|
|
109
31
|
export declare const OPENFIN_LIVE_REPORT_CLEAR = "OPENFIN_LIVE_REPORT_CLEAR";
|
|
110
|
-
/**
|
|
111
|
-
* @ReduxAction OpenFin is now available
|
|
112
|
-
*/
|
|
113
32
|
export declare const OPENFIN_SET_AVAILABLE_ON = "OPENFIN_SET_AVAILABLE_ON";
|
|
114
|
-
/**
|
|
115
|
-
* @ReduxAction OpenFin is no longer available
|
|
116
|
-
*/
|
|
117
33
|
export declare const OPENFIN_SET_AVAILABLE_OFF = "OPENFIN_SET_AVAILABLE_OFF";
|
|
118
|
-
/**
|
|
119
|
-
* @ReduxAction OpenFin is now running
|
|
120
|
-
*/
|
|
121
34
|
export declare const OPENFIN_SET_RUNNING_ON = "OPENFIN_SET_RUNNING_ON";
|
|
122
|
-
/**
|
|
123
|
-
* @ReduxAction OpenFin is no longer running
|
|
124
|
-
*/
|
|
125
35
|
export declare const OPENFIN_SET_RUNNING_OFF = "OPENFIN_SET_RUNNING_OFF";
|
|
126
|
-
/**
|
|
127
|
-
* @ReduxAction set current(selected) report name
|
|
128
|
-
*/
|
|
129
36
|
export declare const OPENFIN_SET_CURRENT_REPORTNAME = "OPENFIN_SET_CURRENT_REPORTNAME";
|
|
130
37
|
export interface PluginsAction extends Redux.Action {
|
|
131
38
|
pluginState: any;
|
|
@@ -5,129 +5,36 @@ exports.PluginsReducer = exports.PluginsSetPluginState = exports.OPENFIN_SET_CUR
|
|
|
5
5
|
* @ReduxAction Plugins have been instantiated
|
|
6
6
|
*/
|
|
7
7
|
exports.PLUGINS_SET_PLUGIN_STATE = 'PLUGINS_SET_PLUGIN_STATE';
|
|
8
|
-
/**
|
|
9
|
-
* @ReduxAction Throttle time for live reports has been set
|
|
10
|
-
*/
|
|
11
8
|
exports.IPUSHPULL_SET_THROTTLE_TIME = 'IPUSHPULL_SET_THROTTLE_TIME';
|
|
12
|
-
/**
|
|
13
|
-
* @ReduxAction A snapshot report has been sent
|
|
14
|
-
*/
|
|
15
9
|
exports.IPUSHPULL_SEND_SNAPSHOT = 'IPUSHPULL_SEND_SNAPSHOT';
|
|
16
|
-
/**
|
|
17
|
-
* @ReduxAction An ipushpull report has been selected
|
|
18
|
-
*/
|
|
19
10
|
exports.IPUSHPULL_REPORT_SELECT = 'IPUSHPULL_REPORT_SELECT';
|
|
20
|
-
/**
|
|
21
|
-
* @ReduxAction Live data has been sent to ipushpull
|
|
22
|
-
*/
|
|
23
11
|
exports.IPUSHPULL_START_LIVE_DATA = 'IPUSHPULL_START_LIVE_DATA';
|
|
24
|
-
/**
|
|
25
|
-
* @ReduxAction Live data to ipushpull has been stopped
|
|
26
|
-
*/
|
|
27
12
|
exports.IPUSHPULL_STOP_LIVE_DATA = 'IPUSHPULL_STOP_LIVE_DATA';
|
|
28
|
-
/**
|
|
29
|
-
* @ReduxAction A new ipushpull page has been added
|
|
30
|
-
*/
|
|
31
13
|
exports.IPUSHPULL_ADD_PAGE = 'IPUSHPULL_ADD_PAGE';
|
|
32
|
-
/**
|
|
33
|
-
* @ReduxAction Logged in to ipushpull
|
|
34
|
-
*/
|
|
35
14
|
exports.IPUSHPULL_LOGIN = 'IPUSHPULL_LOGIN';
|
|
36
|
-
/**
|
|
37
|
-
* @ReduxAction Logged out from ipushpull
|
|
38
|
-
*/
|
|
39
15
|
exports.IPUSHPULL_LOGOUT = 'IPUSHPULL_LOGOUT';
|
|
40
|
-
/**
|
|
41
|
-
* @ReduxAction Error message set from failed login
|
|
42
|
-
*/
|
|
43
16
|
exports.IPUSHPULL_SET_LOGIN_ERROR_MESSAGE = 'IPUSHPULL_SET_LOGIN_ERROR_MESSAGE';
|
|
44
|
-
/**
|
|
45
|
-
* @ReduxAction Login details to ipushpull have been set
|
|
46
|
-
*/
|
|
47
17
|
exports.IPUSHPULL_SET_LOGIN_DETAILS = 'IPUSHPULL_SET_LOGIN_DETAILS';
|
|
48
|
-
/**
|
|
49
|
-
* @ReduxAction ipushpull has been made available
|
|
50
|
-
*/
|
|
51
18
|
exports.IPUSHPULL_SET_AVAILABLE_ON = 'IPUSHPULL_SET_AVAILABLE_ON';
|
|
52
|
-
/**
|
|
53
|
-
* @ReduxAction ipushpull has been made unavailable
|
|
54
|
-
*/
|
|
55
19
|
exports.IPUSHPULL_SET_AVAILABLE_OFF = 'SET_IPUSHPULL_AVAILABLE_OFF';
|
|
56
|
-
/**
|
|
57
|
-
* @ReduxAction ipushpull is now running
|
|
58
|
-
*/
|
|
59
20
|
exports.IPUSHPULL_SET_RUNNING_ON = 'IPUSHPULL_SET_RUNNING_ON';
|
|
60
|
-
/**
|
|
61
|
-
* @ReduxAction ipushpull is no longer running
|
|
62
|
-
*/
|
|
63
21
|
exports.IPUSHPULL_SET_RUNNING_OFF = 'IPUSHPULL_SET_RUNNING_OFF';
|
|
64
|
-
/**
|
|
65
|
-
* @ReduxAction A live report to ipuspull has been set
|
|
66
|
-
*/
|
|
67
22
|
exports.IPUSHPULL_LIVE_REPORT_SET = 'IPUSHPULL_LIVE_REPORT_SET';
|
|
68
|
-
/**
|
|
69
|
-
* @ReduxAction The live report to ipuspull has been cleared
|
|
70
|
-
*/
|
|
71
23
|
exports.IPUSHPULL_LIVE_REPORT_CLEAR = 'IPUSHPULL_LIVE_REPORT_CLEAR';
|
|
72
|
-
/**
|
|
73
|
-
* @ReduxAction ipushpull domain pages have been set
|
|
74
|
-
*/
|
|
75
24
|
exports.IPUSHPULL_DOMAIN_PAGES_SET = 'IPUSHPULL_DOMAIN_PAGES_SET';
|
|
76
|
-
/**
|
|
77
|
-
* @ReduxAction ipushpull domain pages have been cleared
|
|
78
|
-
*/
|
|
79
25
|
exports.IPUSHPULL_DOMAIN_PAGES_CLEAR = 'IPUSHPULL_DOMAIN_PAGES_CLEAR';
|
|
80
|
-
/**
|
|
81
|
-
* @ReduxAction ipushpull set current(selected) report name
|
|
82
|
-
*/
|
|
83
26
|
exports.IPUSHPULL_SET_CURRENT_REPORTNAME = 'IPUSHPULL_SET_CURRENT_REPORTNAME';
|
|
84
|
-
/**
|
|
85
|
-
* @ReduxAction ipushpull set current(selected) folder
|
|
86
|
-
*/
|
|
87
27
|
exports.IPUSHPULL_SET_CURRENT_FOLDER = 'IPUSHPULL_SET_CURRENT_FOLDER';
|
|
88
|
-
/**
|
|
89
|
-
* @ReduxAction ipushpull set current(selected) page
|
|
90
|
-
*/
|
|
91
28
|
exports.IPUSHPULL_SET_CURRENT_PAGE = 'IPUSHPULL_SET_CURRENT_PAGE';
|
|
92
|
-
/**
|
|
93
|
-
* @ReduxAction ipushpull set available pages (depending on current folder)
|
|
94
|
-
*/
|
|
95
29
|
exports.IPUSHPULL_SET_AVAILABLE_PAGES = 'IPUSHPULL_SET_AVAILABLE_PAGES';
|
|
96
|
-
/**
|
|
97
|
-
* @ReduxAction Live data has been sent to OpenFin
|
|
98
|
-
*/
|
|
99
30
|
exports.OPENFIN_START_LIVE_DATA = 'OPENFIN_START_LIVE_DATA';
|
|
100
|
-
/**
|
|
101
|
-
* @ReduxAction Live data is not longer sent to OpenFin
|
|
102
|
-
*/
|
|
103
31
|
exports.OPENFIN_STOP_LIVE_DATA = 'OPENFIN_STOP_LIVE_DATA';
|
|
104
|
-
/**
|
|
105
|
-
* @ReduxAction An OpenFin live report has started
|
|
106
|
-
*/
|
|
107
32
|
exports.OPENFIN_LIVE_REPORT_SET = 'OPENFIN_LIVE_REPORT_SET';
|
|
108
|
-
/**
|
|
109
|
-
* @ReduxAction An OpenFin live report has stopped
|
|
110
|
-
*/
|
|
111
33
|
exports.OPENFIN_LIVE_REPORT_CLEAR = 'OPENFIN_LIVE_REPORT_CLEAR';
|
|
112
|
-
/**
|
|
113
|
-
* @ReduxAction OpenFin is now available
|
|
114
|
-
*/
|
|
115
34
|
exports.OPENFIN_SET_AVAILABLE_ON = 'OPENFIN_SET_AVAILABLE_ON';
|
|
116
|
-
/**
|
|
117
|
-
* @ReduxAction OpenFin is no longer available
|
|
118
|
-
*/
|
|
119
35
|
exports.OPENFIN_SET_AVAILABLE_OFF = 'OPENFIN_SET_AVAILABLE_OFF';
|
|
120
|
-
/**
|
|
121
|
-
* @ReduxAction OpenFin is now running
|
|
122
|
-
*/
|
|
123
36
|
exports.OPENFIN_SET_RUNNING_ON = 'OPENFIN_SET_RUNNING_ON';
|
|
124
|
-
/**
|
|
125
|
-
* @ReduxAction OpenFin is no longer running
|
|
126
|
-
*/
|
|
127
37
|
exports.OPENFIN_SET_RUNNING_OFF = 'OPENFIN_SET_RUNNING_OFF';
|
|
128
|
-
/**
|
|
129
|
-
* @ReduxAction set current(selected) report name
|
|
130
|
-
*/
|
|
131
38
|
exports.OPENFIN_SET_CURRENT_REPORTNAME = 'OPENFIN_SET_CURRENT_REPORTNAME';
|
|
132
39
|
const PluginsSetPluginState = (pluginId, pluginState) => ({
|
|
133
40
|
type: exports.PLUGINS_SET_PLUGIN_STATE,
|
|
@@ -65,61 +65,19 @@ export declare const REMINDER_SCHEDULE_SUSPEND_ALL = "REMINDER_SCHEDULE_SUSPEND_
|
|
|
65
65
|
* @ReduxAction All Reminder Schedules have been unsuspended or activated
|
|
66
66
|
*/
|
|
67
67
|
export declare const REMINDER_SCHEDULE_UNSUSPEND_ALL = "REMINDER_SCHEDULE_UNSUSPEND_ALL";
|
|
68
|
-
/**
|
|
69
|
-
* @ReduxAction An ipushpull Schedule has been added
|
|
70
|
-
*/
|
|
71
68
|
export declare const IPUSHPULL_SCHEDULE_ADD = "IPUSHPULL_SCHEDULE_ADD";
|
|
72
|
-
/**
|
|
73
|
-
* @ReduxAction An ipushpull Schedule has been edited
|
|
74
|
-
*/
|
|
75
69
|
export declare const IPUSHPULL_SCHEDULE_EDIT = "IPUSHPULL_SCHEDULE_EDIT";
|
|
76
|
-
/**
|
|
77
|
-
* @ReduxAction An ipushpull Schedule has been deleted
|
|
78
|
-
*/
|
|
79
70
|
export declare const IPUSHPULL_SCHEDULE_DELETE = "IPUSHPULL_SCHEDULE_DELETE";
|
|
80
|
-
/**
|
|
81
|
-
* @ReduxAction An ipushpull Schedule has been suspended
|
|
82
|
-
*/
|
|
83
71
|
export declare const IPUSHPULL_SCHEDULE_SUSPEND = "IPUSHPULL_SCHEDULE_SUSPEND";
|
|
84
|
-
/**
|
|
85
|
-
* @ReduxAction An ipushpull Schedule has been unsuspended or activated
|
|
86
|
-
*/
|
|
87
72
|
export declare const IPUSHPULL_SCHEDULE_UNSUSPEND = "IPUSHPULL_SCHEDULE_UNSUSPEND";
|
|
88
|
-
/**
|
|
89
|
-
* @ReduxAction All ipushpull Schedules have been suspended
|
|
90
|
-
*/
|
|
91
73
|
export declare const IPUSHPULL_SCHEDULE_SUSPEND_ALL = "IPUSHPULL_SCHEDULE_SUSPEND_ALL";
|
|
92
|
-
/**
|
|
93
|
-
* @ReduxAction All ipushpull Schedules have been unsuspended or activated
|
|
94
|
-
*/
|
|
95
74
|
export declare const IPUSHPULL_SCHEDULE_UNSUSPEND_ALL = "IPUSHPULL_SCHEDULE_UNSUSPEND_ALL";
|
|
96
|
-
/**
|
|
97
|
-
* @ReduxAction An OpenFin Schedule has been added
|
|
98
|
-
*/
|
|
99
75
|
export declare const OPENFIN_SCHEDULE_ADD = "OPENFIN_SCHEDULE_ADD";
|
|
100
|
-
/**
|
|
101
|
-
* @ReduxAction An OpenFin Schedule has been edited
|
|
102
|
-
*/
|
|
103
76
|
export declare const OPENFIN_SCHEDULE_EDIT = "OPENFIN_SCHEDULE_EDIT";
|
|
104
|
-
/**
|
|
105
|
-
* @ReduxAction An OpenFin Schedule has been deleted
|
|
106
|
-
*/
|
|
107
77
|
export declare const OPENFIN_SCHEDULE_DELETE = "OPENFIN_SCHEDULE_DELETE";
|
|
108
|
-
/**
|
|
109
|
-
* @ReduxAction An OpenFin Schedule has been suspended
|
|
110
|
-
*/
|
|
111
78
|
export declare const OPENFIN_SCHEDULE_SUSPEND = "OPENFIN_SCHEDULE_SUSPEND";
|
|
112
|
-
/**
|
|
113
|
-
* @ReduxAction An OpenFin Schedule has been unsuspended or activated
|
|
114
|
-
*/
|
|
115
79
|
export declare const OPENFIN_SCHEDULE_UNSUSPEND = "OPENFIN_SCHEDULE_UNSUSPEND";
|
|
116
|
-
/**
|
|
117
|
-
* @ReduxAction All OpenFin Schedules have been suspended
|
|
118
|
-
*/
|
|
119
80
|
export declare const OPENFIN_SCHEDULE_SUSPEND_ALL = "OPENFIN_SCHEDULE_SUSPEND_ALL";
|
|
120
|
-
/**
|
|
121
|
-
* @ReduxAction All OpenFin Schedules have been unsuspended or activated
|
|
122
|
-
*/
|
|
123
81
|
export declare const OPENFIN_SCHEDULE_UNSUSPEND_ALL = "OPENFIN_SCHEDULE_UNSUSPEND_ALL";
|
|
124
82
|
/**
|
|
125
83
|
* @ReduxAction Schedule Module is ready
|
|
@@ -66,61 +66,19 @@ exports.REMINDER_SCHEDULE_SUSPEND_ALL = 'REMINDER_SCHEDULE_SUSPEND_ALL';
|
|
|
66
66
|
* @ReduxAction All Reminder Schedules have been unsuspended or activated
|
|
67
67
|
*/
|
|
68
68
|
exports.REMINDER_SCHEDULE_UNSUSPEND_ALL = 'REMINDER_SCHEDULE_UNSUSPEND_ALL';
|
|
69
|
-
/**
|
|
70
|
-
* @ReduxAction An ipushpull Schedule has been added
|
|
71
|
-
*/
|
|
72
69
|
exports.IPUSHPULL_SCHEDULE_ADD = 'IPUSHPULL_SCHEDULE_ADD';
|
|
73
|
-
/**
|
|
74
|
-
* @ReduxAction An ipushpull Schedule has been edited
|
|
75
|
-
*/
|
|
76
70
|
exports.IPUSHPULL_SCHEDULE_EDIT = 'IPUSHPULL_SCHEDULE_EDIT';
|
|
77
|
-
/**
|
|
78
|
-
* @ReduxAction An ipushpull Schedule has been deleted
|
|
79
|
-
*/
|
|
80
71
|
exports.IPUSHPULL_SCHEDULE_DELETE = 'IPUSHPULL_SCHEDULE_DELETE';
|
|
81
|
-
/**
|
|
82
|
-
* @ReduxAction An ipushpull Schedule has been suspended
|
|
83
|
-
*/
|
|
84
72
|
exports.IPUSHPULL_SCHEDULE_SUSPEND = 'IPUSHPULL_SCHEDULE_SUSPEND';
|
|
85
|
-
/**
|
|
86
|
-
* @ReduxAction An ipushpull Schedule has been unsuspended or activated
|
|
87
|
-
*/
|
|
88
73
|
exports.IPUSHPULL_SCHEDULE_UNSUSPEND = 'IPUSHPULL_SCHEDULE_UNSUSPEND';
|
|
89
|
-
/**
|
|
90
|
-
* @ReduxAction All ipushpull Schedules have been suspended
|
|
91
|
-
*/
|
|
92
74
|
exports.IPUSHPULL_SCHEDULE_SUSPEND_ALL = 'IPUSHPULL_SCHEDULE_SUSPEND_ALL';
|
|
93
|
-
/**
|
|
94
|
-
* @ReduxAction All ipushpull Schedules have been unsuspended or activated
|
|
95
|
-
*/
|
|
96
75
|
exports.IPUSHPULL_SCHEDULE_UNSUSPEND_ALL = 'IPUSHPULL_SCHEDULE_UNSUSPEND_ALL';
|
|
97
|
-
/**
|
|
98
|
-
* @ReduxAction An OpenFin Schedule has been added
|
|
99
|
-
*/
|
|
100
76
|
exports.OPENFIN_SCHEDULE_ADD = 'OPENFIN_SCHEDULE_ADD';
|
|
101
|
-
/**
|
|
102
|
-
* @ReduxAction An OpenFin Schedule has been edited
|
|
103
|
-
*/
|
|
104
77
|
exports.OPENFIN_SCHEDULE_EDIT = 'OPENFIN_SCHEDULE_EDIT';
|
|
105
|
-
/**
|
|
106
|
-
* @ReduxAction An OpenFin Schedule has been deleted
|
|
107
|
-
*/
|
|
108
78
|
exports.OPENFIN_SCHEDULE_DELETE = 'OPENFIN_SCHEDULE_DELETE';
|
|
109
|
-
/**
|
|
110
|
-
* @ReduxAction An OpenFin Schedule has been suspended
|
|
111
|
-
*/
|
|
112
79
|
exports.OPENFIN_SCHEDULE_SUSPEND = 'OPENFIN_SCHEDULE_SUSPEND';
|
|
113
|
-
/**
|
|
114
|
-
* @ReduxAction An OpenFin Schedule has been unsuspended or activated
|
|
115
|
-
*/
|
|
116
80
|
exports.OPENFIN_SCHEDULE_UNSUSPEND = 'OPENFIN_SCHEDULE_UNSUSPEND';
|
|
117
|
-
/**
|
|
118
|
-
* @ReduxAction All OpenFin Schedules have been suspended
|
|
119
|
-
*/
|
|
120
81
|
exports.OPENFIN_SCHEDULE_SUSPEND_ALL = 'OPENFIN_SCHEDULE_SUSPEND_ALL';
|
|
121
|
-
/**
|
|
122
|
-
* @ReduxAction All OpenFin Schedules have been unsuspended or activated
|
|
123
|
-
*/
|
|
124
82
|
exports.OPENFIN_SCHEDULE_UNSUSPEND_ALL = 'OPENFIN_SCHEDULE_UNSUSPEND_ALL';
|
|
125
83
|
/**
|
|
126
84
|
* @ReduxAction Schedule Module is ready
|
|
@@ -10,6 +10,7 @@ exports.DEFAULT_SETTINGS_PANEL_NAVIGATION_ITEMS = [
|
|
|
10
10
|
'Dashboard',
|
|
11
11
|
'ToolPanel',
|
|
12
12
|
'StatusBar',
|
|
13
|
+
'Theme',
|
|
13
14
|
'-',
|
|
14
15
|
'Layout',
|
|
15
16
|
'CalculatedColumn',
|
|
@@ -23,7 +24,6 @@ exports.DEFAULT_SETTINGS_PANEL_NAVIGATION_ITEMS = [
|
|
|
23
24
|
'FormatColumn',
|
|
24
25
|
'StyledColumn',
|
|
25
26
|
'FlashingCell',
|
|
26
|
-
'Theme',
|
|
27
27
|
'-',
|
|
28
28
|
'QuickSearch',
|
|
29
29
|
'GridFilter',
|
|
@@ -73,11 +73,11 @@ class ThemeService {
|
|
|
73
73
|
if (abLoaded !== '777') {
|
|
74
74
|
logger.consoleError('Please import Adaptable styles from "@adaptabletools/adaptable/index.css"');
|
|
75
75
|
}
|
|
76
|
-
|
|
77
|
-
if (abThemeLoaded !== themeName) {
|
|
76
|
+
const isCustomUserTheme = !this.api.themeApi.internalApi.isSystemTheme(themeName);
|
|
77
|
+
if (!isCustomUserTheme && abThemeLoaded !== themeName) {
|
|
78
78
|
logger.consoleWarn(`Theme "${themeName}" doesn't seem to be loaded! Make sure you import the css file for the "${themeName}" theme!
|
|
79
79
|
|
|
80
|
-
If it's
|
|
80
|
+
If it's an AdapTable system theme, try
|
|
81
81
|
|
|
82
82
|
import "@adaptabletools/adaptable/themes/${themeName}.css"`);
|
|
83
83
|
}
|
|
@@ -218,12 +218,13 @@ const ColumnInfo = (props) => {
|
|
|
218
218
|
React.createElement(FormLayout_1.FormRow, { label: "Select Column" },
|
|
219
219
|
React.createElement(ColumnSelector_1.ColumnSelector, { filterColumn: (column) => !column.alwaysHidden, value: selectedColumnId, onChange: (columnId) => setSelectedColumnId(columnId) })))),
|
|
220
220
|
selectedColumnId && (React.createElement(Tabs_1.Tabs, { mb: 3 },
|
|
221
|
-
React.createElement(Tabs_1.Tabs.Tab, null, "State"),
|
|
222
221
|
React.createElement(Tabs_1.Tabs.Tab, null, "Column Summary"),
|
|
222
|
+
React.createElement(Tabs_1.Tabs.Tab, null, "Column State"),
|
|
223
|
+
React.createElement(Tabs_1.Tabs.Content, null,
|
|
224
|
+
React.createElement(rebass_1.Flex, { flex: 1 }, selectedColumnId && React.createElement(ColumnDefPreview, { column: column }))),
|
|
225
|
+
' ',
|
|
223
226
|
React.createElement(Tabs_1.Tabs.Content, null, selectedColumnId && (React.createElement(rebass_1.Box, { className: BASE_CLASS_NAME }, MODULES_WITH_COLUMN.map((moduleName) => {
|
|
224
227
|
return (React.createElement(ModuleView, { key: moduleName, moduleName: moduleName, selectedColumnId: selectedColumnId }));
|
|
225
|
-
}))))
|
|
226
|
-
React.createElement(Tabs_1.Tabs.Content, null,
|
|
227
|
-
React.createElement(rebass_1.Flex, { flex: 1 }, selectedColumnId && React.createElement(ColumnDefPreview, { column: column })))))));
|
|
228
|
+
}))))))));
|
|
228
229
|
};
|
|
229
230
|
exports.ColumnInfo = ColumnInfo;
|
|
@@ -105,6 +105,13 @@ const FloatingFilterValues = (props) => {
|
|
|
105
105
|
border: 'none',
|
|
106
106
|
},
|
|
107
107
|
},
|
|
108
|
+
...(props.value?.length
|
|
109
|
+
? {
|
|
110
|
+
valueContainer: {
|
|
111
|
+
fontWeight: 'var(--ab-cmp-quickfilter-selected-options-text__font-weight)',
|
|
112
|
+
},
|
|
113
|
+
}
|
|
114
|
+
: {}),
|
|
108
115
|
},
|
|
109
116
|
onMenuOpen,
|
|
110
117
|
onInputChange,
|
|
@@ -12,6 +12,7 @@ const rebass_1 = require("rebass");
|
|
|
12
12
|
const Panel_1 = tslib_1.__importDefault(require("../../components/Panel"));
|
|
13
13
|
const ThemeField_1 = require("./ThemeField");
|
|
14
14
|
const VariantSelector_1 = require("./VariantSelector");
|
|
15
|
+
const AdaptableHelper_1 = require("../../Utilities/Helpers/AdaptableHelper");
|
|
15
16
|
const fields = [
|
|
16
17
|
{
|
|
17
18
|
name: 'Primary Color',
|
|
@@ -77,10 +78,11 @@ const fields = [
|
|
|
77
78
|
const ThemeEditor = (props) => {
|
|
78
79
|
const adaptable = (0, AdaptableContext_1.useAdaptable)();
|
|
79
80
|
const allThemes = adaptable.api.themeApi.getUserThemes();
|
|
80
|
-
const disabled = props.accessLevel === 'ReadOnly';
|
|
81
81
|
const [currentThemeObject, setCurrentThemeObject] = React.useState(() => {
|
|
82
82
|
return adaptable.api.themeApi.getCurrentThemeObject();
|
|
83
83
|
});
|
|
84
|
+
const currentThemeAccessLevel = (0, AdaptableHelper_1.getAccessLevelForObject)(currentThemeObject, props.accessLevel);
|
|
85
|
+
const currentThemeIsReadOnly = currentThemeAccessLevel !== 'Full';
|
|
84
86
|
// THEME variables
|
|
85
87
|
const themeVariables = currentThemeObject?.CSSVariables;
|
|
86
88
|
const valuesFromTheme = fields.reduce((acc, field) => {
|
|
@@ -142,22 +144,22 @@ const ThemeEditor = (props) => {
|
|
|
142
144
|
const saveNameDisabled = !nameHasChanged || nameIsNotUnique || currentThemeObject.Name === '';
|
|
143
145
|
return (React.createElement(Panel_1.default, { header: React.createElement(rebass_1.Flex, { alignItems: "center", width: "100%" },
|
|
144
146
|
React.createElement(rebass_1.Box, { flex: 1 }, " Edit Custom Theme"),
|
|
145
|
-
React.createElement(SimpleButton_1.default, { "data-name": "delete",
|
|
147
|
+
React.createElement(SimpleButton_1.default, { "data-name": "delete", accessLevel: currentThemeAccessLevel, icon: "delete", onClick: handleDeleteTheme, variant: "text" })) },
|
|
146
148
|
React.createElement(FormLayout_1.default, null,
|
|
147
149
|
React.createElement(FormLayout_1.FormRow, { label: "Theme Name" },
|
|
148
|
-
React.createElement(AdaptableInput_1.default, { mr: 2, onChange: (event) => setCurrentThemeObject({
|
|
150
|
+
React.createElement(AdaptableInput_1.default, { disabled: currentThemeIsReadOnly, mr: 2, onChange: (event) => setCurrentThemeObject({
|
|
149
151
|
...currentThemeObject,
|
|
150
152
|
Name: event.target.value.replace(/ /g, '-'),
|
|
151
153
|
}), value: currentThemeObject.Name ?? '' }),
|
|
152
|
-
React.createElement(SimpleButton_1.default, { onClick: handleSaveName, disabled: saveNameDisabled, icon: "save" }),
|
|
154
|
+
React.createElement(SimpleButton_1.default, { onClick: handleSaveName, disabled: saveNameDisabled || currentThemeIsReadOnly, icon: "save", hidden: currentThemeIsReadOnly }),
|
|
153
155
|
React.createElement(rebass_1.Text, { fontSize: 2, marginTop: 1 }, "The name cannot contain spaces."),
|
|
154
156
|
nameIsNotUnique && (React.createElement(rebass_1.Text, { fontSize: 2, color: "var(--ab-color-error)" }, "Name must be unique."))),
|
|
155
157
|
React.createElement(FormLayout_1.FormRow, { label: "Description" },
|
|
156
|
-
React.createElement(AdaptableInput_1.default, { onChange: (event) => handleDescriptionChange('Description', event.target.value), value: currentThemeObject?.Description ?? '' })),
|
|
158
|
+
React.createElement(AdaptableInput_1.default, { disabled: currentThemeIsReadOnly, onChange: (event) => handleDescriptionChange('Description', event.target.value), value: currentThemeObject?.Description ?? '' })),
|
|
157
159
|
React.createElement(FormLayout_1.FormRow, { label: "Variant" },
|
|
158
|
-
React.createElement(VariantSelector_1.VariantSelector, { onChange: handleVariantChange, theme: currentThemeObject })),
|
|
160
|
+
React.createElement(VariantSelector_1.VariantSelector, { onChange: handleVariantChange, theme: currentThemeObject, disabled: currentThemeIsReadOnly })),
|
|
159
161
|
fields.map((field) => {
|
|
160
|
-
return (React.createElement(ThemeField_1.Field, { disabled:
|
|
162
|
+
return (React.createElement(ThemeField_1.Field, { disabled: currentThemeIsReadOnly, key: field.name, type: field.type, name: field.name, value: valuesFromTheme[field.variable], variable: field.variable, onChange: (val) => {
|
|
161
163
|
// needs a fresh copy
|
|
162
164
|
const currentThemeObject = adaptable.api.themeApi.getCurrentThemeObject();
|
|
163
165
|
let newTheme = null;
|
|
@@ -3,5 +3,6 @@ import { AdaptableTheme } from '../../types';
|
|
|
3
3
|
export interface VariantSelectorProps {
|
|
4
4
|
theme: AdaptableTheme;
|
|
5
5
|
onChange: (variant: AdaptableTheme['Variant'] | null) => void;
|
|
6
|
+
disabled?: boolean;
|
|
6
7
|
}
|
|
7
8
|
export declare const VariantSelector: React.FunctionComponent<VariantSelectorProps>;
|
|
@@ -6,9 +6,12 @@ const React = tslib_1.__importStar(require("react"));
|
|
|
6
6
|
const DropdownButton_1 = tslib_1.__importDefault(require("../../components/DropdownButton"));
|
|
7
7
|
const SimpleButton_1 = tslib_1.__importDefault(require("../../components/SimpleButton"));
|
|
8
8
|
const AdaptableContext_1 = require("../AdaptableContext");
|
|
9
|
+
const GeneralConstants_1 = require("../../Utilities/Constants/GeneralConstants");
|
|
9
10
|
const VariantSelector = (props) => {
|
|
10
11
|
const adaptable = (0, AdaptableContext_1.useAdaptable)();
|
|
11
|
-
const systemTemes = adaptable.api.themeApi
|
|
12
|
+
const systemTemes = adaptable.api.themeApi
|
|
13
|
+
.getSystemThemes()
|
|
14
|
+
.filter((theme) => theme.Name !== GeneralConstants_1.OS_THEME);
|
|
12
15
|
const options = systemTemes.map((theme) => ({
|
|
13
16
|
label: theme.Description,
|
|
14
17
|
value: theme.Name,
|
|
@@ -18,7 +21,7 @@ const VariantSelector = (props) => {
|
|
|
18
21
|
? options.find((theme) => theme.value === props.theme.Variant)?.label
|
|
19
22
|
: 'Select a theme';
|
|
20
23
|
return (React.createElement(React.Fragment, null,
|
|
21
|
-
React.createElement(DropdownButton_1.default, { mr: 2, columns: ['label'], items: options }, label),
|
|
22
|
-
React.createElement(SimpleButton_1.default, { onClick: () => props.onChange(null), disabled: !props.theme.Variant, icon: "delete" })));
|
|
24
|
+
React.createElement(DropdownButton_1.default, { mr: 2, columns: ['label'], items: options, disabled: props.disabled }, label),
|
|
25
|
+
React.createElement(SimpleButton_1.default, { onClick: () => props.onChange(null), disabled: !props.theme.Variant || props.disabled, hidden: props.disabled, icon: "delete" })));
|
|
23
26
|
};
|
|
24
27
|
exports.VariantSelector = VariantSelector;
|
|
@@ -323,11 +323,13 @@ class AdaptableAgGrid {
|
|
|
323
323
|
*/
|
|
324
324
|
postLoadHook: (state) => {
|
|
325
325
|
if (this.adaptableOptions.stateOptions.autoMigrateState) {
|
|
326
|
-
|
|
326
|
+
this.api.logError;
|
|
327
|
+
const config = {
|
|
327
328
|
// version 16 actually includes all versions up until 16
|
|
328
329
|
fromVersion: 16,
|
|
329
330
|
logger: this.logger,
|
|
330
|
-
}
|
|
331
|
+
};
|
|
332
|
+
state = AdaptableUpgradeHelper_1.AdaptableUpgradeHelper.migrateAdaptableState(state, config);
|
|
331
333
|
}
|
|
332
334
|
state = this.normalizeAdaptableState(state, config.gridOptions);
|
|
333
335
|
return state;
|
|
@@ -452,6 +452,11 @@ class AgGridAdapter {
|
|
|
452
452
|
this.logger.warn(`Column is undefined, returning 'text' for Type`);
|
|
453
453
|
return 'text';
|
|
454
454
|
}
|
|
455
|
+
const colDefType = [].concat(agColumn.getColDef()?.type || []).filter(Boolean);
|
|
456
|
+
const skippedSpecialCols = ['actionColumn', 'fdc3Column'];
|
|
457
|
+
if (skippedSpecialCols.some((specialColType) => colDefType.includes(specialColType))) {
|
|
458
|
+
return 'unknown';
|
|
459
|
+
}
|
|
455
460
|
let dataType = 'unknown';
|
|
456
461
|
// get the column type if already in store (and not unknown)
|
|
457
462
|
const existingColumn = this.adaptableApi.columnApi.getColumnWithColumnId(agColumn.getId(), logWarning);
|
|
@@ -243,13 +243,6 @@ class AgGridColumnAdapter {
|
|
|
243
243
|
return cellDataTypeEditor;
|
|
244
244
|
}
|
|
245
245
|
});
|
|
246
|
-
this.setColDefProperty(col, 'cellEditorPopup', () => {
|
|
247
|
-
// as specified in https://www.ag-grid.com/react-data-grid/provided-cell-editors/#rich-select-cell-editor
|
|
248
|
-
// agRichSelectCellEditor should always set cellEditorPopup=true. Otherwise the editor will be clipped to the cell contents
|
|
249
|
-
if (shouldShowSelectCellEditor && hasRichSelectCellEditor) {
|
|
250
|
-
return true;
|
|
251
|
-
}
|
|
252
|
-
});
|
|
253
246
|
this.setColDefProperty(col, 'cellEditorParams', (params) => {
|
|
254
247
|
if (shouldShowSelectCellEditor) {
|
|
255
248
|
return (params) => {
|
|
@@ -27,10 +27,10 @@ class AgGridThemeAdapter {
|
|
|
27
27
|
const isSystemTheme = this.api.themeApi.internalApi.isSystemTheme(themeName);
|
|
28
28
|
if (adaptableTheme && (isSystemTheme || variantTheme)) {
|
|
29
29
|
if ((variantTheme || themeName) === GeneralConstants_1.LIGHT_THEME) {
|
|
30
|
-
document.body.dataset.agThemeMode = 'light';
|
|
30
|
+
document.body.dataset.agThemeMode = adaptableTheme.AgThemeMode ?? 'light';
|
|
31
31
|
}
|
|
32
32
|
if ((variantTheme || themeName) === GeneralConstants_1.DARK_THEME) {
|
|
33
|
-
document.body.dataset.agThemeMode = 'dark';
|
|
33
|
+
document.body.dataset.agThemeMode = adaptableTheme.AgThemeMode ?? 'dark';
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
36
|
}
|
|
@@ -122,7 +122,7 @@ const FunctionsDropdown = ({ expressionFunctions, baseClassName }) => {
|
|
|
122
122
|
}, onClick: handleFunctionCategoryChange(option.value), checked: currentFunctionCategory === option.value }, option.label));
|
|
123
123
|
})),
|
|
124
124
|
React.createElement(rebass_1.Flex, null,
|
|
125
|
-
React.createElement(rebass_1.Flex, { className: `${baseClassName}__dropdown-functions-list`, "data-name": "expression-dropdown-
|
|
125
|
+
React.createElement(rebass_1.Flex, { className: `${baseClassName}__dropdown-functions-list`, "data-name": "expression-dropdown-functions-list", flexDirection: "column", p: 2, maxHeight: '50vh' }, orderedGroupNames
|
|
126
126
|
.filter((groupName) => !!groupedFunctions[groupName])
|
|
127
127
|
.map((groupName) => {
|
|
128
128
|
const functionsInGroup = Object.keys(groupedFunctions[groupName]);
|
package/src/env.js
CHANGED
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.default = {
|
|
4
4
|
NEXT_PUBLIC_INFINITE_TABLE_LICENSE_KEY: "StartDate=2021-06-29|EndDate=2030-01-01|Owner=Adaptable|Type=distribution|TS=1624971462479|C=137829811,1004007071,2756196225,1839832928,3994409405,636616862" || '',
|
|
5
|
-
PUBLISH_TIMESTAMP:
|
|
6
|
-
VERSION: "20.0.
|
|
5
|
+
PUBLISH_TIMESTAMP: 1743270632298 || Date.now(),
|
|
6
|
+
VERSION: "20.0.1" || '--current-version--',
|
|
7
7
|
};
|
|
@@ -36,7 +36,7 @@ export interface BaseLayoutModel {
|
|
|
36
36
|
Values: any[][];
|
|
37
37
|
};
|
|
38
38
|
/**
|
|
39
|
-
*
|
|
39
|
+
* Hides aggFunc name in the column header: e.g. 'sum(Bank Balance)' will just be 'Bank Balance'
|
|
40
40
|
*/
|
|
41
41
|
SuppressAggFuncInHeader?: boolean;
|
|
42
42
|
/**
|