2023-11-20 06:59:04 +08:00
|
|
|
import Component from "@glimmer/component";
|
|
|
|
import { tracked } from "@glimmer/tracking";
|
|
|
|
import didInsert from "@ember/render-modifiers/modifiers/did-insert";
|
2024-07-29 12:20:12 +08:00
|
|
|
import { service } from "@ember/service";
|
2023-11-20 06:59:04 +08:00
|
|
|
import { htmlSafe } from "@ember/template";
|
|
|
|
import { ajax } from "discourse/lib/ajax";
|
|
|
|
import { bind } from "discourse-common/utils/decorators";
|
2024-11-20 04:45:18 +08:00
|
|
|
import { i18n } from "discourse-i18n";
|
2024-07-29 12:20:12 +08:00
|
|
|
import AdminConfigAreaCard from "admin/components/admin-config-area-card";
|
2023-11-20 06:59:04 +08:00
|
|
|
import DashboardNewFeatureItem from "admin/components/dashboard-new-feature-item";
|
|
|
|
|
|
|
|
export default class DashboardNewFeatures extends Component {
|
2024-07-29 12:20:12 +08:00
|
|
|
@service currentUser;
|
|
|
|
|
2023-11-20 06:59:04 +08:00
|
|
|
@tracked newFeatures = null;
|
2024-07-29 12:20:12 +08:00
|
|
|
@tracked groupedNewFeatures = null;
|
2023-11-20 06:59:04 +08:00
|
|
|
@tracked isLoaded = false;
|
|
|
|
|
|
|
|
@bind
|
|
|
|
loadNewFeatures() {
|
2024-08-16 07:12:24 +08:00
|
|
|
ajax("/admin/whats-new.json")
|
2023-11-20 06:59:04 +08:00
|
|
|
.then((json) => {
|
2024-07-29 12:20:12 +08:00
|
|
|
const items = json.new_features.reduce((acc, feature) => {
|
|
|
|
const key = moment(feature.released_at || feature.created_at).format(
|
|
|
|
"YYYY-MM"
|
|
|
|
);
|
|
|
|
acc[key] = acc[key] || [];
|
|
|
|
acc[key].push(feature);
|
|
|
|
return acc;
|
|
|
|
}, {});
|
|
|
|
|
|
|
|
this.groupedNewFeatures = Object.keys(items).map((date) => {
|
|
|
|
return {
|
|
|
|
date: moment
|
|
|
|
.tz(date, this.currentUser.user_option.timezone)
|
|
|
|
.format("MMMM YYYY"),
|
|
|
|
features: items[date],
|
|
|
|
};
|
|
|
|
});
|
2023-11-20 06:59:04 +08:00
|
|
|
this.isLoaded = true;
|
|
|
|
})
|
|
|
|
.finally(() => {
|
|
|
|
this.isLoaded = true;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
<template>
|
2024-10-10 09:40:05 +08:00
|
|
|
<div
|
|
|
|
class="admin-config-area__primary-content"
|
|
|
|
{{didInsert this.loadNewFeatures}}
|
|
|
|
>
|
2024-07-29 12:20:12 +08:00
|
|
|
{{#if this.groupedNewFeatures}}
|
|
|
|
{{#each this.groupedNewFeatures as |groupedFeatures|}}
|
|
|
|
<AdminConfigAreaCard @translatedHeading={{groupedFeatures.date}}>
|
2024-10-15 23:54:38 +08:00
|
|
|
<:content>
|
|
|
|
{{#each groupedFeatures.features as |feature|}}
|
|
|
|
<DashboardNewFeatureItem @item={{feature}} />
|
|
|
|
{{/each}}
|
|
|
|
</:content>
|
2024-07-29 12:20:12 +08:00
|
|
|
</AdminConfigAreaCard>
|
2023-11-20 06:59:04 +08:00
|
|
|
{{/each}}
|
|
|
|
{{else if this.isLoaded}}
|
|
|
|
{{htmlSafe
|
|
|
|
(i18n
|
|
|
|
"admin.dashboard.new_features.previous_announcements"
|
|
|
|
url="https://meta.discourse.org/tags/c/announcements/67/release-notes"
|
|
|
|
)
|
|
|
|
}}
|
|
|
|
{{/if}}
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
}
|