Status Update
Comments
ra...@gmail.com <ra...@gmail.com> #2
This also brings back dialog content size animations issues :( But on all devices this time.
See attached video
Repro:
Dialog(
onDismissRequest = {
if (dialogState.canDismiss.value) {
dialogNavigator.hide()
}
},
properties = properties,
content = {
Surface(
modifier = modifier
.safeContentPadding()
.fillMaxWidth(0.8f)
.animateContentSize(),
shape = shape,
color = backgroundColor,
contentColor = contentColor,
) {
.....A composable that change it's size
}
},
)
gv...@gmail.com <gv...@gmail.com> #3
Can you give a fuller example for the animateContentSize()
problem?
[Deleted User] <[Deleted User]> #4
It does that for all the cases where the content change.
properties = DialogProperties(usePlatformDefaultWidth = false)
var show by remember { mutableStateOf(false) }
LaunchedEffect(Unit) {
delay(1000)
show = true
}
Column {
Text("X")
if (show) {
Text"Y)
}
}
Edit: This was a well known long time issue when not using usePlatformDefaultWidth = false
so we were forced to workaround with that.
Now even with it it trigger that. (Depending on the phone, it's either super slow, or laggy and jumping).
je...@gmail.com <je...@gmail.com> #5
I am seeing a problem with decorFitsSystemWindows = false
where it continues to invalidate the layout even after the animation completes. I don't think that's the problem you're worried about, though.
If I understand correctly, the problem you're seeing is something about it being laggy? And it didn't happen in the previous version, right?
That problem is likely due to the Window resizing on every frame, which is more expensive than the window content resizing on every frame. In a previous iteration, the window size was full screen and the content resized itself. You can resolve this yourself by doing this:
Surface(
modifier = Modifier.safeContentPadding()
.fillMaxSize()
.wrapContentHeight()
.fillMaxWidth(0.8f)
.animateContentSize(),
...
I'll see if I can fix the problem with decorFitsSystemWindows = false
invalidating layout continuously.
ma...@google.com <ma...@google.com> #6
There's 2 very different issue here. The main very blocking is the Samsung dialogs from a bottomsheet/popup being at the bottom and under the navigation bar. Samsung is a very large percent of users. And a full rewrite of all M3 AlerDialog to something else to workaround is a pain as most M3 things are private / internal.
The second issue is about the huge lag.
It was present since a very long time with usePlatformDefaultWidth = true
but not with usePlatformDefaultWidth = false
now it's always present.
AFAIR previously all the workaround based on .fillMaxSize()
had issues with the dialog scrim, but I'll try again if there's a fix for the Samsung devices.
er...@gmail.com <er...@gmail.com> #7
I just verified that an AlertDialog
called from a ModalBottomSheet
from a Pixel 9XL works fine. I'll see if I can find a Samsung device to test.
co...@gmail.com <co...@gmail.com> #8
Yes this is specific to Samsung as stated in first message.
I repro via Samsung testlab as I do not have a device myself, but A54 A55 with Android 14 there does reproduce the issue. (And a few different other Android 14 samsung devices from my beta users)
ma...@google.com <ma...@google.com> #9
I just verified that I can repro on a Samsung device.
al...@gmail.com <al...@gmail.com> #10
Perfect.
Just quickly tested the
.fillMaxSize()
.wrapContentHeight()
And it seems to behave correctly for the dialog scrim so works as a solution, may worth a note somewhere as cheating with usePlatformDefaultWidth = false
was often found as solution in a few posts over Internet.
A quick "mostly" related question to the dialog scrim, many users requested an option to hide the status bar in my app to be in full immersive mode, but there's no way to do that with dialogs right now. Is this something that can be requested? I have a fork of M3 BottomSheet to handle that, but handling a fork of the low level dialog requires a full copy and rewrite of everything that depends on it.
Description
1. Write an app that uses locale.setlocale(..)
2. I used the Django Helper
What is the expected output? What do you see instead?
This is the error I get:
Error at /tsc/
unsupported locale setting
Request Method: POST
Request URL:
Exception Type: Error
Exception Value: unsupported locale setting
Exception Location: /base/python_dist/lib/python2.5/locale.py in
setlocale, line 478
Traceback (most recent call last):
File "/base/python_lib/versions/1/django/core/handlers/base.py" in get_response
77. response = callback(request, *callback_args, **callback_kwargs)
File "/base/data/home/apps/henschkowskitest/1.18/tsc/views.py" in directupload
44. converter.convert()
File "/base/data/home/apps/henschkowskitest/1.18/tsc/bsg2tkc.py" in convert
63. locale.setlocale(locale.LC_ALL, 'de') # Google AppEngine
File "/base/python_dist/lib/python2.5/locale.py" in setlocale
478. return _setlocale(category, locale)
Error at /tsc/
unsupported locale setting
What version of the product are you using? On what operating system?
SVN / Linux
Please provide any additional information below.
Tried also locales German_Switzerland and de_DE:
try:
locale.setlocale(locale.LC_ALL, 'German_Switzerland') # Windows
except:
try:
locale.setlocale(locale.LC_ALL, 'de_DE') # UNIX
except:
locale.setlocale(locale.LC_ALL, 'de') # Google AppEngine