94 lines
2.8 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
import { prefixPluginTranslations } from '@strapi/helper-plugin';
2019-04-16 18:23:26 +02:00
import pluginPkg from '../../package.json';
import pluginLogo from './assets/images/logo.svg';
import pluginPermissions from './permissions';
import InputMedia from './components/InputMedia';
import InputModalStepper from './components/InputModalStepper';
2019-04-18 01:10:38 +02:00
import pluginId from './pluginId';
import { getTrad } from './utils';
2019-04-16 18:23:26 +02:00
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 });
app.addMenuLink({
to: `/plugins/${pluginId}`,
icon,
intlLabel: {
id: `${pluginId}.plugin.name`,
defaultMessage: 'Media Library',
},
permissions: pluginPermissions.main,
Component: async () => {
const component = await import(/* webpackChunkName: "upload" */ './pages/App');
return component;
},
});
app.addFields({ type: 'media', Component: InputMedia });
app.registerPlugin({
description: pluginDescription,
icon,
id: pluginId,
isReady: true,
isRequired: pluginPkg.strapi.required || false,
name,
pluginLogo,
});
},
bootstrap(app) {
app.addSettingsLink('global', {
id: 'media-library-settings',
intlLabel: {
id: getTrad('plugin.name'),
defaultMessage: 'Media Library',
},
to: '/settings/media-library',
Component: async () => {
const component = await import(
/* webpackChunkName: "upload-settings" */ './pages/SettingsPage'
);
return 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);
},
};