react
andreact-dom
dependencies have been upgraded to version 16 (see https://legacy.reactjs.org/blog/2017/09/26/react-v16.0.html#breaking-changes).
- ProcessConfiguration allows defining synchronous event handler when there are no dependencies. Downstream projects should prefer using synchronous event handlers as the legacy behavior might be removed in later releases.
- Library files no longer contain version number in their name. Adding content hash or version suffix to prevent caching is responsibility of downstream projects.
- Library files are mostly non-minified so final optimization is responsibility of downstream projects.
- CodeMirror now requires custom ESM build step and styling is no longer being made through custom CSS (see example in the Mock module).
- Changed task runner from Grunt to Gulp and introduced new module
@wrensecurity/commons-ui-build
with shared Gulp task implementation. See individual gulpfiles for inspiration how to switch to Gulp in downstream projects. - Project structure has been migrated from multimodule Maven to single Maven module with NPM
workspaces. Maven artifact coordinates has to be migrated to the new artifact ID with separate
workspace-specific classifier:
forgerock-ui-commons:www:zip -> wrensec-ui-commons:base:zip
forgerock-ui-user:www:zip -> wrensec-ui-commons:user:zip
- Upgraded lodash from 3.x to the newest 4.x version. See breaking changes described in 4.0.0
release notes - /~https://github.com/lodash/lodash/wiki/Changelog#compatibility-warnings.
Following regular expression searches can be performed to check for places that need attention:
- removed methods -
\b(support|findWhere|where|pluck|first|indexBy|invoke|modArgs|padLeft|pairs|rest|restParam|sortByOrder|trimLeft|trimRight|trunc|sortByAll|isDeep)\(
- removed aliases -
\b(all|any|collect|compose|contains|detect|include|inject|methods|object|select|unique)\(
- split out methods -
\b(assign|assignIn|clone|cloneDeep|indexOf|lastIndexOf|invert|invertBy|isEqual|isEqualWith|isMatch|isMatchWith|max|min|merge|mergeWith|omit|pick|sample|sortedIndex|sortedLastIndex|sum|uniq|zipObject)\(
- dropped boolean options -
\b(debounce|mixin|throttle)\(
thisArg
removal (this one is the most tricky) -(?<!\()\bthis\)
- removed methods -
- Introduced Underscore.js as its own dependency because Backbone is not compatible with lodash.
All custom code should explicitly depend on
lodash
only. Hence replaceunderscore
imports withlodash
and remove module alias in RequireJS configuration (underscore
andlodash
are different dependenies from now on). - Upgraded Backbone.js wich has few incompatibilities, mainly
View.delegate
property which is being used as alias todelegateEvents
. This means thatdelegate
MUST NOT be used as custom property (see changes inorg/forgerock/commons/ui/user/delegates/AnonymousProcessDelegate
).
- Build dependencies were upgraded (wrensec-parent, NodeJS, NPM, ...)
-
ViewManager can now handle being passed either a Backbone or a React view.
-
react
andreact-dom
are bundled with commons, ensure you update your product license file(s). e.g. in OpenAM...
// openam-server-only/src/license/THIRD-PARTY.properties
org.forgerock.commons.ui.libs--react--15.2.1=BSD
org.forgerock.commons.ui.libs--react-dom--15.2.1=BSD
-
org/forgerock/commons/ui/common/components/hoc/withRouter
-
React views are not passed parameters from the router as Backbone views are. This is intentional as not all view may need router parameters.
-
withRouter
is a HoC that you use access router parameters in your React component.
import withRouter from "org/forgerock/commons/ui/common/components/hoc/withRouter"
class MyReactComponent extends Component { ... }
export default withRouter(MyReactComponent)
References to UserProfileView in projects which use forgerock-ui-user will need to be updated. In 13.x, use of UserProfileView was determined via dependency injection in the requirejs map aliases, like so:
require.config({ "map": { "*": {
"UserProfileView" : (serverInfo.kbaEnabled === "true"
? "org/forgerock/commons/ui/user/profile/UserProfileKBAView"
: "org/forgerock/commons/ui/user/profile/UserProfileView")
} } });
This was based on the idea that you would swap out one whole view in favor of another, to be responsible for rendering the user profile. Switching the view was used to decide whether or not to show the basic profile or the "KBA"-enhanced version.
In 14.x, the reference to the whole view no longer needs to be replaced. Instead, there is a single instance of the UserProfileView which simply needs to be told which child views are available for rendering additional tabs (such as the KBA tab). For example:
if (serverInfo.kbaEnabled === "true") {
require(["org/forgerock/commons/ui/user/profile/UserProfileKBATab"], (tab) => {
UserProfileView.registerTab(tab);
});
}
The entries for form2js and js2form must be adjusted to match the new version. Previously it was listed like so:
js2form: "libs/js2form-2.0",
form2js: "libs/form2js-2.0",
Now they must be specified like so:
js2form: "libs/js2form-2.0-769718a",
form2js: "libs/form2js-2.0-769718a",
-
There is a new parameter attached to the event for EVENT_SHOW_LOGIN_DIALOG : "authenticatedCallback". This is a function which is expected to be called when the inline login dialog has successfully re-authenticated the user. Since there is an expectation that the EVENT_SHOW_LOGIN_DIALOG could be invoked multiple times, it is recommended that each callback function be stored in a queue (such as the new org/forgerock/commons/ui/common/util/Queue facility) so that they all get called and in the order received. If the implementing product is making use of the default EVENT_SHOW_LOGIN_DIALOG implementation, then nothing needs to be changed in the product to work properly.
-
Updating to Handlebars 4
The path to the new version of handlebars (4.0.5) will need to be adjusted in the root main.js.
- Ability to provide project-specific
KBADelegate
Both OpenAM and OpenIDM need to provide a path to a KBADelegate
, which can be either a project-specific or the commons one.
- Ability to pass (main) link filters to Navigation
The logic within Navigation.js
that filters the master list of links based on various conditions (e.g. roles) has been factored out and is now provided to the Navigation component via a separate module.
The original behaviour is provided via the filter org/forgerock/commons/ui/common/components/navigation/filters/RoleFilter
.
To use, add a new mapping to the RequireJS configuration:
require.config({
map: {
"*" : {
"NavigationFilter" : "org/forgerock/commons/ui/common/components/navigation/filters/RoleFilter"
...
For reference, OpenAM is using org/forgerock/openam/ui/common/components/navigation/filters/RouteNavGroupFilter
.
- Introduction of new user role
ui-self-service-user
Applications will need to add this role to any users that should be able to access the self-service (profile) pages.