Skip to content

Latest commit

 

History

History
71 lines (37 loc) · 4.59 KB

portalfx-extensions-bp-blades.md

File metadata and controls

71 lines (37 loc) · 4.59 KB

Best Practices

Following these best practices usually results in the best performance. Portal development patterns or architectures that are recommended based on customer feedback and usability studies are categorized by the type of blade.

Best Practices for All blades

These patterns are recommended for every extension.

  • Never change the name of a blade or a part. These are unique identifiers that appear in links that users may bookmark, and they are used to locate your blade when a user pins it to the dashboard. Changing the name can break aspects of the user experience.

    • You can safely change the title (displayed in the UI) of the blade.
  • Limit blade parameters updates to the addition of parameters that are marked in TypeScript as optional. Removing, renaming, or adding required parameters will cause breaks if other extensions are pointing to your blade, or if previously pinned tiles are not configured to send those parameters.

  • Never remove parameters from their Parameters type. Instead, ignore them if they are no longer needed.

  • Use standard <a href="#"> tags when adding fxclick to open child blades to make the links accessible.

  • Do not use <div> tags when adding fxClick to open child blades. The

    ` tags require apply additional HTML attributes to make the links accessible.

  • Do not use the Knockout click data-binding to open child Blades. The fxClick data-binding was developed specifically to handle asynchronous click communication between the Portal Shell IFrame and the extension's IFrame.

  • Avoid observables when possible

    The values in non-observables are much more performant than the values in observables. Specifying a string instead of a KnockoutObservable<string>, os specifying a boolean instead of a KnockoutObservable<boolean> will improve performance. The benefit for each operation is small, but when a blade makes tens or hundreds of values, it adds up.

  • Name ViewModel properties properly

    Make sure the only data that the proxied observables layer copies to the Shell is the data that is needed in the extension iFrame. The Shell displays a warning when specific types of objects are being sent to the shell, for example, editScopes, but it can not guard against everything.

    Extension developers should occasionally review the data model to ensure that only the needed data is public. The names of private members begin with an underscore, so that proxied observables are made aware by the naming convention that the members are private and therefore should not be sent to the shell.

Best Practices for Create blades

Best practices for create blades cover common scenarios that will save time and avoid deployment failures.

  • All Create blades should be a single blade. Instead of wizards or picker blades, extensions should use form sections and dropdowns.

  • The subscription, resource group, and location picker blades have been deprecated. Subscription-based resources should use the built-in subscription, resource group, location, and pricing dropdowns instead.

  • Every service should expose a way to get scripts to automate provisioning. Automation options should include CLI, PowerShell, .NET, Java, NodeJs, Python, Ruby, PHP, and REST, in that order. ARM-based services that use template deployment are opted in by default.

Best Practices for Menu blades

Services should use the Menu blade instead of the Settings blade. ARM resources should opt in to the resource menu for a simpler, streamlined menu.

Extensions should migrate to the ResourceMenu for all of their resources.

Best Practices for Resource List blades

Resource List blades are also known as Browse blades.

Browse blades should contain an "Add" command to help customers create new resources quickly. They should also contain Context menu commands in the "..." menu for each row. And, they should show all resource properties in the Column Chooser.

For more information, see the Asset documentation located at portalfx-assets.md.