Skip to content

Latest commit

 

History

History
197 lines (130 loc) · 10.7 KB

top-blades-advanced.md

File metadata and controls

197 lines (130 loc) · 10.7 KB

Advanced Topics

The following sections discuss advanced topics in template blade development.

NOTE: In this discussion, <dir> is the SamplesExtension\Extension\ directory, and <dirParent> is the SamplesExtension\ directory, based on where the samples were installed when the developer set up the SDK. If there is a working copy of the sample in the Dogfood environment, it is also included.


Deep linking

The portal lets the user link directly to a particular blade. As long as your blade does not have the @ReturnsData decorator then users can deep link to it. There are a few supported link formats.

Displaying notifications using the status bar

A status bar can be displayed at the top of a blade. The status bar supports text, and icon, and multiple severities (e.g. warning,info,error) and supports navigating to a blade or external site when clicked.

There is a sample for the status bar at https://df.onecloud.azure-test.net/?feature.samplesextension=true#blade/SamplesExtension/TemplateBladeWithStatusBar.

If you have the source code to the samples you can find the source code at this path: Client/V2/Blades/Template/TemplateBladeWithStatusBar.ts. It is also included in the following code.

import * as ClientResources from "ClientResources"; import { ClickableLink } from "Fx/Composition"; import * as TemplateBlade from "Fx/Composition/TemplateBlade"; import * as BladesArea from "../BladesArea"; import * as Dropdown from "Fx/Controls/DropDown";

@TemplateBlade.Decorator({ htmlTemplate: `

`, }) @TemplateBlade.InjectableModel.Decorator(BladesArea.DataContext) export class TemplateBladeWithStatusBar { public title = ClientResources.templateBladeWithStatusBar; public subtitle: string;
// Dropdown that manages the status of the blade and therefore the status bar
public statusBarState: Dropdown.Contract<TemplateBlade.ContentState>;

public context: TemplateBlade.Context<void, BladesArea.DataContext>;

public onInitialize() {
    const { container } = this.context;

    // Create the Status dropdown
    this.statusBarState = Dropdown.create<TemplateBlade.ContentState>(container, {
        label: "Select the type of the status bar",
        subLabel: "Note: 'None' means there is no Status and therefore no Status Bar",
        suppressDirtyBehavior: true,
        items: [
            { text: "None", value: TemplateBlade.ContentState.None },
            { text: "Warning", value: TemplateBlade.ContentState.Warning },
            { text: "Error", value: TemplateBlade.ContentState.Error },
            { text: "Dirty", value: TemplateBlade.ContentState.Dirty },
            { text: "Info", value: TemplateBlade.ContentState.Info },
            { text: "Upsell", value: TemplateBlade.ContentState.Upsell },
            { text: "Complete", value: TemplateBlade.ContentState.Complete },
        ],
        value: TemplateBlade.ContentState.None,
    });

    // Subscribe to the changes of statusBarState to dictate the Status Bar
    this.statusBarState.value.subscribe(container, statusBarState => {
        container.statusBar({
            text: ClientResources.templateBladeWithStatusBarMessage,
            state: statusBarState,
            onClick: new ClickableLink("http://www.bing.com"),
        });
    });
    return Q(); // This sample loads no data.
}

}

Making your blade pinnable to a dashboard

No-pdl blades can be made pinnable by making the following changes to your code.

  1. Add the @TemplateBlade.Pinnable.Decorator decorator to the Template Blade class, or @FrameBlade.Pinnable.Decorator, @Blade.Pinnable.Decorator for these less commonly used Blade variations.

  2. Implement an onPin' method.

  3. Return a PartReference instance to a Part you design. The Part should open the Blade when clicked.

These concepts are illustrated in the sample located at <dir>/Client/V2/Blades/Pinning/PinnableBlade.ts and in the working copy located at https://df.onecloud.azure-test.net/#blade/SamplesExtension/PinnableBlade/personId/111.

Exception cases that affect the entire blade

The user is not authorized to view the blade

You may determine that the current user does not have access to the current blade's content. In this case you can call container.unauthorized() and the user will be presented with a message that is consistent across all experiences in the portal.

For optimal performance, we recommend you avoid extra calls to determine access rights. When possible, simply try to make the calls needed to load the page and call the unauthorized() function if the call failed with an authorization error.

The service is not configured properly for the user to view the blade

You may have a scenario where the current user can't use the blade for some unexpected reason (e.g. they are not a part of a private preview or they have not done some prerequisite step). For scenarios like this you can call container.enableNotice() to render a generic notice with formatting that will be consistent across all experiences.

The underlying resource for this blade does not exist

A user may try to deep link to a blade for a resource that no longer exists. In this case you can call container.notFound() and provide a message. A generic not found UI will be presented to the user.

The data required to load the blade failed for some unknown reason (e.g. 500 internal server error)

If your blade cannot load because of an unexpected error then you should call the container.fail() API. The message you provide here will be logged, but not presented to the user. This is because you should only use this API for unexpected errors. If you are handling an expected error condition then you should either use the enableNotice() API or do some custom rendering if the scenario requires it.