Allow theming room header buttons

This commit is contained in:
J. Ryan Stinnett 2019-02-12 16:42:11 +00:00
parent c00495304f
commit 8652a094f3
5 changed files with 48 additions and 20 deletions

View file

@ -58,7 +58,6 @@ limitations under the License.
.mx_RoomHeader_buttons { .mx_RoomHeader_buttons {
display: flex; display: flex;
align-items: center;
background-color: $primary-bg-color; background-color: $primary-bg-color;
padding-right: 5px; padding-right: 5px;
} }
@ -116,10 +115,6 @@ limitations under the License.
opacity: 0.6; opacity: 0.6;
} }
.mx_RoomHeader_settingsButton object {
pointer-events: none;
}
.mx_RoomHeader_name, .mx_RoomHeader_name,
.mx_RoomHeader_avatar, .mx_RoomHeader_avatar,
.mx_RoomHeader_avatarPicker, .mx_RoomHeader_avatarPicker,
@ -199,10 +194,32 @@ limitations under the License.
.mx_RoomHeader_button { .mx_RoomHeader_button {
margin-left: 10px; margin-left: 10px;
cursor: pointer; cursor: pointer;
height: 20px;
width: 20px;
background-color: $roomheader-button-color;
mask-repeat: no-repeat;
mask-size: contain;
} }
.mx_RoomHeader_button object { .mx_RoomHeader_settingsButton {
pointer-events: none; mask-image: url('$(res)/img/feather-icons/settings.svg');
}
.mx_RoomHeader_forgetButton {
mask-image: url('$(res)/img/leave.svg');
width: 26px;
}
.mx_RoomHeader_searchButton {
mask-image: url('$(res)/img/feather-icons/search.svg');
}
.mx_RoomHeader_shareButton {
mask-image: url('$(res)/img/feather-icons/share.svg');
}
.mx_RoomHeader_manageIntegsButton {
mask-image: url('$(res)/img/feather-icons/grid.svg');
} }
.mx_RoomHeader_showPanel { .mx_RoomHeader_showPanel {
@ -219,6 +236,7 @@ limitations under the License.
.mx_RoomHeader_pinnedButton { .mx_RoomHeader_pinnedButton {
position: relative; position: relative;
mask-image: url('$(res)/img/icons-pin.svg');
} }
.mx_RoomHeader_pinsIndicator { .mx_RoomHeader_pinsIndicator {

View file

@ -76,6 +76,7 @@ $topleftmenu-color: $text-primary-color;
$roomheader-color: $text-primary-color; $roomheader-color: $text-primary-color;
$roomheader-addroom-color: $header-panel-text-primary-color; $roomheader-addroom-color: $header-panel-text-primary-color;
$tagpanel-button-color: $header-panel-text-primary-color; $tagpanel-button-color: $header-panel-text-primary-color;
$roomheader-button-color: $header-panel-text-primary-color;
$roomtopic-color: $text-secondary-color; $roomtopic-color: $text-secondary-color;
$eventtile-meta-color: $roomtopic-color; $eventtile-meta-color: $roomtopic-color;

View file

@ -146,6 +146,7 @@ $topleftmenu-color: #212121;
$roomheader-color: #45474a; $roomheader-color: #45474a;
$roomheader-addroom-color: #91A1C0; $roomheader-addroom-color: #91A1C0;
$tagpanel-button-color: #91A1C0; $tagpanel-button-color: #91A1C0;
$roomheader-button-color: #91A1C0;
$roomtopic-color: #9fa9ba; $roomtopic-color: #9fa9ba;
$eventtile-meta-color: $roomtopic-color; $eventtile-meta-color: $roomtopic-color;

View file

@ -24,7 +24,6 @@ import ScalarMessaging from '../../../ScalarMessaging';
import Modal from "../../../Modal"; import Modal from "../../../Modal";
import { _t } from '../../../languageHandler'; import { _t } from '../../../languageHandler';
import AccessibleButton from './AccessibleButton'; import AccessibleButton from './AccessibleButton';
import TintableSvg from './TintableSvg';
export default class ManageIntegsButton extends React.Component { export default class ManageIntegsButton extends React.Component {
constructor(props) { constructor(props) {
@ -76,6 +75,7 @@ export default class ManageIntegsButton extends React.Component {
if (this.scalarClient !== null) { if (this.scalarClient !== null) {
const integrationsButtonClasses = classNames({ const integrationsButtonClasses = classNames({
mx_RoomHeader_button: true, mx_RoomHeader_button: true,
mx_RoomHeader_manageIntegsButton: true,
mx_ManageIntegsButton_error: !!this.state.scalarError, mx_ManageIntegsButton_error: !!this.state.scalarError,
}); });
@ -94,8 +94,10 @@ export default class ManageIntegsButton extends React.Component {
} }
integrationsButton = ( integrationsButton = (
<AccessibleButton className={integrationsButtonClasses} onClick={this.onManageIntegrations} title={_t('Manage Integrations')}> <AccessibleButton className={integrationsButtonClasses}
<TintableSvg src={require("../../../../res/img/feather-icons/grid.svg")} width="20" height="20" /> onClick={this.onManageIntegrations}
title={_t('Manage Integrations')}
>
{ integrationsWarningTriangle } { integrationsWarningTriangle }
{ integrationsErrorPopup } { integrationsErrorPopup }
</AccessibleButton> </AccessibleButton>

View file

@ -154,7 +154,6 @@ module.exports = React.createClass({
render: function() { render: function() {
const RoomAvatar = sdk.getComponent("avatars.RoomAvatar"); const RoomAvatar = sdk.getComponent("avatars.RoomAvatar");
const TintableSvg = sdk.getComponent("elements.TintableSvg");
const EmojiText = sdk.getComponent('elements.EmojiText'); const EmojiText = sdk.getComponent('elements.EmojiText');
let searchStatus = null; let searchStatus = null;
@ -228,8 +227,10 @@ module.exports = React.createClass({
if (this.props.onSettingsClick) { if (this.props.onSettingsClick) {
settingsButton = settingsButton =
<AccessibleButton className="mx_RoomHeader_button" onClick={this.props.onSettingsClick} title={_t("Settings")}> <AccessibleButton className="mx_RoomHeader_button mx_RoomHeader_settingsButton"
<TintableSvg src={require("../../../../res/img/feather-icons/settings.svg")} width="20" height="20" /> onClick={this.props.onSettingsClick}
title={_t("Settings")}
>
</AccessibleButton>; </AccessibleButton>;
} }
@ -245,7 +246,6 @@ module.exports = React.createClass({
<AccessibleButton className="mx_RoomHeader_button mx_RoomHeader_pinnedButton" <AccessibleButton className="mx_RoomHeader_button mx_RoomHeader_pinnedButton"
onClick={this.props.onPinnedClick} title={_t("Pinned Messages")}> onClick={this.props.onPinnedClick} title={_t("Pinned Messages")}>
{ pinsIndicator } { pinsIndicator }
<TintableSvg src={require("../../../../res/img/icons-pin.svg")} width="16" height="16" />
</AccessibleButton>; </AccessibleButton>;
} }
@ -260,24 +260,30 @@ module.exports = React.createClass({
let forgetButton; let forgetButton;
if (this.props.onForgetClick) { if (this.props.onForgetClick) {
forgetButton = forgetButton =
<AccessibleButton className="mx_RoomHeader_button" onClick={this.props.onForgetClick} title={_t("Forget room")}> <AccessibleButton className="mx_RoomHeader_button mx_RoomHeader_forgetButton"
<TintableSvg src={require("../../../../res/img/leave.svg")} width="26" height="20" /> onClick={this.props.onForgetClick}
title={_t("Forget room")}
>
</AccessibleButton>; </AccessibleButton>;
} }
let searchButton; let searchButton;
if (this.props.onSearchClick && this.props.inRoom) { if (this.props.onSearchClick && this.props.inRoom) {
searchButton = searchButton =
<AccessibleButton className="mx_RoomHeader_button" onClick={this.props.onSearchClick} title={_t("Search")}> <AccessibleButton className="mx_RoomHeader_button mx_RoomHeader_searchButton"
<TintableSvg src={require("../../../../res/img/feather-icons/search.svg")} width="20" height="20" /> onClick={this.props.onSearchClick}
title={_t("Search")}
>
</AccessibleButton>; </AccessibleButton>;
} }
let shareRoomButton; let shareRoomButton;
if (this.props.inRoom) { if (this.props.inRoom) {
shareRoomButton = shareRoomButton =
<AccessibleButton className="mx_RoomHeader_button" onClick={this.onShareRoomClick} title={_t('Share room')}> <AccessibleButton className="mx_RoomHeader_button mx_RoomHeader_shareButton"
<TintableSvg src={require("../../../../res/img/feather-icons/share.svg")} width="20" height="20" /> onClick={this.onShareRoomClick}
title={_t('Share room')}
>
</AccessibleButton>; </AccessibleButton>;
} }