This repository has been archived on 2023-03-18. You can view files and clone it, but cannot push or open issues or pull requests.
osr-discourse-src/app/assets/javascripts/discourse/components/badge-selector.js.es6
Jarek Radosz fe588cc7f8
DEV: Fix function prototype deprecations (#8681)
* DEV: Fix the function prototype observers deprecation

DEPRECATION: Function prototype extensions have been deprecated, please migrate from function(){}.observes('foo') to observer('foo', function() {}). [deprecation id: function-prototype-extensions.observes] See https://deprecations.emberjs.com/v3.x/#toc_function-prototype-extensions-observes for more details.

* DEV: Fix the function prototype event listeners deprecation

DEPRECATION: Function prototype extensions have been deprecated, please migrate from function(){}.on('foo') to on('foo', function() {}). [deprecation id: function-prototype-extensions.on] See https://deprecations.emberjs.com/v3.x/#toc_function-prototype-extensions-on for more details.

* DEV: Simplify `default as` imports

Co-authored-by: Joffrey JAFFEUX <j.jaffeux@gmail.com>
2020-01-16 18:56:53 +01:00

54 lines
1.3 KiB
JavaScript

import Component from "@ember/component";
import discourseComputed, {
on,
observes
} from "discourse-common/utils/decorators";
import { findRawTemplate } from "discourse/lib/raw-templates";
const { makeArray } = Ember;
export default Component.extend({
@discourseComputed("placeholderKey")
placeholder(placeholderKey) {
return placeholderKey ? I18n.t(placeholderKey) : "";
},
@observes("badgeNames")
_update() {
if (this.canReceiveUpdates === "true") {
this._initializeAutocomplete({ updateData: true });
}
},
@on("didInsertElement")
_initializeAutocomplete(opts) {
let selectedBadges;
$(this.element.querySelector("input")).autocomplete({
allowAny: false,
items: makeArray(this.badgeNames),
single: this.single,
updateData: opts && opts.updateData ? opts.updateData : false,
template: findRawTemplate("badge-selector-autocomplete"),
onChangeItems(items) {
selectedBadges = items;
this.set("badgeNames", items.join(","));
},
transformComplete(g) {
return g.name;
},
dataSource(term) {
return this.badgeFinder(term).then(badges => {
if (!selectedBadges) return badges;
return badges.filter(
badge => !selectedBadges.any(s => s === badge.name)
);
});
}
});
}
});