@google/model-viewer
Version:
Easily display interactive 3D models on the web and in AR!
47 lines (42 loc) • 1.73 kB
text/typescript
/*
* Copyright 2018 Google Inc. All Rights Reserved.
* Licensed under the Apache License, Version 2.0 (the 'License');
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an 'AS IS' BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import {AnimationMixin} from './features/animation.js';
import {ARMixin} from './features/ar.js';
import {ControlsMixin} from './features/controls.js';
import {EnvironmentMixin} from './features/environment.js';
import {LoadingMixin} from './features/loading.js';
import {MagicLeapMixin} from './features/magic-leap.js';
import {StagingMixin} from './features/staging.js';
import ModelViewerElementBase from './model-viewer-base.js';
import {Constructor} from './utilities.js';
import {FocusVisiblePolyfillMixin} from './utilities/focus-visible.js';
type ModelViewerMixin =
(ModelViewerElement: Constructor<ModelViewerElementBase>) =>
Constructor<ModelViewerElementBase>;
const mixins = [
FocusVisiblePolyfillMixin,
AnimationMixin,
LoadingMixin,
ARMixin,
ControlsMixin,
EnvironmentMixin,
StagingMixin,
MagicLeapMixin
];
const ModelViewerElement: Constructor<ModelViewerElementBase> = mixins.reduce(
(Base: Constructor<ModelViewerElementBase>, Mixin: ModelViewerMixin) =>
Mixin(Base),
ModelViewerElementBase);
customElements.define('model-viewer', ModelViewerElement);