The communications platform that puts data protection first.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Rocket.Chat/app/ui-utils/client/lib/TabBar.js

85 lines
1.7 KiB

import _ from 'underscore';
import { ReactiveVar } from 'meteor/reactive-var';
export const TabBar = new class TabBar {
get size() {
return this._size.get();
}
set size(s) {
this._size.set(s);
}
constructor() {
this.buttons = new ReactiveVar({});
this._size = new ReactiveVar(4);
this.extraGroups = {};
}
show() {
$('.flex-tab-bar').show();
}
hide() {
$('.flex-tab-bar').hide();
}
addButton(config) {
if (!config || !config.id) {
return false;
}
const btns = this.buttons.curValue;
btns[config.id] = config;
if (this.extraGroups[config.id]) {
btns[config.id].groups = _.union(btns[config.id].groups || [], this.extraGroups[config.id]);
}
this.buttons.set(btns);
}
removeButton(id) {
const btns = this.buttons.curValue;
delete btns[id];
this.buttons.set(btns);
}
updateButton(id, config) {
const btns = this.buttons.curValue;
if (btns[id]) {
btns[id] = _.extend(btns[id], config);
this.buttons.set(btns);
}
}
getButtons() {
const buttons = _.toArray(this.buttons.get()).filter((button) => !button.condition || button.condition());
return _.sortBy(buttons, 'order');
}
getButton(id) {
return _.findWhere(this.buttons.get(), { id });
}
addGroup(id, groups) {
const btns = this.buttons.curValue;
if (btns[id]) {
btns[id].groups = _.union(btns[id].groups || [], groups);
this.buttons.set(btns);
} else {
this.extraGroups[id] = _.union(this.extraGroups[id] || [], groups);
}
}
removeGroup(id, groups) {
const btns = this.buttons.curValue;
if (btns[id]) {
btns[id].groups = _.difference(btns[id].groups || [], groups);
this.buttons.set(btns);
} else {
this.extraGroups[id] = _.difference(this.extraGroups[id] || [], groups);
}
}
}();