Simone c734c14d5f
feat(main-nav): Main nav refactoring, change links order (#20275)
* feat(main-nav): change links order in main nav

* feat(main-nav): add the position property to order links in the main nav

* feat(main-nav): refactor the sorting of the nav links

* feat(main-nav): add useCollator and format message to sort by name the links
2024-05-13 08:58:09 +02:00

69 lines
1.8 KiB
JavaScript

import { Images } from '@strapi/icons';
import pluginPkg from '../../package.json';
import { MediaLibraryDialog } from './components/MediaLibraryDialog';
import { MediaLibraryInput } from './components/MediaLibraryInput';
import { PERMISSIONS } from './constants';
import pluginId from './pluginId';
import getTrad from './utils/getTrad';
import { prefixPluginTranslations } from './utils/prefixPluginTranslations';
const name = pluginPkg.strapi.name;
export default {
register(app) {
app.addMenuLink({
to: `plugins/${pluginId}`,
icon: Images,
intlLabel: {
id: `${pluginId}.plugin.name`,
defaultMessage: 'Media Library',
},
permissions: PERMISSIONS.main,
Component: () => import('./pages/App'),
position: 4,
});
app.addSettingsLink('global', {
id: 'media-library-settings',
intlLabel: {
id: getTrad('plugin.name'),
defaultMessage: 'Media Library',
},
to: 'media-library',
Component: () => import('./pages/SettingsPage'),
permissions: PERMISSIONS.settings,
});
app.addFields({ type: 'media', Component: MediaLibraryInput });
app.addComponents([{ name: 'media-library', Component: MediaLibraryDialog }]);
app.registerPlugin({
id: pluginId,
name,
});
},
async registerTrads({ locales }) {
const importedTrads = await Promise.all(
locales.map((locale) => {
return import(`./translations/${locale}.json`)
.then(({ default: data }) => {
return {
data: prefixPluginTranslations(data, pluginId),
locale,
};
})
.catch(() => {
return {
data: {},
locale,
};
});
})
);
return Promise.resolve(importedTrads);
},
};