169 lines
4.7 KiB
Plaintext
169 lines
4.7 KiB
Plaintext
import Component from "@glimmer/component";
|
|
import { tracked } from "@glimmer/tracking";
|
|
import { Input } from "@ember/component";
|
|
import { hash } from "@ember/helper";
|
|
import { on } from "@ember/modifier";
|
|
import { action } from "@ember/object";
|
|
import { htmlSafe } from "@ember/template";
|
|
import PluginOutlet from "discourse/components/plugin-outlet";
|
|
import concatClass from "discourse/helpers/concat-class";
|
|
import icon from "discourse-common/helpers/d-icon";
|
|
import i18n from "discourse-common/helpers/i18n";
|
|
import escape from "discourse-common/lib/escape";
|
|
import { iconHTML } from "discourse-common/lib/icon-library";
|
|
|
|
const MAX_COMPONENTS = 4;
|
|
|
|
export default class ThemesListItem extends Component {
|
|
@tracked childrenExpanded = false;
|
|
|
|
get displayHasMore() {
|
|
return this.args.theme?.get("childThemes.length") > MAX_COMPONENTS;
|
|
}
|
|
|
|
get displayComponents() {
|
|
return this.hasComponents && this.args.theme?.isActive;
|
|
}
|
|
|
|
get hasComponents() {
|
|
return this.children.length > 0;
|
|
}
|
|
|
|
@action
|
|
handleClick(event) {
|
|
if (!event.target.classList.contains("others-count")) {
|
|
this.args.navigateToTheme();
|
|
}
|
|
}
|
|
|
|
get children() {
|
|
let children = this.args.theme?.get("childThemes.[]");
|
|
if (this.args.theme?.get("component") || !children) {
|
|
return [];
|
|
}
|
|
children = this.childrenExpanded
|
|
? children
|
|
: children.slice(0, MAX_COMPONENTS);
|
|
return children.map((t) => {
|
|
const name = escape(t.name);
|
|
return t.enabled ? name : `${iconHTML("ban")} ${name}`;
|
|
});
|
|
}
|
|
|
|
get childrenString() {
|
|
return this.children.join(", ");
|
|
}
|
|
|
|
get moreCount() {
|
|
const childrenCount = this.args.theme?.get("childThemes.length");
|
|
if (
|
|
this.args.theme?.get("component") ||
|
|
!childrenCount ||
|
|
this.childrenExpanded
|
|
) {
|
|
return 0;
|
|
}
|
|
return childrenCount - MAX_COMPONENTS;
|
|
}
|
|
|
|
@action
|
|
toggleChildrenExpanded(event) {
|
|
event?.preventDefault();
|
|
this.childrenExpanded = !this.childrenExpanded;
|
|
}
|
|
|
|
<template>
|
|
{{! template-lint-disable no-nested-interactive }}
|
|
<div
|
|
class={{concatClass
|
|
"themes-list-container__item"
|
|
(if @theme.selected "selected")
|
|
}}
|
|
role="button"
|
|
{{on "click" this.handleClick}}
|
|
...attributes
|
|
>
|
|
<div class="inner-wrapper">
|
|
<span>
|
|
<PluginOutlet
|
|
@name="admin-customize-themes-list-item"
|
|
@connectorTagName="span"
|
|
@outletArgs={{hash theme=@theme}}
|
|
/>
|
|
</span>
|
|
|
|
<div class="info">
|
|
{{#if @selectInactiveMode}}
|
|
<Input
|
|
@checked={{@theme.markedToDelete}}
|
|
id={{@theme.id}}
|
|
@type="checkbox"
|
|
/>
|
|
{{/if}}
|
|
<span class="name">
|
|
{{@theme.name}}
|
|
</span>
|
|
|
|
<span class="icons">
|
|
{{#if @theme.selected}}
|
|
{{icon "caret-right"}}
|
|
{{else}}
|
|
{{#if @theme.default}}
|
|
{{icon
|
|
"check"
|
|
class="default-indicator"
|
|
title="admin.customize.theme.default_theme_tooltip"
|
|
}}
|
|
{{/if}}
|
|
{{#if @theme.isPendingUpdates}}
|
|
{{icon
|
|
"arrows-rotate"
|
|
title="admin.customize.theme.updates_available_tooltip"
|
|
class="light-grey-icon"
|
|
}}
|
|
{{/if}}
|
|
{{#if @theme.isBroken}}
|
|
{{icon
|
|
"circle-exclamation"
|
|
class="broken-indicator"
|
|
title="admin.customize.theme.broken_theme_tooltip"
|
|
}}
|
|
{{/if}}
|
|
{{#unless @theme.enabled}}
|
|
{{icon
|
|
"ban"
|
|
class="light-grey-icon"
|
|
title="admin.customize.theme.disabled_component_tooltip"
|
|
}}
|
|
{{/unless}}
|
|
{{/if}}
|
|
</span>
|
|
</div>
|
|
|
|
{{#if this.displayComponents}}
|
|
<div class="components-list">
|
|
<span class="components">{{htmlSafe this.childrenString}}</span>
|
|
|
|
{{#if this.displayHasMore}}
|
|
<a
|
|
href
|
|
{{on "click" this.toggleChildrenExpanded}}
|
|
class="others-count"
|
|
>
|
|
{{#if this.childrenExpanded}}
|
|
{{i18n "admin.customize.theme.collapse"}}
|
|
{{else}}
|
|
{{i18n
|
|
"admin.customize.theme.and_x_more"
|
|
count=this.moreCount
|
|
}}
|
|
{{/if}}
|
|
</a>
|
|
{{/if}}
|
|
</div>
|
|
{{/if}}
|
|
</div>
|
|
</div>
|
|
</template>
|
|
}
|