Ghost/ghost/admin/app/components/gh-psm-visibility-input.js
Gabriel Csapo 8d01fb5556 Switched majority of files from EmberObject to native class syntax using @classic decorator (#2227)
no issue

- ran [ember-native-class-codemod](https://github.com/ember-codemods/ember-native-class-codemod) to convert the majority of remaining EmberObject based controllers and components to native class syntax using the `@classic` decorator
- skipped older style modal components (`components/modal-*.js`) due to observed incompatibilities in some cases
2022-02-01 09:34:03 +00:00

46 lines
1.1 KiB
JavaScript

import Component from '@ember/component';
import classic from 'ember-classic-decorator';
import {action, computed} from '@ember/object';
import {inject as service} from '@ember/service';
const VISIBILITIES = [
{label: 'Public', name: 'public'},
{label: 'Members only', name: 'members'},
{label: 'Paid-members only', name: 'paid'}
];
@classic
export default class GhPsmVisibilityInput extends Component {
@service
settings;
@service
feature;
// public attrs
post = null;
@computed('post.visibility')
get selectedVisibility() {
return this.get('post.visibility') || this.settings.get('defaultContentVisibility');
}
init() {
super.init(...arguments);
this.availableVisibilities = [...VISIBILITIES];
if (this.feature.get('multipleProducts')) {
this.availableVisibilities.push(
{label: 'Specific tier(s)', name: 'tiers'}
);
}
}
@action
updateVisibility(newVisibility) {
this.post.set('visibility', newVisibility);
if (newVisibility !== 'tiers') {
this.post.set('tiers', []);
}
}
}