mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-06 07:21:16 +08:00
added centered for angular
This commit is contained in:
parent
040cdadf2e
commit
974b0ad4f3
58
addons/centered/src/angular.js
vendored
Normal file
58
addons/centered/src/angular.js
vendored
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
import styles from './styles';
|
||||||
|
|
||||||
|
function getComponentSelector(component) {
|
||||||
|
// eslint-disable-next-line no-underscore-dangle
|
||||||
|
return component.__annotations__[0].selector;
|
||||||
|
}
|
||||||
|
|
||||||
|
function getTemplate(metadata) {
|
||||||
|
let tpl = '';
|
||||||
|
if (metadata.component) {
|
||||||
|
const selector = getComponentSelector(metadata.component);
|
||||||
|
tpl = `<${selector}></${selector}>`;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (metadata.template) {
|
||||||
|
tpl = metadata.template;
|
||||||
|
}
|
||||||
|
|
||||||
|
return `
|
||||||
|
<div [ngStyle]="styles.style">
|
||||||
|
<div [ngStyle]="styles.innerStyle">
|
||||||
|
${tpl}
|
||||||
|
</div>
|
||||||
|
</div>`;
|
||||||
|
}
|
||||||
|
|
||||||
|
function getModuleMetadata(metadata) {
|
||||||
|
const { moduleMetadata, component } = metadata;
|
||||||
|
|
||||||
|
if (component && !moduleMetadata) {
|
||||||
|
return {
|
||||||
|
declarations: [metadata.component],
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
if (component && moduleMetadata) {
|
||||||
|
return {
|
||||||
|
...moduleMetadata,
|
||||||
|
declarations: [...moduleMetadata.declarations, metadata.component],
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return moduleMetadata;
|
||||||
|
}
|
||||||
|
|
||||||
|
export default function(metadataFn) {
|
||||||
|
const metadata = metadataFn();
|
||||||
|
|
||||||
|
return {
|
||||||
|
...metadata,
|
||||||
|
template: getTemplate(metadata),
|
||||||
|
moduleMetadata: getModuleMetadata(metadata),
|
||||||
|
props: {
|
||||||
|
...metadata.props,
|
||||||
|
styles,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
@ -1,7 +1,9 @@
|
|||||||
import { window } from 'global';
|
import { window } from 'global';
|
||||||
import ReactCentered from './react';
|
import ReactCentered from './react';
|
||||||
import VueCentered from './vue';
|
import VueCentered from './vue';
|
||||||
|
import AngularCentered from './angular';
|
||||||
|
|
||||||
const Centered = window.STORYBOOK_ENV === 'vue' ? VueCentered : ReactCentered;
|
const Centered = window.STORYBOOK_ENV === 'vue' ? VueCentered : ReactCentered;
|
||||||
|
|
||||||
export default Centered;
|
export default Centered;
|
||||||
|
|
||||||
|
export const centeredAng = AngularCentered;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user