Charlie Tran 843a6c5bbb
feat(frontend): update datahub-web client UI code (#1806)
* Releases updated version of datahub-web client UI code

* Fix typo in yarn lock

* Change yarn lock to match yarn registry directories

* Previous commit missed some paths

* Even more changes to yarnlock missing in previous commit

* Include codegen file for typings

* Add files to get parity for datahub-web and current OS datahub-midtier

* Add in typo fix from previous commit - change to proper license

* Implement proper OS fix for person entity picture url

* Workarounds for open source DH issues

* Fixes institutional memory api and removes unopensourced tabs for datasets

* Fixes search dataset deprecation and user search issue as a result of changes

* Remove internal only options in the avatar menu
2020-08-26 15:44:50 -07:00

56 lines
1.3 KiB
TypeScript

import Component from '@ember/component';
import { IAvatar } from 'datahub-web/typings/app/avatars';
import { set } from '@ember/object';
import { action, computed } from '@ember/object';
import { singularize, pluralize } from 'ember-inflector';
import { tagName, classNames } from '@ember-decorators/component';
@tagName('span')
@classNames('avatar-rollup')
export default class RollupAvatars extends Component {
/**
* References the full list of avatars
* @type {Array<IAvatar>}
*/
avatars: Array<IAvatar> = [];
/**
* Flag indicating if the avatars detail view should be rendered
* @type {boolean}
*/
isShowingAvatars = false;
/**
* The type of avatars being shown
* @type {string}
*/
avatarType = 'entity';
/**
* Returns the text to be shown in the avatar detail page header
* @type {string}
*/
@computed('avatars.length')
get header(): string {
const count = this.avatars.length;
const suffix = this.avatarType;
return `${count} ${count > 1 ? pluralize(suffix) : singularize(suffix)}`;
}
/**
* Handles the component click event
*/
click(): void {
set(this, 'isShowingAvatars', true);
}
/**
* Updates the flag indicating if the view should be rendered
*/
@action
dismissAvatars(): void {
set(this, 'isShowingAvatars', false);
}
}