-
Notifications
You must be signed in to change notification settings - Fork 8.3k
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
full screen mode implementation for dashboard #12265
Conversation
@stacey-gammon woo!! this PR is fantastic. I saw some comments in slack around showing / hiding the query bar and filter bar on hover and agree that should be in addressed in another PR. I also think that for the first iteration, we should address the most prominent use case of showcasing this dashboard. I can't imagine there will be much need for interaction and querying in full screen mode for this scenario. This is looking great! I have some usability comments below.
Hope this feedback helps! Let me know if you need any other clarification |
This is REALLY COOL. This features makes dashboards feel much more polished, to an extent that is disproportionate to the size of the feature. I noticed a UX bug. When the dashboard has no panels, clicking "Add" should probably pop you out of full-screen mode so you can see the "Add panel" dropdown: I also couldn't get the filter and query bar to show up in full screen mode. Am I supposed to be able to do that in this version of the PR? If so, what do I need to do to get them to show? That said, I like all of @alexfrancoeur's suggestions above. My only suggestion would be about our approach. I suggest we refine the UX first and then tackle the appearance and behavior of the "Exit full screen mode" button as the very last step. I think we can make some adjustments to make it more consistent with the look-and-feel and I'm sure @snide has thoughts on this too. |
It's possible (though sounds like it might be browser specific), but I'm not sure I agree with this one. I tried in Google Docs, and full screen doesn't automatically pop the browser into full screen mode. I can see a use case of someone wanting to maximize the browser space, but still be able to quickly tab to other browser windows/desktop icons/etc.
Great idea, and actually checking out Google Docs full screen mode for the above, looks like they only offer a keyboard way to exit Full screen mode. An interesting idea if we want to get rid of the button on the bottom.
I can get rid of it from full screen mode, but I could potentially see the use case, albeit much less common. Maybe just wanting to move around, resize, or see how it will look in Full Screen mode.
Will investigate
Good catch, will look into.
Ah good point, will fix.
Query bar doesn't show up, filter bar should show up if you have a filter applied. We can investigate further options for when to show the query bar (perhaps offer some configurations - would be nice to do the same for embedded mode). But as a first pass, I think we should punt on it. The kbn top nav is tightly coupled to the chrome being visible, so the logic would have to be refactored out first. We'd also have to figure out the UI for the configuration. So I think those are great ideas, but I don't think it should hold up this more simplified version. |
Fixed the bugs mentioned, will wait to hear about overall styling on the button before fixing the dark theme version. |
jenkins, test this |
|
||
.exitFullScreenMode:hover { | ||
bottom: 0px; | ||
transition: all .5s ease; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here's a cleaner animation for you...
Does the following
- Moves the bug to the top, which is where the controls originally start.
- Uses more reliable vars.
- Improves the transition by
- Using transform instead of position (much smoother, gpu now takes over).
- Puts transition on the base selector, now works on on and off hover, instead of just on.
- Speeds it up. In general, no hover animation should take longer than 250ms.
- When in doubt use ease-in-out, rather than just ease.
Note that you should also up the padding to .dashboard-grid
to 20px if you move it up. In general I've been adding similar increased padding across Kibana, so it's not just for this PR that we need it.
.exitFullScreenMode {
background-color: @globalColorLightestGray;
border-bottom-left-radius: 4px;
border-bottom-right-radius: 4px;
border-top-left-radius: 0;
border-top-right-radius: 0;
width: 200px;
height: 40px;
left: 0;
right: 0;
top: 0;
margin-left: auto;
margin-right: auto;
padding-bottom: 0;
position: fixed;
transform: translateY(-26px);
z-index: 50;
display: block;
transition: transform .2s ease-in-out;
border: solid 1px @globalColorLightGray;
.kuiIcon {
display: block;
}
&:hover {
transform: translateY(-1px);
}
}
It’s awkward with no obvious save button to escape edit mode.
Added the new styles (with some slight modifications, including leaving the button on the button after chatting with @snide about the way it looks on the top with filters applied). Also addressed dark theme variation: And remove Full Screen option from edit mode because it's awkward with the lack of the obvious |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this functionality is great! Just a few comments, and I noticed that the browser back button doesn't play that nicely with exiting full screen mode.
@@ -25,6 +25,7 @@ import { notify } from 'ui/notify'; | |||
import './panel/get_object_loaders_for_dashboard'; | |||
import { documentationLinks } from 'ui/documentation_links/documentation_links'; | |||
import { showCloneModal } from './top_nav/show_clone_modal'; | |||
import { ESC_KEY_CODE } from 'ui_framework/services'; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
❤️
@@ -68,9 +78,11 @@ | |||
</form> | |||
</div> | |||
</kbn-top-nav> | |||
</div> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks like a dangling closing tag, and should be able to be removed.
$scope.fullScreenMode = fullScreenMode; | ||
dashboardState.setFullScreenMode(fullScreenMode); | ||
chrome.setVisible(!fullScreenMode); | ||
$scope.$root.$broadcast('globalNav:update'); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think that we should be emitting the globalNav:update
event as this is something that the globalNav
itself used to be doing, and we're hijacking it to re-render the dashboard.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yea, I figured the global navigation did update, so it wasn't that bad, though I hate those broadcasts. I can do $window.dispatchEvent(new Event('resize'));
to trigger the re-render of the grid, which should also fixe the bug @nreese discovered. How do you feel about that? I don't think there is really a good way to tell gridster to resize directly. Or maybe I'm missing a more obvious solution...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Using the native resize
event feels equally gross because it's normally fired by the browser itself, and it feels like we'd be hijacking this as well.
Since the dashboard-grid
is a directive within the dashboard
we shouldn't have to resort to using a $scope.$root.$broadcast
and should be able to just call a function that we pass to it if we need to trigger the resize.
chrome.setVisible(!fullScreenMode); | ||
$scope.$root.$broadcast('globalNav:update'); | ||
if (fullScreenMode) { | ||
onRouteChange = $scope.$on('$routeChangeStart', () => chrome.setVisible(true)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not following what we're doing here, we're calling chrome.setVisible
above.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Gotcha. When the user navigates away, how is the onRouteChange
/deregistration called?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good call, I think I just need to add a call to onRouteChange
inside the $routeChangeStart
handler. Seems to do the trick.
@@ -13,13 +58,12 @@ | |||
dashboard-grid { | |||
display: block; | |||
margin: 0; | |||
padding: 5px; | |||
padding: 20px; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Did we mean to change this here? It seems to add quite a bit of padding even when not in full-screen mode.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In general I've increased the padding on a bunch of our inner panels (see monitoring...etc) to give the controls some space. This was actually one of the few places I missed in my big K6 PR.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's more accessible for those of us with fat fingers! 😉
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good. I just found one instance where an exception is thrown.
$scope.fullScreenMode = fullScreenMode; | ||
dashboardState.setFullScreenMode(fullScreenMode); | ||
chrome.setVisible(!fullScreenMode); | ||
$scope.$root.$broadcast('globalNav:update'); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
jenkins, test this |
This looks great @stacey-gammon! |
jenkins, test this |
@stacey-gammon can we get a Release Note: paragraph at the end of the description describing the functionality please... |
done @jimgoodwin! |
Fixes #9268
Release Note:
You can now enter full screen mode when viewing a dashboard. This hides the Chrome and the top nav bar. If you have any filters applied, you'll see the filter bar, otherwise that will be hidden as well. To exit full screen mode, hover over and click the Kibana button on the lower left side of the page, or simple press the
ESC
key.