composition.js
来自「极限OA开源系统」· JavaScript 代码 · 共 602 行 · 第 1/2 页
JS
602 行
//Constants.
SEP_PADDING = 5
HANDLE_PADDING = 7
// Array of all toolbars.
var yToolbars = new Array();
// Initialize everything when the document is ready
var YInitialized = false;
function document.onreadystatechange() {
if (YInitialized) return;
YInitialized = true;
var i, s, curr;
// Find all the toolbars and initialize them.
for (i=0; i<document.body.all.length; i++) {
curr=document.body.all[i];
if (curr.className == "yToolbar") {
if (! InitTB(curr)) {
alert("工具栏: " + curr.id + " 初始化失败. 状态: false");
}
yToolbars[yToolbars.length] = curr;
}
}
//Lay out the page, set handler.
DoLayout();
window.onresize = DoLayout;
//初始化编辑器
initHTML=bodyTag;
initEditor();
Composition.document.body.innerText=''
Composition.document.body.innerHTML=''
}
// Initialize a toolbar button
function InitBtn(btn) {
btn.onmouseover = BtnMouseOver;
btn.onmouseout = BtnMouseOut;
btn.onmousedown = BtnMouseDown;
btn.onmouseup = BtnMouseUp;
btn.ondragstart = YCancelEvent;
btn.onselectstart = YCancelEvent;
btn.onselect = YCancelEvent;
btn.YUSERONCLICK = btn.onclick;
btn.onclick = YCancelEvent;
btn.YINITIALIZED = true;
return true;
}
//Initialize a toolbar.
function InitTB(y) {
// Set initial size of toolbar to that of the handle
y.TBWidth = 0;
// Populate the toolbar with its contents
if (! PopulateTB(y)) return false;
// Set the toolbar width and put in the handle
y.style.posWidth = y.TBWidth;
return true;
}
// Hander that simply cancels an event
function YCancelEvent() {
event.returnValue=false;
event.cancelBubble=true;
return false;
}
// Toolbar button onmouseover handler
function BtnMouseOver() {
if (event.srcElement.tagName != "IMG") return false;
var image = event.srcElement;
var element = image.parentElement;
// Change button look based on current state of image.
if (image.className == "Ico") element.className = "BtnMouseOverUp";
else if (image.className == "IcoDown") element.className = "BtnMouseOverDown";
event.cancelBubble = true;
}
// Toolbar button onmouseout handler
function BtnMouseOut() {
if (event.srcElement.tagName != "IMG") {
event.cancelBubble = true;
return false;
}
var image = event.srcElement;
var element = image.parentElement;
yRaisedElement = null;
element.className = "Btn";
image.className = "Ico";
event.cancelBubble = true;
}
// Toolbar button onmousedown handler
function BtnMouseDown() {
if (event.srcElement.tagName != "IMG") {
event.cancelBubble = true;
event.returnValue=false;
return false;
}
var image = event.srcElement;
var element = image.parentElement;
element.className = "BtnMouseOverDown";
image.className = "IcoDown";
event.cancelBubble = true;
event.returnValue=false;
return false;
}
// Toolbar button onmouseup handler
function BtnMouseUp() {
if (event.srcElement.tagName != "IMG") {
event.cancelBubble = true;
return false;
}
var image = event.srcElement;
var element = image.parentElement;
if (element.YUSERONCLICK) eval(element.YUSERONCLICK + "anonymous()");
element.className = "BtnMouseOverUp";
image.className = "Ico";
event.cancelBubble = true;
return false;
}
// Populate a toolbar with the elements within it
function PopulateTB(y) {
var i, elements, element;
// Iterate through all the top-level elements in the toolbar
elements = y.children;
for (i=0; i<elements.length; i++) {
element = elements[i];
if (element.tagName == "SCRIPT" || element.tagName == "!") continue;
switch (element.className) {
case "Btn":
if (element.YINITIALIZED == null) {
if (! InitBtn(element)) {
alert("Problem initializing:" + element.id);
return false;
}
}
element.style.posLeft = y.TBWidth;
y.TBWidth += element.offsetWidth + 1;
break;
case "TBGen":
element.style.posLeft = y.TBWidth;
y.TBWidth += element.offsetWidth + 1;
break;
case "TBSep":
element.style.posLeft = y.TBWidth + 2;
y.TBWidth += SEP_PADDING;
break;
case "TBHandle":
element.style.posLeft = 2;
y.TBWidth += element.offsetWidth + HANDLE_PADDING;
break;
default:
alert("Invalid class: " + element.className + " on Element: " + element.id + " <" + element.tagName + ">");
return false;
}
}
y.TBWidth += 1;
return true;
}
function DebugObject(obj) {
var msg = "";
for (var i in TB) {
ans=prompt(i+"="+TB[i]+"\n");
if (! ans) break;
}
}
// Lay out the docked toolbars
function LayoutTBs() {
NumTBs = yToolbars.length;
// If no toolbars we're outta here
if (NumTBs == 0) return;
//Get the total size of a TBline.
var i;
var ScrWidth = 660//(document.body.offsetWidth);
var TotalLen = ScrWidth;
for (i = 0 ; i < NumTBs ; i++) {
TB = yToolbars[i];
if (TB.TBWidth > TotalLen) TotalLen = TB.TBWidth;
}
var PrevTB;
var LastStart = 0;
var RelTop = 0;
var LastWid, CurrWid;
//Set up the first toolbar.
var TB = yToolbars[0];
TB.style.posTop = 0;
TB.style.posLeft = 0;
//Lay out the other toolbars.
var Start = TB.TBWidth;
for (i = 1 ; i < yToolbars.length ; i++) {
PrevTB = TB;
TB = yToolbars[i];
CurrWid = TB.TBWidth;
if ((Start + CurrWid) > ScrWidth) {
//TB needs to go on next line.
Start = 0;
LastWid = TotalLen - LastStart;
}
else {
//Ok on this line.
LastWid = PrevTB.TBWidth;
//RelTop -= TB.style.posHeight;
RelTop -= TB.offsetHeight;
}
//Set TB position and LastTB width.
TB.style.posTop = RelTop;
TB.style.posLeft = Start;
PrevTB.style.width = LastWid;
//Increment counters.
LastStart = Start;
Start += CurrWid;
}
//Set width of last toolbar.
TB.style.width = TotalLen - LastStart;
//Move everything after the toolbars up the appropriate amount.
i--;
TB = yToolbars[i];
var TBInd = TB.sourceIndex;
var A = TB.document.all;
var item;
for (i in A) {
item = A.item(i);
if (! item) continue;
if (! item.style) continue;
if (item.sourceIndex <= TBInd) continue;
if (item.style.position == "absolute") continue;
item.style.posTop = RelTop;
}
}
//Lays out the page.
function DoLayout() {
LayoutTBs();
var TBHeight=0;
for (i = 0 ; i < yToolbars.length ; i++) {
TBHeight += yToolbars[i].offsetHeight;
}
var bodyHeight=document.body.offsetHeight;
var divHeight=switchDiv.offsetHeight;
var objIFrame=document.all.tags("IFRAME")[0];
//标题
if (typeof(infoHeader)!='undefined'){
var tableHeight=infoHeader.offsetHeight;
objIFrame.height=bodyHeight-tableHeight-TBHeight-divHeight;
}else{
objIFrame.height=bodyHeight-TBHeight-divHeight;
}
}
// Check if toolbar is being used when in text mode
function validateMode()
{
if (viewMode=="DESIGN")return true;
alert("请返回到“普通”模式!");
Composition.focus();
return false;
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?