Skip to content

Releases: SchweizerischeBundesbahnen/scion-workbench

18.0.0-beta.4 (@scion/workbench)

28 Aug 12:39
Compare
Choose a tag to compare

18.0.0-beta.4 (2024-08-28)

Bug Fixes

  • workbench/view: update view properties between route deactivation and route activation (5526eec)
  • workbench/router: activate part only if specified by the navigation (51ba3bb)
  • workbench/popup: render popup at the correct position when activating view (a13e93f)
  • workbench/layout: debounce storing workbench layout (076c241)
  • workbench/layout: do not display "Not Found" page when closing a view (03681b5)
  • workbench/layout: serialize properties with a null value (49905f6)

Features

  • workbench/perspective: provide active perspective via WorkbenchService (ee6d22b)
  • workbench/view: enable passing data to an empty-path navigation (3b65d9b)
  • workbench: change WorkbenchService properties to signals to integrate with Angular reactive contexts (17280b3)
  • workbench/perspective: change WorkbenchPerspective properties to signals to integrate with Angular reactive contexts (df6603a)
  • workbench/part: change WorkbenchPart properties to signals to integrate with Angular reactive contexts (6aa6cd1)
  • workbench/view: change WorkbenchView properties to signals to integrate with Angular reactive contexts (4498b52)
  • workbench/dialog: change WorkbenchDialog properties to signals to integrate with Angular reactive contexts (53ab8bb)

BREAKING CHANGES

  • workbench: Migrating WorkbenchService properties to signals has introduced a breaking change.

    Migrate reading of WorkbenchService properties as follows:

    • WorkbenchService.layout => WorkbenchService.layout()
    • WorkbenchService.layout$ => WorkbenchService.layout()
    • WorkbenchService.parts => WorkbenchService.parts()
    • WorkbenchService.parts$ => WorkbenchService.parts()
    • WorkbenchService.perspectives => WorkbenchService.perspectives()
    • WorkbenchService.perspectives$ => WorkbenchService.perspectives()
    • WorkbenchService.theme$ => WorkbenchService.theme()
    • WorkbenchService.views => WorkbenchService.views()
    • WorkbenchService.views$ => WorkbenchService.views()
  • workbench/perspective: Migrating WorkbenchPerspective properties to signals has introduced a breaking change.

    Migrate reading of WorkbenchPerspective properties as follows:

    • WorkbenchPerspective.active => WorkbenchPerspective.active()
    • WorkbenchPerspective.active$ => WorkbenchPerspective.active()
  • workbench/part: Migrating WorkbenchPart properties to signals has introduced a breaking change.

    Migrate reading of WorkbenchPart properties as follows:

    • WorkbenchPart.actions => WorkbenchPart.actions()
    • WorkbenchPart.actions$ => WorkbenchPart.actions()
    • WorkbenchPart.active => WorkbenchPart.active()
    • WorkbenchPart.active$ => WorkbenchPart.active()
    • WorkbenchPart.activeViewId => WorkbenchPart.activeViewId()
    • WorkbenchPart.activeViewId$ => WorkbenchPart.activeViewId()
    • WorkbenchPart.viewIds$ => WorkbenchPart.viewIds()
    • WorkbenchPart.viewIds => WorkbenchPart.viewIds()
  • workbench/view: Migrating WorkbenchView properties to signals has introduced a breaking change.

    The breaking change refers to reading property values. Writable properties are still updated through value assignment. Some properties have also been renamed for consistency reasons.

    Migrate reading of WorkbenchView properties as follows:

    • WorkbenchView.active => WorkbenchView.active()
    • WorkbenchView.active$ => WorkbenchView.active()
    • WorkbenchView.cssClass => WorkbenchView.cssClass()
    • WorkbenchView.closable => WorkbenchView.closable()
    • WorkbenchView.dirty => WorkbenchView.dirty()
    • WorkbenchView.first => WorkbenchView.first()
    • WorkbenchView.heading => WorkbenchView.heading()
    • WorkbenchView.last => WorkbenchView.last()
    • WorkbenchView.navigationHint => WorkbenchView.navigationHint()
    • WorkbenchView.part => WorkbenchView.part()
    • WorkbenchView.position => WorkbenchView.position()
    • WorkbenchView.urlSegments => WorkbenchView.urlSegments()
    • WorkbenchView.scrolledIntoView => WorkbenchView.scrolledIntoView()
    • WorkbenchView.state => WorkbenchView.navigationState()
    • WorkbenchView.title => WorkbenchView.title()
  • workbench/dialog: Migrating WorkbenchDialog properties to signals has introduced a breaking change.

    The breaking change refers to reading property values. Writable properties are still updated through value assignment.

    Migrate reading of WorkbenchDialog properties as follows:

    • WorkbenchDialog.closable => WorkbenchDialog.closable()
    • WorkbenchDialog.cssClass => WorkbenchDialog.cssClass()
    • WorkbenchDialog.padding => WorkbenchDialog.padding()
    • WorkbenchDialog.resizable => WorkbenchDialog.resizable()
    • WorkbenchDialog.size.height => WorkbenchDialog.size.height()
    • WorkbenchDialog.size.width => WorkbenchDialog.size.width()
    • WorkbenchDialog.size.maxHeight => WorkbenchDialog.size.maxHeight()
    • WorkbenchDialog.size.minHeight => WorkbenchDialog.size.minHeight()
    • WorkbenchDialog.size.maxWidth => WorkbenchDialog.size.maxWidth()
    • WorkbenchDialog.size.minWidth => WorkbenchDialog.size.minWidth()
    • WorkbenchDialog.title => WorkbenchDialog.title()
    • Setting an observable as dialog title is no longer supported. Instead, manually subscribe to the observable and set the title.

