mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2025-08-18 19:21:34 +08:00
183 lines
4.7 KiB
TypeScript
183 lines
4.7 KiB
TypeScript
import {coreDirectives, formDirectives, Component, Directive, View, forwardRef} from 'angular2/angular2'
|
|
|
|
import * as util from 'ionic/util';
|
|
import {IonicConfig} from './config';
|
|
import {IonicRouter} from '../routing/router';
|
|
import {ionicBootstrap} from '../components/app/app';
|
|
import {
|
|
Aside, Button, Content, Scroll, Refresher,
|
|
Slides, Slide, SlidePager,
|
|
Tabs, Tab,
|
|
Card, List, ListHeader, Item, ItemGroup, ItemGroupTitle,
|
|
Toolbar,
|
|
Icon,
|
|
IconDirective,
|
|
Checkbox, Switch,
|
|
Input, TextInput, Label,
|
|
Segment, SegmentButton, SegmentControlValueAccessor,
|
|
RadioGroup, RadioButton, SearchBar,
|
|
Nav, NavbarTemplate, Navbar, NavPush, NavPop,
|
|
TapClick, TapDisabled,
|
|
Register,
|
|
ShowWhen, HideWhen,
|
|
|
|
MaterialButton
|
|
} from '../ionic';
|
|
|
|
|
|
// TODO: Why is forwardRef() required when they're already imported above????
|
|
export const IonicDirectives = [
|
|
// Angular
|
|
coreDirectives,
|
|
formDirectives,
|
|
|
|
// Content
|
|
forwardRef(() => Aside),
|
|
forwardRef(() => Button),
|
|
forwardRef(() => Content),
|
|
forwardRef(() => Scroll),
|
|
forwardRef(() => Refresher),
|
|
|
|
// Lists
|
|
forwardRef(() => Card),
|
|
forwardRef(() => List),
|
|
forwardRef(() => ListHeader),
|
|
forwardRef(() => Item),
|
|
forwardRef(() => ItemGroup),
|
|
forwardRef(() => ItemGroupTitle),
|
|
|
|
// Slides
|
|
forwardRef(() => Slides),
|
|
forwardRef(() => Slide),
|
|
forwardRef(() => SlidePager),
|
|
|
|
// Tabs
|
|
forwardRef(() => Tabs),
|
|
forwardRef(() => Tab),
|
|
forwardRef(() => Toolbar),
|
|
|
|
// Media
|
|
forwardRef(() => Icon),
|
|
forwardRef(() => IconDirective),
|
|
|
|
// Form
|
|
forwardRef(() => Segment),
|
|
forwardRef(() => SegmentButton),
|
|
forwardRef(() => SegmentControlValueAccessor),
|
|
forwardRef(() => Checkbox),
|
|
forwardRef(() => RadioGroup),
|
|
forwardRef(() => RadioButton),
|
|
forwardRef(() => Switch),
|
|
//SearchBar,
|
|
|
|
// Input
|
|
forwardRef(() => Input),
|
|
forwardRef(() => TextInput),
|
|
forwardRef(() => Label),
|
|
|
|
// Nav
|
|
forwardRef(() => Nav),
|
|
forwardRef(() => NavbarTemplate),
|
|
forwardRef(() => Navbar),
|
|
forwardRef(() => NavPush),
|
|
forwardRef(() => NavPop),
|
|
forwardRef(() => Register),
|
|
|
|
forwardRef(() => ShowWhen),
|
|
forwardRef(() => HideWhen),
|
|
|
|
// Gestures
|
|
forwardRef(() => TapClick),
|
|
forwardRef(() => TapDisabled),
|
|
|
|
// Material
|
|
forwardRef(() => MaterialButton)
|
|
];
|
|
|
|
class IonicViewImpl extends View {
|
|
constructor(args = {}) {
|
|
args.directives = (args.directives || []).concat(IonicDirectives);
|
|
super(args);
|
|
}
|
|
}
|
|
|
|
export function IonicView(args) {
|
|
return function(cls) {
|
|
var annotations = Reflect.getMetadata('annotations', cls) || [];
|
|
annotations.push(new IonicViewImpl(args));
|
|
Reflect.defineMetadata('annotations', annotations, cls);
|
|
return cls;
|
|
}
|
|
}
|
|
|
|
export function IonicDirective(config) {
|
|
return function(cls) {
|
|
var annotations = Reflect.getMetadata('annotations', cls) || [];
|
|
annotations.push(new Directive(appendConfig(cls, config)));
|
|
Reflect.defineMetadata('annotations', annotations, cls);
|
|
return cls;
|
|
}
|
|
}
|
|
|
|
export function IonicComponent(config) {
|
|
return function(cls) {
|
|
var annotations = Reflect.getMetadata('annotations', cls) || [];
|
|
annotations.push(new Component(appendConfig(cls, config)));
|
|
Reflect.defineMetadata('annotations', annotations, cls);
|
|
return cls;
|
|
}
|
|
}
|
|
|
|
function appendConfig(cls, config) {
|
|
config.host = config.host || {};
|
|
|
|
cls.defaultProperties = config.defaultProperties || {};
|
|
|
|
config.properties = config.properties || [];
|
|
|
|
for (let prop in cls.defaultProperties) {
|
|
// add the property to the component "properties"
|
|
config.properties.push(prop);
|
|
|
|
// set the component "hostProperties", so the instance's
|
|
// property value will be used to set the element's attribute
|
|
config.host['[attr.' + util.pascalCaseToDashCase(prop) + ']'] = prop;
|
|
}
|
|
|
|
cls.delegates = config.delegates;
|
|
|
|
let componentId = config.classId || (config.selector && config.selector.replace('ion-', ''));
|
|
config.host['class'] = ((config.host['class'] || '') + ' ' + componentId).trim();
|
|
|
|
// the mode will get figured out when the component is constructed
|
|
config.host['[attr.mode]'] = 'clsMode';
|
|
|
|
return config;
|
|
}
|
|
|
|
export function App(args={}) {
|
|
return function(cls) {
|
|
// get current annotations
|
|
let annotations = Reflect.getMetadata('annotations', cls) || [];
|
|
|
|
// create @Component
|
|
args.selector = args.selector || 'ion-app';
|
|
annotations.push(new Component(args));
|
|
|
|
// create @View
|
|
// if no template was provided, default so it has a root ion-nav
|
|
if (!args.templateUrl && !args.template) {
|
|
args.template = '<ion-nav></ion-nav>';
|
|
}
|
|
|
|
annotations.push(new IonicViewImpl(args));
|
|
|
|
// redefine with added annotations
|
|
Reflect.defineMetadata('annotations', annotations, cls);
|
|
|
|
ionicBootstrap(cls, args.config, args.routes);
|
|
|
|
return cls;
|
|
}
|
|
}
|