Skip to content

Releases: vaadin/flow

Vaadin Flow 24.4.10

21 Oct 07:37
cc752d4
Compare
Choose a tag to compare

Changes since 24.4.9

All changes

Fixes

  • Clear CurrentInstance before invoking new session tasks (#6349) (#20255)
    Commit · Pull request · Issue

    Commands enqueued by VaadinSession.access() in general have nothing to do with each other. The only thing they have in common is they share the same VaadinSession (and, by implication, VaadinService). Therefore, if command №1 invoked UI.setCurrent() and command №2 invokes UI.getCurrent(), command №2 should read null, not the random UI from command №1 that it has nothing to do with.

  • Prevent possible error on embedded component disconnect (#20260)
    Commit · Pull request

  • Force hotdeploy with hilla (#20251)
    Commit · Pull request

  • Resolve route parameters when rerouting and forwardin with query parameters (#20210)
    Commit · Pull request · Issue

  • VaadinSessionScopes for all sessions are destroyed when any single session expires #20092 (#20103)
    Commit · Pull request

  • Perform server navigation roundtrip only when client side navigation is completed (#20187) (CP: 24.4)
    Commit · Pull request · Issue

  • Always fetch reactEnabled from service (#20125) (CP: 24.4)
    Commit · Pull request

  • Consider layout prefixes when checking for route and alias paths (#20126)
    Commit · Pull request · Issue

  • Allow null response in logout (#20057)
    Commit · Pull request · Issue

    Don't throw NullPointerException in case of null VaadinServletResponse in AuthenticationContext#logout. Tolerate null response better in case when running with @Push(transport = Transport.WEBSOCKET), or when response is null for some other reason. Makes logout also work in WEBSOCKET mode by automatically switching to WEBSOCKET_XHR for one additional request that executes logout.

Vaadin Flow 24.3.19

21 Oct 07:37
7198204
Compare
Choose a tag to compare

Changes since 24.3.18

All changes

Fixes

  • Clear CurrentInstance before invoking new session tasks (#6349) (#20255)
    Commit · Pull request · Issue

    Commands enqueued by VaadinSession.access() in general have nothing to do with each other. The only thing they have in common is they share the same VaadinSession (and, by implication, VaadinService). Therefore, if command №1 invoked UI.setCurrent() and command №2 invokes UI.getCurrent(), command №2 should read null, not the random UI from command №1 that it has nothing to do with.

  • Resolve route parameters when rerouting and forwarding with query parameters (#20210) (CP: 24.3)
    Commit · Pull request · Issue

  • Consider layout prefixes when checking for route and alias paths (#20126)
    Commit · Pull request · Issue

  • Allow null response in logout (#20057) (CP: 24.3)
    Commit · Pull request · Issue

    Don't throw NullPointerException in case of null VaadinServletResponse in AuthenticationContext#logout. Tolerate null response better in case when running with @Push(transport = Transport.WEBSOCKET), or when response is null for some other reason. Makes logout also work in WEBSOCKET mode by automatically switching to WEBSOCKET_XHR for one additional request that executes logout.

Vaadin Flow 23.5.7

21 Oct 07:02
d1ecf56
Compare
Choose a tag to compare

Changes since 23.5.6

All changes

Fixes

  • Clear CurrentInstance before invoking new session tasks (#6349) (#20255)
    Commit · Pull request · Issue

    Commands enqueued by VaadinSession.access() in general have nothing to do with each other. The only thing they have in common is they share the same VaadinSession (and, by implication, VaadinService). Therefore, if command №1 invoked UI.setCurrent() and command №2 invokes UI.getCurrent(), command №2 should read null, not the random UI from command №1 that it has nothing to do with.

  • Resolve route parameters when rerouting and forwarding with query parameters (#20210) (CP: 23.5)
    Commit · Pull request · Issue

  • Consider layout prefixes when checkin for route and alias paths (#20126) (CP: 23.5)
    Commit · Pull request · Issue


Vaadin Flow 2.11.2

21 Oct 07:02
0858723
Compare
Choose a tag to compare

Changes since 2.11.1

All changes

Fixes

  • Clear CurrentInstance before invoking new session tasks (#6349) (#20255)
    Commit · Pull request · Issue

    Commands enqueued by VaadinSession.access() in general have nothing to do with each other. The only thing they have in common is they share the same VaadinSession (and, by implication, VaadinService). Therefore, if command №1 invoked UI.setCurrent() and command №2 invokes UI.getCurrent(), command №2 should read null, not the random UI from command №1 that it has nothing to do with.

Vaadin Flow 24.5.0

16 Oct 07:35
324cc03
Compare
Choose a tag to compare

All Changes since Vaadin Flow 24.4

New features

  • Automatic Flow main layouts
    Docs

    Vaadin Flow automatically adds the Flow and Hilla routes to the router layout that is marked with AtLayout new annotation:

    // Main Layout:
    @Layout
    @AnonymousAllowed
     public class MainLayout extends AppLayout {
     }
    
    // Flow route:
    @PermitAll
    @Route("flow") // no layout reference is needed
     public class FlowView extends VerticalLayout {
     }

    Includes the following commits:

    • Automatic Flow layout
      Commit · Pull request

      Automatically match layout for both flow and hilla route. format Add server layout usage information to routes.tsx template This reverts commit bad2fec. Have OutletElement as a tsx file in flow-react jar Add javadoc for auto layout getParentLayout method.

    • Generate layout.json
      Commit · Pull request

      Generate a layout.json for Hilla to automatically enable server layouts part of vaadin/hilla#2709.

  • Dynamic menu items in Flow main layout
    Docs

    Collects and provides AtMenu annotated Flow routes and Hilla views filtered by access control resolutions, can be used in the Flow main layout to render links in the navigation bar in a generic way without explicit Java classes for routes:

    // Use dynamic menus in layout class:
    List<MenuEntry> menuEntries = MenuConfiguration.getMenuEntries();
    menuEntries.forEach(entry -> {
       sideNav.addItem(new SideNavItem(entry.title(), entry.path(), new SvgIcon(entry.icon()));
    };
    
    // Flow route
    @Menu(title = "Flow view", icon = "vaadin:group")
    @Route("flow")
     public class FlowView extends VerticalLayout {
     }
    
    // Hilla view
    export const config: ViewConfig = {
       menu: {
         title: "Hilla User page",
         icon: 'vaadin:user'
       }
    };
    export default function Hilla() {
    }
    • Add collectMenuItemsList() to MenuRegistry
      Commit · Pull request · Issue

    • Get menu views api
      Commit · Pull request · Issue

      Create MenuRegistry for getting automatic menu views for population.

    • Filter client routes by authentication and role
      Commit · Pull request

      Add filtering of menu client routes by checking authentication and roles. Do not check for routes in ClientRoutesProvider as the results are generated from the same source data as the data read/generated by MenuRegistry.

  • Flow components as children for React-based component
    Doc · Commit · Pull request · Issue

    Allows having Flow Components as children in a ReactAdapterComponent (Flow wrapper for React component).

    // Example of main layout in React with a Flow component as a content in this layout:
    @Layout
    @JsModule("./ReactLayout.tsx")
    @Tag("react-layout")
    public class ReactLayout extends ReactAdapterComponent 
                               implements RouterLayout {
        @Override
        public void showRouterLayoutContent(
                                   HasElement content) {
            if (content != null) {
                // bind Flow component to React element with the "flowContent" key
                getContentElement("flowContent").appendChild(content.getElement());
            }
        }
    }
    // Main Layout in React
    class ReactLayoutElement extends ReactAdapterElement {
       protected render(hooks: RenderHooks) {
       const content = hooks.useContent('flowContent');
        return (
          <div style={{flexGrow: 1, padding: '20px'}}>
            <AppBar position="fixed">
              <Toolbar>
                <Typography variant="h6" component="div">
                  React Layout
                </Typography>
              </Toolbar>
            </AppBar>
           {content}
          </div>
        )
      }
    }
    customElements.define('react-layout', ReactLayoutElement);
  • HotSwap improvements

    Provides a single endpoint for hotswap tools that internally chooses the best strategy of UI update - full page reload or UI component reload.

    Includes the following commits:

  • Record support in Binder
    Docs · Commit · Pull request

    Provides an API to use Java Records as bean types for read-only beans in Binder.

  • Support for nonce-based strict Content Security Policy
    Docs

    Vaadin Flow isn’t generally compatible with strict CSP rules, however, with some effort, nonce-based strict CSP can be used with Vaadin Flow applications. See the linked documentation for how to set it up.

  • Add alternative translate methods to I18NProvider
    Commit · Pull request · Issue

    Adds static I18NProvider#translate methods for alternative way to get translation. Compares to calling getTranslation via VaadinService.getCurrent().getInstantiator().getI18NProvider(). translate methods throws IllegalStateException without active VaadinService.

  • Speedup startup time by excluding jars
    Commit · Pull request · Issue

    Optimize class scanning of VaadinServletContextInitializer by excluding some commonly used jars and add support for vaadin.blocked-jar boolean property in META-INF/VAADIN/package.properties to exclude whole jar content from the class scanner.

  • Added HasLabelAsText interface to NativeButtonElement.
    Commit · Pull request

  • Filterable class scanning of JAR
    Commit · Pull request · Issue

    This change improves optimization of class scanning of VaadinServletContextInitializer by reading optional configuration file within a JAR dependency. Configuration file is a regular properties file that can contain vaadin.allowed-packages or vaadin.blocked-packages to exclude/include packages being scanned by VaadinServletContextInitializer. Package exclusion/inclusion effects only classes in the JAR/module where META-INF/VAADIN/package.properties is located at. Notice that this is only affecting the performance of the class scanning of Vaadin specific annotations and types and this feature is not meant to be used for excluding packages from the whole application. E.g. excluding VaadinServiceInitListener in a Spring application is not stopping Spring and Vaadin initializing it anyway, although some time-consuming actions like DevModeServletContextListener would still exclude it for optimization.

  • Add raw html table and related components
    Commit · Pull request

  • Create converters for numeric values from NumberField
    Commit · Pull request · Issue

    This pull request introduces converter classes which converts between Numeric data types. This change addresses the need for such converters as outlined in issue #5134. With the availability of a NumberField in Vaadin, it is essential to have converters that facilitate the use of various number formats with this component.

  • Add ValueContext.getBinder()
    Commit · Pull request

    original authors: @archiecobbs and @mstahv

  • Load Lumo utility CSS by default
    Commit · Pull request

    The imports have been manually defined in all new starter projects for a long time so this is not supposed to break much anything.

  • Upgrade to TypeScript 5.5
    Commit · [Pu...

Read more

Vaadin Flow 24.6.0.alpha1

17 Oct 06:20
1937249
Compare
Choose a tag to compare
Pre-release

Changes since 24.5.0

All changes

Breaking changes

  • Wrap each enum on a separate line when there are many of them
    Commit · Pull request

  • Upgrade minimum supported Gradle version to 8.7
    Commit · Pull request

    Jackson 2.18 is incompatible with Gradle 8.4 because it contains classes compiled with Java 22. This change bumps Gradle minumum supported version to 8.7 that supports Java 22.

New features

  • Add drag image for DragSource
    Commit · Pull request · Issue

    Adds DragSource#setDragImage(ComponentdragImage ) and DragSource#setDragImage(Component dragImage, int offsetX, int offsetY). API is used to set image component as a drag image for drag source component. Follows specification of HTML Drag and Drop API for DataTransfer#setDragImage() method.

Vaadin Flow 24.5.0.rc2

14 Oct 06:17
4a9d126
Compare
Choose a tag to compare
Pre-release

Changes since 24.5.0.rc1

All changes

Fixes

Vaadin Flow 24.5.0.rc1

10 Oct 06:01
2538e4d
Compare
Choose a tag to compare
Pre-release

No changes since 24.5.0.beta7

Vaadin Flow 24.5.0.beta7

09 Oct 13:31
419622e
Compare
Choose a tag to compare
Pre-release

Changes since 24.5.0.beta6

All changes

New features

  • Add a helper method for menu's page title (#20165)
    Commit · Pull request · Issue

    Adds a new static helper method that gives a page title for views shown using menu.

Fixes

Vaadin Flow 24.5.0.beta6

09 Oct 08:46
7ea97e1
Compare
Choose a tag to compare
Pre-release

Changes since 24.5.0.beta5

All changes

Fixes

  • Update document title for client route (#20184)
    Commit · Pull request

    Updates document title for client view with flow layout based on ViewConfig.title and when not overridden by server's HasDynamicTitle.

  • Navigatin to client view from server (#20151)
    Commit · Pull request

    Navigation to the client view using server navigate should work normally and not try to add layout for non layout client view.

  • Reintroduce static methods used by Hilla (#20168)
    Commit · Pull request

    Reintroduces static methods used by Hilla in FlowModeAbstractMojo, preserving the ClassFinder creation improvements for Flow mojos.

  • Fix auto layout hotswap
    Commit · Pull request

    Refactor hotswap logic and tests to align with changes introduced by #20120.

  • Reload route configuration upon layout changes
    Commit · Pull request · Issue

    When a [At]Layout annotated class is modified, the changes are not propagated to the route registry after hotswap happens. This change updates Route registry layouts configuration and re-registers routes potentially impacted by the change to apply the new settings. It also checks the route target chain for active UIs in order to trigger a page refresh if the layout changes should be applied.

Chore