1.0.0-beta.25 (@scion/workbench-client)

28 Aug 12:18
Compare
Choose a tag to compare

1.0.0-beta.25 (2024-08-28)

Bug Fixes

  • workbench-client/dialog: unsubscribe previous title observable when setting new title observable (2e72b39)

18.0.0-beta.3 (@scion/workbench)

21 Jun 07:31
Compare
Choose a tag to compare

18.0.0-beta.3 (2024-06-21)

Bug Fixes

  • workbench/perspective: create default perspective if no perspective exists (7010623)
  • workbench/view: align microfrontend with view bounds when moving it to another part of the same size (e57f0d0)
  • workbench/view: do not error when initializing view in ngOnInit (1374260)
  • workbench/view: initialize microfrontend loaded into inactive view (764f89e)

Features

  • workbench/perspective: activate first view of each part if not specified (161d05d)
  • workbench/perspective: enable micro app to contribute perspective (f20f607), closes #449
  • workbench/view: display "Not Found" page if microfrontend is not available (93be385)

BREAKING CHANGES

  • workbench/perspective: The return type of the function to select the initial perspective has changed. To migrate, return the perspective id instead of the perspective instance.
  • workbench: SCION Workbench requires @scion/microfrontend-platform version 1.3.0 or later.
  • workbench: SCION Workbench requires @scion/workbench-client version 1.0.0-beta.24 or later.

1.0.0-beta.24 (@scion/workbench-client)

21 Jun 07:05
Compare
Choose a tag to compare

1.0.0-beta.24 (2024-06-21)

Features

  • workbench-client/router: control workbench part to navigate views (af702d0)
  • workbench-client/view: provide part via view handle (849d7f3)
  • workbench-client/perspective: enable micro app to contribute perspective (f20f607), closes #449

18.0.0-beta.2 (@scion/workbench)

13 Jun 14:13
Compare
Choose a tag to compare

18.0.0-beta.2 (2024-06-13)

Code Refactoring

  • workbench: change default icon font directory from /assets/fonts to /fonts (d347dae)

BREAKING CHANGES

  • workbench: The default icon font directory has changed from /assets/fonts to /fonts.

    To migrate:

    • Move the fonts folder from /src/assets to /public.
    • Include content of the public folder in angular.json:
      "assets": [
        {
          "glob": "**/*",
          "input": "public"
        }
      ]
    • Alternatively, to not change the folder structure, you can configure a custom path to the icon font directory in your styles.scss:
      use '@scion/workbench' with (
        $icon-font: (
          directory: 'assets/fonts'
        )
      );

