80 lines
2.5 KiB
JavaScript
Raw Normal View History

// 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
2019-04-16 18:23:26 +02:00
import pluginPkg from '../../package.json';
import pluginLogo from './assets/images/logo.svg';
2020-02-13 09:01:32 +01:00
import App from './containers/App';
import Initializer from './containers/Initializer';
import SettingsPage from './containers/SettingsPage';
import InputMedia from './components/InputMedia';
import InputModalStepper from './containers/InputModalStepper';
import trads from './translations';
2019-04-18 01:10:38 +02:00
import pluginId from './pluginId';
import { getTrad } from './utils';
2019-04-16 18:23:26 +02:00
export default strapi => {
const pluginDescription = pluginPkg.strapi.description || pluginPkg.description;
const icon = pluginPkg.strapi.icon;
const name = pluginPkg.strapi.name;
const plugin = {
blockerComponent: null,
blockerComponentProps: {},
description: pluginDescription,
fileModel: null,
icon,
id: pluginId,
initializer: Initializer,
injectedComponents: [],
isReady: false,
isRequired: pluginPkg.strapi.required || false,
layout: null,
lifecycles: null,
leftMenuLinks: [],
leftMenuSections: [],
2020-02-13 09:01:32 +01:00
mainComponent: App,
name,
pluginLogo,
preventComponentRendering: false,
settings: {
global: [
{
title: {
id: getTrad('plugin.name'),
defaultMessage: 'Media Library',
},
name: 'media-library',
to: `${strapi.settingsBaseURL}/media-library`,
Component: SettingsPage,
// TODO write documentation
permissions: [{ action: 'plugins::upload.settings.read', subject: null }],
},
],
},
trads,
menu: {
pluginsSectionLinks: [
{
destination: `/plugins/${pluginId}`,
icon,
label: {
id: `${pluginId}.plugin.name`,
defaultMessage: 'Media Library',
},
name,
permissions: [{ action: 'plugins::upload.read', subject: null }],
},
],
},
};
2019-04-16 18:23:26 +02:00
strapi.registerComponent({ name: 'media-library', Component: InputModalStepper });
strapi.registerField({ type: 'media', Component: InputMedia });
return strapi.registerPlugin(plugin);
2019-04-16 18:23:26 +02:00
};