1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-07-19 21:29:42 +02:00
documize/gui/app/components/ui/ui-toolbar-icon.js

61 lines
1.5 KiB
JavaScript
Raw Normal View History

2022-01-10 17:14:08 -05:00
/* eslint-disable ember/no-classic-classes */
/* eslint-disable ember/require-tagless-components */
// Copyright 2016 Documize Inc. <legal@documize.com>. All rights reserved.
//
// This software (Documize Community Edition) is licensed under
// GNU AGPL v3 http://www.gnu.org/licenses/agpl-3.0.en.html
//
// You can operate outside the AGPL restrictions by purchasing
// Documize Enterprise Edition and obtaining a commercial license
// by contacting <sales@documize.com>.
//
// https://documize.com
import { inject as service } from '@ember/service';
import { computed } from '@ember/object';
import Component from '@ember/component';
export default Component.extend({
router: service(),
tagName: 'i',
classNames: ['dicon'],
classNameBindings: ['calcClass'],
color: '',
icon: '',
tooltip: '',
selected: false,
2022-01-10 17:14:08 -05:00
attributeBindings: ['title'],
2022-01-11 12:40:52 -05:00
tabindex: 0,
ariaRole: "button",
2022-01-10 17:14:08 -05:00
title: computed('tooltip', function() {
return this.tooltip;
}),
calcClass: computed('selected', function() {
let c = '';
let icon = this.icon;
if (this.color !== '') c += this.color + ' ';
if (this.selected === true) c += 'icon-selected' + ' ';
if (icon !== '') c += icon + ' ';
return c.trim();
}),
click(e) {
if (!_.isUndefined(this.onClick)) {
this.onClick(e);
this.notifyPropertyChange('calcClass');
return;
}
if (!_.isUndefined(this.linkTo)) {
2018-12-14 15:47:41 +00:00
// TODO: pass in linkModel, linkOptions
// https://emberjs.com/api/ember/3.5/classes/RouterService/methods/transitionTo?anchor=transitionTo
this.router.transitionTo(this.get('linkTo'));
}
}
});