Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Lens] Formula time shift #101718

Merged
merged 306 commits into from
Jun 17, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
306 commits
Select commit Hold shift + click to select a range
7832aeb
Move formula into a tab
wylieconlon Mar 4, 2021
f05c647
:fire: Leftovers from previous merge
dej611 Mar 4, 2021
d050e6f
:sparkles: Move over namedArgs from previous function
dej611 Mar 4, 2021
37c9c5f
:white_check_mark: Add tests for transferable scenarios
dej611 Mar 4, 2021
006f569
Merge branch 'lens/formula-error-handling' of github.com:dej611/kiban…
dej611 Mar 4, 2021
135987c
:white_check_mark: Fixed broken test
dej611 Mar 4, 2021
28847f1
:sparkles: Use custom label for axis
dej611 Mar 4, 2021
5524cf2
Allow switching back and forth to formula tab
wylieconlon Mar 4, 2021
6650f67
Add a section for the function reference
wylieconlon Mar 4, 2021
1e32e0a
Add modal editor and markdown docs
wylieconlon Mar 5, 2021
cacf486
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 5, 2021
2bc7f6c
Change the way math nodes are validated
wylieconlon Mar 5, 2021
367de12
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 8, 2021
d42d02e
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 9, 2021
e0cd7d4
Use custom portal to fix monaco positioning
wylieconlon Mar 10, 2021
a1e8412
Fix model sharing issues
wylieconlon Mar 10, 2021
039a5c2
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 10, 2021
86f36dd
Provide signature help
wylieconlon Mar 11, 2021
dba216c
:bug: Fix small test issue
dej611 Mar 11, 2021
4d5ce24
:bug: Mark pow arguments as required
dej611 Mar 11, 2021
f47c5db
:bug: validate on first render only if a formula is present
dej611 Mar 11, 2021
e102ad2
:fire: Remove log10 fn for now
dej611 Mar 11, 2021
1483d9d
:sparkles: Improved math validation + add tests for math functions
dej611 Mar 11, 2021
1e510cc
Merge remote-tracking branch upstream/master into lens/formula-error-…
dej611 Mar 17, 2021
9069161
Merge branch 'master' into lens/formula-error-handling
kibanamachine Mar 18, 2021
c4e6be8
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 23, 2021
89bf4d2
Fix mount/unmount issues with Monaco
wylieconlon Mar 24, 2021
2334c1b
[Lens] Fully unmount React when flyout closes
wylieconlon Mar 24, 2021
3f2b10f
Merge remote-tracking branch 'origin/master' into lens/unmount-bug
wylieconlon Mar 25, 2021
502f74d
Fix bug with editor frame unmounting
wylieconlon Mar 25, 2021
5df313c
Fix type
wylieconlon Mar 25, 2021
dc20489
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 25, 2021
5c4b75f
Merge branch 'lens/unmount-bug' into lens/formulas
wylieconlon Mar 25, 2021
7dfed34
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 26, 2021
2382797
Add tests for monaco providers, add hover provider
wylieconlon Mar 26, 2021
f746acf
Add test for last_value
wylieconlon Mar 26, 2021
81eace1
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 29, 2021
387059e
Usability improvements
wylieconlon Mar 29, 2021
1065a76
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 30, 2021
46bd80f
Add KQL and Lucene named parameters
wylieconlon Mar 30, 2021
14ec327
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Mar 31, 2021
bbf55a2
Add kql, lucene completion and validation
wylieconlon Mar 31, 2021
9351572
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Apr 1, 2021
c7e4154
Fix autocomplete on weird characters and properly connect KQL
wylieconlon Apr 1, 2021
15ccac2
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Apr 2, 2021
08a985c
Highlight functions that have additional requirements after validating
wylieconlon Apr 2, 2021
daa5685
Fix type error and move help text to popover
wylieconlon Apr 2, 2021
ccf7266
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Apr 5, 2021
0c1cfa9
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Apr 5, 2021
239c72d
Fix escape characters inside KQL
wylieconlon Apr 5, 2021
fa57951
:bug: Fix dataType issue when moving over to Formula
dej611 Apr 6, 2021
3da8f82
Merge branch 'lens/formula-error-handling' of github.com:dej611/kiban…
dej611 Apr 6, 2021
1fd06bf
Automatically insert single quotes on every named param
wylieconlon Apr 6, 2021
b62f96e
Only insert single quotes when typing kql= or lucene=
wylieconlon Apr 8, 2021
d563cb5
Reorganize help popover
wylieconlon Apr 8, 2021
32fdfbf
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Apr 21, 2021
c81b47c
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Apr 21, 2021
edb522d
Fix merge issues
wylieconlon Apr 21, 2021
87b435b
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Apr 27, 2021
7169655
Update grammar for formulas
wylieconlon Apr 27, 2021
e01bca8
Fix bad merge
wylieconlon Apr 27, 2021
ec493d1
Rough fullscreen mode
wylieconlon Apr 28, 2021
255a40f
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon Apr 28, 2021
90cff4a
Type updates
wylieconlon Apr 28, 2021
12391f6
Pass through fullscreen state
wylieconlon Apr 28, 2021
83ae9bf
Remove more chrome from full screen mode
wylieconlon Apr 29, 2021
f520d2f
Fix minor bugs in formula typing
wylieconlon Apr 30, 2021
23f65d8
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon May 4, 2021
5a26025
🐛 Decouple column order of references and output
wylieconlon May 4, 2021
e6ff6d7
🔧 Fix tests and types
wylieconlon May 4, 2021
198ca29
✅ Add first functional test
wylieconlon May 5, 2021
ddd5515
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon May 5, 2021
d335aa3
Fix copying formulas and empty formula
wylieconlon May 6, 2021
bf264ed
Trigger suggestion prompt when hitting enter on function or typing kql=
wylieconlon May 6, 2021
a317738
🐛 Prevent flyout from closing while interacting with monaco
wylieconlon May 7, 2021
b2272f9
Merge branch 'master' into lens/formula-error-handling
kibanamachine May 10, 2021
bd87d98
refactoring
flash1293 May 10, 2021
571501a
move main column generation into parse module
flash1293 May 10, 2021
70a6b86
fix tests
flash1293 May 10, 2021
1883964
refactor small formula styles and markup
MichaelMarcialis May 10, 2021
96988e8
Merge branch 'lens/formula-error-handling' of github.com:wylieconlon/…
MichaelMarcialis May 10, 2021
40c43e4
documentation
flash1293 May 10, 2021
203b622
adjustments in formula footer
MichaelMarcialis May 10, 2021
b4a36ad
Formula refactoring (#12)
flash1293 May 10, 2021
2088c8e
Merge remote-tracking branch 'origin/master' into lens/formulas
wylieconlon May 10, 2021
9655e7d
more style and markup tweak for custom formula
MichaelMarcialis May 10, 2021
09659a2
Fix tests
wylieconlon May 10, 2021
03563b4
[Expressions] Use table column ID instead of name when set
wylieconlon May 10, 2021
f3ba457
[Lens] Create managedReference type for formulas
flash1293 Jan 21, 2021
2fce117
Merge branch 'lens/formula-error-handling' of github.com:wylieconlon/…
MichaelMarcialis May 11, 2021
c210c4b
Fix test failures
wylieconlon May 11, 2021
e8ef7e8
Fix i18n types
wylieconlon May 11, 2021
16387e8
fix fullscreen flex issues
MichaelMarcialis May 11, 2021
9114256
Delete managedReference when replacing
wylieconlon May 11, 2021
4ea324d
refactor css and markup; add button placeholders
MichaelMarcialis May 11, 2021
394555c
[Lens] Formulas
wylieconlon May 11, 2021
a33545e
Tests for formula
wylieconlon May 11, 2021
b06888e
Merge branch 'lens/managed-reference' into lens/formula-editor
wylieconlon May 11, 2021
1a74b65
added error count placeholder
MichaelMarcialis May 12, 2021
c0577f0
Add tooltips
MichaelMarcialis May 12, 2021
557b3a8
Merge branch 'lens/formula-error-handling' into formula-documentation
flash1293 May 12, 2021
51a8f62
Merge remote-tracking branch 'wylieconlon/lens/formula-error-handling…
flash1293 May 12, 2021
614b357
Merge remote-tracking branch 'MichaelMarcialis/lens/formula-error-han…
flash1293 May 12, 2021
c2f23a4
Merge remote-tracking branch 'origin/master' into lens/managed-reference
wylieconlon May 12, 2021
0b347ff
Refactoring from code review
wylieconlon May 12, 2021
9b6515c
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon May 12, 2021
2471c1f
Merge branch 'lens/managed-reference' into lens/formula-editor
wylieconlon May 12, 2021
bac5fd6
Merge remote-tracking branch 'MichaelMarcialis/lens/formula-error-han…
wylieconlon May 12, 2021
64ee982
Fix some editor issues
wylieconlon May 12, 2021
41789fb
Merge remote-tracking branch 'origin/master' into map-column-id
wylieconlon May 13, 2021
628cf8d
Update ID matching to match by name sometimes
wylieconlon May 13, 2021
cf51972
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon May 13, 2021
5421775
Improve performance of Monaco, fix formulas with 0, update labels
wylieconlon May 13, 2021
4d25851
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon May 14, 2021
8f6a6a0
Improve performance of full screen toggle
wylieconlon May 14, 2021
dd27759
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon May 14, 2021
a6a6fae
Fix formula tests
wylieconlon May 14, 2021
5413d7a
Merge branch 'master' into map-column-id
kibanamachine May 17, 2021
a85d91c
Merge remote-tracking branch 'wylieconlon/lens/formula-error-handling…
flash1293 May 17, 2021
5c97610
Merge remote-tracking branch 'upstream/master' into formula-documenta…
flash1293 May 17, 2021
507dd53
fix stuff
flash1293 May 17, 2021
468cfcf
Add an extra case to prevent insertion of duplicate column
wylieconlon May 18, 2021
d222796
Merge remote-tracking branch 'origin/master' into map-column-id
wylieconlon May 18, 2021
9f4d647
Simplify logic and add test for output ID
wylieconlon May 18, 2021
c0d28a9
add telemetry for Lens formula (#15)
flash1293 May 18, 2021
7f1df87
Respond to review comments
wylieconlon May 19, 2021
65e61a1
:sparkles: Improve the signatures with better documentation and examples
dej611 May 19, 2021
e4a5bcc
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon May 19, 2021
9abe037
Merge remote-tracking branch 'joe/formula-documentation' into lens/fo…
wylieconlon May 19, 2021
371703c
adjust border styles to account for docs collapse
MichaelMarcialis May 19, 2021
eb658fe
refactor docs markup; restructure docs obj; styles
MichaelMarcialis May 19, 2021
01af0b6
Merge branch 'lens/formula-error-handling' of github.com:wylieconlon/…
MichaelMarcialis May 19, 2021
f8cab62
Formula signature + doc improvements (https://github.com/wylieconlon/…
wylieconlon May 19, 2021
342c23d
Merge remote-tracking branch 'MichaelMarcialis/formula-documentation-…
wylieconlon May 19, 2021
4d7d2ba
Fix formula auto reordering (#18)
flash1293 May 20, 2021
c97f6f6
Fix and improve suggestion experience in Formula (#19)
dej611 May 24, 2021
4aac893
:sparkles: Add query validation for quotes
dej611 May 24, 2021
97a2457
Usability updates & type fixes
wylieconlon May 24, 2021
969ffd9
Merge branch 'master' into map-column-id
kibanamachine May 25, 2021
934d3bb
Merge branch 'master' into lens/formula-error-handling
kibanamachine May 25, 2021
b84faf9
add search to formula
flash1293 May 25, 2021
1ade3f3
fix form styles to match designs
MichaelMarcialis May 25, 2021
a8f4ec8
fix text styles; revert to Markdown for control
MichaelMarcialis May 25, 2021
f419cb6
:ok_hand: Integrated more feedback
dej611 May 26, 2021
4b4bf18
Merge pull request #13 from MichaelMarcialis/lens/formula-doc-3-mm
flash1293 May 26, 2021
72d25ce
improve search
flash1293 May 26, 2021
12ddbf7
improve suggestions
flash1293 May 26, 2021
d086cca
improve suggestions even more
flash1293 May 26, 2021
d07dae3
:bug: Fix i18n issues (#22)
dej611 May 26, 2021
faca9e2
Persist formula on leave, fix fullscreen and popovers
wylieconlon May 26, 2021
232e02d
Fix documentation tests
wylieconlon May 26, 2021
f7bcefd
Merge remote-tracking branch 'joe/lens/formula-doc-3' into lens/formu…
wylieconlon May 26, 2021
c0b7da0
Merge remote-tracking branch 'dej611/lens/formula-kql-validation' int…
wylieconlon May 26, 2021
c41b932
Merge remote-tracking branch 'joe/lens/formula-suggestions' into lens…
wylieconlon May 26, 2021
759e168
:label: fix type issue
dej611 May 27, 2021
0542a10
:bug: Remove hidden operations from valid functions list
dej611 May 27, 2021
195a5a6
:bug: Fix empty string query edge case
dej611 May 27, 2021
c51e8e0
:bug: Enable more suggestions + extends validation
dej611 May 28, 2021
cc41fc5
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon May 28, 2021
bbf5aac
Fix tests that depended on setState being called without function
wylieconlon May 28, 2021
7de19c9
Merge remote-tracking branch 'dej611/lens/formula-more-fixes' into le…
wylieconlon May 28, 2021
4ab340b
Error state and text wrapping updates
wylieconlon May 28, 2021
32713dd
:sparkles: Add new module to CodeEditor for brackets matching (#25)
dej611 May 28, 2021
fc2c3c9
Fix type
wylieconlon May 28, 2021
3637ee6
show warning
flash1293 May 31, 2021
ed47705
keep current quick function
flash1293 May 31, 2021
e56ef54
:sparkles: Improve suggestions within kql query
dej611 May 31, 2021
fcc775f
:camera: Fix snapshot editor test
dej611 May 31, 2021
ad50a7e
:bug: Improved suggestion for single quote and refactored debounce
dej611 May 31, 2021
7c897dc
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon Jun 1, 2021
290627c
:wqerge remote-tracking branch 'dej611/lens/formula-more-suggestions'…
wylieconlon Jun 1, 2021
8e1934d
Fix lodash usage
wylieconlon Jun 1, 2021
8d4778b
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon Jun 1, 2021
8d04687
Merge branch 'master' into map-column-id
kibanamachine Jun 1, 2021
068d8dc
Merge remote-tracking branch 'fork/map-column-id' into lens/formula-e…
wylieconlon Jun 1, 2021
dfb8cb5
Fix tests
wylieconlon Jun 1, 2021
e12c711
Merge remote-tracking branch 'joe/lens/keep-quick-function-around' in…
wylieconlon Jun 1, 2021
a610e37
Revert "keep current quick function"
wylieconlon Jun 1, 2021
dd2fb49
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon Jun 1, 2021
710061a
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon Jun 2, 2021
507a421
Improve performance of dispatch by using timeout
wylieconlon Jun 2, 2021
b92c8e6
Improve memoization of datapanel
wylieconlon Jun 2, 2021
e00bd4a
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon Jun 2, 2021
48e22ba
Fix escape characters
wylieconlon Jun 2, 2021
b349a1c
fix reduced suggestions
flash1293 Jun 3, 2021
6426034
fix responsiveness
flash1293 Jun 3, 2021
e4a9535
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon Jun 3, 2021
548f7f1
Merge remote-tracking branch 'joe/fix-doc-help-responsiveness' into l…
wylieconlon Jun 3, 2021
5d17588
fix unit test
flash1293 Jun 3, 2021
5222093
Merge remote-tracking branch 'joe/fix-suggestions' into lens/formula-…
wylieconlon Jun 3, 2021
12192a2
Merge remote-tracking branch 'joe/fix-unit-test' into lens/formula-ed…
wylieconlon Jun 3, 2021
3e9ebdb
Fix autocomplete on nested math
wylieconlon Jun 3, 2021
ae81c0e
Show errors and warnings on first render
wylieconlon Jun 3, 2021
2b44b2f
fix transposing column crash
flash1293 Jun 4, 2021
3096a2e
Merge remote-tracking branch 'origin/master' into lens/formula-editor
wylieconlon Jun 4, 2021
08a1f80
Merge remote-tracking branch 'joe/fix-async-state-update' into lens/f…
wylieconlon Jun 4, 2021
d1628b7
Update comment
wylieconlon Jun 4, 2021
48d7ff7
:bug: Fix field error message
dej611 Jun 4, 2021
1b97e8b
fix test types
flash1293 Jun 4, 2021
5cd99fe
:memo: Fix i18n name
dej611 Jun 4, 2021
881592a
:lipstick: Manage wordwrap via react component
dej611 Jun 4, 2021
1d16ef9
Fix selector for palettes that interferes with quick functions
wylieconlon Jun 4, 2021
5bf9c14
Merge remote-tracking branch 'dej611/lens/formula-field-message' into…
wylieconlon Jun 4, 2021
bbfd225
Merge remote-tracking branch 'dej611/lens/formula-word-wrap' into len…
wylieconlon Jun 4, 2021
fd2ea82
Use word wrapping by default
wylieconlon Jun 4, 2021
6f79509
Errors for managed references are handled at the top level
wylieconlon Jun 4, 2021
2e3cdd1
:bug: Move the cursor just next to new inserted text
dej611 Jun 7, 2021
1e422fa
:alembic: First pass for performance
dej611 Jun 7, 2021
bf66960
Merge branch 'master' into lens/formula-error-handling
kibanamachine Jun 7, 2021
0578cc5
:bug: Fix unwanted change
dej611 Jun 7, 2021
0b76853
:zap: Memoize as many combobox props as possible
dej611 Jun 7, 2021
affc0b3
:zap: More memoization
dej611 Jun 7, 2021
0762f2f
Show errors in hover
wylieconlon Jun 7, 2021
304fb64
Use temporary invalid state when moving away from formula
wylieconlon Jun 7, 2021
c3be427
Merge remote-tracking branch 'dej611/lens/formula-autocomplete-escape…
wylieconlon Jun 7, 2021
57e67f5
Remove setActiveDimension and shouldClose, fixed by async setters
wylieconlon Jun 7, 2021
875dd04
Merge remote-tracking branch 'dej611/lens/formula-performance-attempt…
wylieconlon Jun 7, 2021
199eece
Fix test dependency
wylieconlon Jun 7, 2021
b0e4dda
Merge branch 'master' into lens/formula-error-handling
kibanamachine Jun 8, 2021
aca7aba
do not show quick functions tab
flash1293 Jun 8, 2021
16b0d40
increase documentation popover width
flash1293 Jun 8, 2021
7e7b91e
Merge branch 'master' into lens/formula-error-handling
kibanamachine Jun 8, 2021
9a7b4bc
fix functional test
flash1293 Jun 8, 2021
7f5dbea
Call setActiveDimension when updating visualization
wylieconlon Jun 8, 2021
fd2878f
fix some things, break others
flash1293 Jun 8, 2021
4b81e5d
Simplify handling of flyout with incomplete columns
wylieconlon Jun 8, 2021
f9a9c9a
Fix test issues
wylieconlon Jun 8, 2021
2fbf051
add suggestions and improve autocomplete
flash1293 Jun 9, 2021
ff32add
Merge branch 'lens/formula-error-handling' into lens/formula-time-shift
flash1293 Jun 9, 2021
bca4cb5
Merge remote-tracking branch 'upstream/master' into lens/formula-erro…
flash1293 Jun 9, 2021
93da501
add description to formula telemetry
flash1293 Jun 9, 2021
e350d19
Merge branch 'lens/formula-error-handling' into lens/formula-time-shift
flash1293 Jun 9, 2021
fd8bbc9
fix schema
flash1293 Jun 9, 2021
4b192bb
Merge branch 'lens/formula-error-handling' into lens/formula-time-shift
flash1293 Jun 9, 2021
75b8da7
fix problems
flash1293 Jun 9, 2021
d1f9231
fix type problem
flash1293 Jun 9, 2021
df38a26
complete time shift in formula
flash1293 Jun 9, 2021
6997ed3
fix types
flash1293 Jun 9, 2021
e2e4e6d
Update from design feedback
wylieconlon Jun 9, 2021
28cf06e
More review comments
wylieconlon Jun 9, 2021
9ec3c9a
Hide callout border from v7 theme
wylieconlon Jun 9, 2021
77105b0
Merge branch 'lens/formula-error-handling' into lens/formula-time-shift
flash1293 Jun 10, 2021
54f02f3
fix test
flash1293 Jun 10, 2021
af45859
Merge remote-tracking branch 'upstream/master' into lens/formula-time…
flash1293 Jun 10, 2021
a5d9b92
Merge branch 'master' into lens/formula-time-shift
kibanamachine Jun 14, 2021
51e0afd
Merge remote-tracking branch 'upstream/master' into lens/formula-time…
flash1293 Jun 15, 2021
cc16b18
review comments
flash1293 Jun 15, 2021
f08b38b
Merge branch 'master' into lens/formula-time-shift
kibanamachine Jun 15, 2021
989b899
Merge branch 'master' into lens/formula-time-shift
kibanamachine Jun 16, 2021
479cd30
Merge branch 'master' into lens/formula-time-shift
kibanamachine Jun 17, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -400,6 +400,8 @@ export function DimensionEditor(props: DimensionEditorProps) {
<ReferenceEditor
key={index}
layer={state.layers[layerId]}
layerId={layerId}
activeData={props.activeData}
columnId={referenceId}
updateLayer={(
setter:
Expand Down Expand Up @@ -494,6 +496,8 @@ export function DimensionEditor(props: DimensionEditorProps) {
{shouldDisplayExtraOptions && ParamEditor && (
<ParamEditor
layer={state.layers[layerId]}
layerId={layerId}
activeData={props.activeData}
updateLayer={setStateWrapper}
columnId={columnId}
currentColumn={state.layers[layerId].columns[columnId]}
Expand Down Expand Up @@ -608,6 +612,8 @@ export function DimensionEditor(props: DimensionEditorProps) {
const formulaTab = ParamEditor ? (
<ParamEditor
layer={state.layers[layerId]}
layerId={layerId}
activeData={props.activeData}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks like it'll cause extra re-renders of the formula panel and all the others, any idea how much of an impact this has?

updateLayer={setStateWrapper}
columnId={columnId}
currentColumn={state.layers[layerId].columns[columnId]}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ describe('reference editor', () => {
isFullscreen: false,
toggleFullscreen: jest.fn(),
setIsCloseable: jest.fn(),
layerId: '1',
};
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -35,11 +35,14 @@ import { hasField } from '../utils';
import type { IndexPattern, IndexPatternLayer, IndexPatternPrivateState } from '../types';
import { trackUiEvent } from '../../lens_ui_telemetry';
import { VisualizationDimensionGroupConfig } from '../../types';
import { IndexPatternDimensionEditorProps } from './dimension_panel';

const operationPanels = getOperationDisplay();

export interface ReferenceEditorProps {
layer: IndexPatternLayer;
layerId: string;
activeData?: IndexPatternDimensionEditorProps['activeData'];
selectionStyle: 'full' | 'field' | 'hidden';
validation: RequiredReference;
columnId: string;
Expand Down Expand Up @@ -67,6 +70,8 @@ export interface ReferenceEditorProps {
export function ReferenceEditor(props: ReferenceEditorProps) {
const {
layer,
layerId,
activeData,
columnId,
updateLayer,
currentIndexPattern,
Expand Down Expand Up @@ -350,6 +355,8 @@ export function ReferenceEditor(props: ReferenceEditorProps) {
updateLayer={updateLayer}
currentColumn={column}
layer={layer}
layerId={layerId}
activeData={activeData}
columnId={columnId}
indexPattern={currentIndexPattern}
dateRange={dateRange}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,21 +8,22 @@
import { EuiButtonIcon } from '@elastic/eui';
import { EuiFormRow, EuiFlexItem, EuiFlexGroup } from '@elastic/eui';
import { EuiComboBox } from '@elastic/eui';
import { FormattedMessage } from '@kbn/i18n/react';
import { uniq } from 'lodash';
import { i18n } from '@kbn/i18n';
import React, { useEffect, useRef, useState } from 'react';
import { Query } from 'src/plugins/data/public';
import { search } from '../../../../../../src/plugins/data/public';
import { parseTimeShift } from '../../../../../../src/plugins/data/common';
import {
adjustTimeScaleLabelSuffix,
IndexPatternColumn,
operationDefinitionMap,
} from '../operations';
import { IndexPattern, IndexPatternLayer, IndexPatternPrivateState } from '../types';
import { IndexPattern, IndexPatternLayer } from '../types';
import { IndexPatternDimensionEditorProps } from './dimension_panel';
import { FramePublicAPI } from '../../types';
import {
getDateHistogramInterval,
getLayerTimeShiftChecks,
timeShiftOptions,
} from '../time_shift_utils';

// to do: get the language from uiSettings
export const defaultFilter: Query = {
Expand Down Expand Up @@ -59,75 +60,6 @@ export function setTimeShift(
};
}

const timeShiftOptions = [
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.hour', {
defaultMessage: '1 hour (1h)',
}),
value: '1h',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.3hours', {
defaultMessage: '3 hours (3h)',
}),
value: '3h',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.6hours', {
defaultMessage: '6 hours (6h)',
}),
value: '6h',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.12hours', {
defaultMessage: '12 hours (12h)',
}),
value: '12h',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.day', {
defaultMessage: '1 day (1d)',
}),
value: '1d',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.week', {
defaultMessage: '1 week (1w)',
}),
value: '1w',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.month', {
defaultMessage: '1 month (1M)',
}),
value: '1M',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.3months', {
defaultMessage: '3 months (3M)',
}),
value: '3M',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.6months', {
defaultMessage: '6 months (6M)',
}),
value: '6M',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.year', {
defaultMessage: '1 year (1y)',
}),
value: '1y',
},
{
label: i18n.translate('xpack.lens.indexPattern.timeShift.previous', {
defaultMessage: 'Previous',
}),
value: 'previous',
},
];

