66 lines
2.8 KiB
JavaScript
66 lines
2.8 KiB
JavaScript
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
});
|
|
};
|
|
/*
|
|
* Copyright [2019] [Doric.Pub]
|
|
*
|
|
* 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 { Panel } from "../ui/panel";
|
|
import { takeLet } from "../pattern/candies";
|
|
/**
|
|
* Only supports x,y,width,height,corner(just for four corners),rotation,bgColor,
|
|
* @param panel @see Panel
|
|
*/
|
|
export function animate(context) {
|
|
const entity = context.entity;
|
|
if (entity instanceof Panel) {
|
|
let panel = entity;
|
|
return (args) => __awaiter(this, void 0, void 0, function* () {
|
|
yield context.callNative('animate', 'submit');
|
|
args.animations();
|
|
return takeLet(panel.getRootView())(root => {
|
|
if (root.isDirty()) {
|
|
const model = root.toModel();
|
|
model.duration = args.duration;
|
|
const ret = context.callNative('animate', 'animateRender', model);
|
|
root.clean();
|
|
return ret;
|
|
}
|
|
for (let map of panel.allHeadViews()) {
|
|
for (let v of map.values()) {
|
|
if (v.isDirty()) {
|
|
const model_1 = v.toModel();
|
|
const ret_1 = context.callNative('animate', 'animateRender', model_1);
|
|
v.clean();
|
|
return ret_1;
|
|
}
|
|
}
|
|
}
|
|
throw new Error('Cannot find any animated elements');
|
|
});
|
|
});
|
|
}
|
|
else {
|
|
return (args) => {
|
|
return Promise.reject(`Cannot find panel in Context:${context.id}`);
|
|
};
|
|
}
|
|
}
|