-
Notifications
You must be signed in to change notification settings - Fork 860
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
[MM-61717] Refresh Settings Modal without Bootstrap #3337
base: master
Are you sure you want to change the base?
Conversation
@devinbinnie in the description you ask for us to test on the builds generated by the PR but they seem to be failing |
@enahum Looks like it went through - https://github.com/mattermost/desktop/actions/runs/13389165374 |
303fe4e
to
19a9238
Compare
Here are the test results below: Test Summary for Linux on commit ed79ac3New failed tests found on Linux:
Test Summary for macOS on commit ed79ac3All stable tests passed on macOS. Test Summary for Windows on commit ed79ac3New failed tests found on Windows:
|
@abhijit-singh @enahum @hmhealey This should be ready for review at your convenience. |
Here are the test results below: Test Summary for Linux on commit f156901New failed tests found on Linux:
Test Summary for macOS on commit f156901All stable tests passed on macOS. Test Summary for Windows on commit f156901New failed tests found on Windows:
|
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.
overall looks good to me
@@ -38,16 +38,17 @@ function handleShowOnboardingScreens(showWelcomeScreen: boolean, showNewServerMo | |||
log.debug('handleShowOnboardingScreens', {showWelcomeScreen, showNewServerModal, mainWindowIsVisible}); | |||
|
|||
if (showWelcomeScreen) { | |||
if (ModalManager.isModalDisplayed()) { | |||
const welcomeScreen = ModalManager.modalQueue.find((modal) => modal.key === 'welcomeScreen'); |
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.
not major, but it would be good to have welcomeScreen
as a constant
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.
Agreed, we should actually do this across the board for all of the modal names.
Seems like something AI could help me hash out real quick ;)
I'll put it in a follow-up change though.
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.
const welcomeScreen = ModalManager.modalQueue.find((modal) => modal.key === 'welcomeScreen'); | ||
if (welcomeScreen?.view.webContents.isLoading()) { | ||
welcomeScreen?.view.webContents.once('did-finish-load', () => { | ||
const welcomeScreenTest = ModalManager.modalQueue.find((modal) => modal.key === 'welcomeScreen'); |
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.
and then use it here as well
<button | ||
id={`RadioSetting_${id}_${option.value}`} | ||
className='RadioSetting__radio' | ||
key={index} |
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 is better as index.toString() or `${index}`
<div className='ServerSetting__serverList'> | ||
{(servers.map((server, index) => ( | ||
<div | ||
key={index} |
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.
same here
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.
Thanks @devinbinnie! Looks good. I spotted a few issues:
- Pressing
Esc
to close the settings modal crashes the app with this error:
TypeError: Cannot read properties of undefined (reading 'stack')
at Object.createErrorReport (/private/var/folders/0c/6xhd1slj4tv6mw_bcfdt94s40000gn/T/AppTranslocation/D9C204DE-C58D-472D-8881-928B80864B47/d/Mattermost.app/Contents/Resources/app.asar/index.js:2:118270)
at Object.showExceptionDialog (/private/var/folders/0c/6xhd1slj4tv6mw_bcfdt94s40000gn/T/AppTranslocation/D9C204DE-C58D-472D-8881-928B80864B47/d/Mattermost.app/Contents/Resources/app.asar/index.js:2:116774)
at process.<anonymous> (/private/var/folders/0c/6xhd1slj4tv6mw_bcfdt94s40000gn/T/AppTranslocation/D9C204DE-C58D-472D-8881-928B80864B47/d/Mattermost.app/Contents/Resources/app.asar/index.js:2:116568)
at process.emit (node:events:518:28)
at emitUnhandledRejection (node:internal/process/promises:250:13)
at warnWithErrorCodeUnhandledRejectionsMode (node:internal/process/promises:404:19)
at processPromiseRejections (node:internal/process/promises:470:17)
at process.processTicksAndRejections (node:internal/process/task_queues:96:32)
- We should probably give a minimum height to the modal. How we have done it in other places (Team settings modal, user settings modal) is by having a min-height: 475px; applied to the modal body—we can add the same here.
data:image/s3,"s3://crabby-images/5e9c2/5e9c272c1ee1c5fbd4b2dacc0945ea1bc672ca53" alt="image"
- For the
Add server
,Edit server
modals, we need to have another overlay, or push the original settings modal below the overlay.
data:image/s3,"s3://crabby-images/7c04f/7c04fff022a822cd6427b5a664b1fcf4b85e5d34" alt="image"
- In the dark mode, some of the borders and dividers aren't visible. Can we check if they're using the
center-channel-color-rgb
variable with a 0.08 opacity?
data:image/s3,"s3://crabby-images/af5af/af5af8ad0f2c3abf681027d9d7f3b5c22b7ce1c0" alt="image"
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.
@devinbinnie if we delete all servers, we still see the modal open and click through the different options.
data:image/s3,"s3://crabby-images/dfcc1/dfcc15d06d679eebeff23262812c55375f8f62af" alt="Screenshot 2025-02-25 at 11 03 11 PM"
data:image/s3,"s3://crabby-images/ac136/ac1360fece6faf1d82d064f0c08a1ba753189721" alt="image"
This was using
I don't think that's a problem, the user may want to look at other settings while in the modal, so closing it on them would be jarring. @abhijit-singh If you're okay with this I'll leave it as-is. |
It'll be great to add some empty state text, possibly along with an illustration, instead of just blank space after the heading - Figma design Also, I just noticed one more small thing — Clicking just below the modal in some cases (when the modal height is less) does not close it. Ideally clicking anywhere outside the modal should close it. |
Can't reproduce this, can you try again after I put a new build up? I might have inadvertently fixed it. |
Thanks @devinbinnie for the quick updates! Just a couple things remaining:
![]() ![]() ![]() |
@abhijit-singh Fixed! Issue with the CSS variables |
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.
Awesome, thanks @devinbinnie!
Summary
This PR introduced a completely redesigned Settings Modal, that completely abandons the original Bootstrap-based design (and Bootstrap itself) and introduces a look and feel similar to the rest of our Mattermost apps. Credit to @abhijit-singh for the work on these designs :)
The page is broken down into a number of individual
Setting
components that represent individual controls that can be re-used and re-purposed for different settings. All of the settings themselves are then defined indefinition.tsx
which references these components. A few exceptions needed to be made where either additional data was required, special designs were need, or some dependencies needed to be satisfied. However, the hope is that adding/modifying/removing settings should be pretty easy from now on.I would highly recommend downloading one of the available PR builds for this, and trying it out on different OSes to make sure that all of the settings are working and that no unexpected UI/UX bugs show up. I have done some preliminary testing on each OS to ensure nothing glaring exists, but to make this bulletproof it will take some time and a fine tooth comb.
Ticket Link
https://mattermost.atlassian.net/browse/MM-61717
Device Information
This PR was tested on:
Screenshots
Release Note