export function TimeShift({
selectedColumn,
columnId,
Expand Down Expand Up @@ -157,38 +89,12 @@ export function TimeShift({
return null;
}

let dateHistogramInterval: null | moment.Duration = null;
const dateHistogramColumn = layer.columnOrder.find(
(colId) => layer.columns[colId].operationType === 'date_histogram'
const { isValueTooSmall, isValueNotMultiple, canShift } = getLayerTimeShiftChecks(
getDateHistogramInterval(layer, indexPattern, activeData, layerId)
);
if (!dateHistogramColumn && !indexPattern.timeFieldName) {
return null;
}
if (dateHistogramColumn && activeData && activeData[layerId] && activeData[layerId]) {
const column = activeData[layerId].columns.find((col) => col.id === dateHistogramColumn);
if (column) {
dateHistogramInterval = search.aggs.parseInterval(
search.aggs.getDateHistogramMetaDataByDatatableColumn(column)?.interval || ''
);
}
}

function isValueTooSmall(parsedValue: ReturnType<typeof parseTimeShift>) {
return (
dateHistogramInterval &&
parsedValue &&
typeof parsedValue === 'object' &&
parsedValue.asMilliseconds() < dateHistogramInterval.asMilliseconds()
);
}

function isValueNotMultiple(parsedValue: ReturnType<typeof parseTimeShift>) {
return (
dateHistogramInterval &&
parsedValue &&
typeof parsedValue === 'object' &&
!Number.isInteger(parsedValue.asMilliseconds() / dateHistogramInterval.asMilliseconds())
);
if (!canShift) {
return null;
}

const parsedLocalValue = localValue && parseTimeShift(localValue);
Expand Down Expand Up @@ -305,90 +211,3 @@ export function TimeShift({
</div>
);
}

export function getTimeShiftWarningMessages(
state: IndexPatternPrivateState,
{ activeData }: FramePublicAPI
) {
if (!state) return;
const warningMessages: React.ReactNode[] = [];
Object.entries(state.layers).forEach(([layerId, layer]) => {
let dateHistogramInterval: null | string = null;
const dateHistogramColumn = layer.columnOrder.find(
(colId) => layer.columns[colId].operationType === 'date_histogram'
);
if (!dateHistogramColumn) {
return;
}
if (dateHistogramColumn && activeData && activeData[layerId]) {
const column = activeData[layerId].columns.find((col) => col.id === dateHistogramColumn);
if (column) {
dateHistogramInterval =
search.aggs.getDateHistogramMetaDataByDatatableColumn(column)?.interval || null;
}
}
if (dateHistogramInterval === null) {
return;
}
const shiftInterval = search.aggs.parseInterval(dateHistogramInterval)!.asMilliseconds();
let timeShifts: number[] = [];
const timeShiftMap: Record<number, string[]> = {};
Object.entries(layer.columns).forEach(([columnId, column]) => {
if (column.isBucketed) return;
let duration: number = 0;
if (column.timeShift) {
const parsedTimeShift = parseTimeShift(column.timeShift);
if (parsedTimeShift === 'previous' || parsedTimeShift === 'invalid') {
return;
}
duration = parsedTimeShift.asMilliseconds();
}
timeShifts.push(duration);
if (!timeShiftMap[duration]) {
timeShiftMap[duration] = [];
}
timeShiftMap[duration].push(columnId);
});
timeShifts = uniq(timeShifts);

if (timeShifts.length < 2) {
return;
}

timeShifts.forEach((timeShift) => {
if (timeShift === 0) return;
if (timeShift < shiftInterval) {
timeShiftMap[timeShift].forEach((columnId) => {
warningMessages.push(
<FormattedMessage
key={`small-${columnId}`}
id="xpack.lens.indexPattern.timeShiftSmallWarning"
defaultMessage="{label} uses a time shift of {columnTimeShift} which is smaller than the date histogram interval of {interval}. To prevent mismatched data, use a multiple of {interval} as time shift."
values={{
label: <strong>{layer.columns[columnId].label}</strong>,
interval: <strong>{dateHistogramInterval}</strong>,
columnTimeShift: <strong>{layer.columns[columnId].timeShift}</strong>,
}}
/>
);
});
} else if (!Number.isInteger(timeShift / shiftInterval)) {
timeShiftMap[timeShift].forEach((columnId) => {
warningMessages.push(
<FormattedMessage
key={`multiple-${columnId}`}
id="xpack.lens.indexPattern.timeShiftMultipleWarning"
defaultMessage="{label} uses a time shift of {columnTimeShift} which is not a multiple of the date histogram interval of {interval}. To prevent mismatched data, use a multiple of {interval} as time shift."
values={{
label: <strong>{layer.columns[columnId].label}</strong>,
interval: dateHistogramInterval,
columnTimeShift: layer.columns[columnId].timeShift!,
}}
/>
);
});
}
});
});
return warningMessages;
}
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ import { deleteColumn, isReferenced } from './operations';
import { UiActionsStart } from '../../../../../src/plugins/ui_actions/public';
import { GeoFieldWorkspacePanel } from '../editor_frame_service/editor_frame/workspace_panel/geo_field_workspace_panel';
import { DraggingIdentifier } from '../drag_drop';
import { getTimeShiftWarningMessages } from './dimension_panel/time_shift';
import { getStateTimeShiftWarningMessages } from './time_shift_utils';

export { OperationType, IndexPatternColumn, deleteColumn } from './operations';

Expand Down Expand Up @@ -462,7 +462,7 @@ export function getIndexPatternDatasource({
});
return messages.length ? messages : undefined;
},
getWarningMessages: getTimeShiftWarningMessages,
getWarningMessages: getStateTimeShiftWarningMessages,
checkIntegrity: (state) => {
const ids = Object.values(state.layers || {}).map(({ indexPatternId }) => indexPatternId);
return ids.filter((id) => !state.indexPatterns[id]);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ export const counterRateOperation: OperationDefinition<
scale: 'ratio',
references: referenceIds,
timeScale,
timeShift: previousColumn?.timeShift,
timeShift: columnParams?.shift || previousColumn?.timeShift,
filter: getFilter(previousColumn, columnParams),
params: getFormatFromPreviousColumn(previousColumn),
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,7 @@ export const cumulativeSumOperation: OperationDefinition<
operationType: 'cumulative_sum',
isBucketed: false,
scale: 'ratio',
timeShift: previousColumn?.timeShift,
timeShift: columnParams?.shift || previousColumn?.timeShift,
filter: getFilter(previousColumn, columnParams),
references: referenceIds,
params: getFormatFromPreviousColumn(previousColumn),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@ export const derivativeOperation: OperationDefinition<
references: referenceIds,
timeScale: previousColumn?.timeScale,
filter: getFilter(previousColumn, columnParams),
timeShift: previousColumn?.timeShift,
timeShift: columnParams?.shift || previousColumn?.timeShift,
params: getFormatFromPreviousColumn(previousColumn),
};
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -98,9 +98,9 @@ export const movingAverageOperation: OperationDefinition<
isBucketed: false,
scale: 'ratio',
references: referenceIds,
timeScale: previousColumn?.timeScale,
timeShift: columnParams?.shift || previousColumn?.timeShift,
filter: getFilter(previousColumn, columnParams),
timeShift: previousColumn?.timeShift,
timeScale: previousColumn?.timeScale,
params: {
window,
...getFormatFromPreviousColumn(previousColumn),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ export const cardinalityOperation: OperationDefinition<CardinalityIndexPatternCo
sourceField: field.name,
isBucketed: IS_BUCKETED,
filter: getFilter(previousColumn, columnParams),
timeShift: previousColumn?.timeShift,
timeShift: columnParams?.shift || previousColumn?.timeShift,
params: getFormatFromPreviousColumn(previousColumn),
};
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,7 @@ export const countOperation: OperationDefinition<CountIndexPatternColumn, 'field
sourceField: field.name,
timeScale: previousColumn?.timeScale,
filter: getFilter(previousColumn, columnParams),
timeShift: previousColumn?.timeShift,
timeShift: columnParams?.shift || previousColumn?.timeShift,
params:
previousColumn?.dataType === 'number' &&
previousColumn.params &&
Expand Down Expand Up @@ -118,7 +118,7 @@ export const countOperation: OperationDefinition<CountIndexPatternColumn, 'field
defaultMessage: `
Calculates the number of documents.

Example: Calculate the number of documents:
Example: Calculate the number of documents:
\`count()\`

Example: Calculate the number of documents matching a certain filter:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,7 @@ const indexPattern2: IndexPattern = {
const uiSettingsMock = {} as IUiSettingsClient;

const defaultOptions = {
layerId: '1',
storage: {} as IStorageWrapper,
uiSettings: uiSettingsMock,
savedObjectsClient: {} as SavedObjectsClientContract,
Expand Down
Loading