MDL-83872 core: creating button and text_align properties

This issue creates a couple of enum to style buttons and text
alignments. Enums can be used by output classes to limit the
types of values accepted by using strict types.
This commit is contained in:
ferran 2025-01-16 15:30:59 +01:00
parent 139a0ad5f0
commit 802920fd4c
2 changed files with 96 additions and 0 deletions

View file

@ -0,0 +1,51 @@
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
namespace core\output\local\properties;
/**
* Button style property enum.
*
* @package core
* @copyright 2024 Ferran Recio <ferran@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
enum button: string {
case PRIMARY = 'btn-primary';
case SECONDARY = 'btn-secondary';
case SUCCESS = 'btn-success';
case DANGER = 'btn-danger';
case PRIMARY_OUTLINE = 'btn-outline-primary';
case SECONDARY_OUTLINE = 'btn-outline-secondary';
/**
* Returns the CSS classes for the property based on its type.
*
* @return string The CSS classes.
*/
public function classes(): string {
return match ($this) {
self::PRIMARY => ' btn btn-primary',
self::SECONDARY => ' btn btn-secondary',
self::SUCCESS => ' btn btn-success',
self::DANGER => ' btn btn-danger',
self::PRIMARY_OUTLINE => ' btn btn-outline-primary',
self::SECONDARY_OUTLINE => ' btn btn-outline-secondary',
};
}
}

View file

@ -0,0 +1,45 @@
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
namespace core\output\local\properties;
/**
* Text align property enum.
*
* @package core
* @copyright 2024 Ferran Recio <ferran@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
enum text_align: string {
case START = 'start';
case END = 'end';
case CENTER = 'center';
case JUSTIIFY = 'justify';
/**
* Returns the CSS classes for the property based on its type.
*
* @return string The CSS classes.
*/
public function classes(): string {
return match ($this) {
self::START => ' text-start',
self::END => ' text-end',
self::CENTER => ' text-center',
self::JUSTIIFY => ' text-justify',
};
}
}