Ghost-Admin/app/components/gh-contentfilter.js

36 lines
1.3 KiB
JavaScript

import Component from '@glimmer/component';
import {get} from '@ember/object';
import {inject as service} from '@ember/service';
export default class GhContentfilterComponent extends Component {
@service customViews;
@service feature;
@service router;
get showCustomViewManagement() {
let isAdmin = get(this.args.currentUser || {}, 'isAdmin');
let onPostsScreen = this.router.currentRouteName === 'posts';
let isDefaultView = this.customViews?.activeView?.isDefault;
let hasFilter = this.args.selectedType.value
|| this.args.selectedVisibility.value
|| this.args.selectedAuthor.slug
|| this.args.selectedTag.slug
|| this.args.selectedOrder.value;
return isAdmin && onPostsScreen && !isDefaultView && hasFilter;
}
calculateActionsDropdownPosition(trigger, content) {
let {top, left, width, height} = trigger.getBoundingClientRect();
// content.firstElementChild is required because we use .dropdown-menu which is absolute positioned
let {width: contentWidth} = content.firstElementChild.getBoundingClientRect();
let style = {
left: left + width - contentWidth,
top: top + height + 5
};
return {style};
}
}