77 lines
2.5 KiB
JavaScript
77 lines
2.5 KiB
JavaScript
|
import MultiSelectHeaderComponent from "select-kit/components/multi-select/multi-select-header";
|
||
|
import { computed } from "@ember/object";
|
||
|
import { gt } from "@ember/object/computed";
|
||
|
import { isTesting } from "discourse-common/config/environment";
|
||
|
import layout from "select-kit/templates/components/email-group-user-chooser-header";
|
||
|
|
||
|
export default MultiSelectHeaderComponent.extend({
|
||
|
layout,
|
||
|
classNames: ["email-group-user-chooser-header"],
|
||
|
hasHiddenItems: gt("hiddenItemsCount", 0),
|
||
|
|
||
|
shownItems: computed("hiddenItemsCount", function () {
|
||
|
if (
|
||
|
this.selectKit.noneItem === this.selectedContent ||
|
||
|
this.hiddenItemsCount === 0
|
||
|
) {
|
||
|
return this.selectedContent;
|
||
|
}
|
||
|
return this.selectedContent.slice(
|
||
|
0,
|
||
|
this.selectedContent.length - this.hiddenItemsCount
|
||
|
);
|
||
|
}),
|
||
|
|
||
|
hiddenItemsCount: computed(
|
||
|
"selectedContent.[]",
|
||
|
"selectKit.options.autoWrap",
|
||
|
"selectKit.isExpanded",
|
||
|
function () {
|
||
|
if (
|
||
|
!this.selectKit.options.autoWrap ||
|
||
|
this.selectKit.isExpanded ||
|
||
|
this.selectedContent === this.selectKit.noneItem ||
|
||
|
this.selectedContent.length <= 1 ||
|
||
|
isTesting()
|
||
|
) {
|
||
|
return 0;
|
||
|
} else {
|
||
|
const selectKitHeaderWidth = this.element.offsetWidth;
|
||
|
const choices = this.element.querySelectorAll(".selected-name.choice");
|
||
|
const input = this.element.querySelector(".filter-input");
|
||
|
const alreadyHidden = this.element.querySelector(".x-more-item");
|
||
|
if (alreadyHidden) {
|
||
|
const hiddenCount = parseInt(
|
||
|
alreadyHidden.getAttribute("data-hidden-count"),
|
||
|
10
|
||
|
);
|
||
|
return (
|
||
|
hiddenCount +
|
||
|
(this.selectedContent.length - (choices.length + hiddenCount))
|
||
|
);
|
||
|
}
|
||
|
if (choices.length === 0 && this.selectedContent.length > 0) {
|
||
|
return 0;
|
||
|
}
|
||
|
let total = choices[0].offsetWidth + input.offsetWidth;
|
||
|
let shownItemsCount = 1;
|
||
|
let shouldHide = false;
|
||
|
for (let i = 1; i < choices.length - 1; i++) {
|
||
|
const currentWidth = choices[i].offsetWidth;
|
||
|
const nextWidth = choices[i + 1].offsetWidth;
|
||
|
const ratio =
|
||
|
(total + currentWidth + nextWidth) / selectKitHeaderWidth;
|
||
|
if (ratio >= 0.95) {
|
||
|
shouldHide = true;
|
||
|
break;
|
||
|
} else {
|
||
|
shownItemsCount++;
|
||
|
total += currentWidth;
|
||
|
}
|
||
|
}
|
||
|
return shouldHide ? choices.length - shownItemsCount : 0;
|
||
|
}
|
||
|
}
|
||
|
),
|
||
|
});
|