Chainlit / chainlit

Build Conversational AI in minutes ⚡️
https://docs.chainlit.io
Apache License 2.0
6.95k stars 914 forks source link

When I send a code block or a field with tags, the dialog box extends beyond the window #1422

Open Mgrsc opened 4 hours ago

Mgrsc commented 4 hours ago

Describe the bug When I send a code block or a field with tags, the dialog box extends beyond the window.

To Reproduce

send

<img src="" alt="Red dot" />

or send

    ```python
@trace
def oauth_callback(
    func: Callable[
        [str, str, Dict[str, str], User, Optional[str]], Awaitable[Optional[User]]
    ],
) -> Callable:
    """
    Framework agnostic decorator to authenticate the user via oauth

    Args:
        func (Callable[[str, str, Dict[str, str], User, Optional[str]], Awaitable[Optional[User]]]): The authentication callback to execute.

    Example:
        @cl.oauth_callback
        async def oauth_callback(provider_id: str, token: str, raw_user_data: Dict[str, str], default_app_user: User, id_token: Optional[str]) -> Optional[User]:

    Returns:
        Callable[[str, str, Dict[str, str], User, Optional[str]], Awaitable[Optional[User]]]: The decorated authentication callback.
    """

    if len(get_configured_oauth_providers()) == 0:
        raise ValueError(
            "You must set the environment variable for at least one oauth provider to use oauth authentication."
        )

    config.code.oauth_callback = wrap_user_function(func)
    return func


**Expected behavior**
Normally within the window range

**Screenshots**
![image](https://github.com/user-attachments/assets/0fdb145d-97bf-416f-85e9-1330ac3015ed)
![image](https://github.com/user-attachments/assets/0e12fab3-fbd2-431b-af14-f9cf8e4d0afd)

**Desktop (please complete the following information):**

- OS: [windows11]
- Browser [firefox,edge,chrome]
dosubot[bot] commented 4 hours ago

To address the issue of dialog boxes extending beyond the window when sending code blocks or fields with tags in Chainlit, you can try the following solutions:

  1. CSS Adjustments: Ensure that the CSS for dialog boxes includes properties to handle overflow. You can add or modify the CSS to include overflow: auto; or overflow: scroll; to ensure content is contained within the dialog box.

  2. Responsive Design: Check if the dialog box component is using responsive design techniques. You might need to set a maximum width or use media queries to adjust the size based on the screen size.

  3. ScrollContainer Component: Chainlit uses a ScrollContainer component with overflowY: 'auto' to manage scrolling. Ensure this is applied to your dialog boxes to handle content overflow properly [1].

  4. Custom Configuration: If you have custom CSS or JavaScript, ensure they are correctly configured in the config.toml file to override default styles if necessary [2].

These steps should help in managing the dialog box size and preventing it from extending beyond the window.

To continue talking to Dosu, mention @dosu.