Files
Yajbir Singh f1b860b25c
Some checks failed
check / markdownlint (push) Has been cancelled
check / spellchecker (push) Has been cancelled
updated
2025-12-11 19:03:17 +05:30

3201 lines
128 KiB
JavaScript
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
* (c) Copyright Ascensio System SIA 2010-2023
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish
* street, Riga, Latvia, EU, LV-1050.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
"use strict";
(function (window, undefined) {
var InitClass = AscFormat.InitClass;
var CAnimTexture = AscFormat.CAnimTexture;
const STATE_FLAG_SELECTED = 1;
const STATE_FLAG_HOVERED = 2;
const STATE_FLAG_PRESSED = 4;
const STATE_FLAG_DISABLED = 8;
const CONTROL_TYPE_UNKNOWN = 0;
const CONTROL_TYPE_LABEL = 1;
const CONTROL_TYPE_IMAGE = 2;
const CONTROL_TYPE_BUTTON = 3;
const CONTROL_TYPE_HEADER = 4;
const CONTROL_TYPE_SCROLL_VERT = 5;
const CONTROL_TYPE_SCROLL_HOR = 6;
const CONTROL_TYPE_TIMELINE_CONTAINER = 7;
const CONTROL_TYPE_TIMELINE = 8;
const CONTROL_TYPE_SEQ_LIST_CONTAINER = 9;
const CONTROL_TYPE_SEQ_LIST = 10;
const CONTROL_TYPE_ANIM_SEQ = 11;
const CONTROL_TYPE_ANIM_GROUP_LIST = 12;
const CONTROL_TYPE_ANIM_GROUP = 13;
const CONTROL_TYPE_ANIM_ITEM = 14;
const CONTROL_TYPE_EFFECT_BAR = 15;
function CControl(oParentControl) {
AscFormat.ExecuteNoHistory(function () {
AscFormat.CShape.call(this);
this.setRecalculateInfo();
this.setBDeleted(false);
this.setLayout(0, 0, 0, 0);
}, this, []);
this.parent = editor.WordControl.m_oLogicDocument.Slides[0];
this.parentControl = oParentControl;
this.state = 0;
this.hidden = false;
this.previous = null;
this.next = null;
}
InitClass(CControl, AscFormat.CShape, CONTROL_TYPE_UNKNOWN);
CControl.prototype.getSeqList = function () {
let oParentControl = this.parentControl;
while (oParentControl) {
if (oParentControl instanceof CSeqList) {
return oParentControl;
}
oParentControl = oParentControl.parentControl;
}
return null;
};
CControl.prototype.DEFALT_WRAP_OBJECT = {
oTxWarpStruct: null,
oTxWarpStructParamarks: null,
oTxWarpStructNoTransform: null,
oTxWarpStructParamarksNoTransform: null
};
CControl.prototype.setHidden = function (bVal) {
if (this.hidden !== bVal) {
this.hidden = bVal;
this.onUpdate();
}
};
CControl.prototype.show = function () {
this.setHidden(false);
};
CControl.prototype.hide = function () {
this.setHidden(true);
};
CControl.prototype.isHidden = function () {
return this.hidden;
};
CControl.prototype.notAllowedWithoutId = function () {
return false;
};
//define shape methods
CControl.prototype.getBodyPr = function () {
return this.bodyPr;
};
CControl.prototype.getScrollOffsetX = function (oChild) {
return 0;
};
CControl.prototype.getScrollOffsetY = function (oChild) {
return 0;
};
CControl.prototype.getParentScrollOffsetX = function (oChild) {
if (this.parentControl) {
return this.parentControl.getScrollOffsetX(oChild);
}
return 0;
};
CControl.prototype.getParentScrollOffsetY = function (oChild) {
if (this.parentControl) {
return this.parentControl.getScrollOffsetY(oChild);
}
return 0;
};
CControl.prototype.getFullTransformMatrix = function () {
return this.transform;
};
CControl.prototype.getInvFullTransformMatrix = function () {
return this.invertTransform;
};
CControl.prototype.multiplyParentTransforms = function (oLocalTransform) {
var oMT = AscCommon.global_MatrixTransformer;
var oTransform = oMT.CreateDublicateM(oLocalTransform);
var oScrollMatrix = new AscCommon.CMatrix();
oScrollMatrix.tx = this.getParentScrollOffsetX(this);
oScrollMatrix.ty = this.getParentScrollOffsetY(this);
oMT.MultiplyAppend(oTransform, oScrollMatrix);
var oParentTransform = this.parentControl && this.parentControl.getFullTransformMatrix();
oParentTransform && oMT.MultiplyAppend(oTransform, oParentTransform);
return oTransform;
};
CControl.prototype.getFullTransform = function () {
return this.transform;
};
CControl.prototype.getFullTextTransform = function () {
return this.transformText;
};
CControl.prototype.recalculate = function () {
AscFormat.CShape.prototype.recalculate.call(this);
};
CControl.prototype.recalculateBrush = function () {
this.brush = null;
};
CControl.prototype.recalculatePen = function () {
this.pen = null;
};
CControl.prototype.recalculateContent = function () {
};
CControl.prototype.recalculateGeometry = function () {
//this.calcGeometry = AscFormat.CreateGeometry("rect");
//this.calcGeometry.Recalculate(this.extX, this.extY);
};
CControl.prototype.recalculateTransform = function () {
if (!this.transform) {
this.transform = new AscCommon.CMatrix();
}
var tx = this.getLeft();
var ty = this.getTop();
this.x = tx;
this.y = ty;
this.rot = 0;
this.extX = this.getWidth();
this.extY = this.getHeight();
this.flipH = false;
this.flipV = false;
ty += this.getParentScrollOffsetY(this);
var oCurParent = this.parentControl;
if (oCurParent) {
tx += oCurParent.transform.tx;
ty += oCurParent.transform.ty
}
this.transform.tx = tx;
this.transform.ty = ty;
if (!this.invertTransform) {
this.invertTransform = new AscCommon.CMatrix();
}
this.invertTransform.tx = -tx;
this.invertTransform.ty = -ty;
this.localTransform = this.transform;
};
CControl.prototype.recalculateTransformText = function () {
if (!this.transformText) {
this.transformText = new AscCommon.CMatrix();
}
this.transformText.tx = this.transform.tx;
this.transformText.ty = this.transform.ty;
if (!this.invertTransformText) {
this.invertTransformText = new AscCommon.CMatrix();
}
this.invertTransformText.tx = -this.transform.tx;
this.invertTransformText.ty = -this.transform.ty;
this.localTransformText = this.transformText;
};
CControl.prototype.recalculateBounds = function () {
var dX = this.transform.tx;
var dY = this.transform.ty;
this.bounds.reset(dX, dY, dX + this.getWidth(), dY + this.getHeight())
};
CControl.prototype.recalculateSnapArrays = function () {
};
CControl.prototype.checkAutofit = function (bIgnoreWordShape) {
return false;
};
CControl.prototype.checkTextWarp = function (oContent, oBodyPr, dWidth, dHeight, bNeedNoTransform, bNeedWarp) {
return this.DEFALT_WRAP_OBJECT;
};
CControl.prototype.addToRecalculate = function () {
};
CControl.prototype.canHandleEvents = function () {
return true;
};
CControl.prototype.getPenWidth = function (graphics) {
var fScale = graphics.m_oCoordTransform.sx;
var nPenW = AscCommon.AscBrowser.convertToRetinaValue(1, true) / fScale;
return nPenW;
};
CControl.prototype.draw = function (graphics) {
if (this.isHidden()) { return false; }
if (!this.checkUpdateRect(graphics.updatedRect)) { return false; }
this.recalculateTransform();
this.recalculateTransformText();
const sFillColor = this.getFillColor();
const sOutlineColor = this.getOutlineColor();
let oColor;
if (sOutlineColor || sFillColor) {
graphics.SaveGrState();
graphics.transform3(this.transform);
var x = 0;
var y = 0;
var extX = this.getWidth();
var extY = this.getHeight();
if (sFillColor) {
oColor = AscCommon.RgbaHexToRGBA(sFillColor);
graphics.b_color1(oColor.R, oColor.G, oColor.B, 0xFF);
graphics.rect(x, y, extX, extY);
graphics.df();
}
if (sOutlineColor) {
oColor = AscCommon.RgbaHexToRGBA(sOutlineColor);
graphics.SetIntegerGrid(true);
var nPenW = this.getPenWidth(graphics);
//graphics.p_width(100);//AscCommon.AscBrowser.convertToRetinaValue(1, true);
graphics.p_color(oColor.R, oColor.G, oColor.B, 0xFF);
graphics.drawHorLine(0, y, x, x + extX, nPenW);
graphics.drawHorLine(0, y + extY, x, x + extX, nPenW);
graphics.drawVerLine(2, x, y, y + extY, nPenW);
graphics.drawVerLine(2, x + extX, y, y + extY, nPenW);
graphics.ds();
}
graphics.RestoreGrState();
}
AscFormat.CShape.prototype.draw.call(this, graphics);
return true;
};
CControl.prototype.hit = function (x, y) {
if (this.parentControl && !this.parentControl.hit(x, y)) {
return false;
}
var oInv = this.invertTransform;
var tx = oInv.TransformPointX(x, y);
var ty = oInv.TransformPointY(x, y);
return tx >= 0 && tx <= this.extX && ty >= 0 && ty <= this.extY;
};
CControl.prototype.setStateFlag = function (nFlag, bValue) {
var nOldState = this.state;
if (bValue) {
this.state |= nFlag;
} else {
this.state &= (~nFlag);
}
if (nOldState !== this.state) {
this.onUpdate();
}
};
CControl.prototype.getStateFlag = function (nFlag) {
return (this.state & nFlag) !== 0;
};
CControl.prototype.isHovered = function () {
return this.getStateFlag(STATE_FLAG_HOVERED);
};
CControl.prototype.isActive = function () {
if (this.parentControl) {
if (!this.eventListener && this.parentControl.isEventListener(this)) {
return true;
}
}
return false;
};
CControl.prototype.setHoverState = function () {
this.setStateFlag(STATE_FLAG_HOVERED, true);
};
CControl.prototype.setNotHoverState = function () {
this.setStateFlag(STATE_FLAG_HOVERED, false);
};
CControl.prototype.onMouseMove = function (e, x, y) {
if (e.IsLocked) {
return false;
}
if (!this.canHandleEvents()) {
return false;
}
const bHover = !!this.hit(x, y);
const bHoverChanged = bHover !== this.isHovered();
if(bHoverChanged) {
this.setStateFlag(STATE_FLAG_HOVERED, bHover);
}
return false;
};
CControl.prototype.onMouseDown = function (e, x, y) {
if (!this.canHandleEvents()) {
return false;
}
if (this.hit(x, y)) {
if (this.parentControl) {
this.parentControl.setEventListener(this);
}
return true;
}
return false;
};
CControl.prototype.onMouseUp = function (e, x, y) {
if (this.parentControl) {
if (this.parentControl.isEventListener(this)) {
this.parentControl.setEventListener(null);
return true;
}
}
return false;
};
CControl.prototype.onMouseWheel = function (e, deltaY, X, Y) {
return false;
};
CControl.prototype.onUpdate = function () {
if (this.parentControl) {
var oBounds = this.getBounds();
this.parentControl.onChildUpdate(oBounds);
}
};
CControl.prototype.onChildUpdate = function (oBounds) {
if (this.parentControl) {
this.parentControl.onChildUpdate(oBounds);
}
};
CControl.prototype.checkUpdateRect = function (oUpdateRect) {
var oBounds = this.getBounds();
if (oUpdateRect && oBounds) {
if (!oUpdateRect.isIntersectOther(oBounds)) {
return false;
}
}
return true;
};
CControl.prototype.recalculate = function () {
AscFormat.CShape.prototype.recalculate.call(this);
};
/**
* Sets the location and dimensions of the control inside the parent container.
*
* @param {number} dX - Offset of the element along the X axis relative to the upper-left corner of the parent container.
* @param {number} dY - Offset of the element along the Y axis relative to the upper-left corner of the parent container.
* @param {number} dExtX - Width of the element.
* @param {number} dExtY - Height of the element.
*
* @note
* - Negative values for dX and dY are supported with behavior similar to "overflow: hidden" in CSS.
* - Negative values for dExtX and dExtY are not supported and may lead to unexpected behavior.
* - It is recommended to avoid using negative values for dExtX and dExtY to ensure proper rendering and hit detection.
*/
CControl.prototype.setLayout = function (dX, dY, dExtX, dExtY) {
if (!this.spPr) {
this.spPr = new AscFormat.CSpPr();
}
if (!this.spPr.xfrm) {
this.spPr.xfrm = new AscFormat.CXfrm();
}
this.spPr.xfrm.offX = dX;
this.spPr.xfrm.offY = dY;
this.spPr.xfrm.extX = dExtX;
this.spPr.xfrm.extY = dExtY;
this.handleUpdateExtents();
};
CControl.prototype.getLeft = function () {
return this.spPr.xfrm.offX;
};
CControl.prototype.getTop = function () {
return this.spPr.xfrm.offY;
};
CControl.prototype.getRight = function () {
return this.spPr.xfrm.offX + this.spPr.xfrm.extX;
};
CControl.prototype.getBottom = function () {
return this.spPr.xfrm.offY + this.spPr.xfrm.extY;
};
CControl.prototype.getWidth = function () {
return this.spPr.xfrm.extX;
};
CControl.prototype.getHeight = function () {
return this.spPr.xfrm.extY;
};
CControl.prototype.getBounds = function () {
return AscFormat.ExecuteNoHistory(function () {
this.recalculateBounds();
this.recalculateTransform();
this.recalculateTransformText();
return this.bounds;
}, this, []);
};
CControl.prototype.convertRelToAbs = function (oPos) {
var oAbsPos = { x: oPos.x, y: oPos.y };
var oParent = this;
while (oParent) {
oAbsPos.x += oParent.getLeft();
oAbsPos.y += oParent.getTop();
oParent = oParent.parentControl;
}
return oAbsPos;
};
CControl.prototype.convertAbsToRel = function (oPos) {
var oRelPos = { x: oPos.x, y: oPos.y };
var oParent = this;
while (oParent) {
oRelPos.x -= oParent.getLeft();
oRelPos.y -= oParent.getTop();
oParent = oParent.parentControl;
}
return oRelPos;
};
CControl.prototype.getNext = function () {
return this.next;
};
CControl.prototype.getPrevious = function () {
return this.previous;
};
CControl.prototype.setNext = function (v) {
this.next = v;
};
CControl.prototype.setPrevious = function (v) {
this.previous = v;
};
CControl.prototype.setParentControl = function (v) {
this.parentControl = v;
};
CControl.prototype.getTiming = function () {
var oSlide = this.getSlide();
if (oSlide) {
return oSlide.timing;
}
return null;
};
CControl.prototype.getSlide = function () {
var oSlide = null;
if (editor.WordControl && editor.WordControl.m_oLogicDocument) {
oSlide = editor.WordControl.m_oLogicDocument.GetCurrentSlide();
return oSlide;
}
return null;
};
CControl.prototype.getSlideNum = function () {
var oSlide = this.getSlide();
if (oSlide) {
return oSlide.num;
}
return -1;
};
CControl.prototype.getFillColor = function () {
console.error('Method "getFillColor" must be implemented in ' + this.constructor.name);
return null;
};
CControl.prototype.getOutlineColor = function () {
console.error('Method "getOutlineColor" must be implemented in ' + this.constructor.name);
return null;
};
CControl.prototype.drawShdw = function () {
};
function CControlContainer(oParentControl) {
CControl.call(this, oParentControl);
this.children = [];
this.recalcInfo.recalculateChildrenLayout = true;
this.recalcInfo.recalculateChildren = true;
this.eventListener = null;
}
InitClass(CControlContainer, CControl, CONTROL_TYPE_UNKNOWN);
CControlContainer.prototype.isEventListener = function (oChild) {
return this.eventListener === oChild;
};
CControlContainer.prototype.onScroll = function () {
};
CControlContainer.prototype.onStartScroll = function () {
};
CControlContainer.prototype.onEndScroll = function () {
};
CControlContainer.prototype.clear = function () {
for (var nIdx = this.children.length - 1; nIdx > -1; --nIdx) {
this.removeControl(this.children[nIdx]);
}
};
CControlContainer.prototype.addControl = function (oChild) {
var oLast = this.children[this.children.length - 1];
this.children.push(oChild);
if (oLast) {
oLast.setNext(oChild);
oChild.setPrevious(oLast);
oChild.setParentControl(this);
}
return oChild;
};
CControlContainer.prototype.removeControl = function (oChild) {
var nIdx = this.getChildIdx(oChild);
this.removeByIdx(nIdx);
};
CControlContainer.prototype.removeByIdx = function (nIdx) {
if (nIdx > -1 && nIdx < this.children.length) {
var oChild = this.children[nIdx];
oChild.setNext(null);
oChild.setPrevious(null);
oChild.setParentControl(null);
var oPrev = this.children[nIdx - 1] || null;
var oNext = this.children[nIdx + 1] || null;
if (oPrev) {
oPrev.setNext(oNext);
}
if (oNext) {
oNext.setPrevious(oPrev);
}
this.children.splice(nIdx, 1);
}
};
CControlContainer.prototype.getChildIdx = function (oChild) {
for (var nChild = 0; nChild < this.children.length; ++nChild) {
if (this.children[nChild] === oChild) {
return nChild;
}
}
return -1;
};
CControlContainer.prototype.getChildByType = function (nType) {
for (var nChild = 0; nChild < this.children.length; ++nChild) {
var oChild = this.children[nChild];
if (oChild.getObjectType() === nType) {
return oChild;
}
}
return null;
};
CControlContainer.prototype.getChild = function (nIdx) {
if (nIdx > -1 && nIdx < this.children.length) {
return this.children[nIdx];
}
};
CControlContainer.prototype.draw = function (graphics) {
if (!CControl.prototype.draw.call(this, graphics)) {
return false;
}
this.clipStart(graphics);
for (var nChild = 0; nChild < this.children.length; ++nChild) {
this.children[nChild].draw(graphics);
}
this.clipEnd(graphics);
return true;
};
CControlContainer.prototype.clipStart = function (graphics) {
};
CControlContainer.prototype.clipEnd = function (graphics) {
};
CControlContainer.prototype.recalculateChildrenLayout = function () {
};
CControlContainer.prototype.recalculateChildren = function () {
};
CControlContainer.prototype.recalculate = function () {
AscFormat.ExecuteNoHistory(function () {
CControl.prototype.recalculate.call(this);
if (this.recalcInfo.recalculateChildren) {
this.recalculateChildren();
this.recalcInfo.recalculateChildren = false;
}
if (this.recalcInfo.recalculateChildrenLayout) {
this.recalculateChildrenLayout();
this.recalcInfo.recalculateChildrenLayout = false;
}
for (var nChild = 0; nChild < this.children.length; ++nChild) {
this.children[nChild].recalculate();
}
}, this, []);
};
CControlContainer.prototype.setLayout = function (dX, dY, dExtX, dExtY) {
AscFormat.ExecuteNoHistory(function () {
CControl.prototype.setLayout.call(this, dX, dY, dExtX, dExtY);
this.recalcInfo.recalculateChildrenLayout = true;
}, this, []);
};
CControlContainer.prototype.handleUpdateExtents = function () {
this.recalcInfo.recalculateChildrenLayout = true;
CControl.prototype.handleUpdateExtents.call(this);
};
CControlContainer.prototype.setEventListener = function (oChild) {
if (oChild) {
this.eventListener = oChild;
if (this.parentControl) {
this.parentControl.setEventListener(this);
}
} else {
this.eventListener = null;
if (this.parentControl) {
this.parentControl.setEventListener(null);
}
}
};
CControlContainer.prototype.onMouseDown = function (e, x, y) {
for (var nChild = this.children.length - 1; nChild >= 0; --nChild) {
if (this.children[nChild].onMouseDown(e, x, y)) {
return true;
}
}
return CControl.prototype.onMouseDown.call(this, e, x, y);
};
CControlContainer.prototype.onMouseMove = function (e, x, y) {
for (var nChild = this.children.length - 1; nChild >= 0; --nChild) {
if (this.children[nChild].onMouseMove(e, x, y)) {
return true;
}
}
return CControl.prototype.onMouseMove.call(this, e, x, y);
};
CControlContainer.prototype.onMouseUp = function (e, x, y) {
for (var nChild = this.children.length - 1; nChild >= 0; --nChild) {
if (this.children[nChild].onMouseUp(e, x, y)) {
return true;
}
}
return CControl.prototype.onMouseUp.call(this, e, x, y);
};
CControlContainer.prototype.onMouseWheel = function (e, deltaY, X, Y) {
for (var nChild = 0; nChild < this.children.length; ++nChild) {
if (this.children[nChild].onMouseWheel(e, deltaY, X, Y)) {
return true;
}
}
return CControl.prototype.onMouseWheel.call(this, e, deltaY, X, Y);
};
CControlContainer.prototype.isScrolling = function () {
for (var nChild = 0; nChild < this.children.length; ++nChild) {
var oChild = this.children[nChild];
if (oChild.isOnScroll && oChild.isOnScroll()) {
return true;
}
}
return false;
};
CControlContainer.prototype.canHandleEvents = function () {
return false;
};
CControlContainer.prototype.onResize = function () {
this.handleUpdateExtents();
this.recalculate();
};
CControlContainer.prototype.getFillColor = function () {
return null;
};
CControlContainer.prototype.getOutlineColor = function () {
return null;
};
function CTopControl(oDrawer) {
CControlContainer.call(this, null);
this.drawer = oDrawer;
}
InitClass(CTopControl, CControlContainer, CONTROL_TYPE_UNKNOWN);
CTopControl.prototype.onUpdateRect = function (oBounds) {
if (this.drawer) {
this.drawer.OnAnimPaneChanged(oBounds);
}
};
CTopControl.prototype.onUpdate = function () {
var oBounds = this.getBounds();
this.onUpdateRect(oBounds);
};
CTopControl.prototype.onChildUpdate = function (oBounds) {
this.onUpdateRect(oBounds);
};
CTopControl.prototype.onResize = function () {
this.setLayout(0, 0, this.drawer.GetWidth(), this.drawer.GetHeight());
CControlContainer.prototype.onResize.call(this);
this.onUpdate();
};
function CLabel(oParentControl, sString, nFontSize, bBold, nParaAlign) {
CControl.call(this, oParentControl);
this.fontSize = nFontSize;
this.bold = bBold;
this.paraAlign = nParaAlign;
AscFormat.ExecuteNoHistory(function () {
const oRGB = AscCommon.RgbaHexToRGBA(AscCommon.GlobalSkin.AnimPaneText);
const oColor = new AscCommonWord.CDocumentColor(oRGB.R, oRGB.G, oRGB.B, false);
var oTxLstStyle = new AscFormat.TextListStyle();
oTxLstStyle.levels[0] = new CParaPr();
oTxLstStyle.levels[0].DefaultRunPr = new AscCommonWord.CTextPr();
oTxLstStyle.levels[0].DefaultRunPr.FontSize = this.fontSize;
oTxLstStyle.levels[0].DefaultRunPr.Bold = this.bold;
oTxLstStyle.levels[0].DefaultRunPr.Color = oColor;
oTxLstStyle.levels[0].DefaultRunPr.RFonts.SetAll("Arial", -1);
if (AscFormat.isRealNumber(this.paraAlign)) oTxLstStyle.levels[0].Jc = this.paraAlign;
this.createTextBody();
this.txBody.setLstStyle(oTxLstStyle);
this.bodyPr = new AscFormat.CBodyPr();
this.bodyPr.setDefault();
this.bodyPr.anchor = 1; //vertical align ctr
this.bodyPr.resetInsets();
this.bodyPr.horzOverflow = AscFormat.nHOTClip;
this.bodyPr.vertOverflow = AscFormat.nVOTClip;
this.cachedMaxWidth = 0;
this.setString(sString);
}, this, []);
}
InitClass(CLabel, CControl, CONTROL_TYPE_LABEL);
CLabel.prototype.getString = function () {
return AscCommon.translateManager.getValue(this.string);
};
CLabel.prototype.recalculateContent = function () {
this.txBody.content.Recalc_AllParagraphs_CompiledPr();
const oRGB = AscCommon.RgbaHexToRGBA(AscCommon.GlobalSkin.AnimPaneText);
const oColor = new AscCommonWord.CDocumentColor(oRGB.R, oRGB.G, oRGB.B, false);
this.txBody.lstStyle.levels[0].DefaultRunPr.Color = oColor;
if (!this.txBody.bFit || !AscFormat.isRealNumber(this.txBody.fitWidth) || this.txBody.fitWidth > this.getWidth()) {
this.txBody.recalculateOneString(this.getString());
}
// this.recalculateGeometry();
this.recalculateTransform();
};
CLabel.prototype.setString = function(str) {
this.string = str;
this.initStringContent();
};
CLabel.prototype.initStringContent = function() {
AscFormat.ExecuteNoHistory(function () {
this.txBody.checkContentFit(this.getString());
this.cachedMaxWidth = this.txBody.content.RecalculateMinMaxContentWidth().Max;
}, this, []);
};
CLabel.prototype.canHandleEvents = function () {
return false;
};
CLabel.prototype.getFillColor = function () {
return null;
};
CLabel.prototype.getOutlineColor = function () {
return null;
};
CLabel.prototype.recalculateTransformText = function () {
var Y = this.getHeight() / 2 - this.txBody.content.GetSummaryHeight() / 2;
if (!this.transformText) {
this.transformText = new AscCommon.CMatrix();
}
this.transformText.tx = this.transform.tx;
this.transformText.ty = this.transform.ty + Y;
if (!this.invertTransformText) {
this.invertTransformText = new AscCommon.CMatrix();
}
this.invertTransformText.tx = -this.transformText.tx;
this.invertTransformText.ty = -this.transformText.ty;
this.localTransformText = this.transformText;
};
CLabel.prototype.recalculateTransformText2 = function () {
return null;
};
CLabel.prototype.getContentOneStringSizes = function () {
return AscFormat.ExecuteNoHistory(function () {
this.recalculateContent();
return this.txBody.getContentOneStringSizes();
}, this, []);
};
CLabel.prototype.setLayout = function (dX, dY, dExtX, dExtY) {
this.superclass.prototype.setLayout.call(this, dX, dY, dExtX, dExtY);
if(this.txBody) {
this.txBody.bFit = false;
}
};
function CImageControl(oParentControl, sBase64Image, width, height) {
CControl.call(this, oParentControl)
this.src = sBase64Image;
this.imgWidth = width || 0;
this.imgHeight = height || 0;
}
InitClass(CImageControl, CControl, CONTROL_TYPE_IMAGE);
CImageControl.prototype.canHandleEvents = function () {
return false;
};
CImageControl.prototype.draw = function(graphics) {
if (!this.src) { return false; }
if (this.isHidden()) { return false; }
if (!this.checkUpdateRect(graphics.updatedRect)) { return false; }
const left = this.bounds.l + (this.getWidth() - this.imgWidth) / 2;
const top = this.bounds.t + (this.getHeight() - this.imgHeight) / 2;
graphics.SaveGrState();
graphics.SetIntegerGrid(false);
graphics.drawImage(this.src, left, top, this.imgWidth, this.imgHeight);
graphics.RestoreGrState();
};
CImageControl.prototype.getFillColor = function () {
return null;
};
CImageControl.prototype.getOutlineColor = function () {
return null;
};
function CButton(oParentControl, fOnMouseDown, fOnMouseMove, fOnMouseUp) {
CControlContainer.call(this, oParentControl);
this.onMouseDownCallback = fOnMouseDown;
this.onMouseMoveCallback = fOnMouseMove;
this.onMouseUpCallback = fOnMouseUp;
}
InitClass(CButton, CControlContainer, CONTROL_TYPE_BUTTON);
CButton.prototype.onMouseDown = function (e, x, y) {
if (this.onMouseDownCallback && this.onMouseDownCallback.call(this, e, x, y)) {
return true;
}
return CControlContainer.prototype.onMouseDown.call(this, e, x, y);
};
CButton.prototype.onMouseMove = function (e, x, y) {
if (this.onMouseMoveCallback && this.onMouseMoveCallback.call(this, e, x, y)) {
return true;
}
return CControlContainer.prototype.onMouseMove.call(this, e, x, y);
};
CButton.prototype.onMouseUp = function (e, x, y) {
if (this.onMouseUpCallback && this.onMouseUpCallback.call(this, e, x, y)) {
return true;
}
return CControlContainer.prototype.onMouseUp.call(this, e, x, y);
};
CButton.prototype.canHandleEvents = function () {
return true;
};
CButton.prototype.draw = function (graphics) {
if (!CControl.prototype.draw.call(this, graphics)) { return false; }
const contentOpacity = this.getContentOpacity();
graphics.put_GlobalAlpha(true, contentOpacity);
for (var nChild = 0; nChild < this.children.length; ++nChild) {
this.children[nChild].draw(graphics);
}
graphics.put_GlobalAlpha(false);
return true;
};
CButton.prototype.getContentOpacity = function () {
if (this.isDisabled()) { return 0.6 }
return 1;
}
CButton.prototype.getFillColor = function () {
const oSkin = AscCommon.GlobalSkin;
if (this.isDisabled()) { return null; }
if (this.isHovered()) { return oSkin.AnimPaneButtonFillHovered; }
if (this.sName === 'playButton') { return oSkin.type === 'light' ? oSkin.AnimPanePlayButtonFill : null; }
return null;
};
CButton.prototype.getOutlineColor = function () {
if (this.sName === 'playButton') { return AscCommon.GlobalSkin.AnimPanePlayButtonOutline; }
return null;
};
CButton.prototype.isPressed = function () {
return this.getStateFlag(STATE_FLAG_PRESSED);
};
CButton.prototype.disable = function () {
return this.setStateFlag(STATE_FLAG_DISABLED, true)
};
CButton.prototype.enable = function () {
return this.setStateFlag(STATE_FLAG_DISABLED, false)
};
CButton.prototype.isDisabled = function () {
return this.getStateFlag(STATE_FLAG_DISABLED);
};
function CAnimPaneHeader(oDrawer) {
CTopControl.call(this, oDrawer);
this.label = this.addControl(new CLabel(this, 'Animation Pane', HEADER_LABEL_FONTSIZE, true, AscCommon.align_Left));
this.playButton = this.addControl(new CButton(this, null, null, managePreview));
this.playButton.sName = 'playButton';
this.playButton.icon = this.playButton.addControl(new CImageControl(
this.playButton, null,
10 * AscCommon.g_dKoef_pix_to_mm, 10 * AscCommon.g_dKoef_pix_to_mm /* 10x10 svg icon (play and stop icons both) */
));
this.playButton.label = this.playButton.addControl(new CLabel(this.playButton, '', PLAY_BUTTON_LABEL_FONTSIZE));
this.moveUpButton = this.addControl(new CButton(this, null, null, moveChosenUp));
this.moveUpButton.icon = this.moveUpButton.addControl(new CImageControl(
this.moveUpButton,
AscCommon.GlobalSkin.type == 'light' ? arrowUpIcon_dark : arrowUpIcon_light,
12 * AscCommon.g_dKoef_pix_to_mm, 7 * AscCommon.g_dKoef_pix_to_mm /* 12x7 svg icon*/
));
this.moveDownButton = this.addControl(new CButton(this, null, null, moveChosenDown));
this.moveDownButton.icon = this.moveDownButton.addControl(new CImageControl(
this.moveDownButton,
AscCommon.GlobalSkin.type == 'light' ? arrowDownIcon_dark : arrowDownIcon_light,
12 * AscCommon.g_dKoef_pix_to_mm, 7 * AscCommon.g_dKoef_pix_to_mm /* 12x7 svg icon*/
));
this.closeButton = this.addControl(new CButton(this, null, null, closePanel));
this.closeButton.icon = this.closeButton.addControl(new CImageControl(
this.closeButton,
AscCommon.GlobalSkin.type == 'light' ? closeIcon_dark : closeIcon_light,
10 * AscCommon.g_dKoef_pix_to_mm, 10 * AscCommon.g_dKoef_pix_to_mm /* 10x10 svg icon*/
));
// Event handlers for button of CAnimPaneHeader ---
function managePreview(event, x, y) {
if (!this.hit(x, y)) { return; }
if (this.isDisabled()) { return; }
if(Asc.editor.asc_IsStartedAnimationPreview()) {
Asc.editor.asc_StopAnimationPreview();
} else {
const timing = this.parentControl.getTiming();
const bIncludeFollowing = timing && (timing.getSelectedEffects().length === 1);
Asc.editor.asc_StartAnimationPreview(this.parentControl.isStartAllPreview(), bIncludeFollowing);
}
}
function moveChosenUp(event, x, y) {
if (!this.hit(x, y)) { return }
if (this.isDisabled()) { return }
if (Asc.editor.asc_canMoveAnimationEarlier()) {
if (Asc.editor.asc_IsStartedAnimationPreview()) {
Asc.editor.asc_StopAnimationPreview()
}
Asc.editor.asc_moveAnimationEarlier()
}
}
function moveChosenDown(event, x, y) {
if (!this.hit(x, y)) { return }
if (this.isDisabled()) { return }
if (Asc.editor.asc_canMoveAnimationLater()) {
if (Asc.editor.asc_IsStartedAnimationPreview()) {
Asc.editor.asc_StopAnimationPreview()
}
Asc.editor.asc_moveAnimationLater()
}
}
function closePanel(event, x, y) {
if (!this.hit(x, y)) { return }
if (this.isDisabled()) { return }
Asc.editor.asc_ShowAnimPane(false);
Asc.editor.sendEvent('asc_onCloseAnimPane');
}
// --- end of event handlers for buttons of CAnimPaneHeader
}
InitClass(CAnimPaneHeader, CTopControl, CONTROL_TYPE_HEADER);
CAnimPaneHeader.prototype.isStartAllPreview = function () {
const timing = this.getTiming();
if (!timing) { return true; }
const aSelectedEffects = timing.getSelectedEffects();
return aSelectedEffects.length === 0;
};
CAnimPaneHeader.prototype.getPlayButtonText = function () {
if (Asc.editor.asc_IsStartedAnimationPreview()) { return 'Stop'; }
if (this.isStartAllPreview()) { return 'Play All'; } // No timing or zero selected effects
if (this.getTiming().getSelectedEffects().length === 1) { return 'Play From'; } // One selected
return 'Play Selected'; // Many selected
};
CAnimPaneHeader.prototype.getPlayButtonIcon = function() {
let sPlayButtonIcon = "";
if(Asc.editor.asc_IsStartedAnimationPreview()) {
sPlayButtonIcon = AscCommon.GlobalSkin.type == 'light' ? stopIcon_dark : stopIcon_light;
}
else {
sPlayButtonIcon = AscCommon.GlobalSkin.type == 'light' ? playIcon_dark : playIcon_light;
}
return sPlayButtonIcon;
};
CAnimPaneHeader.prototype.checkLayout = function() {
AscFormat.ExecuteNoHistory(function () {
if(this.playButton.label.string !== this.getPlayButtonText()) {
this.recalculateChildrenLayout();
this.onUpdate();
}
}, this, []);
};
CAnimPaneHeader.prototype.recalculateChildrenLayout = function () {
let gap;
this.moveUpButton.icon.src =AscCommon.GlobalSkin.type == 'light' ? arrowUpIcon_dark : arrowUpIcon_light;
this.moveDownButton.icon.src = AscCommon.GlobalSkin.type == 'light' ? arrowDownIcon_dark : arrowDownIcon_light;
this.closeButton.icon.src = AscCommon.GlobalSkin.type == 'light' ? closeIcon_dark : closeIcon_light;
this.label.setLayout(COMMON_LEFT_MARGIN, 0, Math.min(HEADER_LABEL_WIDTH, this.label.cachedMaxWidth), this.getHeight());
let sPlayButtonText = this.getPlayButtonText();
let sPlayButtonIcon = this.getPlayButtonIcon();
this.playButton.icon.src = sPlayButtonIcon;
gap = (PLAY_BUTTON_HEIGHT - PLAY_BUTTON_ICON_SIZE) / 2;
this.playButton.icon.setLayout(PLAY_BUTTON_LEFT_PADDING, gap, PLAY_BUTTON_ICON_SIZE, PLAY_BUTTON_ICON_SIZE);
let oButtonLabel = this.playButton.label;
oButtonLabel.setString(sPlayButtonText);
let dLabelWidth = oButtonLabel.cachedMaxWidth;
oButtonLabel.setLayout(
this.playButton.icon.getRight() + PLAY_BUTTON_LABEL_LEFT_MARGIN,
0,
dLabelWidth,
PLAY_BUTTON_HEIGHT
);
oButtonLabel.recalculate();
this.playButton.setLayout(
this.label.getRight() + PLAY_BUTTON_LEFT_MARGIN,
(HEADER_HEIGHT - PLAY_BUTTON_HEIGHT) / 2,
this.playButton.icon.getRight() + PLAY_BUTTON_LABEL_LEFT_MARGIN + oButtonLabel.getWidth() + PLAY_BUTTON_RIGHT_PADDING,
PLAY_BUTTON_HEIGHT
);
this.moveUpButton.icon.setLayout(0, 0, MOVE_BUTTON_SIZE, MOVE_BUTTON_SIZE);
gap = (HEADER_HEIGHT - MOVE_BUTTON_SIZE) / 2;
this.moveUpButton.setLayout(
this.playButton.getRight() + MOVE_UP_BUTTON_LEFT_MARGIN,
gap,
MOVE_BUTTON_SIZE,
MOVE_BUTTON_SIZE
);
this.moveUpButton.recalculate();
this.moveDownButton.icon.setLayout(0, 0, MOVE_BUTTON_SIZE, MOVE_BUTTON_SIZE);
this.moveDownButton.setLayout(
this.moveUpButton.getRight() + MOVE_DOWN_BUTTON_LEFT_MARGIN,
gap,
MOVE_BUTTON_SIZE,
MOVE_BUTTON_SIZE
);
this.moveDownButton.recalculate();
this.closeButton.icon.setLayout(0, 0, CLOSE_BUTTON_SIZE, CLOSE_BUTTON_SIZE);
gap = (HEADER_HEIGHT - CLOSE_BUTTON_SIZE) / 2;
this.closeButton.setLayout(
this.getRight() - COMMON_RIGHT_MARGIN - CLOSE_BUTTON_SIZE,
gap,
CLOSE_BUTTON_SIZE,
CLOSE_BUTTON_SIZE
);
this.closeButton.recalculate();
};
CAnimPaneHeader.prototype.onMouseMove = function (e, x, y) {
const animPane = Asc.editor.WordControl.m_oAnimPaneApi;
animPane.SetCursorType('default', new CMouseMoveData());
for (var nChild = this.children.length - 1; nChild >= 0; --nChild) {
if (this.children[nChild].onMouseMove(e, x, y)) {
return true;
}
}
return CControl.prototype.onMouseMove.call(this, e, x, y);
};
function CTimelineContainer(oDrawer) {
CTopControl.call(this, oDrawer);
this.drawer = oDrawer;
this.zoomOutButton = this.addControl(
new CButton(this, null, null, function (e, x, y) {
if (this.hit(x, y)) editor.asc_ZoomOutTimeline();
})
);
this.zoomOutButton.icon = this.zoomOutButton.addControl(
new CImageControl(
this.zoomOutButton,
AscCommon.GlobalSkin.type == 'light' ? zoomOutIcon_dark : zoomOutIcon_light,
10 * AscCommon.g_dKoef_pix_to_mm, 1 * AscCommon.g_dKoef_pix_to_mm /* 10x1 svg image */
)
);
this.zoomLabel = this.addControl(new CLabel(this, 'Zoom', ZOOM_LABEL_FONTSIZE, false, AscCommon.align_Center));
this.zoomInButton = this.addControl(
new CButton(this, null, null, function (e, x, y) {
if (this.hit(x, y)) editor.asc_ZoomInTimeline();
})
);
this.zoomInButton.icon = this.zoomInButton.addControl(
new CImageControl(
this.zoomInButton,
AscCommon.GlobalSkin.type == 'light' ? zoomInIcon_dark : zoomInIcon_light,
11 * AscCommon.g_dKoef_pix_to_mm, 11 * AscCommon.g_dKoef_pix_to_mm /* 11x11 svg image */
)
);
this.timeline = this.addControl(new CTimeline(this));
this.onMouseDownCallback = function (event, x, y) {
if(Asc.editor.asc_IsStartedAnimationPreview()) {
Asc.editor.asc_StopAnimationPreview();
}
}
}
InitClass(CTimelineContainer, CTopControl, CONTROL_TYPE_TIMELINE_CONTAINER);
CTimelineContainer.prototype.recalculateChildrenLayout = function () {
this.zoomOutButton.icon.src = AscCommon.GlobalSkin.type == 'light' ? zoomOutIcon_dark : zoomOutIcon_light;
this.zoomInButton.icon.src = AscCommon.GlobalSkin.type == 'light' ? zoomInIcon_dark : zoomInIcon_light;
this.zoomInButton.setLayout(
TIMELINE_SCROLL_ABSOLUTE_LEFT - TIMELINE_HEIGHT + (TIMELINE_HEIGHT - ZOOM_BUTTON_SIZE) / 2,
(TIMELINE_HEIGHT - ZOOM_BUTTON_SIZE) / 2,
ZOOM_BUTTON_SIZE,
ZOOM_BUTTON_SIZE
);
this.zoomInButton.icon.setLayout(0, 0, ZOOM_BUTTON_SIZE, ZOOM_BUTTON_SIZE);
const nZoomLabelWidth = Math.min(this.zoomLabel.cachedMaxWidth, ZOOM_LABEL_WIDTH) + 2 * ZOOM_LABEL_MARGIN;
this.zoomLabel.setLayout(
this.zoomInButton.getLeft() - nZoomLabelWidth,
0,
nZoomLabelWidth,
this.getHeight()
);
this.zoomOutButton.setLayout(
this.zoomLabel.getLeft() - ZOOM_BUTTON_SIZE,
(TIMELINE_HEIGHT - ZOOM_BUTTON_SIZE) / 2,
ZOOM_BUTTON_SIZE,
ZOOM_BUTTON_SIZE
);
this.zoomOutButton.icon.setLayout(0, 0, ZOOM_BUTTON_SIZE, ZOOM_BUTTON_SIZE);
const timelineWidth = this.getWidth() -
(COMMON_LEFT_MARGIN + COMMON_RIGHT_MARGIN) -
(SCALE_BUTTON_LEFT_MARGIN + SCALE_BUTTON_WIDTH + TIMELINE_SCROLL_LEFT_MARGIN) - (ANIM_ITEM_HEIGHT - MENU_BUTTON_SIZE) / 2;
this.timeline.setLayout(
TIMELINE_SCROLL_ABSOLUTE_LEFT,
(TIMELINE_HEIGHT - TIMELINE_SCROLL_HEIGHT) / 2,
timelineWidth,
TIMELINE_SCROLL_HEIGHT
);
};
CTimelineContainer.prototype.draw = function (graphics) {
if (!CTopControl.prototype.draw.call(this, graphics)) {
return false;
}
// this.clipStart(graphics);
for (var nChild = 0; nChild < this.children.length; ++nChild) {
this.children[nChild].draw(graphics);
}
// graphics.RemoveClipRect();
// this.clipEnd(graphics);
return true;
};
CTimelineContainer.prototype.onMouseDown = function (e, x, y) {
if (this.onMouseDownCallback && this.onMouseDownCallback.call(this, e, x, y)) {
return true;
}
return CTopControl.prototype.onMouseDown.call(this, e, x, y);
};
function CTimeline(oParentControl, oContainer, oChild) {
CControlContainer.call(this, oParentControl);
this.container = oContainer;
this.scrolledChild = oChild;
this.isScrollerHovered;
this.isStickedToPointer;
this.startButton = this.addControl(new CButton(this, onFirstBtnMouseDown, null, onMouseUp));
this.startButton.icon = this.startButton.addControl(new CImageControl(
this.startButton,
AscCommon.GlobalSkin.type == 'light' ? arrowLeftIcon_dark : arrowLeftIcon_light,
5 * AscCommon.g_dKoef_pix_to_mm, 9 * AscCommon.g_dKoef_pix_to_mm /* 5x9 svg image */
));
this.endButton = this.addControl(new CButton(this, onSecondBtnMouseDown, null, onMouseUp));
this.endButton.icon = this.endButton.addControl(new CImageControl(
this.endButton,
AscCommon.GlobalSkin.type == 'light' ? arrowRightIcon_dark : arrowRightIcon_light,
5 * AscCommon.g_dKoef_pix_to_mm, 9 * AscCommon.g_dKoef_pix_to_mm /* 5x9 svg image */
));
function onFirstBtnMouseDown(e, x, y) {
if (!this.hit(x, y)) { return }
this.parentControl.setEventListener(this);
let step = SCROLL_STEP * this.parentControl.getWidth()
this.parentControl.startScroll(-step);
return true;
}
function onSecondBtnMouseDown(e, x, y) {
if (!this.hit(x, y)) { return }
this.parentControl.setEventListener(this);
let step = SCROLL_STEP * this.parentControl.getWidth()
this.parentControl.startScroll(step);
return true;
}
function onMouseUp(e, x, y) {
if (this.parentControl.isEventListener(this)) {
this.parentControl.setEventListener(null);
this.parentControl.endScroll();
return true;
}
return false;
}
this.timerId = null;
this.timeoutId = null;
// This fields supposed to be private
// so it should not be changed directly.
// Use set methods instead (setScrollOffset, setStartTime)
this.scrollOffset = 0; // in millimeters
this.startTime = 0; // in seconds
this.timeScaleIndex = 2;
// Tmp field for demoPreview
this.tmpScrollOffset = null;
// Labels cache
this.labels = {};
this.usedLabels = {};
this.cachedParaPr = null
this.onMouseDownCallback = function stickToPointer(event, x, y) {
if (!this.hitInScroller(x, y)) { return; }
this.isStickedToPointer = true;
this.onUpdate()
}
this.onMouseUpCallback = function unstickFromPointer(event, x, y) {
this.isStickedToPointer = false;
if (this.isOnScroll()) { this.endScroll(); }
this.onUpdate();
}
this.onMouseMoveCallback = function handlePointerMovement(event, x, y) {
// Updating hover state of the scroller
const tmpIsScrollerHovered = this.hitInScroller(x, y);
if (this.isScrollerHovered !== tmpIsScrollerHovered) {
this.isScrollerHovered = tmpIsScrollerHovered;
this.onUpdate();
}
if (!this.isStickedToPointer) { return; }
let oInv = this.getInvFullTransformMatrix();
let tx = oInv.TransformPointX(x, y);
let newScrollOffset = tx - this.getRulerStart() - TIMELINE_SCROLLER_WIDTH / 2;
// Check if the boundaried are reached and start scrolling if so
let leftBorder = this.getRulerStart();
let rightBorder = this.getRulerEnd();
if (tx <= leftBorder || tx >= rightBorder) {
if (!this.isOnScroll()) {
let scrollStep = this.getWidth() * SCROLL_STEP / 10;
scrollStep = tx <= leftBorder ? -scrollStep : scrollStep;
let scrollTimerDelay = 0;
let scrollTimerInterval = 50;
this.startScroll(scrollStep, scrollTimerDelay, scrollTimerInterval);
}
}
else this.endScroll();
// Updating scrollOffset
this.setScrollOffset(newScrollOffset)
}
}
InitClass(CTimeline, CControlContainer, CONTROL_TYPE_TIMELINE);
CTimeline.prototype.limitScrollOffset = function (newScrollOffset /* in millimeters */) {
return Math.max(0, Math.min(newScrollOffset, this.getMaxScrollOffset()));
};
CTimeline.prototype.getScrollOffset = function () {
return this.tmpScrollOffset !== null ? this.tmpScrollOffset : this.scrollOffset;
};
CTimeline.prototype.setScrollOffset = function (newScrollOffset /* in millimeters */) {
let oldScrollOffset = this.getScrollOffset()
this.scrollOffset = this.limitScrollOffset(newScrollOffset)
let difference = this.posToTime(this.getScrollOffset()) - this.posToTime(oldScrollOffset) // difference in seconds
this.setStartTime(this.getStartTime() + difference)
this.parentControl.onScroll();
this.onUpdate();
};
CTimeline.prototype.getMaxScrollOffset = function () {
return this.getWidth() - 2 * TIMELINE_SCROLL_BUTTON_SIZE - TIMELINE_SCROLLER_WIDTH;
};
CTimeline.prototype.getStartTime = function () {
return this.startTime;
};
CTimeline.prototype.setStartTime = function (newStartTime /* in seconds */) {
this.startTime = Math.max(0, newStartTime)
this.parentControl.onScroll();
this.onUpdate();
// also updating seqList to redraw effect bars
editor.WordControl.m_oAnimPaneApi.list.Control.seqList.onUpdateSeqList()
};
CTimeline.prototype.getCurrentTime = function() {
return this.posToTime(this.getScrollOffset() + this.startButton.getWidth() + TIMELINE_SCROLLER_WIDTH / 2)
}
CTimeline.prototype.startScroll = function (step /* in millimeters */, scrollTimerDelay, scrollTimerInterval) {
if (typeof scrollTimerDelay === 'undefined') { scrollTimerDelay = SCROLL_TIMER_DELAY }
if (typeof scrollTimerInterval === 'undefined') { scrollTimerInterval = SCROLL_TIMER_INTERVAL }
this.endScroll();
var oScroll = this;
oScroll.addScroll(step);
this.timeoutId = setTimeout(function () {
oScroll.timeoutId = null;
oScroll.timerId = setInterval(function () {
oScroll.addScroll(step);
}, scrollTimerInterval);
}, scrollTimerDelay);
};
CTimeline.prototype.addScroll = function (step /* in millimeters */) {
let newStartTime = this.posToTime(this.getZeroShift() + step)
const seqList = editor.WordControl.m_oAnimPaneApi.list.Control.seqList
seqList.forEachAnimItem(function (animItem) {
if (!animItem.hitResult) { return }
animItem.handleTimelineScroll(step);
})
this.setStartTime(newStartTime)
};
CTimeline.prototype.endScroll = function () {
if (this.timerId !== null) {
clearInterval(this.timerId);
this.timerId = null;
}
if (this.timeoutId !== null) {
clearTimeout(this.timeoutId);
this.timeoutId = null;
}
this.setStateFlag(STATE_FLAG_SELECTED, false);
};
CTimeline.prototype.isOnScroll = function () {
return this.timerId !== null || this.timeoutId !== null;
// return this.timerId !== null || this.timeoutId !== null || this.parentControl.isEventListener(this);
};
CTimeline.prototype.startDrawLabels = function () {
this.usedLabels = {};
};
CTimeline.prototype.endDrawLabels = function () {
for (var nTime in this.labels) {
if (!this.usedLabels[nTime]) {
var oLabel = this.labels[nTime];
oLabel.parentControl = null;
oLabel.bDeleted = true;
delete this.labels[nTime];
}
}
};
CTimeline.prototype.getLabel = function (nTime, scale) {
this.usedLabels[nTime] = true;
if (this.labels[nTime] && AscFormat.fApproxEqual(this.labels[nTime].scale, scale, 0.01)) {
return this.labels[nTime];
}
return this.cacheLabel(nTime, scale);
};
CTimeline.prototype.cacheLabel = function (nTime, scale) {
return AscFormat.ExecuteNoHistory(function () {
var oLabel = new CLabel(this, this.getTimeString(nTime), TIMELINE_LABEL_FONTSIZE, false, AscCommon.align_Center);
var oContent = oLabel.txBody.content;
oLabel.setLayout(0, 0, TIMELINE_LABEL_WIDTH, this.getHeight());
if (this.cachedParaPr) {
oContent.Content[0].CompiledPr = this.cachedParaPr;
} else {
oContent.SetApplyToAll(true);
oContent.SetParagraphAlign(AscCommon.align_Center);
oContent.SetApplyToAll(false);
}
oLabel.recalculate();
if (!this.cachedParaPr) {
this.cachedParaPr = oContent.Content[0].CompiledPr;
}
var oBaseTexture = oLabel.getAnimTexture(scale);
if (oBaseTexture) {
this.labels[nTime] = new CAnimTexture(this, oBaseTexture.canvas, oBaseTexture.scale, oBaseTexture.x, oBaseTexture.y);
}
return this.labels[nTime];
}, this, []);
};
CTimeline.prototype.getTimeString = function (nTime) {
if (nTime < 60) {
return "" + nTime;
}
const nSeconds = nTime % 60;
const nMinutes = ((nTime / 60) >> 0) % 60;
let sSeconds = padZero(nSeconds);
let sMinutes = padZero(nMinutes);
if (nTime < 3600) {
return (sMinutes + ":") + sSeconds;
}
return (((nTime / 3600) >> 0) + ":") + sMinutes + ":" + sSeconds;
function padZero(number) {
return number < 10 ? "0" + number : "" + number;
}
};
CTimeline.prototype.drawLabel = function (graphics, dPos, nTime) {
var oLabelTexture = this.getLabel(nTime, graphics.m_oCoordTransform.sx);
var oMatrix = new AscCommon.CMatrix();
var dWidth = oLabelTexture.canvas.width / oLabelTexture.scale;
var dHeight = oLabelTexture.canvas.height / oLabelTexture.scale;
graphics.drawImage2(oLabelTexture.canvas,
dPos - dWidth / 2, this.getHeight() / 2 - dHeight / 2,
dWidth,
dHeight);
// var oContent = oLabel.txBody.content;
// oContent.ShiftView(dPos - TIMELINE_LABEL_WIDTH / 2, this.getHeight() / 2 - oContent.GetSummaryHeight() / 2);
// oContent.Draw(0, graphics);
// oContent.ResetShiftView();
};
CTimeline.prototype.drawMark = function (graphics, dPos) {
var dHeight = this.getHeight() / 3;
var nPenW = this.getPenWidth(graphics);
graphics.drawVerLine(1, dPos, dHeight, dHeight + dHeight, nPenW);
};
CTimeline.prototype.start = function (graphics, dPos) {
var dHeight = this.getHeight() / 3;
var nPenW = this.getPenWidth(graphics);
graphics.drawVerLine(1, dPos, dHeight, dHeight + dHeight, nPenW);
};
CTimeline.prototype.handleUpdateExtents = function () {
this.labels = {};
this.usedLabels = {};
this.cachedParaPr = null;
if(this.startButton && this.endButton) {
this.startButton.icon.src = AscCommon.GlobalSkin.type == 'light' ? arrowLeftIcon_dark : arrowLeftIcon_light;
this.endButton.icon.src = AscCommon.GlobalSkin.type == 'light' ? arrowRightIcon_dark : arrowRightIcon_light;
}
CControlContainer.prototype.handleUpdateExtents.call(this);
};
CTimeline.prototype.draw = function (graphics) {
if (this.isHidden()) { return false }
if (!this.checkUpdateRect(graphics.updatedRect)) { return false }
this.getStartTime() === 0 ? this.startButton.disable() : this.startButton.enable();
graphics.SaveGrState();
// var dPenW = this.getPenWidth(graphics);
// graphics.SetIntegerGrid(true);
// graphics.p_width(dPenW);
// var sColor = this.children[0].getOutlineColor();
// var oColor = AscCommon.RgbaHexToRGBA(sColor);
// graphics.p_color(oColor.R, oColor.G, oColor.B, 255);
// var dPaneLeft = this.children[0].getRight();
// var dPaneWidth = this.getWidth() - (this.children[0].getWidth() + this.children[1].getWidth());
// graphics.rect(dPaneLeft, 0, dPaneWidth, this.getHeight());
// graphics.ds();
// graphics.RestoreGrState();
const sColor = AscCommon.GlobalSkin.AnimPaneTimelineRulerOutline;
var oColor = AscCommon.RgbaHexToRGBA(sColor);
var dPaneLeft = this.getRulerStart();
var dPaneWidth = this.getRulerEnd() - dPaneLeft;
var x = dPaneLeft;
var y = 0;
var extX = dPaneWidth;
var extY = this.getHeight();
graphics.transform3(this.transform);
graphics.SetIntegerGrid(true);
var nPenW = this.getPenWidth(graphics);
graphics.p_color(oColor.R, oColor.G, oColor.B, 0xFF);
graphics.drawHorLine(0, y, x, x + extX, nPenW);
graphics.drawHorLine(0, y + extY, x, x + extX, nPenW);
graphics.drawVerLine(2, x, y, y + extY, nPenW);
graphics.drawVerLine(2, x + extX, y, y + extY, nPenW);
graphics.ds();
//draw marks
//find first visible
var fStartTime = this.posToTime(this.getRulerStart());
var fTimeInterval = TIME_SCALES[this.timeScaleIndex];
var nMarksCount = TIME_INTERVALS[this.timeScaleIndex] === LONG_TIME_INTERVAL ? 10 : 2;
var dTimeOfSmallInterval = fTimeInterval / nMarksCount;
var nStartIntervalIdx = this.startTime / dTimeOfSmallInterval >> 0;
var nEndIntervalIdx = this.posToTime(this.getRulerEnd()) / dTimeOfSmallInterval + 0.5 >> 0;
this.startDrawLabels();
graphics.SaveGrState();
var nInterval;
graphics.AddClipRect(x, y, extX, extY);
oColor = AscCommon.RgbaHexToRGBA(AscCommon.GlobalSkin.AnimPaneTimelineRulerTick);
graphics.p_color(oColor.R, oColor.G, oColor.B, 0xFF);
for (nInterval = nStartIntervalIdx; nInterval <= nEndIntervalIdx; ++nInterval) {
var dTime = nInterval * dTimeOfSmallInterval;
var dPos = this.timeToPos(dTime);
if (nInterval % nMarksCount !== 0) {
this.drawMark(graphics, dPos);
} else {
this.drawLabel(graphics, dPos, dTime);
}
}
graphics.ds();
// for(nInterval = nFirstInterval; nInterval <= nLastInterval; ++nInterval) {
// var dTime = nInterval*dSmallInterval;
// var dPos = this.timeToPos(dTime);
// if(nInterval % nMarksCount === 0) {
// this.drawLabel(graphics, dPos, dTime);
// }
// }
graphics.RestoreGrState();
this.endDrawLabels();
//
this.drawScroller(graphics);
graphics.RestoreGrState();
if (!CControlContainer.prototype.draw.call(this, graphics)) {
return false;
}
};
CTimeline.prototype.drawScroller = function (graphics) {
let x = this.getRulerStart() + this.getScrollOffset();
let y = 0;
let extX = TIMELINE_SCROLLER_WIDTH;
let extY = this.getHeight();
const oSkin = AscCommon.GlobalSkin;
const oFillColor = AscCommon.RgbaHexToRGBA(oSkin.AnimPaneTimelineScrollerFill);
let nOpacity;
if (this.isStickedToPointer) {
nOpacity = 0.5;//oSkin.AnimPaneTimelineScrollerOpacityActive;
} else if (this.isScrollerHovered) {
nOpacity = oSkin.AnimPaneTimelineScrollerOpacityHovered;
} else {
nOpacity = oSkin.AnimPaneTimelineScrollerOpacity;
}
graphics.b_color1(oFillColor.R, oFillColor.G, oFillColor.B, nOpacity * 255);
graphics.rect(x, y, extX, extY);
graphics.df();
let nPenW = this.getPenWidth(graphics);
let sColor = oSkin.AnimPaneTimelineScrollerOutline;
let oColor = AscCommon.RgbaHexToRGBA(sColor);
graphics.p_color(oColor.R, oColor.G, oColor.B, 0xFF);
graphics.drawHorLine(0, y, x, x + extX, nPenW);
graphics.drawHorLine(0, y + extY, x, x + extX, nPenW);
graphics.drawVerLine(2, x, y, y + extY, nPenW);
graphics.drawVerLine(2, x + extX, y, y + extY, nPenW);
if (this.tmpScrollOffset !== null) {
graphics.SaveGrState();
graphics.RemoveClipRect();
// const seqList = Asc.editor.WordControl.m_oAnimPaneApi.list.Control.seqList
// graphics.drawVerLine(1, x + extX / 2, seqList.getTop(), y, nPenW);
graphics.drawVerLine(1, x + extX / 2, y - 1000, y, nPenW);
graphics.RestoreGrState();
}
return true;
};
CTimeline.prototype.hitInScroller = function(x, y) {
// x, y - relatively to this.parentContainer
// tx, ty - relatively to this
let oInv = this.getInvFullTransformMatrix();
let tx = oInv.TransformPointX(x, y);
let ty = oInv.TransformPointY(x, y);
let l = this.getRulerStart() + this.getScrollOffset();
let t = 0;
let r = l + TIMELINE_SCROLLER_WIDTH;
let b = t + this.getHeight();
return tx >= l && tx <= r && ty >= t && ty <= b;
}
CTimeline.prototype.onPreviewStart = function() {
AscFormat.ExecuteNoHistory(function () {
this.tmpScrollOffset = 0;
this.setStartTime(0);
const previewTimings = Asc.editor.WordControl.m_oLogicDocument.previewPlayer.timings;
this.demoTiming = previewTimings[0]; // effects are smoothed to follow each other
this.rawDemoTiming = previewTimings[1]; // timing with only effects for preview (without smoothing)
const oPaneApi = Asc.editor.WordControl.m_oAnimPaneApi;
oPaneApi.list.Control.recalculateByTiming(this.rawDemoTiming);
oPaneApi.header.Control.recalculateChildrenLayout();
oPaneApi.header.OnPaint();
oPaneApi.timeline.OnPaint();
oPaneApi.list.OnPaint();
// this.onUpdate();
}, this, []);
}
CTimeline.prototype.onPreviewStop = function() {
AscFormat.ExecuteNoHistory(function () {
this.demoTiming = null;
this.rawDemoTiming = null;
this.tmpScrollOffset = null;
this.setStartTime(0);
const oPaneApi = Asc.editor.WordControl.m_oAnimPaneApi;
oPaneApi.list.Control.recalculateByTiming(this.getTiming());
oPaneApi.header.Control.recalculateChildrenLayout();
oPaneApi.header.OnPaint();
oPaneApi.timeline.OnPaint();
oPaneApi.list.OnPaint();
// this.onUpdate();
}, this, []);
}
CTimeline.prototype.onPreview = function(elapsedTicks) {
if (this.tmpScrollOffset === null) { return; }
if (!this.demoTiming) { return; }
const currentlyPlayingDemoEffects = this.getCurrentlyPlayingDemoEffects(elapsedTicks);
const currentlyPlayingDemoEffect = currentlyPlayingDemoEffects[0]; // first in group
const correction = (currentlyPlayingDemoEffect)
? currentlyPlayingDemoEffect.originalNode.getBaseTime() - currentlyPlayingDemoEffect.getBaseTime()
: 0;
this.tmpScrollOffset = this.getNewTmpScrollOffset(elapsedTicks, correction);
const seqList = Asc.editor.WordControl.m_oAnimPaneApi.list.Control.seqList;
seqList.setCurrentlyPlaying(currentlyPlayingDemoEffects);
// this.parentControl.drawer == editor.WordControl.m_oAnimPaneApi.timeline
Asc.editor.WordControl.m_oAnimPaneApi.timeline.OnPaint();
Asc.editor.WordControl.m_oAnimPaneApi.list.OnPaint();
}
CTimeline.prototype.getCurrentlyPlayingDemoEffects = function (elapsedTicks) {
const demoEffects = this.demoTiming.getRootSequences()[0].getAllEffects();
const rawDemoEffects = this.rawDemoTiming.getRootSequences()[0].getAllEffects();
rawDemoEffects.forEach(function (effect, index) {
effect.originalDemoNode = demoEffects[index];
});
// Getting level 3 Time Node Containers
// Each contains either 'after'-effect or 'click'-effect with mulpiple 'with'-effects
const lvl3DemoTimingNodes = this.demoTiming.getRootSequences(0)[0].getChildrenTimeNodes()[0].getChildrenTimeNodes();
// Getting first active level 3 Time Node Container
// to get currently active demo effect
let activeDemoEffect = null;
for (let nodeIndex = lvl3DemoTimingNodes.length - 1; nodeIndex >= 0; --nodeIndex) {
const node = lvl3DemoTimingNodes[nodeIndex];
if (node.isActive()) {
activeDemoEffect = node.getAllAnimEffects()[0];
break;
}
}
if(activeDemoEffect) {
// Get index of active demo effect (in array of all raw demo effects)
let activeDemoEffectIndex;
for (let nEffect = 0; nEffect < rawDemoEffects.length; nEffect++) {
if (rawDemoEffects[nEffect].originalNode === activeDemoEffect.originalNode) {
activeDemoEffectIndex = nEffect;
break;
}
}
// Get group of active raw demo effects and their corresponding demo effects
const activeRawDemoEffects = rawDemoEffects[activeDemoEffectIndex].getTimeNodeWithLvl(2).getAllAnimEffects();
const activeDemoEffects = activeRawDemoEffects.map(function (rawEffect) {
return rawEffect.originalDemoNode;
});
return activeDemoEffects;
}
return [];
};
CTimeline.prototype.getNewTmpScrollOffset = function (elapsedTicks, correction) {
const leftLimit = 0;
const rightLimit = this.getRulerEnd() - this.getZeroShift();
let newTmpScrollOffset = ms_to_mm(elapsedTicks + correction) - ms_to_mm(this.getStartTime() * 1000);
if (newTmpScrollOffset < leftLimit) {
this.setStartTime(0);
newTmpScrollOffset = 0;
}
if (newTmpScrollOffset > rightLimit) {
const rulerDur = mm_to_ms(this.getRulerEnd() - this.getRulerStart()) / 1000; // seconds
this.setStartTime(this.getStartTime() + rulerDur / 2);
newTmpScrollOffset -= ms_to_mm(rulerDur / 2);
}
return newTmpScrollOffset;
function ms_to_mm(nMilliseconds) {
const index = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline.timeScaleIndex;
return nMilliseconds * TIME_INTERVALS[index] / TIME_SCALES[index] / 1000;
}
function mm_to_ms(nMillimeters) {
const index = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline.timeScaleIndex;
return nMillimeters / TIME_INTERVALS[index] * TIME_SCALES[index] * 1000;
}
};
CTimeline.prototype.getRulerStart = function () {
return this.startButton.getRight();
};
CTimeline.prototype.getRulerEnd = function () {
return this.getWidth() - this.endButton.getWidth();
};
CTimeline.prototype.getZeroShift = function () {
// Returns the value (in millimeters) of the left margin of the start of the ruler
return this.getRulerStart() + TIMELINE_SCROLLER_WIDTH / 2;
};
/*
* Functions to convert time to pos and vice versa
*/
CTimeline.prototype.getLinearCoeffs = function () {
//linear relationship x = a*t + b
var a = TIME_INTERVALS[this.timeScaleIndex] / TIME_SCALES[this.timeScaleIndex];
var b = this.getZeroShift() - a * this.startTime;
return { a: a, b: b };
};
CTimeline.prototype.timeToPos = function (fTime) {
//linear relationship x = a*t + b
var oCoefs = this.getLinearCoeffs();
return oCoefs.a * fTime + oCoefs.b;
};
CTimeline.prototype.posToTime = function (fPos) {
//linear relationship x = a*t + b
var oCoefs = this.getLinearCoeffs();
return (fPos - oCoefs.b) / oCoefs.a;
};
CTimeline.prototype.changeTimelineScale = function (bZoomOut) {
this.timeScaleIndex = bZoomOut ?
Math.min(this.timeScaleIndex + 1, TIME_SCALES.length - 1) :
Math.max(this.timeScaleIndex - 1, 0)
this.onUpdate();
// also updating seqList to redraw effect bars
editor.WordControl.m_oAnimPaneApi.list.Control.seqList.onUpdateSeqList();
}
CTimeline.prototype.canHandleEvents = function () {
return true;
};
CTimeline.prototype.recalculateChildrenLayout = function () {
this.startButton.setLayout(0, 0, TIMELINE_SCROLL_BUTTON_SIZE, TIMELINE_SCROLL_BUTTON_SIZE);
this.startButton.icon.setLayout(0, 0, TIMELINE_SCROLL_BUTTON_SIZE, TIMELINE_SCROLL_BUTTON_SIZE);
this.endButton.setLayout(this.getWidth() - TIMELINE_SCROLL_BUTTON_SIZE, 0, TIMELINE_SCROLL_BUTTON_SIZE, TIMELINE_SCROLL_BUTTON_SIZE);
this.endButton.icon.setLayout(0, 0, TIMELINE_SCROLL_BUTTON_SIZE, TIMELINE_SCROLL_BUTTON_SIZE);
const currentScrollOffset = this.getScrollOffset()
if (currentScrollOffset >= this.getMaxScrollOffset()) {
this.setScrollOffset(currentScrollOffset)
}
};
CTimeline.prototype.onMouseDown = function (e, x, y) {
if (this.onMouseDownCallback && this.onMouseDownCallback.call(this, e, x, y)) {
return true;
}
return CControlContainer.prototype.onMouseDown.call(this, e, x, y);
};
CTimeline.prototype.onMouseMove = function (e, x, y) {
if (this.onMouseMoveCallback && this.onMouseMoveCallback.call(this, e, x, y)) {
return true;
}
return CControlContainer.prototype.onMouseMove.call(this, e, x, y);
};
CTimeline.prototype.onMouseUp = function (e, x, y) {
if (this.onMouseUpCallback && this.onMouseUpCallback.call(this, e, x, y)) {
return true;
}
return CControlContainer.prototype.onMouseUp.call(this, e, x, y);
};
function CSeqListContainer(oDrawer) {
CTopControl.call(this, oDrawer);
this.seqList = this.addControl(new CSeqList(this));
this.onMouseDownCallback = function (event, x, y) {
if(Asc.editor.asc_IsStartedAnimationPreview()) {
Asc.editor.asc_StopAnimationPreview();
}
if (this.seqList.hit(x, y)) { return }
this.seqList.forEachAnimItem(function (animItem) { animItem.effect.deselect() })
Asc.editor.WordControl.m_oLogicDocument.RedrawCurSlide()
Asc.editor.WordControl.m_oLogicDocument.Document_UpdateInterfaceState()
}
}
InitClass(CSeqListContainer, CTopControl, CONTROL_TYPE_SEQ_LIST_CONTAINER);
CSeqListContainer.prototype.recalculateChildrenLayout = function () {
this.seqList.setLayout(
COMMON_LEFT_MARGIN,
0,
this.getWidth() - COMMON_LEFT_MARGIN - COMMON_RIGHT_MARGIN,
this.seqList.getHeight());
this.seqList.recalculate();
this.setLayout(0, 0, this.getWidth(), this.seqList.getHeight());
};
CSeqListContainer.prototype.recalculateByTiming = function (customTiming) {
AscFormat.ExecuteNoHistory(function () {
if (!customTiming) { return; }
this.seqList.recalculateChildren(customTiming);
this.seqList.recalculateChildrenLayout();
this.seqList.parentControl.recalculateChildrenLayout();
this.seqList.parentControl.onUpdate();
this.seqList.parentControl.drawer.CheckScroll();
}, this, []);
};
CSeqListContainer.prototype.onScroll = function () {
this.onUpdate();
};
CSeqListContainer.prototype.onMouseWheel = function (e, deltaY, X, Y) {
return false;
};
CSeqListContainer.prototype.onMouseDown = function (e, x, y) {
if (this.onMouseDownCallback && this.onMouseDownCallback.call(this, e, x, y)) {
return true;
}
return CTopControl.prototype.onMouseDown.call(this, e, x, y);
};
function CSeqList(oParentControl) {
CControlContainer.call(this, oParentControl);
// this.children - mainSeq, interactiveSeq
this.indexLabelWidth = null;
// Tmp field for animItems moving up/down
this.pressingPoint = null;
this.nPressedSlot = null;
this.nCurrentSlot = null;
this.bTopPart = false;
this.getIndexLabelWidth = function () {
if (this.indexLabelWidth === null) {
let nMaxIndexWidth = 0;
this.forEachAnimItem(function (oAnimItem) {
if (oAnimItem.indexLabel) {
const nIndexWidth = oAnimItem.indexLabel.cachedMaxWidth;
if (nIndexWidth > nMaxIndexWidth) {
nMaxIndexWidth = nIndexWidth;
}
}
});
this.indexLabelWidth = Math.min(nMaxIndexWidth, INDEX_LABEL_WIDTH);
}
return this.indexLabelWidth;
};
this.onMouseDownCallback = function (event, x, y) {
const oThis = this;
this.forEachAnimItem(function (animItem, index, groupIndex, seqIndex) {
const hit = animItem.hit(x, y);
const hitInEffectBar = animItem.hitInEffectBar(x, y);
const hitInMenuButton = animItem.contextMenuButton.hit(x, y);
if (hit && !hitInEffectBar && !hitInMenuButton) {
oThis.nPressedSlot = index + seqIndex;
oThis.pressingPoint = { x: x, y: y };
}
})
this.onUpdate();
}
this.onMouseMoveCallback = function (event, x, y) {
if (this.nPressedSlot === null) { return }
const oThis = this;
const minRadius = 2; // in millimeters
const currentShift = Math.sqrt(Math.pow(oThis.pressingPoint.x - x, 2) + Math.pow(oThis.pressingPoint.y - y, 2));
const bDistancePassed = currentShift >= minRadius;
if (!bDistancePassed) { return }
let nLastCheckedSeq = null;
let hit = null;
this.forEachAnimItem(function (animItem, index, groupIndex, seqIndex) {
const seqLabel = oThis.children[seqIndex].label;
if (seqIndex !== nLastCheckedSeq && seqLabel !== null && seqLabel.hit(x, y)) {
hit = 'top';
nLastCheckedSeq = seqIndex;
} else {
hit = animItem.hit(x, y);
}
if (hit) {
oThis.nCurrentSlot = index + seqIndex;
oThis.bTopPart = (hit === 'top');
}
})
this.onUpdate();
}
this.onMouseUpCallback = function (event, x, y) {
if (this.nCurrentSlot !== null && this.nPressedSlot !== null) {
let moves = this.nCurrentSlot - this.nPressedSlot;
if (moves > 0 && this.bTopPart) { moves -= 1; }
if (moves < 0 && !this.bTopPart) { moves += 1; }
if (moves > 0) {
if (Asc.editor.asc_canMoveAnimationLater(moves)) {
Asc.editor.asc_moveAnimationLater(moves)
}
}
if (moves < 0) {
if (Asc.editor.asc_canMoveAnimationEarlier(Math.abs(moves))) {
Asc.editor.asc_moveAnimationEarlier(Math.abs(moves))
}
}
}
this.pressingPoint = null;
this.nPressedSlot = null;
this.nCurrentSlot = null;
this.onUpdate();
}
}
InitClass(CSeqList, CControlContainer, CONTROL_TYPE_SEQ_LIST);
CSeqList.prototype.recalculateChildren = function (oCustomTiming) {
this.clear();
const oTiming = oCustomTiming || this.getTiming();
if (!oTiming) { return }
const aAllSeqs = oTiming.getRootSequences();
let oLastSeqView = null; // Зачем нужна эта переменная?
for (var nSeq = 0; nSeq < aAllSeqs.length; ++nSeq) {
const oSeqView = new CAnimSequence(this, aAllSeqs[nSeq]);
this.addControl(oSeqView);
oLastSeqView = oSeqView;
}
};
CSeqList.prototype.recalculateChildrenLayout = function () {
this.indexLabelWidth = null;
let dLastBottom = 0;
for (let nChild = 0; nChild < this.children.length; ++nChild) {
const oSeq = this.children[nChild];
oSeq.setLayout(0, dLastBottom, this.getWidth(), 0);
oSeq.recalculate();
dLastBottom = oSeq.getBottom();
}
this.setLayout(this.getLeft(), this.getTop(), this.getWidth(), dLastBottom);
};
CSeqList.prototype.draw = function (graphics) {
if (!CControlContainer.prototype.draw.call(this, graphics)) { return false; }
// Draw horizontal line when animItem is moving
if (this.nCurrentSlot !== null) {
const oThis = this;
let currentAnimItem;
this.forEachAnimItem(function(animItem, index, groupIndex, seqIndex) {
if (index + seqIndex === oThis.nCurrentSlot) currentAnimItem = animItem;
})
const transformX = function (x, y) { return graphics.m_oFullTransform.TransformPointX(x, y) + 0.5 >> 0; }
const transformY = function (x, y) { return graphics.m_oFullTransform.TransformPointY(x, y) + 0.5 >> 0; }
const yCord = this.bTopPart ? currentAnimItem.bounds.t : currentAnimItem.bounds.b;
const triangle_diagonal_half = 1; // mm
const outerLeft = transformX(this.getLeft(), yCord);
const innerLeft = transformX(this.getLeft() + triangle_diagonal_half, yCord);
const innerRight = transformX(this.getRight() - triangle_diagonal_half, yCord);
const outerRight = transformX(this.getRight(), yCord);
const top = transformY(0, yCord - triangle_diagonal_half);
const center = transformY(0, yCord);
const bottom = transformY(0, yCord + triangle_diagonal_half);
graphics.SaveGrState();
graphics.RemoveClipRect();
let ctx = graphics.m_oContext;
ctx.beginPath();
ctx.moveTo(innerLeft, center);
ctx.lineTo(outerLeft, top);
ctx.lineTo(outerLeft, bottom);
ctx.lineTo(innerLeft, center);
ctx.lineTo(innerRight, center);
ctx.lineTo(outerRight, top);
ctx.lineTo(outerRight, bottom);
ctx.lineTo(innerRight, center);
graphics.df();
graphics.ds();
graphics.RestoreGrState();
}
// Draw preview line
const timeline = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline;
if (timeline.tmpScrollOffset !== null) {
graphics.SaveGrState();
graphics.RemoveClipRect();
let sColor = AscCommon.GlobalSkin.AnimPaneTimelineScrollerOutline;
let oColor = AscCommon.RgbaHexToRGBA(sColor);
graphics.p_color(oColor.R, oColor.G, oColor.B, 255);
const xCord = timeline.getLeft() + timeline.getZeroShift() + timeline.tmpScrollOffset;
const height = this.parentControl.drawer.GetHeight() + editor.WordControl.m_oAnimPaneApi.list.Scroll * g_dKoef_pix_to_mm;
graphics.drawVerLine(1, xCord, this.getTop(), this.getTop() + height, this.getPenWidth(graphics));
graphics.RestoreGrState();
}
return true;
}
CSeqList.prototype.onMouseDown = function (e, x, y) {
if (this.onMouseDownCallback) this.onMouseDownCallback(e, x, y);
return CControlContainer.prototype.onMouseDown.call(this, e, x, y);
};
CSeqList.prototype.onMouseMove = function (e, x, y) {
if (this.onMouseMoveCallback) this.onMouseMoveCallback(e, x, y);
return CControlContainer.prototype.onMouseMove.call(this, e, x, y);
};
CSeqList.prototype.onMouseUp = function (e, x, y) {
if (this.onMouseUpCallback) this.onMouseUpCallback(e, x, y);
return CControlContainer.prototype.onMouseUp.call(this, e, x, y);
};
CSeqList.prototype.onUpdateSeqList = function () {
if (Asc.editor.WordControl.m_oAnimPaneApi.list.Control) {
this.onUpdate()
}
}
CSeqList.prototype.checkCachedTexture = function (graphics) {
var dGraphicsScale = graphics.m_oCoordTransform.sx;
if (this.cachedCanvas) {
var dScale = this.cachedCanvas.scale;
if (AscFormat.fApproxEqual(dScale, dGraphicsScale)) {
return this.cachedCanvas;
}
}
this.bDrawTexture = true;
var oBaseTexture = this.getAnimTexture(dGraphicsScale);
if (oBaseTexture) {
this.cachedCanvas = new CAnimTexture(this, oBaseTexture.canvas, oBaseTexture.scale, oBaseTexture.x, oBaseTexture.y);
}
else {
this.cachedCanvas = null;
}
this.bDrawTexture = false;
return this.cachedCanvas;
};
CSeqList.prototype.clearCachedTexture = function () {
if (this.cachedCanvas) {
this.cachedCanvas = null;
}
};
CSeqList.prototype.setCurrentlyPlaying = function (demoEffects) {
if (!demoEffects) { return; }
const originalEffects = demoEffects.map(
function (demoEffect) {
return demoEffect.originalNode;
}
);
this.forEachAnimItem(
function (animItem) {
animItem.isCurrentlyPlaying = (originalEffects.indexOf(animItem.effect.originalNode) > -1);
}
)
};
CSeqList.prototype.forEachAnimItem = function (callback) {
// У счетчиков сквозная нумерация
let seqCounter = 0;
let groupCounter = 0;
let itemCounter = 0;
this.children.forEach(function (seq) {
seq.animGroups.forEach(function (group) {
group.children.forEach(function (animItem) {
callback(animItem, itemCounter, groupCounter, seqCounter);
itemCounter++;
})
groupCounter++;
})
seqCounter++;
})
};
// mainSeq or interactiveSeq
function CAnimSequence(oParentControl, oSeq) {
CControlContainer.call(this, oParentControl);
this.seq = oSeq;
this.label = null; //this.addControl(new CLabel(this, "seq"));
this.animGroups = [];
}
InitClass(CAnimSequence, CControlContainer, CONTROL_TYPE_ANIM_SEQ);
CAnimSequence.prototype.getSeq = function () {
return this.seq;
};
CAnimSequence.prototype.recalculateChildren = function () {
this.clear();
let sLabel = this.seq.getLabel();
if (typeof sLabel === "string" && sLabel.length > 0) {
this.label = this.addControl(new CLabel(this, sLabel, 9, true, AscCommon.align_Left));
}
const aAllEffects = this.seq.getAllEffects();
const animGroups = AscFormat.groupBy(aAllEffects, function (effect) { return effect.getIndexInSequence(); })
for (let indexInSequence in animGroups) {
const oAnimGroup = this.addControl(new CAnimGroup(this, animGroups[indexInSequence]));
this.animGroups[this.animGroups.length] = oAnimGroup;
}
};
CAnimSequence.prototype.recalculateChildrenLayout = function () {
let dCurY = 0;
if (this.label) {
dCurY += SEQ_LABEL_MARGIN;
this.label.setLayout(SEQ_LABEL_MARGIN, dCurY, this.getWidth(), SEQ_LABEL_HEIGHT);
this.label.recalculate();
dCurY += this.label.getHeight() + SEQ_LABEL_MARGIN;
}
for (let nGroup = 0; nGroup < this.animGroups.length; ++nGroup) {
this.animGroups[nGroup].setLayout(0, dCurY, this.getWidth(), 0);
this.animGroups[nGroup].recalculate();
dCurY += this.animGroups[nGroup].getHeight();
}
this.setLayout(this.getLeft(), this.getTop(), this.getWidth(), dCurY);
};
function CAnimGroup(oParentControl, aAllGroupEffects) {
CControlContainer.call(this, oParentControl);
this.effects = aAllGroupEffects;
}
InitClass(CAnimGroup, CControlContainer, CONTROL_TYPE_ANIM_GROUP_LIST);
CAnimGroup.prototype.getSeq = function () {
return this.parentControl.getSeq();
};
CAnimGroup.prototype.recalculateChildren = function () {
this.clear();
for (let nCurEffect = this.effects.length - 1; nCurEffect >= 0; --nCurEffect) {
const oItem = new CAnimItem(this, this.effects[nCurEffect]);
this.addControl(oItem);
}
};
CAnimGroup.prototype.recalculateChildrenLayout = function () {
let dLastBottom = 0;
for (let nChild = 0; nChild < this.children.length; ++nChild) {
let oChild = this.children[nChild];
oChild.setLayout(0, dLastBottom, this.getWidth(), ANIM_ITEM_HEIGHT);
oChild.recalculate();
dLastBottom = oChild.getBottom();
}
this.setLayout(this.getLeft(), this.getTop(), this.getWidth(), dLastBottom);
};
CAnimGroup.prototype.draw = function(graphics) {
if (this.isHidden()) { return false; }
if (!this.checkUpdateRect(graphics.updatedRect)) { return false; }
if (!CControlContainer.prototype.draw.call(this, graphics)) { return false; }
// Connection lines drawing
let bShouldDraw = false;
this.effects.some(function (effect) {
if (effect.isSelected()) return bShouldDraw = true;
})
if (!bShouldDraw) { return }
const oThis = this;
const timeline = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline;
const timelineShift = ms_to_mm(timeline.getStartTime() * 1000);
let afterItems = []
this.children.forEach(function (animItem) {
if (animItem.effect.isAfterEffect()) afterItems[afterItems.length] = animItem;
})
if (afterItems.length === 0) { return }
graphics.SaveGrState();
graphics.AddClipRect(
afterItems[0].getLeftBorder(),
oThis.parentControl.getTop(),
afterItems[0].getRightBorder() - afterItems[0].getLeftBorder(),
oThis.parentControl.getBottom() - oThis.parentControl.getTop()
);
for (let i = 0; i < afterItems.length; i++) {
const animItem = afterItems[i];
if (animItem.effect === this.effects[this.effects.length - 1]) {
// effects in group are arranged backwards
continue;
}
const align = 0;
const x = ms_to_mm(animItem.effect.getBaseTime()) + animItem.getLeftBorder() - timelineShift;
let top = afterItems[i-1] ? oThis.getTop() + afterItems[i-1].getTop() : oThis.getTop();
top += oThis.parentControl.getTop();
let bottom = afterItems[i+1] ? oThis.getTop() + afterItems[i+1].getTop() : oThis.getBottom();
bottom += oThis.parentControl.getTop();
graphics.drawVerLine(align, x, top, bottom, oThis.getPenWidth(graphics));
}
graphics.RestoreGrState();
function ms_to_mm(nMilliseconds) {
const index = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline.timeScaleIndex;
return nMilliseconds * TIME_INTERVALS[index] / TIME_SCALES[index] / 1000;
}
}
function CAnimItem(oParentControl, oEffect) {
CControlContainer.call(this, oParentControl);
this.effect = oEffect;
if (this.effect.isClickEffect() || !this.effect.getPreviousEffect()) {
this.indexLabel = this.addControl(new CLabel(this, this.effect.getIndexInSequence() + "", INDEX_LABEL_FONTSIZE, false, AscCommon.align_Center))
}
// Event type image
const eventImg = this.getEventImage();
this.eventTypeImage = this.addControl(new CImageControl(this, eventImg.src, eventImg.width, eventImg.height));
// Effect type image
const effectImg = this.getEffectImage();
this.effectTypeImage = this.addControl(new CImageControl(this, effectImg.src, effectImg.width, effectImg.height));
this.effectLabel = this.addControl(new CLabel(this, this.getEffectLabelText(), EFFECT_LABEL_FONTSIZE, false, AscCommon.align_Left));
this.contextMenuButton = this.addControl(new CButton(this, function (e, x, y) {
if (this.hit(x, y) && (e.Button === AscCommon.g_mouse_button_left)) {
this.pressedFlag = true;
}
}, null, showContextMenu));
this.contextMenuButton.icon = this.contextMenuButton.addControl(new CImageControl(
this.contextMenuButton,
AscCommon.GlobalSkin.type == 'light' ? menuButtonIcon_dark : menuButtonIcon_light,
10 * AscCommon.g_dKoef_pix_to_mm, 2 * AscCommon.g_dKoef_pix_to_mm /* 10x2 svg image */
));
this.contextMenuButton.sendContextMenuEvent = function (customX, customY) {
const coords = editor.WordControl.m_oDrawingDocument.ConvertAnimPaneCoordsToCursor(
AscFormat.isRealNumber(customX) ? customX : this.bounds.l,
(AscFormat.isRealNumber(customY) ? customY : this.bounds.t) + HEADER_HEIGHT - editor.WordControl.m_oAnimPaneApi.list.Scroll * g_dKoef_pix_to_mm
);
const data = new AscCommonSlide.CContextMenuData()
data.Type = Asc.c_oAscContextMenuTypes.AnimEffect;
data.X_abs = coords.X;
data.Y_abs = coords.Y;
if (!AscFormat.isRealNumber(customX)) {
data.ButtonWidth = (this.bounds.r - this.bounds.l) * g_dKoef_mm_to_pix;
}
if (!AscFormat.isRealNumber(customY)) {
data.ButtonHeight = (this.bounds.b - this.bounds.t) * g_dKoef_mm_to_pix;
}
data.EffectStartType = this.parentControl.effect.getNodeType();
editor.sync_ContextMenuCallback(data);
}
function showContextMenu(e, x, y) {
if (this.hit(x, y) && !this.isHidden()) {
if (this.pressedFlag) {
this.sendContextMenuEvent();
this.pressedFlag = false;
}
}
}
// Temp fields for effect bar movement
this.tmpDelay = null;
this.tmpDuration = null;
this.tmpRepeatCount = null;
// Callback functions for effect bar events
this.onMouseDownCallback = function (event, x, y) {
if (!this.hit(x, y)) { return }
if (!this.contextMenuButton.hit(x, y)) {
this.updateSelectState(event);
}
const hitRes = this.hitInEffectBar(x, y);
if (hitRes) {
this.hitResult = hitRes;
this.tmpDelay = this.getDelay();
this.tmpDuration = this.getDuration();
if (this.effect.isUntilEffect() && hitRes.type === 'right') {
this.tmpRepeatCount = this.getRepeatCount();
this.initialTmpRepeatCount = this.tmpRepeatCount;
}
this.onUpdate();
}
}
this.onMouseMoveCallback = function (event, x, y) {
if (this.hit(x, y)) {
this.updateCursorType(x, y);
}
if (!this.hitResult) { return }
this.handleMovement(x, y);
this.handleScrollCondition(x, y);
this.onUpdate();
}
this.onMouseUpCallback = function (event, x, y) {
if (this.hit(x, y)) {
if (event.Button === AscCommon.g_mouse_button_right) {
this.contextMenuButton.sendContextMenuEvent(x, y);
}
}
if (!this.hitResult) { return }
this.setNewEffectParams(this.tmpDelay, this.tmpDuration, this.tmpRepeatCount);
this.hitResult = this.tmpDelay = this.tmpDuration = this.tmpRepeatCount = null;
this.onUpdate()
}
}
InitClass(CAnimItem, CControlContainer, CONTROL_TYPE_ANIM_ITEM);
CAnimItem.prototype.recalculateChildrenLayout = function () {
const oSeqLst = this.getSeqList();
const nIndexLabelWidth = oSeqLst ? oSeqLst.getIndexLabelWidth() : 0;
if (this.indexLabel) this.indexLabel.setLayout(0, 0, nIndexLabelWidth, ANIM_ITEM_HEIGHT)
this.eventTypeImage.setLayout(nIndexLabelWidth, 0, EVENT_TYPE_ICON_SIZE, EVENT_TYPE_ICON_SIZE);
this.effectTypeImage.src = this.getEffectImage().src;
this.effectTypeImage.setLayout(this.eventTypeImage.getRight(), 0, EFFECT_TYPE_ICON_SIZE, EFFECT_TYPE_ICON_SIZE);
const zeroPos = COMMON_LEFT_MARGIN + SCALE_BUTTON_LEFT_MARGIN + SCALE_BUTTON_WIDTH + TIMELINE_SCROLL_LEFT_MARGIN + TIMELINE_SCROLL_BUTTON_SIZE;
const labelWidth = zeroPos - COMMON_LEFT_MARGIN - (nIndexLabelWidth + EVENT_TYPE_ICON_SIZE + EFFECT_TYPE_ICON_SIZE);
const gap = (ANIM_ITEM_HEIGHT - EFFECT_BAR_HEIGHT) / 2;
this.effectLabel.setLayout(this.effectTypeImage.getRight(), gap, labelWidth, EFFECT_BAR_HEIGHT);
const menuBtnGap = (ANIM_ITEM_HEIGHT - MENU_BUTTON_SIZE) / 2;
const menuBtnLeft = this.getRight() - MENU_BUTTON_SIZE - menuBtnGap;
this.contextMenuButton.setLayout(menuBtnLeft, menuBtnGap, MENU_BUTTON_SIZE, MENU_BUTTON_SIZE);
this.contextMenuButton.icon.src = AscCommon.GlobalSkin.type == 'light' ? menuButtonIcon_dark : menuButtonIcon_light;
this.contextMenuButton.icon.setLayout(0, 0, MENU_BUTTON_SIZE, MENU_BUTTON_SIZE);
};
CAnimItem.prototype.getEventImage = function () {
let eventImg = {};
if (this.effect.isClickEffect()) {
eventImg.src = clickEffectIcon;
eventImg.width = 11 * AscCommon.g_dKoef_pix_to_mm;
eventImg.height = 16 * AscCommon.g_dKoef_pix_to_mm;
}
if (this.effect.isAfterEffect()) {
eventImg.src = afterEffectIcon;
eventImg.width = 16 * AscCommon.g_dKoef_pix_to_mm;
eventImg.height = 16 * AscCommon.g_dKoef_pix_to_mm;
}
return eventImg;
};
CAnimItem.prototype.getEffectImage = function () {
let effectImg = {};
if (this.effect.cTn.presetClass === AscFormat.PRESET_CLASS_ENTR) {
effectImg.src = entrEffectIcon;
effectImg.width = 20 * AscCommon.g_dKoef_pix_to_mm;
effectImg.height = 20 * AscCommon.g_dKoef_pix_to_mm;
}
if (this.effect.cTn.presetClass === AscFormat.PRESET_CLASS_EMPH) {
effectImg.src = emphEffectIcon;
effectImg.width = 20 * AscCommon.g_dKoef_pix_to_mm;
effectImg.height = 20 * AscCommon.g_dKoef_pix_to_mm;
}
if (this.effect.cTn.presetClass === AscFormat.PRESET_CLASS_EXIT) {
effectImg.src = exitEffectIcon;
effectImg.width = 20 * AscCommon.g_dKoef_pix_to_mm;
effectImg.height = 20 * AscCommon.g_dKoef_pix_to_mm;
}
if (this.effect.cTn.presetClass === AscFormat.PRESET_CLASS_PATH) {
effectImg.src = AscCommon.GlobalSkin.type === 'light' ? pathEffectIcon_dark : pathEffectIcon_light;
effectImg.width = 20 * AscCommon.g_dKoef_pix_to_mm;
effectImg.height = 20 * AscCommon.g_dKoef_pix_to_mm;
}
return effectImg;
};
CAnimItem.prototype.updateSelectState = function (event) {
const oThis = this;
const seqList = Asc.editor.WordControl.m_oAnimPaneApi.list.Control.seqList;
if (event.Button === AscCommon.g_mouse_button_right && !oThis.effect.isSelected()) {
seqList.forEachAnimItem(function (animItem) {
animItem.effect === oThis.effect ? animItem.effect.select() : animItem.effect.deselect();
})
}
if (event.Button === AscCommon.g_mouse_button_left) {
if (event.CtrlKey) {
oThis.effect.toggleSelect();
} else {
seqList.forEachAnimItem(function (animItem) {
animItem.effect === oThis.effect ? animItem.effect.select() : animItem.effect.deselect();
})
}
}
Asc.editor.WordControl.m_oLogicDocument.RedrawCurSlide();
Asc.editor.WordControl.m_oLogicDocument.Document_UpdateInterfaceState();
}
CAnimItem.prototype.updateCursorType = function (x, y) {
const cursorType = this.getNewCursorType(x, y);
const mouseMoveData = this.getMouseMoveData(x, y);
const animPane = Asc.editor.WordControl.m_oAnimPaneApi;
animPane.SetCursorType(cursorType, mouseMoveData);
animPane.sentMouseMoveData = mouseMoveData;
}
CAnimItem.prototype.getNewCursorType = function (x, y) {
const isVerticalDrag = null !== editor.WordControl.m_oAnimPaneApi.list.Control.seqList.nPressedSlot;
if (isVerticalDrag) {
return 'grabbing';
}
let draggingAnimItem;
editor.WordControl.m_oAnimPaneApi.list.Control.seqList.forEachAnimItem(function (animItem) {
if (animItem.hitResult) {
draggingAnimItem = animItem;
}
});
const hitRes = draggingAnimItem
? draggingAnimItem.hitResult
: (this.hitResult || this.hitInEffectBar(x, y));
const cursorTypes = {
'left': 'col-resize',
'right': 'col-resize',
'partition': 'col-resize',
'center': 'ew-resize'
};
const cursorType = hitRes
? cursorTypes[hitRes.type]
: this.contextMenuButton.hit(x, y) ? 'default' : 'ns-resize';
return cursorType;
};
CAnimItem.prototype.getMouseMoveData = function (x, y) {
const coords = editor.WordControl.m_oDrawingDocument.ConvertAnimPaneCoordsToCursor(
x, y + HEADER_HEIGHT - editor.WordControl.m_oAnimPaneApi.list.Scroll * g_dKoef_pix_to_mm
);
const mouseMoveData = new CMouseMoveData();
mouseMoveData.X_abs = coords.X;
mouseMoveData.Y_abs = coords.Y;
const isVerticalDrag = null !== editor.WordControl.m_oAnimPaneApi.list.Control.seqList.nPressedSlot;
if (!this.contextMenuButton.hit(x, y) && !isVerticalDrag) {
mouseMoveData.Type = Asc.c_oAscMouseMoveDataTypes.EffectInfo;
const tooltipInfo = this.getInfoForTooltip(x, y);
if (typeof tooltipInfo === 'string') {
mouseMoveData.EffectText = tooltipInfo;
} else {
mouseMoveData.EffectDescription = tooltipInfo;
}
}
return mouseMoveData;
};
CAnimItem.prototype.getInfoForTooltip = function (x, y) {
// If there is a pressed animItem - we take the information from it,
// otherwise - from this one (literally 'this' xd)
let currentAnimItem = this;
const seqList = editor.WordControl.m_oAnimPaneApi.list.Control.seqList
seqList.forEachAnimItem(function (animItem) {
if (animItem.hitResult) { currentAnimItem = animItem; }
})
const templateStrings = {
startTime: AscCommon.translateManager.getValue('Start: ${0}s'),
endTime: AscCommon.translateManager.getValue('End: ${0}s'),
loopTime: AscCommon.translateManager.getValue('Loop: ${0}s'),
};
// When dragging (when animItem's bar is pressed)
if (currentAnimItem.hitResult) {
let time;
switch (currentAnimItem.hitResult.type) {
case 'center':
time = currentAnimItem.getDelay() / 1000;
return templateStrings.startTime.replace('${0}', time.toFixed(1));
case 'left':
time = currentAnimItem.getDelay() / 1000;
return templateStrings.startTime.replace('${0}', time.toFixed(1));
case 'right':
time = currentAnimItem.getDelay() / 1000 + currentAnimItem.getDuration() / 1000;
return templateStrings.endTime.replace('${0}', time.toFixed(1));
case 'partition':
time = (currentAnimItem.getDuration() / 1000);
return templateStrings.loopTime.replace('${0}', time.toFixed(1));
}
}
if (currentAnimItem.hitInEffectBar(x, y)) {
const startTime = (currentAnimItem.getDelay() / 1000).toFixed(1);
const endTime = ((currentAnimItem.getDelay() + currentAnimItem.getDuration()) / 1000).toFixed(1);
const result = [
templateStrings.startTime.replace('${0}', startTime),
templateStrings.endTime.replace('${0}', endTime),
];
return result.join(', ');
} else {
// Belongs to [AscFormat.NODE_TYPE_AFTEREFFECT, AscFormat.NODE_TYPE_CLICKEFFECT, AscFormat.NODE_TYPE_WITHEFFECT]
const eventType = currentAnimItem.effect.getNodeType();
// Belongs to [AscFormat.PRESET_CLASS_ENTR, AscFormat.PRESET_CLASS_EMPH, AscFormat.PRESET_CLASS_EXIT, AscFormat.PRESET_CLASS_PATH]
const presetClass = currentAnimItem.effect.cTn.presetClass;
// Belongs to presets of animation - [AscFormat.ENTRANCE_APPEAR, ..., AscFormat.EMPHASIS_FILL_COLOR, ...]
const presetId = currentAnimItem.effect.cTn.presetID;
const shapeName = currentAnimItem.effect.getObjectName();
return [eventType, presetClass, presetId, shapeName];
}
}
CAnimItem.prototype.getEffectLabelText = function () {
const objectName = this.effect.getObjectName();
const objectText = this.effect.getObjectText();
return objectText ? (objectName + ': ' + objectText) : objectName;
};
CAnimItem.prototype.handleScrollCondition = function (x, y) {
const leftBorder = this.getLeftBorder();
const rightBorder = this.getRightBorder();
const timeline = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline;
if (x <= leftBorder || x >= rightBorder) {
if (!timeline.isOnScroll()) {
let scrollStep = timeline.getWidth() * SCROLL_STEP / 10;
scrollStep = x <= leftBorder ? -scrollStep : scrollStep;
let scrollTimerDelay = 0;
let scrollTimerInterval = 50;
timeline.startScroll(scrollStep, scrollTimerDelay, scrollTimerInterval);
}
} else timeline.endScroll();
}
CAnimItem.prototype.handleMovement = function (x, y) {
const timeline = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline;
const timelineShift = this.ms_to_mm(timeline.getStartTime() * 1000);
const repeats = this.getRepeatCount() / 1000;
let pointOfLanding = x - this.getLeftBorder() + timelineShift;
if (this.hitResult.type === 'right') {
if (this.effect.isUntilEffect()) {
const pointOfContact = this.ms_to_mm(this.effect.getFullDelay() + this.effect.asc_getDuration() * this.initialTmpRepeatCount / 1000);
let diff = this.mm_to_ms(pointOfLanding - pointOfContact);
const newTmpRepeatCount = this.initialTmpRepeatCount + diff / (this.effect.asc_getDuration() / 1000);
this.tmpRepeatCount = Math.max(newTmpRepeatCount, MIN_ALLOWED_REPEAT_COUNT);
} else {
const pointOfContact = this.ms_to_mm(this.effect.getFullDelay() + this.effect.asc_getDuration() * repeats);
let diff = this.mm_to_ms(pointOfLanding - pointOfContact);
const newTmpDuration = this.effect.asc_getDuration() + diff / repeats;
this.tmpDuration = Math.max(MIN_ALLOWED_DURATION, newTmpDuration);
}
}
if (this.hitResult.type === 'left') {
const pointOfContact = this.ms_to_mm(this.effect.getFullDelay());
const basePoint = this.ms_to_mm(this.effect.getBaseTime());
pointOfLanding = Math.max(pointOfLanding, basePoint);
const diff = this.mm_to_ms(pointOfLanding - pointOfContact);
const newTmpDuration = this.effect.asc_getDuration() - diff / repeats;
const newTmpDelay = this.effect.getFullDelay() + diff;
const maxNewTmpDuration = this.effect.getFullDelay() / repeats + this.effect.asc_getDuration();
const maxNewTmpDelay = this.effect.getFullDelay() + (this.effect.asc_getDuration() - MIN_ALLOWED_DURATION) * repeats;
if (this.effect.isUntilEffect()) {
this.tmpDelay = Math.max(newTmpDelay, this.effect.getBaseTime());
} else {
this.tmpDuration = Math.min(Math.max(newTmpDuration, MIN_ALLOWED_DURATION), maxNewTmpDuration);
this.tmpDelay = Math.min(Math.max(newTmpDelay, this.effect.getBaseTime()), maxNewTmpDelay);
}
}
if (this.hitResult.type === 'center') {
const pointOfContact = this.ms_to_mm(this.effect.getFullDelay()) + this.hitResult.offset;
const diff = this.mm_to_ms(pointOfLanding - pointOfContact);
const newTmpDelay = this.effect.getFullDelay() + diff;
this.tmpDelay = Math.max(newTmpDelay, this.effect.getBaseTime());
}
if (this.hitResult.type === 'partition') {
const pointOfContact = this.ms_to_mm(this.effect.getFullDelay() + this.effect.asc_getDuration() * this.hitResult.index);
const diff = this.mm_to_ms(pointOfLanding - pointOfContact);
const newTmpDuration = this.effect.asc_getDuration() + diff / this.hitResult.index;
this.tmpDuration = Math.max(MIN_ALLOWED_DURATION, newTmpDuration);
}
}
CAnimItem.prototype.handleTimelineScroll = function (step) {
if (!this.hitResult) { return }
const repeats = this.getRepeatCount() / 1000;
const diff = this.mm_to_ms(step);
let newTmpDelay;
let newTmpDuration;
let newTmpRepeatCount;
switch (this.hitResult.type) {
case 'center':
newTmpDelay = this.tmpDelay + diff;
this.tmpDelay = Math.max(newTmpDelay, this.effect.getBaseTime());
break;
case 'right':
if (this.effect.isUntilEffect()) {
newTmpRepeatCount = this.tmpRepeatCount + diff / (this.effect.asc_getDuration() / 1000);
this.tmpRepeatCount = Math.max(newTmpRepeatCount, MIN_ALLOWED_REPEAT_COUNT);
} else {
newTmpDuration = this.tmpDuration + diff / repeats;
this.tmpDuration = Math.max(MIN_ALLOWED_DURATION, newTmpDuration);
}
break;
case 'left':
newTmpDuration = this.tmpDuration - diff / repeats;
newTmpDelay = this.tmpDelay + diff;
const maxNewTmpDuration = (this.effect.getFullDelay() - this.effect.getBaseTime()) / repeats + this.effect.asc_getDuration();
const maxNewTmpDelay = this.effect.getFullDelay() + (this.effect.asc_getDuration() - MIN_ALLOWED_DURATION) * repeats;
if (this.effect.isUntilEffect()) {
this.tmpDelay = Math.max(newTmpDelay, this.effect.getBaseTime());
} else {
this.tmpDuration = Math.min(Math.max(newTmpDuration, MIN_ALLOWED_DURATION), maxNewTmpDuration);
this.tmpDelay = Math.min(Math.max(newTmpDelay, this.effect.getBaseTime()), maxNewTmpDelay);
}
break;
case 'partition':
newTmpDuration = this.tmpDuration + diff / this.hitResult.index;
this.tmpDuration = Math.max(MIN_ALLOWED_DURATION, newTmpDuration);
break;
}
this.onUpdate();
}
CAnimItem.prototype.ms_to_mm = function (nMilliseconds) {
if (nMilliseconds === null || nMilliseconds === undefined) { return }
const index = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline.timeScaleIndex;
return nMilliseconds * TIME_INTERVALS[index] / TIME_SCALES[index] / 1000;
};
CAnimItem.prototype.mm_to_ms = function (nMillimeters) {
if (nMillimeters === null || nMillimeters === undefined) { return }
const index = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline.timeScaleIndex;
return nMillimeters / TIME_INTERVALS[index] * TIME_SCALES[index] * 1000;
};
CAnimItem.prototype.getDelay = function () {
return this.tmpDelay !== null ? this.tmpDelay : this.effect.getFullDelay();
}
CAnimItem.prototype.getDuration = function () {
return this.tmpDuration !== null ? this.tmpDuration : this.effect.asc_getDuration()
}
CAnimItem.prototype.getRepeatCount = function () {
if (this.tmpRepeatCount !== null) { return this.tmpRepeatCount; }
else if (this.effect.asc_getRepeatCount() > 0) { return this.effect.asc_getRepeatCount(); }
else {
const bounds = this.getEffectBarBounds();
const width = bounds.r - bounds.l;
const totalWidth = this.getRightBorder() - bounds.l;
return (totalWidth / width * 1000) >> 0; // approximate repeat counter
}
}
CAnimItem.prototype.getLeftBorder = function () {
const timeline = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline;
return timeline.getLeft() + timeline.getZeroShift();
}
CAnimItem.prototype.getRightBorder = function () {
const timeline = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline;
return timeline.getRight() - TIMELINE_SCROLL_BUTTON_SIZE;
}
CAnimItem.prototype.getEffectBarBounds = function () {
const timeline = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control.timeline;
const timelineShift = timeline.getStartTime() * 1000;
let l = this.ms_to_mm(this.getDelay()) + this.getLeftBorder() - this.ms_to_mm(timelineShift);
let r = l + this.ms_to_mm(this.getDuration());
let t = this.bounds.t + (ANIM_ITEM_HEIGHT - EFFECT_BAR_HEIGHT) / 2;
let b = t + EFFECT_BAR_HEIGHT;
if (this.effect.isInstantEffect()) {
return { l: l, r: l + EFFECT_BAR_HEIGHT, t: t, b: b }
}
return { l: l, r: r, t: t, b: b }
};
CAnimItem.prototype.draw = function drawEffectBar(graphics) {
const timelineContainer = Asc.editor.WordControl.m_oAnimPaneApi.timeline.Control
if (!timelineContainer) { return }
this.effect.isSelected() ? this.contextMenuButton.show() : this.contextMenuButton.hide();
if (!CControlContainer.prototype.draw.call(this, graphics)) { return false }
if (this.isHidden()) { return false }
if (!this.checkUpdateRect(graphics.updatedRect)) { return false }
graphics.SaveGrState();
const clipL = this.getLeftBorder();
const clipT = this.bounds.t;
const clipW = this.getRightBorder() - clipL;
const clipH = this.bounds.b - this.bounds.t;
graphics.AddClipRect(clipL, clipT, clipW, clipH);
const oSkin = AscCommon.GlobalSkin;
let sFillColor, sOutlineColor;
switch (this.effect.cTn.presetClass) {
case AscFormat.PRESET_CLASS_ENTR:
sFillColor = oSkin.AnimPaneEffectBarFillEntrance;
sOutlineColor = oSkin.AnimPaneEffectBarOutlineEntrance;
break;
case AscFormat.PRESET_CLASS_EMPH:
sFillColor = oSkin.AnimPaneEffectBarFillEmphasis;
sOutlineColor = oSkin.AnimPaneEffectBarOutlineEmphasis;
break;
case AscFormat.PRESET_CLASS_EXIT:
sFillColor = oSkin.AnimPaneEffectBarFillExit;
sOutlineColor = oSkin.AnimPaneEffectBarOutlineExit;
break;
case AscFormat.PRESET_CLASS_PATH:
sFillColor = oSkin.AnimPaneEffectBarFillPath;
sOutlineColor = oSkin.AnimPaneEffectBarOutlinePath;
break;
default:
sFillColor = '#A0A0A0';
sOutlineColor = '#404040';
}
// hex to rgba
const oFillColorRGBA = AscCommon.RgbaHexToRGBA(sFillColor);
const oOutlineColorRGBA = AscCommon.RgbaHexToRGBA(sOutlineColor);
// rgba to CShapeColor
let oFillColor = new AscFormat.CShapeColor(oFillColorRGBA.R, oFillColorRGBA.G, oFillColorRGBA.B);
let oOutlineColor = new AscFormat.CShapeColor(oOutlineColorRGBA.R, oOutlineColorRGBA.G, oOutlineColorRGBA.B);
// change brightness of CShapeColor during demo preview
if (Asc.editor.asc_IsStartedAnimationPreview()) {
if (!this.isCurrentlyPlaying) {
oFillColor = oFillColor.getColorData(0.4);
oOutlineColor = oOutlineColor.getColorData(0.4);
}
}
graphics.b_color1(oFillColor.r, oFillColor.g, oFillColor.b, 255);
graphics.p_color(oOutlineColor.r, oOutlineColor.g, oOutlineColor.b, 255);
const bounds = this.getEffectBarBounds();
if (this.effect.isInstantEffect()) {
// In case we need to draw a triangle
let transform = graphics.m_oFullTransform;
let left = (transform.TransformPointX(bounds.l, bounds.t) + 0.5) >> 0;
let top = (transform.TransformPointY(bounds.l, bounds.t) + 0.5) >> 0;
let right = (transform.TransformPointX(bounds.r, bounds.t) + 0.5) >> 0;
let bottom = (transform.TransformPointY(bounds.l, bounds.b) + 0.5) >> 0;
let ctx = graphics.m_oContext;
ctx.beginPath();
ctx.moveTo(left, top);
ctx.lineTo(left + 5, top);
ctx.lineTo(right, top + (bottom - top) / 2);
ctx.lineTo(left + 5, bottom);
ctx.lineTo(left, bottom);
ctx.lineTo(left, top);
graphics.df();
graphics.ds();
} else {
let repeats;
if (this.effect.isUntilEffect() && this.tmpRepeatCount === null) {
// In case we need to draw an infinite bar with an arrow
const barWidth = Math.max(this.getRightBorder() - bounds.l - EFFECT_BAR_HEIGHT, this.ms_to_mm(MIN_ALLOWED_DURATION));
// repeats = barWidth / (bounds.r - bounds.l);
repeats = this.getRepeatCount() / 1000;
let transform = graphics.m_oFullTransform;
let left = (transform.TransformPointX(bounds.l, bounds.t) + 0.5) >> 0;
let top = (transform.TransformPointY(bounds.l, bounds.t) + 0.5) >> 0;
let right = (transform.TransformPointX(bounds.l + barWidth, bounds.t) + 0.5) >> 0;
let bottom = (transform.TransformPointY(bounds.l, bounds.b) + 0.5) >> 0;
let ctx = graphics.m_oContext;
ctx.beginPath();
ctx.moveTo(left, top);
ctx.lineTo(right, top);
ctx.lineTo(right + 5, top);
ctx.lineTo(right + EFFECT_BAR_HEIGHT * g_dKoef_mm_to_pix, top + (bottom - top) / 2);
ctx.lineTo(right + 5, bottom);
ctx.lineTo(right, bottom);
ctx.lineTo(left, bottom);
ctx.lineTo(left, top);
graphics.df();
graphics.ds();
// renew clipRect to clip marks
graphics.RemoveClipRect();
graphics.AddClipRect(clipL, clipT, clipW - EFFECT_BAR_HEIGHT, clipH);
} else {
// In case we need to draw a bar
repeats = this.getRepeatCount() / 1000;
const barWidth = (bounds.r - bounds.l) * repeats;
graphics.rect(bounds.l, bounds.t, barWidth, bounds.b - bounds.t);
graphics.df();
graphics.ds();
}
// draw marks
if ((bounds.r - bounds.l) >= 2 * g_dKoef_pix_to_mm) {
const gap = (bounds.b - bounds.t) / 5;
for (let markIndex = 1; markIndex < repeats; markIndex++) {
const xCord = bounds.l + markIndex * (bounds.r - bounds.l)
graphics.drawVerLine(2, xCord, bounds.t + gap, bounds.b - gap, this.getPenWidth(graphics));
}
}
}
graphics.RestoreGrState();
};
CAnimItem.prototype.hitInEffectBar = function (x, y) {
if (!this.hit(x, y)) { return null; }
const bounds = this.getEffectBarBounds();
const isOutOfBorders = x < this.getLeftBorder() || x > this.getRightBorder() || y < bounds.t || y > bounds.b
if (isOutOfBorders) { return null; }
const width = bounds.r - bounds.l;
const repeats = this.getRepeatCount() / 1000;
const delta = AscFormat.DIST_HIT_IN_LINE / 2
let barRight = this.effect.isUntilEffect() ? this.getRightBorder() : bounds.l + width * repeats;
barRight = Math.max(bounds.l + this.ms_to_mm(MIN_ALLOWED_DURATION), barRight);
if (!this.effect.isInstantEffect()) {
if (x >= bounds.l - delta && x <= bounds.l + delta) {
return { type: 'left' };
}
if (this.effect.isUntilEffect()) {
if (x >= barRight - EFFECT_BAR_HEIGHT - delta && x <= barRight + delta) {
return { type: 'right' };
}
} else {
if (x >= barRight - delta && x <= barRight + delta) {
return { type: 'right' };
}
}
const partitionIndex = (x - bounds.l) / width >> 0;
// if effect isUntilEffect condition (partitionIndex < repeats) doesnt matter
if (partitionIndex > 0 && (this.effect.isUntilEffect() || partitionIndex < repeats)) {
const partitionPos = bounds.l + partitionIndex * width;
if (x <= partitionPos + delta && x >= partitionPos - delta) {
return { type: 'partition', index: partitionIndex };
}
}
}
if (x > bounds.l && x < barRight) {
return { type: 'center', offset: x - bounds.l };
}
return null;
};
CAnimItem.prototype.hit = function (x, y) {
const headerY = y + HEADER_HEIGHT - editor.WordControl.m_oAnimPaneApi.list.Scroll * g_dKoef_pix_to_mm
if (editor.WordControl.m_oAnimPaneApi.header.Control.hit(x, headerY)) {
return false;
}
if (this.parentControl && !this.parentControl.hit(x, y)) { return false; }
const oInv = this.invertTransform;
const tx = oInv.TransformPointX(x, y);
const ty = oInv.TransformPointY(x, y);
if (tx >= 0 && tx <= this.extX) {
if (ty >= 0 && ty <= this.extY / 2) { return 'top' }
if (ty > this.extY / 2 && ty <= this.extY) { return 'bottom' }
}
return false;
};
CAnimItem.prototype.setNewEffectParams = function (newDelay, newDuration, newRepeatCount) {
const minAllowedDelta = 1 // in ms
let dOwnNewDelay = newDelay - this.effect.getBaseTime();
const delayDiff = Math.abs(dOwnNewDelay - this.effect.asc_getDelay());
const durationDiff = Math.abs(newDuration - this.effect.asc_getDuration());
const repeatCountDiff = Math.abs(newRepeatCount - this.effect.asc_getRepeatCount());
const effectCopy = AscFormat.ExecuteNoHistory(function () {
let oCopy = this.effect.createDuplicate();
oCopy.merge(this.effect);
return oCopy;
}, this, []);
if (dOwnNewDelay !== null && dOwnNewDelay !== undefined && delayDiff >= minAllowedDelta) {
effectCopy.asc_putDelay(dOwnNewDelay);
}
if (newDuration !== null && newDuration !== undefined && durationDiff >= minAllowedDelta) {
effectCopy.asc_putDuration(newDuration);
}
if (newRepeatCount !== null && newRepeatCount !== undefined && repeatCountDiff >= 1) {
effectCopy.asc_putRepeatCount(newRepeatCount);
}
if (this.effect.isEqualProperties(effectCopy)) { return }
Asc.editor.WordControl.m_oLogicDocument.SetAnimationProperties(effectCopy, false);
};
CAnimItem.prototype.onMouseDown = function (e, x, y) {
if (this.onMouseDownCallback && this.onMouseDownCallback.call(this, e, x, y)) {
return true;
}
return CControlContainer.prototype.onMouseDown.call(this, e, x, y);
};
CAnimItem.prototype.onMouseMove = function (e, x, y) {
if (this.onMouseMoveCallback && this.onMouseMoveCallback.call(this, e, x, y)) {
return true;
}
return CControlContainer.prototype.onMouseMove.call(this, e, x, y);
};
CAnimItem.prototype.onMouseUp = function (e, x, y) {
if (this.onMouseUpCallback && this.onMouseUpCallback.call(this, e, x, y)) {
return true;
}
return CControlContainer.prototype.onMouseUp.call(this, e, x, y);
};
CAnimItem.prototype.canHandleEvents = function () {
return true;
};
CAnimItem.prototype.getFillColor = function() {
const oSkin = AscCommon.GlobalSkin;
if (this.effect.isSelected()) { return oSkin.AnimPaneItemFillSelected; }
if (this.isHovered()) { return oSkin.AnimPaneItemFillHovered; }
return null;
};
// HEADER
const HEADER_HEIGHT = 40 * AscCommon.g_dKoef_pix_to_mm;
const HEADER_LABEL_FONTSIZE = 10;
const HEADER_LABEL_WIDTH = 101 * AscCommon.g_dKoef_pix_to_mm;
const PLAY_BUTTON_HEIGHT = 24 * AscCommon.g_dKoef_pix_to_mm;
const PLAY_BUTTON_LEFT_MARGIN = 30 * AscCommon.g_dKoef_pix_to_mm;
const PLAY_BUTTON_LEFT_PADDING = 8 * AscCommon.g_dKoef_pix_to_mm;
const PLAY_BUTTON_RIGHT_PADDING = 12 * AscCommon.g_dKoef_pix_to_mm;
const PLAY_BUTTON_ICON_SIZE = 20 * AscCommon.g_dKoef_pix_to_mm;;
const PLAY_BUTTON_LABEL_FONTSIZE = 9;
const PLAY_BUTTON_MAX_LABEL_WIDTH = 100 * g_dKoef_pix_to_mm;
const PLAY_BUTTON_LABEL_LEFT_MARGIN = 4 * AscCommon.g_dKoef_pix_to_mm;
const MOVE_BUTTON_SIZE = 24 * AscCommon.g_dKoef_pix_to_mm;
const MOVE_UP_BUTTON_LEFT_MARGIN = 14 * AscCommon.g_dKoef_pix_to_mm;
const MOVE_DOWN_BUTTON_LEFT_MARGIN = 4 * AscCommon.g_dKoef_pix_to_mm;
const CLOSE_BUTTON_SIZE = 24 * AscCommon.g_dKoef_pix_to_mm;
// TIMELINE
const TIMELINE_HEIGHT = 40 * AscCommon.g_dKoef_pix_to_mm;
const TIMELINE_SCROLL_HEIGHT = 17 * AscCommon.g_dKoef_pix_to_mm;
const TIMELINE_SCROLL_ABSOLUTE_LEFT = 143 * AscCommon.g_dKoef_pix_to_mm;
const TIMELINE_SCROLL_LEFT_MARGIN = 10 * AscCommon.g_dKoef_pix_to_mm;
const TIMELINE_SCROLL_RIGHT_MARGIN = 40 * AscCommon.g_dKoef_pix_to_mm;
const TIMELINE_SCROLL_BUTTON_SIZE = 17 * AscCommon.g_dKoef_pix_to_mm;
const TIMELINE_SCROLLER_WIDTH = 16 * AscCommon.g_dKoef_pix_to_mm;
const ZOOM_BUTTON_SIZE = 20 * AscCommon.g_dKoef_pix_to_mm;
const ZOOM_LABEL_FONTSIZE = 9;
const ZOOM_LABEL_WIDTH = 80 * AscCommon.g_dKoef_pix_to_mm;
const ZOOM_LABEL_MARGIN = 5 * AscCommon.g_dKoef_pix_to_mm;
const SCALE_BUTTON_WIDTH = 76 * AscCommon.g_dKoef_pix_to_mm;
const SCALE_BUTTON_LEFT_MARGIN = 43 * AscCommon.g_dKoef_pix_to_mm;
const TIMELINE_LABEL_WIDTH = 100;
const TIMELINE_LABEL_FONTSIZE = 7.5;
const SCROLL_TIMER_INTERVAL = 150;
const SCROLL_TIMER_DELAY = 600;
const SCROLL_STEP = 0.26
const TIME_SCALES = [0.25, 1, 1, 2, 5, 10, 20, 60, 120, 300, 600, 600]; // in seconds
const SMALL_TIME_INTERVAL = 15;
const MIDDLE_1_TIME_INTERVAL = 20;
const MIDDLE_2_TIME_INTERVAL = 25;
const LONG_TIME_INTERVAL = 30;
const TIME_INTERVALS = [
SMALL_TIME_INTERVAL,
LONG_TIME_INTERVAL, //1
SMALL_TIME_INTERVAL, //1
SMALL_TIME_INTERVAL, //2
MIDDLE_1_TIME_INTERVAL, //5
MIDDLE_1_TIME_INTERVAL,//10
MIDDLE_1_TIME_INTERVAL,//20
MIDDLE_2_TIME_INTERVAL,//60
MIDDLE_2_TIME_INTERVAL,//120
MIDDLE_2_TIME_INTERVAL,//300
MIDDLE_2_TIME_INTERVAL,//600
SMALL_TIME_INTERVAL//600
]; // in mms
// SEQUENCE LIST
const SEQ_LABEL_MARGIN = 3;
const SEQ_LABEL_HEIGHT = 15 * AscCommon.g_dKoef_pix_to_mm;
const ANIM_ITEM_HEIGHT = 24 * AscCommon.g_dKoef_pix_to_mm;
const INDEX_LABEL_FONTSIZE = 7.5;
const INDEX_LABEL_WIDTH = 19 * AscCommon.g_dKoef_pix_to_mm;
const EVENT_TYPE_ICON_SIZE = ANIM_ITEM_HEIGHT;
const EFFECT_TYPE_ICON_SIZE = ANIM_ITEM_HEIGHT;
const EFFECT_LABEL_FONTSIZE = 7.5;
const EFFECT_BAR_HEIGHT = ANIM_ITEM_HEIGHT * 5 / 8;
const MENU_BUTTON_SIZE = 15 * AscCommon.g_dKoef_pix_to_mm;
const MIN_ALLOWED_DURATION = 10; // milliseconds
const MIN_ALLOWED_REPEAT_COUNT = 10; // equals 0.01 of full effect duration
// COMMON
const COMMON_LEFT_MARGIN = 14 * AscCommon.g_dKoef_pix_to_mm;
const COMMON_RIGHT_MARGIN = 20 * AscCommon.g_dKoef_pix_to_mm;
// const ALIGNMENT_LINE = MATH.max(CLOSE_BUTTON_SIZE, MENU_BUTTON_SIZE, TIMELINE_SCROLL_BUTTON_SIZE) / 2;
// ICONS
const playIcon_dark = '';
const playIcon_light = '';
const stopIcon_dark = '';
const stopIcon_light = '';
const clickEffectIcon = '';
const afterEffectIcon = '';
const entrEffectIcon = '';
const emphEffectIcon = '';
const exitEffectIcon = '';
const pathEffectIcon_light = '';
const pathEffectIcon_dark = '';
const arrowUpIcon_dark = '';
const arrowUpIcon_light = '';
const arrowDownIcon_dark = '';
const arrowDownIcon_light = '';
const closeIcon_dark = '';
const closeIcon_light = '';
const menuButtonIcon_dark = '';
const menuButtonIcon_light = '';
const arrowLeftIcon_dark = '';
const arrowLeftIcon_light = '';
const arrowRightIcon_dark = '';
const arrowRightIcon_light = '';
const zoomInIcon_dark = '';
const zoomInIcon_light = '';
const zoomOutIcon_dark = '';
const zoomOutIcon_light = '';
const getIconsForLoad = function () {
return [
clickEffectIcon, afterEffectIcon,
entrEffectIcon, emphEffectIcon, exitEffectIcon,
pathEffectIcon_dark, pathEffectIcon_light,
playIcon_dark, playIcon_light,
stopIcon_dark, stopIcon_light,
arrowUpIcon_dark, arrowUpIcon_light,
arrowDownIcon_dark, arrowDownIcon_light,
closeIcon_dark, closeIcon_light,
menuButtonIcon_dark, menuButtonIcon_light,
arrowLeftIcon_dark, arrowLeftIcon_light,
arrowRightIcon_dark, arrowRightIcon_light,
zoomInIcon_dark, zoomInIcon_light,
zoomOutIcon_dark, zoomOutIcon_light,
];
}
// EXPORTS
window['AscCommon'] = window['AscCommon'] || {};
window['AscCommon'].CAnimPaneHeader = CAnimPaneHeader;
window['AscCommon'].CSeqListContainer = CSeqListContainer;
window['AscCommon'].CTimelineContainer = CTimelineContainer;
window['AscCommon'].getIconsForLoad = getIconsForLoad;
})(window);