DEV: Document showModal, allow setting more config via DModalBody

Having these things configured at the invocation of showModal is a strange API, and means that any changes to the modal require updating the call sites. It makes much more sense for these to be defined as part of the modal's own template. This was already supported for many of the properties. This commit adds support for the `modalClass` and `titleAriaElementId` config to be passed to DModalBody.

For now there is no deprecation message. Support for passing these things to `showModal` will be dropped as part of an upcoming conversion of modals from controllers to components.
This commit is contained in:
David Taylor 2023-05-15 11:15:07 +01:00
parent f2482b5daa
commit 35f29bd25b
3 changed files with 22 additions and 2 deletions

View File

@ -41,6 +41,8 @@ export default class DModalBody extends Component {
"submitOnEnter", "submitOnEnter",
"dismissable", "dismissable",
"headerClass", "headerClass",
"modalClass",
"titleAriaElementId",
]) ])
); );
} }

View File

@ -93,7 +93,9 @@ export default class DModal extends Component {
} }
get ariaLabelledby() { get ariaLabelledby() {
if (this.args.titleAriaElementId) { if (this.modalBodyData.titleAriaElementId) {
return this.modalBodyData.titleAriaElementId;
} else if (this.args.titleAriaElementId) {
return this.args.titleAriaElementId; return this.args.titleAriaElementId;
} else if (this.args.title) { } else if (this.args.title) {
return "discourse-modal-title"; return "discourse-modal-title";

View File

@ -2,7 +2,23 @@ import I18n from "I18n";
import { dasherize } from "@ember/string"; import { dasherize } from "@ember/string";
import { getOwner } from "discourse-common/lib/get-owner"; import { getOwner } from "discourse-common/lib/get-owner";
export default function (name, opts) { /**
* Render a modal
*
* @param {string} name - the controller/template name for the modal body.
*
* @param {Object} [options] - options
* @param {string} [options.model] - An object which will be set as the `model` property on the controller
* @param {boolean} [options.admin] - look under the admin namespace for the controller/template
* @param {string} [options.templateName] - override the template name to render
* @param {string} [options.title] - (deprecated) translation key for modal title. Pass `@title` to DModalBody instead
* @param {string} [options.titleTranslated] - (deprecated) translated modal title. Pass `@rawTitle` to DModalBody instead
* @param {string} [options.modalClass] - (deprecated) classname for modal. Pass `@modalClass` to DModalBody instead
* @param {string} [options.titleAriaElementId] - (deprecated) Pass `@titleAriaElementId` to DModalBody instead
*
* @returns {Controller} The modal controller instance
*/
export default function showModal(name, opts) {
opts = opts || {}; opts = opts || {};
let container = getOwner(this); let container = getOwner(this);