// NOTE TO PLUGINS DEVELOPERS: // If you modify this file by adding new options to the plugin entry point // Here's the file: strapi/docs/3.0.0-beta.x/plugin-development/frontend-field-api.md // Here's the file: strapi/docs/3.0.0-beta.x/guides/registering-a-field-in-admin.md // Also the strapi-generate-plugins/files/admin/src/index.js needs to be updated // IF THE DOC IS NOT UPDATED THE PULL REQUEST WILL NOT BE MERGED import React from 'react'; import { CheckPagePermissions, prefixPluginTranslations } from '@strapi/helper-plugin'; import pluginPkg from '../../package.json'; import pluginLogo from './assets/images/logo.svg'; import pluginPermissions from './permissions'; import Initializer from './components/Initializer'; import InputMedia from './components/InputMedia'; import InputModalStepper from './components/InputModalStepper'; import SettingsPage from './pages/SettingsPage'; import reducers from './reducers'; import pluginId from './pluginId'; import { getTrad } from './utils'; const pluginDescription = pluginPkg.strapi.description || pluginPkg.description; const icon = pluginPkg.strapi.icon; const name = pluginPkg.strapi.name; export default { register(app) { // TODO update doc and guides app.addComponents({ name: 'media-library', Component: InputModalStepper }); // TODO update guide app.addFields({ type: 'media', Component: InputMedia }); app.addReducers(reducers); app.registerPlugin({ description: pluginDescription, icon, id: pluginId, initializer: Initializer, isReady: false, isRequired: pluginPkg.strapi.required || false, name, pluginLogo, menu: { pluginsSectionLinks: [ { to: `/plugins/${pluginId}`, icon, intlLabel: { id: `${pluginId}.plugin.name`, defaultMessage: 'Media Library', }, permissions: pluginPermissions.main, }, ], }, }); }, boot(app) { app.addSettingsLink('global', { id: 'media-library-settings', intlLabel: { id: getTrad('plugin.name'), defaultMessage: 'Media Library', }, to: '/settings/media-library', Component: () => ( ), permissions: pluginPermissions.settings, }); }, async registerTrads({ locales }) { const importedTrads = await Promise.all( locales.map(locale => { return import( /* webpackChunkName: "upload-translation-[request]" */ `./translations/${locale}.json` ) .then(({ default: data }) => { return { data: prefixPluginTranslations(data, pluginId), locale, }; }) .catch(() => { return { data: {}, locale, }; }); }) ); return Promise.resolve(importedTrads); }, };