Word.js 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504
  1. //查看指定文件,,判断是否保存或者覆盖,包括创建邀请协作人员,创建编辑历史,创建生成链接.创建热门模板。加载当前word文档的内容。创建光标,监控键盘输入等。这里是iframe中的word起始点。
  2. //监控输入输出,
  3. //添加成员,共同编辑。
  4. Namespace.register("U.MD.O.W");
  5. //由于当前文档的js是加载在ifame里面的,获取不到外部的文档(www.1473.cn)信息。所以通过传递参数设置全局变量的形式保存当前文档信息。
  6. //id是word文档id,PID是文档归属的目录id,fileinfo是文档的实体信息fileinfo,OL初始化回调函数,userid是当前文档创建者的id。 historyid就是最新历史记录的id
  7. U.MD.O.W = {
  8. "fileinfo": null, //文档的信息
  9. "userinfo": null, //文档用户的信息
  10. "historyid": US.EMPTYGUID, //历史记录更新的id
  11. "permission": { //权限设置
  12. "edit": false,
  13. "web": false
  14. },
  15. "init": false
  16. };
  17. US = parent.US;
  18. //#region 初始化区域
  19. //------------------------------------------------------------------------------初始化Word----------------------------------------------------------------------------
  20. //查看指定文件,,判断是否保存或者覆盖,包括创建邀请协作人员,创建编辑历史,创建生成链接.创建热门模板。加载当前word文档的内容。创建光标,监控键盘输入等。这里是iframe中的word起始点。
  21. /**
  22. * word初始化的处理
  23. *
  24. * @param {object} 文档信息
  25. * @param {object} 登录用户信息
  26. * @return {object} 返回当前窗体
  27. */
  28. U.MD.O.W.load = function (fileinfo, userinfo) {
  29. U.MD.O.W.variable(fileinfo, userinfo); //初始化全局变量
  30. U.MD.O.W.LoadContent(fileinfo); //加载内容
  31. U.MD.O.W.setEvent(); //设置事件
  32. //加载功能
  33. U.MD.O.W.Panel.LoadPlayUser(fileinfo); //加载协助人员窗体
  34. U.MD.O.W.Panel.loadlink(fileinfo); //加载链接窗体
  35. U.MD.O.W.Panel.LoadHotTemplates(); //加载热门模板
  36. U.MD.O.W.Panel.LoadOfficeHistory(fileinfo); //加载历史记录
  37. }
  38. /**
  39. * 设置事件
  40. *
  41. */
  42. U.MD.O.W.setEvent = function () {
  43. //设置建站文件的保存及新建事件
  44. if (U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un') {
  45. //设置新建事件
  46. $('#U_MD_O_H_new')[0].onclick = function () {
  47. U.MD.O.W.T.N.newNav();
  48. }
  49. //设置保存事件
  50. $('#U_MD_O_H_save')[0].onclick = function () {
  51. U.MD.O.W.T.N.saveNav(function () {
  52. U.MD.O.W.T.N.savePage(null, true);
  53. });
  54. }
  55. $('body').addClass('U_MD_O_W_Nav');
  56. }
  57. //添加Ctrl+S快捷保存事件
  58. $('body').bind('keydown', function (e) {
  59. var currKey = 0;
  60. e = e || event || window.event;
  61. currKey = e.keyCode;
  62. if (currKey == 83 && (e.ctrlKey || e.metaKey)) {
  63. $('#U_MD_O_H_save')[0].onclick();
  64. U.UF.EV.stopDefault();
  65. U.UF.EV.stopBubble()
  66. }
  67. });
  68. }
  69. /**
  70. * 初始化全局变量
  71. * @param {object} 文档信息
  72. * @param {object} 登录用户信息
  73. *
  74. */
  75. U.MD.O.W.variable = function (fileinfo, userinfo) {
  76. if (!U.MD.O.W.fileinfo) {
  77. U.MD.O.W.fileinfo = fileinfo //文档信息
  78. // return true;
  79. }
  80. U.MD.O.W.userinfo = userinfo; //用户信息
  81. U.MD.O.W.setPermission(); //获取权限
  82. return false;
  83. }
  84. /**
  85. * 加载Word编辑区域的内容
  86. * @param {string} 文档信息
  87. */
  88. U.MD.O.W.LoadContent = function (fileinfo) {
  89. var _permission = U.MD.O.W.permission; //获取权限
  90. var _synergy = _permission.web; //获取协同权限
  91. var _fileid = fileinfo.UserDirectoryID; //文档id
  92. //新建文件的处理
  93. if (fileinfo.newfile) {
  94. //un新建文件的处理
  95. if (U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un') {
  96. var _defaultnav;
  97. try {
  98. _defaultnav = JSON.parse(U.MD.O.W.fileinfo.UsOffice);
  99. } catch (e) {
  100. _defaultnav = { logo: "", nav: [{ pageId: Guid.newGuid(), name: "初始页面"}] };
  101. }
  102. U.MD.O.W.T.N.form(_defaultnav);
  103. }
  104. //初始化编辑器
  105. U.MD.O.W.E.initEditor();
  106. delete fileinfo.newfile;
  107. }
  108. //互联办公文档获取数据
  109. else if (_synergy) {
  110. parent.U.A.Request(US.SCOKET, [U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un' ? 'getNav' : "getWord", _fileid, US.pageId, U.MD.O.W.userinfo.UserId], U.MD.O.W.AsynLoad, ["", fileinfo, _synergy]); //获取office内容
  111. }
  112. //普通文档在数据库里面获取数据
  113. else {
  114. parent.U.A.Request(US.AUTH, ["GetFileContent", _fileid], U.MD.O.W.AsynLoad, ["", fileinfo, _synergy]);
  115. }
  116. }
  117. /**
  118. * 异步获取Word编辑区域的数据
  119. *
  120. */
  121. U.MD.O.W.AsynLoad = function (r) { //object 值
  122. var _permission,
  123. _context = r.context, //获取array值
  124. _fileinfo = _context[1], //获取文件信息
  125. _synergy = _context[2]; //互联权限
  126. //内容处理
  127. if (r.value && r.value.UsOffice !== undefined) {
  128. r = r.value.UsOffice;
  129. } else {
  130. r = r.value;
  131. }
  132. //un文件 导航文件处理
  133. if (U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un') {
  134. if (typeof r != 'object') {
  135. try {
  136. r = JSON.parse(r);
  137. } catch (e) {
  138. r = { logo: "", nav: [{ pageId: Guid.newGuid(), name: "恢复内容"}] };
  139. }
  140. }
  141. U.MD.O.W.T.N.form(r);
  142. }
  143. //word文件处理
  144. else {
  145. U.MD.O.W.fileinfo.UsOffice = (r || _fileinfo.UsOffice || "").unEscapeQuotes(); //word内容
  146. //加载编辑器和内容
  147. U.MD.O.W.E.initEditor(_synergy); //初始化编辑器
  148. }
  149. }
  150. //#endregion
  151. //#region 保存区域
  152. /**
  153. * 保存Word
  154. *
  155. * @param {function} 保存回调函数
  156. */
  157. U.MD.O.W.save = function () {
  158. //判断用户是否登录,只有登录用户才能保存信息
  159. if (!top.U.MD.U.L.isLogin(function (userinfo) { U.MD.O.W.userinfo = userinfo; })) {
  160. var _isftp,
  161. _isgroupuser,
  162. _uid = U.MD.O.W.userinfo.UserId,
  163. _el = $("#U_MD_O_H_wordEditor")[0], //word编辑区域
  164. _fileinfo = U.MD.O.W.fileinfo, //文件信息
  165. _fileid = _fileinfo.UserDirectoryID, //文件ID
  166. _name = top.$('#UD_Word' + _fileid + ' .U_MD_O_H_head_navigation_Title')[0].value, //文件名
  167. _html = _el.innerHTML.escapeQuotes(); //内容
  168. //判断文档是否是已经保存到数据库的文档
  169. if (_fileid && _fileinfo.UserId && _fileinfo.UserallDirectoryName && U.MD.O.W.permission.edit) { //如果是已经保存到数据库的文档,那么直接保存内容
  170. U.MD.O.W.Panel.InsertOfficeHistory(_fileinfo, _html, _name, _el); //插入历史记录
  171. //保存到数据库
  172. top.U.A.Request(US.AUTH, ["SaveFileContent", US.userInfo.UserId, _fileid, _html, _name], function (r) {
  173. U.MD.O.W.fileinfo.UsOffice = r.context[1].innerHTML;
  174. U.Alert("保存成功");
  175. }, (['', _el])); //保存到数据库
  176. }
  177. //如果文件没有保存,那么直接新建文件
  178. else {
  179. var _newfileid = Guid.newGuid();
  180. //调用word新建文档的处理
  181. top.U.MD.DK.VW.chosenSaveFile('uw', _newfileid, _name, function (fileinfo) {
  182. top.$('#UD_Word' + _fileid)[0].id = 'UD_Word' + _newfileid;
  183. top.$('#UD_Word' + _newfileid + ' .U_MD_O_H_head_navigation_Title')[0].value = fileinfo.UserDirectoryName;
  184. U.MD.O.W.fileinfo = fileinfo //文档信息
  185. _isgroup = U.Json.select(US.friend.group, {
  186. "GroupManageID": fileinfo.GroupID
  187. })[0];
  188. if (_isgroup) {
  189. U.MD.O.W.permission.web = true;
  190. top.U.A.Request(US.SCOKET, ["newWordSave", _newfileid, _html, fileinfo.UserDirectoryName, US.userInfo.UserId, US.pageId], function (r) {
  191. U.Alert("保存成功");
  192. U.MD.O.W.fileinfo.UsOffice = _el.innerHTML;
  193. $('#U_MD_O_H_wordEditor')[0].editor.operaNotice = U.MD.O.W.E.operationNotice;
  194. U.MD.O.W.permission.edit = true;
  195. });
  196. } else {
  197. //保存到数据库
  198. top.U.A.Request(US.AUTH, ["SaveFileContent", US.userInfo.UserId, _newfileid, _html, fileinfo.UserDirectoryName], function (r) {
  199. U.MD.O.W.fileinfo.UsOffice = r.context[1].innerHTML;
  200. U.MD.O.W.permission.edit = true;
  201. U.Alert("保存成功");
  202. }, (['', _el])); //保存到数据库
  203. }
  204. });
  205. }
  206. }
  207. }
  208. U.MD.O.W.updateName = function () {
  209. if (!top.U.MD.U.L.isLogin(function (userinfo) { U.MD.O.W.userinfo = userinfo; })) {
  210. var _fileinfo = U.MD.O.W.fileinfo, //文件信息
  211. _type = U.MD.O.W.fileinfo.UserDirectoryExtendType == 'un' ? 'nav' : 'word',
  212. _fileid = _fileinfo.UserDirectoryID, //文件ID
  213. _name = top.$('#UD_Word' + _fileid + ' .U_MD_O_H_head_navigation_Title')[0].value; //文件名
  214. //判断文档是否是已经保存到数据库的文档
  215. if (U.MD.O.W.permission.edit && _fileid && _fileinfo.UserId && _fileinfo.UserallDirectoryName) { //如果是已经保存到数据库的文档,那么直接保存内容
  216. if (U.MD.O.W.permission.web) {
  217. top.U.A.Request(US.SCOKET, ["updateName", _type, _fileid, _name, US.userInfo.UserId, US.pageId], function (r) {
  218. if (r.value == "updateNameSuccess") {
  219. _fileinfo.UserallDirectoryName = _name; //文件全写的名字
  220. _fileinfo.UserDirectoryName = _name.addEllipsis(20); //文件的缩略名
  221. }
  222. });
  223. }
  224. else {
  225. top.U.A.Request(US.DISK, ["UpdateFileInfo", _fileid, _name], function (r) {
  226. if (r.value) {
  227. _fileinfo.UserallDirectoryName = _name; //文件全写的名字
  228. _fileinfo.UserDirectoryName = _name.addEllipsis(20); //文件的缩略名
  229. }
  230. });
  231. }
  232. }
  233. }
  234. }
  235. //#endregion
  236. //#region 新建文档
  237. /**
  238. * 文件文档
  239. *
  240. */
  241. U.MD.O.W.newDoc = function () {
  242. parent.U.MD.D.I.openApplication("word", { "userid": US.userInfo.UserId, "directoryid": US.FTPFOLDERID }); //打开文档处理
  243. }
  244. //#endregion
  245. //#region 纸张大小
  246. /**
  247. * 编辑器权限函数
  248. * @return 返回用户权限json
  249. */
  250. U.MD.O.W.setPermission = function () {
  251. var _iseditor, //是否可编辑
  252. _isgroup; //群用户
  253. if (!U.MD.O.W.fileinfo.UserId && !U.MD.O.W.fileinfo.UserID) { //新建文档给予编辑权限
  254. U.MD.O.W.permission.edit = false; //就给其编辑权限
  255. return;
  256. }
  257. if (U.MD.O.W.fileinfo && US.friend.group) {//判断用户是否在群里操作群文件
  258. _isgroup = U.Json.select(US.friend.group, {
  259. "GroupManageID": U.MD.O.W.fileinfo.GroupID
  260. })[0];
  261. }
  262. if (U.MD.O.W.fileinfo && ((U.MD.O.W.fileinfo.GroupID && U.MD.O.W.fileinfo.GroupID == U.MD.O.W.userinfo.UserId) || U.MD.O.W.fileinfo.UserId == US.userInfo.UserId)) {//判断是否是有编辑权限
  263. _iseditor = true;
  264. }
  265. if (_isgroup) {//是ftp用户就判断是不是群用户
  266. U.MD.O.W.permission.web = true; //互联办公的权限
  267. U.MD.O.W.permission.edit = true; //就给其编辑权限
  268. } else if (_iseditor) {
  269. U.MD.O.W.permission.edit = true; //就给其编辑权限
  270. }
  271. }
  272. /**
  273. * 文档分享
  274. */
  275. U.MD.O.W.shareFileToChat = function () {
  276. top.U.MD.F.J.selectFriendForm(function (groupid) {
  277. var _fileInfo = U.MD.O.W.fileinfo,
  278. _message = {
  279. fileName: _fileInfo.UserallDirectoryName,
  280. fileType: _fileInfo.UserDirectoryExtendType,
  281. fileSize: _fileInfo.UserDirectorySize,
  282. fileID: _fileInfo.UserDirectoryID
  283. }
  284. if (!groupid) {
  285. var _chooseNumber = top.U.MD.F.J.selectUserInfo.NeedUser;
  286. for (var i = 0; i < _chooseNumber.length; i++) {
  287. U.A.Request(US.CD, [US.DB, "UseStudio_Friends", "SentMessageToFriend", US.userInfo.UserId, _chooseNumber[i].UserId, US.userInfo.UserNickName, JSON.stringify(_message), 6, false], function () {
  288. U.alert('文档已分享到小伙伴!');
  289. });
  290. }
  291. } else {
  292. U.A.Request(US.CD, [US.DB, "UseStudio_Friends", "SendMessageToGroup", groupid, Guid.newGuid(), US.userInfo.UserId, JSON.stringify(_message), US.userInfo.UserNickName], function () {
  293. U.alert('文档分享成功,到群看看吧!');
  294. });
  295. }
  296. });
  297. }
  298. document.oncontextmenu = U.UF.EV.stopDefault; //禁止右键菜单
  299. /**
  300. * 附件
  301. */
  302. U.MD.O.W.accessory = function () {
  303. if (!U.MD.U.L.isLogin()) {
  304. var _confirm = $$('div'),
  305. _pickarea = $$("div", { "style": { "cssText": "display:table; width: 100%; height: auto; "} }, _confirm),
  306. _picklocal = $$("div", { "style": { "cssText": "display:table-cell; width:235px; height:170px; background-color:#f5f5f5;text-align:center; vertical-align: middle;cursor: pointer;"} }, _pickarea),
  307. _pickline = $$("div", { "style": { "cssText": "display:table-cell; width:1px; height: 100%; background-color:#cecece;"} }, _pickarea),
  308. _pickoa = $$("div", { "style": { "cssText": "display:table-cell; width:234px; height:100%; background-color:#f5f5f5;text-align:center; vertical-align: middle;cursor: pointer;"} }, _pickarea);
  309. $$("img", { "onerror": U.MD.C.imgError, src: "/img/officefileicon.png", style: { "vertical-align": "middle"} }, _picklocal);
  310. $$("img", { "onerror": U.MD.C.imgError, src: "/img/oaofficeicon.png", style: { "vertical-align": "middle"} }, _pickoa);
  311. $$('span', { innerText: '从网盘添加', style: { "margin-left": "10px"} }, _pickoa);
  312. $$('span', { innerText: '从本地上传', style: { "margin-left": "10px"} }, _picklocal);
  313. var _locaInp = $$('input', { id: "U_MD_O_cloud", type: "file", style: { cssText: "position: absolute; visibility: hidden;" }, multiple: "" }, _picklocal);
  314. var _range;
  315. var _form = new U.UF.UI.form(
  316. "上传附件",
  317. _confirm,
  318. {
  319. "style": {
  320. "cssText": "font-size: 16px; background: rgb(255,255,255); width: 470px; position: fixed; box-shadow: rgb(0, 0, 0) 2px 1px 5px; "
  321. }
  322. },
  323. {
  324. "istop": true,
  325. "isenlarge": false,
  326. "isstretching": false,
  327. "isnarrow": false
  328. },
  329. {
  330. "style": {
  331. "cssText": " background: #3c475b;padding:4px 0 ; color: rgb(255,255,255); "
  332. }
  333. });
  334. $(_picklocal).bind({
  335. "mouseover": function () { _picklocal.style.backgroundColor = "#dcdcdc"; },
  336. "mouseout": function () { _picklocal.style.backgroundColor = "#f5f5f5"; },
  337. "mousedown": function () {
  338. _range = U.UF.E.getRangeAt();
  339. _locaInp.click();
  340. }
  341. });
  342. $(_pickoa).bind({
  343. "mouseover": function () { _pickoa.style.backgroundColor = "#dcdcdc"; },
  344. "mouseout": function () { _pickoa.style.backgroundColor = "#f5f5f5"; },
  345. "mousedown": function () {
  346. _range = U.UF.E.getRangeAt();
  347. },
  348. "click": function () {
  349. top.U.MD.DK.VW.choseFile(function (file) {
  350. // var _ppel = $$('span', { style: { cssText: "display:inline-block; position: relative; max-width: 300px;"} }),
  351. // _parent = $$('img', { "src": "http://fs.1473.cn/" + file.UserDirectoryUrl, style: { cssText: "width: 100%;"} }, _ppel),
  352. // _videoStart = $$("span", { "style": { "width": "97px", "height": "96px", "background-image": "url('/img/YS2017.png')", "display": "inline-block", "background-repeat": "no-repeat", "background-position": "-1015px -362px", "position": "absolute", "top": "25%", "left": "35%"} }, _ppel);
  353. // var _message = {
  354. // fileName: file.UserallDirectoryName,
  355. // fileType: file.UserDirectoryExtendType,
  356. // fileSize: file.UserDirectorySize,
  357. // fileID: file.UserDirectoryID,
  358. // fileUrl: file.UserDirectoryUrl
  359. // };
  360. // U.UF.E.reSelectRange(_range);
  361. U.UF.E.reSelectRange(_range);
  362. var _box = $$('div');
  363. var _img = $$('img', { src: "http://fs.1473.cn/" + file.UserDirectoryUrl }, _box)
  364. U.UF.E.textFormat(_box.outerHTML, $('#U_MD_O_H_wordEditor')[0])
  365. });
  366. }
  367. });
  368. $(_locaInp).bind({
  369. "mousedown": function () {
  370. _range = U.UF.E.getRangeAt(); //记录失焦前光标的位置
  371. },
  372. "change": function (e) {
  373. U.UF.E.reSelectRange(_range); //重新聚焦光标
  374. var _file = e.target.files[0], //获取本地选中文件
  375. _type = _file.type.split('/'); //获取选中文件的类型
  376. switch (_type[0]) {
  377. case "image": //图片
  378. U.UF.E.picture(this, $('#U_MD_O_H_wordEditor')[0]);
  379. break;
  380. case "audio": //音频
  381. U.UF.UP.inputUpload([this], "http://disk.1473.cn/USUpfile.ashx?typename=UseStudioEditor&UserId=c1fd0834-ea9a-44eb-b216-2a051c2240d8", function (data) {
  382. var _el = U.MD.O.W.accessory.printFile('video', data.value); //样式
  383. //以下代码仅仅提供展示,音频暂时无法上传
  384. if ($('#showplace').length) {
  385. $('#showplace').find('div[usbody="true"]')[0].appendchild(_el);
  386. return;
  387. }
  388. var _box = $$('div', {});
  389. _box.appendChild(_el);
  390. new U.UF.UI.form("展示位", _box, { id: "showplace", style: { cssText: "width: 600px; height: 500px"} });
  391. })
  392. break;
  393. case "video":
  394. // U.UF.UP.inputUpload([this], "http://disk.1473.cn/USUpfile.ashx?typename=UseStudioEditor&UserId=c1fd0834-ea9a-44eb-b216-2a051c2240d8", function (data) { //最终用例
  395. // //var _el = U.MD.O.W.accessory.printFile('video', data.value, _file);
  396. //
  397. // })
  398. var _box = $$('span'), //测试能否将canvas插入文档中用例
  399. _canvas = $$('canvas', {}, _box);
  400. var _ctx = _canvas.getContext('2d');
  401. _canvas.width = 300;
  402. _canvas.height = 200;
  403. _ctx.fillRect(0, 0, 300, 200);
  404. U.UF.E.insertContent(_box, _range, $('#U_MD_O_H_wordEditor')[0]);
  405. break;
  406. }
  407. }
  408. })
  409. }
  410. }
  411. /**
  412. * 打开视频控件
  413. */
  414. U.MD.O.W.accessory.openVideo = function () {
  415. alert(11);
  416. }
  417. /**
  418. * 输出文件样式
  419. */
  420. U.MD.O.W.accessory.printFile = function (type, data, files) {
  421. var _div = $$('span', { style: { cssText: "display: inline-block"} });
  422. switch (type) {
  423. case "video":
  424. var video = document.createElement('video'),
  425. _second, _mintue;
  426. video.src = "http://fs.1473.cn/" + data[0]
  427. video.addEventListener('canplaythrough', function (e) { //拿到视频的时长
  428. var s = Math.ceil(e.target.duration) % 60,
  429. m = Math.floor(e.target.duration / 60);
  430. _second = s < 10 ? "0" + s : s;
  431. _mintue = m < 10 ? "0" + m : m;
  432. var _img = $$('img', { src: "/img/YS2017.png" }),
  433. _img2 = $$('img', { src: "http://fs.1473.cn/" + data[1] });
  434. _img2.onload = function () { //当图片加载好后
  435. _ctx.drawImage(_img2, 0, 0, 300, 150); //关键帧图片
  436. _ctx.drawImage(_img, 1015, 362, 97, 97, 110, 20, 97, 97); //播放图片
  437. _ctx.fillStyle = "#ffffff"; //填充颜色
  438. _ctx.fillText(_mintue + ":" + _second, 10, 140);
  439. }
  440. })
  441. var _canvas = $$('canvas', { style: { cssText: "border:1px solid #000000;"} }, _div),
  442. _ctx = _canvas.getContext('2d');
  443. _canvas.width = 300;
  444. _canvas.height = 150;
  445. _canvas.onclick = function () {
  446. U.MD.UI.video("http://fs.1473.cn/" + data[0], 300, 150, false, $('#showplace').find('div[usbody="true"]')[0]);
  447. }
  448. break;
  449. case "audio":
  450. // var _box = $$('div', { style: { cssText: "display:inline-block; width: 146px; background-color: #3F8BDD; color: #ffffff;"} }, _div);
  451. // $$('img', { src: "#", style: { cssText: "width: 17px; height: 20px; background-color: #ffffff;"} });
  452. // $$('span', { innerText: '15"' });
  453. break;
  454. }
  455. return _div;
  456. }
  457. //#endregion