18.0.0-beta.1 (@scion/workbench)

10 Jun 12:32
Compare
Choose a tag to compare

18.0.0-beta.1 (2024-06-10)

Dependencies

  • workbench: update @scion/workbench to Angular 18 (d39fa85)

BREAKING CHANGES

17.0.0-beta.9 (@scion/workbench)

22 May 09:18
Compare
Choose a tag to compare

17.0.0-beta.9 (2024-05-22)

Bug Fixes

  • workbench/dialog: avoid ExpressionChangedAfterItHasBeenCheckedError when registering dialog header, footer and actions (5554428)
  • workbench/dialog: set initial focus on delayed content (312280e)

Features

  • workbench/message-box: enable microfrontend display in a message box (3e9d88d)

BREAKING CHANGES

  • workbench/message-box: Support for displaying microfrontend in a message box has been added.

    To migrate, update to the latest version of @scion/workbench-client.

1.0.0-beta.23 (@scion/workbench-client)

22 May 05:10
Compare
Choose a tag to compare

1.0.0-beta.23 (2024-05-21)

Features

  • workbench-client/message-box: enable microfrontend display in a message box (3e9d88d), closes #488

BREAKING CHANGES

  • workbench-client/message-box: The signature of the WorkbenchMessageBoxService.open method has changed.

    To migrate:

    • To display a text message, pass the message as the first argument, not via the content property in the options.
    • To display a custom message box, pass the qualifier as the first argument and options, if any, as the second argument.

    Example migration to display a text message

    // Before Migration
    inject(WorkbenchMessageBoxService).open({
      content: 'Do you want to continue?',
      actions: {yes: 'Yes', no: 'No'},
    });
    
    // After Migration
    inject(WorkbenchMessageBoxService).open('Do you want to continue?', {
      actions: {yes: 'Yes', no: 'No'},
    });

    Example migration to open a custom message box capability

    // Before Migration
    inject(WorkbenchMessageBoxService).open({
        title: 'Unsaved Changes',
        params: {changes: ['change 1', 'change 2']},
        actions: {yes: 'Yes', no: 'No'},
      },
      {confirmation: 'unsaved-changes'},
    );
    
    // After Migration
    inject(WorkbenchMessageBoxService).open({confirmation: 'unsaved-changes'}, {
      title: 'Unsaved Changes',
      params: {changes: ['change 1', 'change 2']},
      actions: {yes: 'Yes', no: 'No'},
    });

17.0.0-beta.8 (@scion/workbench)

07 May 10:20
Compare
Choose a tag to compare

17.0.0-beta.8 (2024-05-07)

Bug Fixes

  • workbench/view: fix issues to prevent a view from closing (a280af9), closes #27 #344
  • workbench/view: update view properties when navigating an open view (02a24ff)

Code Refactoring

  • workbench/router: remove blank prefix from navigation extras (446fa51)
  • workbench/router: remove option to close view via workbench router link (88d1704)

Dependencies

  • workbench: require Angular version 17.0.6 or later to fix angular/angular#53239 (dd78d07)

Features

  • workbench/router: control workbench part to navigate views (0bf35a7)
  • workbench/router: provide API to modify the workbench layout (46ea446)
  • workbench/router: support navigation to children of the empty path route (da578a9), closes #487
  • workbench: provide function to set up the SCION Workbench (1a506ef)
  • workbench: support navigation of views in the initial layout (or perspective) (1ffd757), closes #445

