| Index: lib/src/init.dart
|
| diff --git a/lib/src/init.dart b/lib/src/init.dart
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..512134da1d6853195ea865290aa17f3590d1c788
|
| --- /dev/null
|
| +++ b/lib/src/init.dart
|
| @@ -0,0 +1,29 @@
|
| +// Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file
|
| +// for details. All rights reserved. Use of this source code is governed by a
|
| +// BSD-style license that can be found in the LICENSE file.
|
| +library web_components.src.init;
|
| +
|
| +import 'dart:async';
|
| +import 'package:initialize/initialize.dart' show InitializerFilter;
|
| +import 'package:web_components/web_components.dart';
|
| +import 'mirror_initializer.dart' as init;
|
| +
|
| +/// Performs html import aware initialization by crawling all imported documents
|
| +/// and initializing any script tags which appear in them.
|
| +///
|
| +/// By default, this will run all [HtmlImport] initializers, followed in a 2nd
|
| +/// phase by all [CustomElement] and [CustomElementProxy] initializers. Then,
|
| +/// unless [initAll] is [false], it will run all remaining initializers.
|
| +///
|
| +/// If a [typeFilter] or [customFilter] are supplied, only one phase is ran
|
| +/// with the supplied filters.
|
| +Future initWebComponents({List<Type> typeFilter, InitializerFilter customFilter,
|
| + bool initAll: true}) {
|
| + if (typeFilter != null || customFilter != null) {
|
| + return init.run(typeFilter: typeFilter, customFilter: customFilter);
|
| + } else {
|
| + return init.run(typeFilter: [HtmlImport])
|
| + .then((_) => init.run(typeFilter: [CustomElement, CustomElementProxy]))
|
| + .then((_) => initAll ? init.run() : null);
|
| + }
|
| +}
|
|
|