UNPKG

@openui5/sap.m

Version:

OpenUI5 UI Library sap.m

293 lines (253 loc) 9.19 kB
/*! * UI development toolkit for HTML5 (OpenUI5) * (c) Copyright 2009-2022 SAP SE or an SAP affiliate company. * Licensed under the Apache License, Version 2.0 - see LICENSE.txt. */ sap.ui.define([ "./library", "sap/ui/core/Control", "./WizardStepRenderer", "./Button", "./TitlePropagationSupport", "sap/base/Log" ], function(library, Control, WizardStepRenderer, Button, TitlePropagationSupport, Log) { "use strict"; /** * Constructor for a new WizardStep. * * @param {string} [sId] ID for the new control, generated automatically if no ID is given * @param {object} [mSettings] Initial settings for the new control * * @class * A container control used to aggregate user input controls as part of an sap.m.Wizard. * <h3>Overview</h3> * WizardStep gives the developer the ability to validate, invalidate the step and define subsequent steps. * The WizardStep control control is supposed to be used only as an aggregation of the {@link sap.m.Wizard Wizard} control, * and should not be used as a standalone one. * <h3>Structure</h3> * <ul> * <li>Each wizard step has a title. Additionally it can have an icon.</li> * <li>Each wizard step can be validated by setting the <code>validated</code> property. This action will trigger the rendering of the Next step button.</li> * <li>If the execution needs to branch after a given step, you should set all possible next steps in the <code>subsequentSteps</code> aggregation. * @extends sap.ui.core.Control * @author SAP SE * @version 1.60.39 * * @constructor * @public * @since 1.30 * @alias sap.m.WizardStep * @ui5-metamodel This control/element also will be described in the UI5 (legacy) designtime metamodel */ var WizardStep = Control.extend("sap.m.WizardStep", /** @lends sap.m.WizardStep.prototype */ { metadata: { properties: { /** * Determines the title of the step. * The title is visualized in the Wizard control. */ title: {type: "string", group: "appearance", defaultValue: ""}, /** * Determines the icon that is displayed for this step. * The icon is visualized in the progress navigation part of the Wizard control. * <b>Note:</b> In order for the icon to be displayed, each step in the Wizard should have * this property defined, otherwise the default numbering will be displayed. */ icon: {type: "sap.ui.core.URI", group: "Appearance", defaultValue: ""}, /** * Indicates whether or not the step is validated. * When a step is validated a Next button is visualized in the Wizard control. * @since 1.32 */ validated: {type: "boolean", group: "Behavior", defaultValue: true}, /** * Indicates whether or not the step is optional. * When a step is optional an "(Optional)" label is displayed under the step's title. * @since 1.54 */ optional: {type: "boolean", group: "Appearance", defaultValue: false} }, events: { /** * This event is fired after the user presses the Next button in the Wizard, * or on <code>nextStep</code> method call from the app developer. */ complete: { parameters: {} }, /** * This event is fired on next step activation from the Wizard. */ activate: { parameters: {} } }, defaultAggregation: "content", aggregations: { /** * The content of the Wizard Step. */ content: {type: "sap.ui.core.Control", multiple: true, singularName: "content"}, /** * The next button of the Wizard Step. * @since 1.58 */ _nextButton: { type: "sap.m.Button", multiple: false, visibility: "hidden"} }, associations: { /** * This association is used only when the <code>enableBranching</code> property of the Wizard is set to true. * Use the association to store the next steps that are about to come after the current. * If this is going to be a final step - leave this association empty. * @since 1.32 */ subsequentSteps : {type : "sap.m.WizardStep", multiple : true, singularName : "subsequentStep"}, /** * The next step to be taken after the step is completed. * Set this association value in the complete event of the current WizardStep. * @since 1.32 */ nextStep : {type: "sap.m.WizardStep", multiple: false} } } }); // Add title propagation support TitlePropagationSupport.call(WizardStep.prototype, "content", function () {return this.getId() + "-title";}); WizardStep.prototype.init = function () { this._resourceBundle = sap.ui.getCore().getLibraryResourceBundle("sap.m"); this._fnNextButtonPress; this._oNextButton = new Button(this.getId() + "-nextButton", { text: this._resourceBundle.getText("WIZARD_STEP") + 2, type: "Emphasized", enabled: this.getValidated() }).addStyleClass("sapMWizardNextButton"); this._oNextButton.addEventDelegate({ onAfterRendering: function () { setTimeout(function () { var oButton = this._oNextButton, oButtonDomRef = oButton.getDomRef(); if (oButton.getEnabled()) { oButton.addStyleClass("sapMWizardNextButtonVisible"); oButtonDomRef && oButtonDomRef.removeAttribute("aria-hidden"); } else { oButton.removeStyleClass("sapMWizardNextButtonVisible"); // aria-hidden attribute is used instead of setVisible(false) // in order to preserve the current animation implementation oButtonDomRef && oButtonDomRef.setAttribute("aria-hidden", true); } }.bind(this), 0); } }, this); this.setAggregation("_nextButton", this._oNextButton); this._initTitlePropagationSupport(); }; WizardStep.prototype.setValidated = function (validated) { this.setProperty("validated", validated, true); var parent = this._getWizardParent(); if (parent === null) { return this; } if (validated) { parent.validateStep(this); } else { parent.invalidateStep(this); } return this; }; WizardStep.prototype.setNextStep = function (value) { this.setAssociation("nextStep", value, true); var parent = this._getWizardParent(); if (parent !== null) { parent._checkCircularReference(this._getNextStepReference()); parent._updateProgressNavigator(); } return this; }; /** * setVisible shouldn't be used on wizard steps. * If you need to show/hide steps based on some condition - use the branching property instead * @param {boolean} visible Whether the step should be visible * @returns {sap.m.WizardStep} this instance for method chaining */ WizardStep.prototype.setVisible = function (visible) { this.setProperty("visible", visible, true); Log.warning("Don't use the set visible method for wizard steps. If you need to show/hide steps based on some condition - use the branching property of the Wizard instead."); return this; }; WizardStep.prototype._isLeaf = function () { if ( this.getNextStep() === null && this.getSubsequentSteps().length === 0 ) { return true; } return false; }; WizardStep.prototype._isBranched = function () { return this.getSubsequentSteps().length > 1; }; WizardStep.prototype._getNextStepReference = function () { if (this.getNextStep() !== null) { return sap.ui.getCore().byId(this.getNextStep()); } if (this.getSubsequentSteps().length === 1) { return sap.ui.getCore().byId(this.getSubsequentSteps()[0]); } return null; }; WizardStep.prototype._containsSubsequentStep = function (stepId) { return this.getSubsequentSteps().some(function (step) { return step === stepId; }); }; WizardStep.prototype._getWizardParent = function () { var parent = this.getParent(); while (!(parent instanceof sap.m.Wizard)) { if (parent === null) { return null; } parent = parent.getParent(); } return parent; }; WizardStep.prototype._markAsLast = function () { this.addStyleClass("sapMWizardLastActivatedStep"); }; WizardStep.prototype._unMarkAsLast = function () { this.removeStyleClass("sapMWizardLastActivatedStep"); }; /** * Attaches the press handler for the next button press * @param {function} fnPress The press handler to be executed on next button press * @sap-restricted sap.m.Wizard * @private */ WizardStep.prototype._attachNextButtonHandler = function (fnPress) { this._fnNextButtonPress = fnPress; this._oNextButton.attachPress(fnPress); }; /** * Detaches the press handler for the next button press * @sap-restricted sap.m.Wizard * @private */ WizardStep.prototype._detachNextButtonHandler = function () { this._oNextButton.detachPress(this._fnNextButtonPress); }; WizardStep.prototype._activate = function () { var parent = this._getWizardParent(); if (this.hasStyleClass("sapMWizardStepActivated")) { return; } if (parent) { this._oNextButton.setVisible(parent.getShowNextButton()); } this._markAsLast(); this.addStyleClass("sapMWizardStepActivated"); this.fireActivate(); }; WizardStep.prototype._deactivate = function () { this.removeStyleClass("sapMWizardStepActivated"); }; WizardStep.prototype._complete = function () { this._unMarkAsLast(); this.fireComplete(); }; return WizardStep; });