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

[8.x] [visualize embeddable] fix panel disappears from dashboard when canceling edit after dashboard save (#193914) #194152

Merged
merged 1 commit into from
Sep 26, 2024

Conversation

kibanamachine
Copy link
Contributor

Backport

This will backport the following commits from main to 8.x:

Questions ?

Please refer to the Backport tool documentation

…ling edit after dashboard save (elastic#193914)

Part of elastic#193905. Broke work into
separate PRs to backport map embeddable changes to 8.15.

Resolves issue for Visualize embeddable and dashboard empty screen. The
problem is that Visualize embeddable is using a stale result from
`parentApi.getAppContext`. Dashboard's `getAppContext` changes the
`getCurrentPath` when the dashboard has a saved object id. By using the
stale results, `getCurrentPath` returned `#/create` instead of
`#/view/`. The fix is to get a current version of `getAppContext` when
required.

### Test steps
1. create new dashboard
2. Click "Add panel" (problem also exists when using "Add from library")
3. Select "Aggregation based"
4.  In editor, click "Save and return"
5. Save dashboard
6. Click "Edit" in panel context menu
7. In editor, click "Cancel"
8. Ensure visualize panel is still displayed in dashboard

(cherry picked from commit d6c8840)
@kibana-ci
Copy link
Collaborator

💚 Build Succeeded

Metrics [docs]

Module Count

Fewer modules leads to a faster build time

id before after diff
visualizations 475 476 +1

Async chunks

Total size of all lazy-loaded chunks that will be downloaded as the user navigates the app

id before after diff
dashboard 490.6KB 490.5KB -117.0B
visualizations 315.6KB 315.7KB +52.0B
total -65.0B

Page load bundle

Size of the bundles that are downloaded on every page load. Target size is below 100kb

id before after diff
visualizations 71.0KB 70.9KB -34.0B

To update your PR or re-run it, just comment with:
@elasticmachine merge upstream

cc @nreese

@kibanamachine kibanamachine merged commit 71e98e8 into elastic:8.x Sep 26, 2024
23 checks passed
neptunian pushed a commit to neptunian/kibana that referenced this pull request Oct 1, 2024
… canceling edit after dashboard save (elastic#193914) (elastic#194152)

# Backport

This will backport the following commits from `main` to `8.x`:
- [[visualize embeddable] fix panel disappears from dashboard when
canceling edit after dashboard save
(elastic#193914)](elastic#193914)

<!--- Backport version: 9.4.3 -->

### Questions ?
Please refer to the [Backport tool
documentation](https://github.com/sqren/backport)

<!--BACKPORT [{"author":{"name":"Nathan
Reese","email":"reese.nathan@elastic.co"},"sourceCommit":{"committedDate":"2024-09-26T13:47:04Z","message":"[visualize
embeddable] fix panel disappears from dashboard when canceling edit
after dashboard save (elastic#193914)\n\nPart of
elastic#193905. Broke work
into\r\nseparate PRs to backport map embeddable changes to
8.15.\r\n\r\nResolves issue for Visualize embeddable and dashboard empty
screen. The\r\nproblem is that Visualize embeddable is using a stale
result from\r\n`parentApi.getAppContext`. Dashboard's `getAppContext`
changes the\r\n`getCurrentPath` when the dashboard has a saved object
id. By using the\r\nstale results, `getCurrentPath` returned `#/create`
instead of\r\n`#/view/`. The fix is to get a current version of
`getAppContext` when\r\nrequired.\r\n\r\n### Test steps\r\n1. create new
dashboard\r\n2. Click \"Add panel\" (problem also exists when using
\"Add from library\")\r\n3. Select \"Aggregation based\"\r\n4. In
editor, click \"Save and return\"\r\n5. Save dashboard\r\n6. Click
\"Edit\" in panel context menu\r\n7. In editor, click \"Cancel\"\r\n8.
Ensure visualize panel is still displayed in
dashboard","sha":"d6c8840a561484bee74dbcb335290c879e82d370","branchLabelMapping":{"^v9.0.0$":"main","^v8.16.0$":"8.x","^v(\\d+).(\\d+).\\d+$":"$1.$2"}},"sourcePullRequest":{"labels":["release_note:fix","Team:Presentation","v9.0.0","project:embeddableRebuild","v8.16.0","backport:version"],"title":"[visualize
embeddable] fix panel disappears from dashboard when canceling edit
after dashboard
save","number":193914,"url":"https://github.com/elastic/kibana/pull/193914","mergeCommit":{"message":"[visualize
embeddable] fix panel disappears from dashboard when canceling edit
after dashboard save (elastic#193914)\n\nPart of
elastic#193905. Broke work
into\r\nseparate PRs to backport map embeddable changes to
8.15.\r\n\r\nResolves issue for Visualize embeddable and dashboard empty
screen. The\r\nproblem is that Visualize embeddable is using a stale
result from\r\n`parentApi.getAppContext`. Dashboard's `getAppContext`
changes the\r\n`getCurrentPath` when the dashboard has a saved object
id. By using the\r\nstale results, `getCurrentPath` returned `#/create`
instead of\r\n`#/view/`. The fix is to get a current version of
`getAppContext` when\r\nrequired.\r\n\r\n### Test steps\r\n1. create new
dashboard\r\n2. Click \"Add panel\" (problem also exists when using
\"Add from library\")\r\n3. Select \"Aggregation based\"\r\n4. In
editor, click \"Save and return\"\r\n5. Save dashboard\r\n6. Click
\"Edit\" in panel context menu\r\n7. In editor, click \"Cancel\"\r\n8.
Ensure visualize panel is still displayed in
dashboard","sha":"d6c8840a561484bee74dbcb335290c879e82d370"}},"sourceBranch":"main","suggestedTargetBranches":["8.x"],"targetPullRequestStates":[{"branch":"main","label":"v9.0.0","branchLabelMappingKey":"^v9.0.0$","isSourceBranch":true,"state":"MERGED","url":"https://github.com/elastic/kibana/pull/193914","number":193914,"mergeCommit":{"message":"[visualize
embeddable] fix panel disappears from dashboard when canceling edit
after dashboard save (elastic#193914)\n\nPart of
elastic#193905. Broke work
into\r\nseparate PRs to backport map embeddable changes to
8.15.\r\n\r\nResolves issue for Visualize embeddable and dashboard empty
screen. The\r\nproblem is that Visualize embeddable is using a stale
result from\r\n`parentApi.getAppContext`. Dashboard's `getAppContext`
changes the\r\n`getCurrentPath` when the dashboard has a saved object
id. By using the\r\nstale results, `getCurrentPath` returned `#/create`
instead of\r\n`#/view/`. The fix is to get a current version of
`getAppContext` when\r\nrequired.\r\n\r\n### Test steps\r\n1. create new
dashboard\r\n2. Click \"Add panel\" (problem also exists when using
\"Add from library\")\r\n3. Select \"Aggregation based\"\r\n4. In
editor, click \"Save and return\"\r\n5. Save dashboard\r\n6. Click
\"Edit\" in panel context menu\r\n7. In editor, click \"Cancel\"\r\n8.
Ensure visualize panel is still displayed in
dashboard","sha":"d6c8840a561484bee74dbcb335290c879e82d370"}},{"branch":"8.x","label":"v8.16.0","branchLabelMappingKey":"^v8.16.0$","isSourceBranch":false,"state":"NOT_CREATED"}]}]
BACKPORT-->

Co-authored-by: Nathan Reese <reese.nathan@elastic.co>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants