Releases: SchweizerischeBundesbahnen/scion-workbench
18.0.0-beta.4 (@scion/workbench)
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)
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)
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
version1.3.0
or later. - workbench: SCION Workbench requires
@scion/workbench-client
version1.0.0-beta.24
or later.
1.0.0-beta.24 (@scion/workbench-client)
1.0.0-beta.24 (2024-06-21)
Features
18.0.0-beta.2 (@scion/workbench)
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' ) );
- Move the
18.0.0-beta.1 (@scion/workbench)
18.0.0-beta.1 (2024-06-10)
Dependencies
- workbench: update @scion/workbench to Angular 18 (d39fa85)
BREAKING CHANGES
-
workbench: Updating
@scion/workbench
to Angular 18 introduced a breaking change.To migrate:
- update your application to Angular 18; for detailed migration instructions, refer to https://v18.angular.dev/update-guide;
- update @scion/components to version 18; for detailed migration instructions, refer to https://github.com/SchweizerischeBundesbahnen/scion-toolkit/blob/master/CHANGELOG_COMPONENTS.md;
17.0.0-beta.9 (@scion/workbench)
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)
1.0.0-beta.23 (2024-05-21)
Features
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'}, });
- To display a text message, pass the message as the first argument, not via the
17.0.0-beta.8 (@scion/workbench)
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
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 theWorkbenchViewPreDestroy
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
inWorkbenchNavigationExtras
has been renamed.To migrate, update to the latest version of
@scion/workbench-client
and useWorkbenchNavigationExtras.position
instead ofWorkbenchNavigationExtras.blankInsertionIndex
. -
workbench/router: Property
blankPartId
inWorkbenchNavigationExtras
has been renamed.To migrate, use
WorkbenchNavigationExtras.partId
instead ofWorkbenchNavigationExtras.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: () => ..., }, ]);
- Remove the
-
workbench: Changed type of view id from
string
toViewId
.If storing the view id in a variable, change its type from
string
toViewId
. -
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
, theWorkbenchRouter
, or theWorkbenchService
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)
1.0.0-beta.22 (2024-05-07)
Bug Fixes
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 theViewClosingListener
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
inWorkbenchNavigationExtras
has been renamed.Use
WorkbenchNavigationExtras.position
instead ofWorkbenchNavigationExtras.blankInsertionIndex
. -
workbench-client/view: Changed type of view id from
string
toViewId
.If storing the view id in a variable, change its type from
string
toViewId
.