BREAKING CHANGES

  • workbench/view: Interface and method for preventing closing of a view have changed.

    To migrate, implement the CanClose instead of the WorkbenchViewPreDestroy interface.

    Before migration:

    class YourComponent implements WorkbenchViewPreDestroy {
      public async onWorkbenchViewPreDestroy(): Promise<boolean> {
        // return `true` to close the view, otherwise `false`.
      }
    }

    After migration:

    class YourComponent implements CanClose {
      public async canClose(): Promise<boolean> {
        // return `true` to close the view, otherwise `false`.
      }
    }
  • workbench/router: Property blankInsertionIndex in WorkbenchNavigationExtras has been renamed.

    To migrate, update to the latest version of @scion/workbench-client and use WorkbenchNavigationExtras.position instead of WorkbenchNavigationExtras.blankInsertionIndex.

  • workbench/router: Property blankPartId in WorkbenchNavigationExtras has been renamed.

    To migrate, use WorkbenchNavigationExtras.partId instead of WorkbenchNavigationExtras.blankPartId.

  • workbench: Views in the initial layout (or perspective) must now be navigated.

    Previously, no explicit navigation was required because views and routes were coupled via route outlet and view id.

    Migrate the layout as follows:

    Explicitly navigate views, passing an empty array of commands and the view id as navigation hint.

    // Before Migration
    provideWorkbench({
      layout: (factory: WorkbenchLayoutFactory) => factory
        .addPart(MAIN_AREA)
        .addPart('left', {relativeTo: MAIN_AREA, align: 'left'})
        .addView('navigator', {partId: 'left', activateView: true}),
    });
    
    // After Migration
    provideWorkbench({
      layout: (factory: WorkbenchLayoutFactory) => factory
        .addPart(MAIN_AREA)
        .addPart('left', {relativeTo: MAIN_AREA, align: 'left'})
        .addView('navigator', {partId: 'left', activateView: true})
        // Navigate view, passing hint to match route.
        .navigateView('navigator', [], {hint: 'navigator'}),
    });

    Migrate the routes as follows:

    • Remove the outlet property;
    • Add canMatchWorkbenchView guard and initialize it with the hint passed to the navigation;
    // Before Migration
    provideRouter([
      {
        path: '',
        outlet: 'navigator',
        loadComponent: () => ...,
      },
    ]);
    
    // After Migration
    provideRouter([
      {
        path: '',
        // Match route only if navigated with specified hint.
        canMatch: [canMatchWorkbenchView('navigator')],
        loadComponent: () => ...,
      },
    ]);
  • workbench: Changed type of view id from string to ViewId.

    If storing the view id in a variable, change its type from string to ViewId.

  • workbench/router: Removed the option to close a view via the wbRouterLink directive.

    The router link can no longer be used to close a view. To close a view, use the WorkbenchView, the WorkbenchRouter, or the WorkbenchService instead.

    Examples:

    // Closing a view via `WorkbenchView` handle
    inject(WorkbenchView).close();
    
    // Closing view(s) via `WorkbenchRouter`
    inject(WorkbenchRouter).navigate(['path/*/view'], {close: true});
    
    // Closing view(s) via `WorkbenchService`
    inject(WorkbenchService).closeViews('view.1', 'view.2');
  • workbench: SCION Workbench requires Angular version 17.0.6 or later to fix angular/angular#53239

1.0.0-beta.22 (@scion/workbench-client)

07 May 09:47
Compare
Choose a tag to compare

1.0.0-beta.22 (2024-05-07)

Bug Fixes

  • workbench-client/view: fix issues to prevent a view from closing (a280af9), closes #27 #344

Refactor

  • workbench-client/router: remove blank prefix from navigation extras (446fa51)

BREAKING CHANGES

  • workbench-client/view: Interface and method for preventing closing of a view have changed.

    To migrate, implement the CanClose instead of the ViewClosingListener interface.

    Before migration:

    class YourComponent implements ViewClosingListener {
     
      constructor() {
        Beans.get(WorkbenchView).addClosingListener(this);
      }
     
      public async onClosing(event: ViewClosingEvent): Promise<void> {
        // invoke 'event.preventDefault()' to prevent closing the view.
      }
    }

    After migration:

    class YourComponent implements CanClose {
     
      constructor() {
        Beans.get(WorkbenchView).addCanClose(this);
      }
     
      public async canClose(): Promise<boolean> {
        // return `true` to close the view, otherwise `false`.
      }
    }
  • workbench-client/router: Property blankInsertionIndex in WorkbenchNavigationExtras has been renamed.

    Use WorkbenchNavigationExtras.position instead of WorkbenchNavigationExtras.blankInsertionIndex.

  • workbench-client/view: Changed type of view id from string to ViewId.

    If storing the view id in a variable, change its type from string to ViewId.