wpsjs
Version:
用于开发wps加载项的工具包
79 lines (75 loc) • 2.67 kB
JavaScript
import { GETDOCNAME, CREATETASKPANE, NEWDOC, ADDSTRING, CLOSEDOC, SETDEMOSPAN, OPENWEB } from "../actions/dialog";
import * as Immutable from "immutable";
import Util from "../js/util.js"
/* global wps:false */
const defaultState = Immutable.Map({
docName: null,
demoSpan: "waiting..."
});
export default function (state = defaultState, action) {
switch (action.type) {
case GETDOCNAME:
{
let doc = window.Application.ActiveWorkbook
let textValue
if (!doc){
textValue = "当前没有打开任何文档"
} else {
textValue = doc.Name
}
let newState = state.set('docName', textValue)
return newState
}
case NEWDOC:
{
window.Application.Workbooks.Add()
break;
}
case CREATETASKPANE:
{
let tsId = window.Application.PluginStorage.getItem("taskpane_id")
if (!tsId){
let tskpane = window.Application.CreateTaskPane(Util.GetUrlPath() + "taskpane")
let id = tskpane.ID
window.Application.PluginStorage.setItem("taskpane_id", id)
tskpane.Visible = true
}else{
let tskpane = window.Application.GetTaskPane(tsId)
tskpane.Visible = true
}
break
}
case ADDSTRING:
{
let curSheet = window.Application.ActiveSheet;
if (curSheet){
curSheet.Cells.Item(1, 1).Formula="Hello, wps加载项!" + curSheet.Cells.Item(1, 1).Formula
}
break;
}
case CLOSEDOC:
{
if (window.Application.Workbooks.Count < 2)
{
alert("当前只有一个文档,别关了。")
break
}
let doc = window.Application.ActiveWorkbook
if (doc)
doc.Close()
break;
}
case SETDEMOSPAN:
{
let newState = state.set('demoSpan', action.data)
return newState
}
case OPENWEB:
{
let param = state.get('demoSpan')
window.Application.OAAssist.ShellExecute(param)
}
default:
}
return state;
}