更新代码
34
vendor/rulong/dwz-panel/composer.json
vendored
Normal file
@@ -0,0 +1,34 @@
|
||||
{
|
||||
"name": "rulong/dwz-panel",
|
||||
"description": "",
|
||||
"license": "MIT",
|
||||
"authors": [
|
||||
{
|
||||
"name": "C.Jason",
|
||||
"email": "chenjxlg@163.com"
|
||||
}
|
||||
],
|
||||
"require": {
|
||||
"php": ">=7.1.3",
|
||||
"laravel/framework": "*",
|
||||
"mews/captcha": "^2.2"
|
||||
},
|
||||
"autoload": {
|
||||
"psr-0": {
|
||||
"RuLong\\Panel": "src/"
|
||||
},
|
||||
"files": [
|
||||
"src/helpers.php"
|
||||
]
|
||||
},
|
||||
"extra": {
|
||||
"laravel": {
|
||||
"providers": [
|
||||
"RuLong\\Panel\\ServiceProvider"
|
||||
],
|
||||
"aliases": {
|
||||
"Admin": "RuLong\\Panel\\Facades\\Admin"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
48
vendor/rulong/dwz-panel/config/captcha.php
vendored
Normal file
@@ -0,0 +1,48 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* 验证码配置
|
||||
*/
|
||||
return [
|
||||
|
||||
'characters' => '2346789abcdefghjmnpqrtuxyzABCDEFGHJMNPQRTUXYZ',
|
||||
|
||||
'default' => [
|
||||
'length' => 4,
|
||||
'width' => 115,
|
||||
'height' => 34,
|
||||
'quality' => 90,
|
||||
'fontColors' => ['#2c3e50', '#c0392b', '#16a085', '#c0392b', '#8e44ad', '#303f9f', '#f57c00', '#795548'],
|
||||
],
|
||||
|
||||
'flat' => [
|
||||
'length' => 6,
|
||||
'width' => 160,
|
||||
'height' => 46,
|
||||
'quality' => 90,
|
||||
'lines' => 6,
|
||||
'bgImage' => false,
|
||||
'bgColor' => '#ecf2f4',
|
||||
'fontColors' => ['#2c3e50', '#c0392b', '#16a085', '#c0392b', '#8e44ad', '#303f9f', '#f57c00', '#795548'],
|
||||
'contrast' => -5,
|
||||
],
|
||||
|
||||
'mini' => [
|
||||
'length' => 3,
|
||||
'width' => 60,
|
||||
'height' => 32,
|
||||
],
|
||||
|
||||
'inverse' => [
|
||||
'length' => 5,
|
||||
'width' => 120,
|
||||
'height' => 36,
|
||||
'quality' => 90,
|
||||
'sensitive' => true,
|
||||
'angle' => 12,
|
||||
'sharpen' => 10,
|
||||
'blur' => 2,
|
||||
'invert' => true,
|
||||
'contrast' => -5,
|
||||
],
|
||||
];
|
||||
141
vendor/rulong/dwz-panel/config/rulong.php
vendored
Normal file
@@ -0,0 +1,141 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* 后台默认配置
|
||||
*/
|
||||
return [
|
||||
|
||||
'title' => 'R.Admin',
|
||||
|
||||
'directory' => app_path('Admin'),
|
||||
|
||||
'desc' => '<p>快速开发后台框架</p><p>基于PHP 7.1+,更快的运行速度</p><p>Laravel + DwzUI</p>',
|
||||
|
||||
'login_helps' => [
|
||||
[
|
||||
'title' => '忘记密码怎么办?',
|
||||
'url' => 'https://www.cjango.com/',
|
||||
],
|
||||
],
|
||||
|
||||
'route' => [
|
||||
'prefix' => 'admin',
|
||||
'middleware' => ['web', 'rulong'],
|
||||
'namespace' => 'App\\Admin\\Controllers',
|
||||
],
|
||||
|
||||
'auth' => [
|
||||
'guards' => [
|
||||
'rulong' => [
|
||||
'driver' => 'session',
|
||||
'provider' => 'rulong',
|
||||
],
|
||||
],
|
||||
|
||||
'providers' => [
|
||||
'rulong' => [
|
||||
'driver' => 'eloquent',
|
||||
'model' => RuLong\Panel\Models\Admin::class,
|
||||
],
|
||||
],
|
||||
],
|
||||
|
||||
'logs' => [
|
||||
'enable' => true,
|
||||
'except' => [
|
||||
'/',
|
||||
'dashboard',
|
||||
'password',
|
||||
'logs*',
|
||||
],
|
||||
],
|
||||
'permission' => [
|
||||
'except' => [
|
||||
'/',
|
||||
'auth*',
|
||||
'dashboard',
|
||||
'password',
|
||||
],
|
||||
],
|
||||
|
||||
'ueditor' => [
|
||||
'imageActionName' => 'uploadImage',
|
||||
'imageFieldName' => 'upfile',
|
||||
'imageMaxSize' => 2048000,
|
||||
'imageAllowFiles' => ['.png', '.jpg', '.jpeg', '.gif', '.bmp'],
|
||||
'imageCompressEnable' => true,
|
||||
'imageCompressBorder' => 1600,
|
||||
'imageInsertAlign' => 'none',
|
||||
'imageUrlPrefix' => '',
|
||||
'imagePathFormat' => '/uploads/images/{yyyy}/{mm}/{dd}/{hash}',
|
||||
|
||||
/* 涂鸦图片上传配置项 */
|
||||
'scrawlActionName' => 'uploadScrawl',
|
||||
'scrawlFieldName' => 'upfile',
|
||||
'scrawlPathFormat' => '/uploads/images/{yyyy}/{mm}/{dd}/{hash}',
|
||||
'scrawlMaxSize' => 2048000,
|
||||
'scrawlUrlPrefix' => '',
|
||||
'scrawlInsertAlign' => 'none',
|
||||
|
||||
/* 截图工具上传 */
|
||||
'snapscreenActionName' => 'uploadImage',
|
||||
'snapscreenPathFormat' => '/uploads/images/{yyyy}/{mm}/{dd}/{hash}',
|
||||
'snapscreenUrlPrefix' => '',
|
||||
'snapscreenInsertAlign' => 'none',
|
||||
|
||||
/* 抓取远程图片配置 */
|
||||
'catcherActionName' => 'catchImage',
|
||||
'catcherLocalDomain' => [],
|
||||
'catcherFieldName' => 'source',
|
||||
'catcherPathFormat' => '/uploads/images/{yyyy}/{mm}/{dd}/{hash}',
|
||||
'catcherUrlPrefix' => '',
|
||||
'catcherMaxSize' => 2048000,
|
||||
'catcherAllowFiles' => ['.png', '.jpg', '.jpeg', '.gif', '.bmp'],
|
||||
|
||||
/* 上传视频配置 */
|
||||
'videoActionName' => 'uploadVideo',
|
||||
'videoFieldName' => 'upfile',
|
||||
'videoPathFormat' => '/uploads/videos/{yyyy}/{mm}/{dd}/{hash}',
|
||||
'videoUrlPrefix' => '',
|
||||
'videoMaxSize' => 102400000,
|
||||
'videoAllowFiles' => [
|
||||
'.flv', '.swf', '.mkv', '.avi', '.rm', '.rmvb', '.mpeg', '.mpg',
|
||||
'.ogg', '.ogv', '.mov', '.wmv', '.mp4', '.webm', '.mp3', '.wav', '.mid',
|
||||
],
|
||||
|
||||
/* 上传文件配置 */
|
||||
'fileActionName' => 'uploadFile',
|
||||
'fileFieldName' => 'upfile',
|
||||
'filePathFormat' => '/uploads/files/{yyyy}/{mm}/{dd}/{hash}',
|
||||
'fileUrlPrefix' => '',
|
||||
'fileMaxSize' => 51200000,
|
||||
'fileAllowFiles' => [
|
||||
'.png', '.jpg', '.jpeg', '.gif', '.bmp',
|
||||
'.flv', '.swf', '.mkv', '.avi', '.rm', '.rmvb', '.mpeg', '.mpg',
|
||||
'.ogg', '.ogv', '.mov', '.wmv', '.mp4', '.webm', '.mp3', '.wav', '.mid',
|
||||
'.rar', '.zip', '.tar', '.gz', '.7z', '.bz2', '.cab', '.iso',
|
||||
'.doc', '.docx', '.xls', '.xlsx', '.ppt', '.pptx', '.pdf', '.txt', '.md', '.xml',
|
||||
],
|
||||
|
||||
/* 列出指定目录下的图片 */
|
||||
'imageManagerActionName' => 'listImage',
|
||||
'imageManagerListPath' => '/uploads/images/',
|
||||
'imageManagerListSize' => 20,
|
||||
'imageManagerUrlPrefix' => '',
|
||||
'imageManagerInsertAlign' => 'none',
|
||||
'imageManagerAllowFiles' => ['.png', '.jpg', '.jpeg', '.gif', '.bmp'],
|
||||
|
||||
/* 列出指定目录下的文件 */
|
||||
'fileManagerActionName' => 'listFile',
|
||||
'fileManagerListPath' => '/uploads/files/',
|
||||
'fileManagerUrlPrefix' => '',
|
||||
'fileManagerListSize' => 20,
|
||||
'fileManagerAllowFiles' => [
|
||||
'.png', '.jpg', '.jpeg', '.gif', '.bmp',
|
||||
'.flv', '.swf', '.mkv', '.avi', '.rm', '.rmvb', '.mpeg', '.mpg',
|
||||
'.ogg', '.ogv', '.mov', '.wmv', '.mp4', '.webm', '.mp3', '.wav', '.mid',
|
||||
'.rar', '.zip', '.tar', '.gz', '.7z', '.bz2', '.cab', '.iso',
|
||||
'.doc', '.docx', '.xls', '.xlsx', '.ppt', '.pptx', '.pdf', '.txt', '.md', '.xml',
|
||||
],
|
||||
],
|
||||
];
|
||||
94
vendor/rulong/dwz-panel/database/migrations/0000_00_00_000000_create_admin_tables.php
vendored
Normal file
@@ -0,0 +1,94 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
class CreateAdminTables extends Migration
|
||||
{
|
||||
/**
|
||||
* Run the migrations.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function up()
|
||||
{
|
||||
Schema::create('admins', function (Blueprint $table) {
|
||||
$table->increments('id');
|
||||
$table->string('username', 32);
|
||||
$table->string('password');
|
||||
$table->string('nickname', 32)->nullable();
|
||||
$table->string('remember_token')->nullable();
|
||||
$table->timestamps();
|
||||
$table->softDeletes();
|
||||
});
|
||||
|
||||
Schema::create('admin_logins', function (Blueprint $table) {
|
||||
$table->increments('id');
|
||||
$table->integer('admin_id')->unsigned();
|
||||
$table->string('login_ip', 15)->nullable();
|
||||
$table->timestamp('created_at')->nullable();
|
||||
});
|
||||
|
||||
Schema::create('admin_menus', function (Blueprint $table) {
|
||||
$table->increments('id');
|
||||
$table->integer('parent_id')->unsigned();
|
||||
$table->string('title', 64);
|
||||
$table->integer('sort')->unsigned();
|
||||
$table->string('uri')->nullable();
|
||||
$table->timestamps();
|
||||
});
|
||||
|
||||
Schema::create('admin_operation_logs', function (Blueprint $table) {
|
||||
$table->bigInteger('id', true)->unsigned();
|
||||
$table->integer('admin_id')->unsigned()->index();
|
||||
$table->string('path');
|
||||
$table->string('method', 10);
|
||||
$table->string('ip', 15);
|
||||
$table->text('input')->nullable();
|
||||
$table->timestamp('created_at')->nullable();
|
||||
});
|
||||
|
||||
Schema::create('admin_roles', function (Blueprint $table) {
|
||||
$table->increments('id');
|
||||
$table->string('name', 64);
|
||||
$table->string('description')->nullable();
|
||||
$table->text('rules')->nullable();
|
||||
$table->timestamps();
|
||||
$table->softDeletes();
|
||||
});
|
||||
|
||||
Schema::create('admin_role_user', function (Blueprint $table) {
|
||||
$table->integer('role_id')->unsigned();
|
||||
$table->integer('admin_id')->unsigned();
|
||||
$table->timestamps();
|
||||
$table->primary(['role_id', 'admin_id']);
|
||||
});
|
||||
|
||||
Schema::create('storages', function (Blueprint $table) {
|
||||
$table->increments('id');
|
||||
$table->string('name', 255);
|
||||
$table->string('hash', 32)->index();
|
||||
$table->string('type', 32);
|
||||
$table->integer('size')->unsigned();
|
||||
$table->string('path', 255);
|
||||
$table->timestamp('created_at')->nullable();
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Reverse the migrations.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function down()
|
||||
{
|
||||
Schema::disableForeignKeyConstraints();
|
||||
Schema::drop('admins');
|
||||
Schema::drop('admin_logins');
|
||||
Schema::drop('admin_menus');
|
||||
Schema::drop('admin_operation_logs');
|
||||
Schema::drop('admin_roles');
|
||||
Schema::drop('admin_role_user');
|
||||
}
|
||||
}
|
||||
244
vendor/rulong/dwz-panel/resources/assets/dwz.frag.xml
vendored
Normal file
@@ -0,0 +1,244 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<_AJAX_>
|
||||
|
||||
<!-- dwz.dialog -->
|
||||
<_PAGE_ id="dialogFrag"><![CDATA[
|
||||
<div class="dialog" style="top:150px; left:300px;">
|
||||
<div class="dialogHeader" onselectstart="return false;" oncopy="return false;" onpaste="return false;" oncut="return false;">
|
||||
<div class="dialogHeader_r">
|
||||
<div class="dialogHeader_c">
|
||||
<a class="close" href="#close">close</a>
|
||||
<a class="maximize" href="#maximize">maximize</a>
|
||||
<a class="restore" href="#restore">restore</a>
|
||||
<a class="minimize" href="#minimize">minimize</a>
|
||||
<h1>弹出窗口</h1>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="dialogContent layoutBox unitBox">
|
||||
</div>
|
||||
<div class="dialogFooter"><div class="dialogFooter_r"><div class="dialogFooter_c"></div></div></div>
|
||||
<div class="resizable_h_l" tar="nw"></div>
|
||||
<div class="resizable_h_r" tar="ne"></div>
|
||||
<div class="resizable_h_c" tar="n"></div>
|
||||
<div class="resizable_c_l" tar="w" style="height:300px;"></div>
|
||||
<div class="resizable_c_r" tar="e" style="height:300px;"></div>
|
||||
<div class="resizable_f_l" tar="sw"></div>
|
||||
<div class="resizable_f_r" tar="se"></div>
|
||||
<div class="resizable_f_c" tar="s"></div>
|
||||
</div>
|
||||
]]></_PAGE_>
|
||||
<!-- dwz.dialog shadow -->
|
||||
<_PAGE_ id="dialogProxy"><![CDATA[
|
||||
<div id="dialogProxy" class="dialog dialogProxy">
|
||||
<div class="dialogHeader">
|
||||
<div class="dialogHeader_r">
|
||||
<div class="dialogHeader_c">
|
||||
<a class="close" href="#close">close</a>
|
||||
<a class="maximize" href="#maximize">maximize</a>
|
||||
<a class="minimize" href="#minimize">minimize</a>
|
||||
<h1></h1>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="dialogContent"></div>
|
||||
<div class="dialogFooter">
|
||||
<div class="dialogFooter_r">
|
||||
<div class="dialogFooter_c">
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
]]></_PAGE_>
|
||||
<!-- dwz.dialog taskbar -->
|
||||
<_PAGE_ id="taskbar"><![CDATA[
|
||||
<div id="taskbar" style="left:0px; display:none;">
|
||||
<div class="taskbarContent">
|
||||
<ul></ul>
|
||||
</div>
|
||||
<div class="taskbarLeft taskbarLeftDisabled" style="display:none;">taskbarLeft</div>
|
||||
<div class="taskbarRight" style="display:none;">taskbarRight</div>
|
||||
</div>
|
||||
]]></_PAGE_>
|
||||
|
||||
<!-- other dwz fragment -->
|
||||
<_PAGE_ id="dwzFrag"><![CDATA[
|
||||
<div id="splitBar"></div>
|
||||
<div id="splitBarProxy"></div>
|
||||
|
||||
<!--拖动效果-->
|
||||
<div class="resizable"></div>
|
||||
<!--阴影-->
|
||||
<div class="shadow" style="width:508px; top:148px; left:296px;">
|
||||
<div class="shadow_h">
|
||||
<div class="shadow_h_l"></div>
|
||||
<div class="shadow_h_r"></div>
|
||||
<div class="shadow_h_c"></div>
|
||||
</div>
|
||||
<div class="shadow_c">
|
||||
<div class="shadow_c_l" style="height:296px;"></div>
|
||||
<div class="shadow_c_r" style="height:296px;"></div>
|
||||
<div class="shadow_c_c" style="height:296px;"></div>
|
||||
</div>
|
||||
<div class="shadow_f">
|
||||
<div class="shadow_f_l"></div>
|
||||
<div class="shadow_f_r"></div>
|
||||
<div class="shadow_f_c"></div>
|
||||
</div>
|
||||
</div>
|
||||
<!--遮盖屏幕-->
|
||||
<div id="alertBackground" class="alertBackground"></div>
|
||||
<div id="dialogBackground" class="dialogBackground"></div>
|
||||
|
||||
<div id='background' class='background'></div>
|
||||
<div id='progressBar' class='progressBar'>数据加载中,请稍等...</div>
|
||||
]]></_PAGE_>
|
||||
|
||||
<!-- dwz.pagination -->
|
||||
<_PAGE_ id="pagination"><![CDATA[
|
||||
<ul>
|
||||
<li class="j-first">
|
||||
<a class="first" href="javascript:;"><span>首页</span></a>
|
||||
<span class="first"><span>首页</span></span>
|
||||
</li>
|
||||
<li class="j-prev">
|
||||
<a class="previous" href="javascript:;"><span>上一页</span></a>
|
||||
<span class="previous"><span>上一页</span></span>
|
||||
</li>
|
||||
#pageNumFrag#
|
||||
<li class="j-next">
|
||||
<a class="next" href="javascript:;"><span>下一页</span></a>
|
||||
<span class="next"><span>下一页</span></span>
|
||||
</li>
|
||||
<li class="j-last">
|
||||
<a class="last" href="javascript:;"><span>末页</span></a>
|
||||
<span class="last"><span>末页</span></span>
|
||||
</li>
|
||||
<li class="jumpto"><input class="textInput" type="text" size="4" value="#currentPage#" /><input class="goto" type="button" value="确定" /></li>
|
||||
</ul>
|
||||
]]></_PAGE_>
|
||||
|
||||
|
||||
<!-- dwz.alertMsg -->
|
||||
<_PAGE_ id="alertBoxFrag"><![CDATA[
|
||||
<div id="alertMsgBox" class="alert"><div class="alertContent"><div class="#type#"><div class="alertInner"><h1>#title#</h1><div class="msg">#message#</div></div><div class="toolBar"><ul>#butFragment#</ul></div></div></div><div class="alertFooter"><div class="alertFooter_r"><div class="alertFooter_c"></div></div></div></div>
|
||||
]]></_PAGE_>
|
||||
|
||||
<_PAGE_ id="alertButFrag"><![CDATA[
|
||||
<li><a class="button" rel="#callback#" onclick="alertMsg.close()" href="javascript:"><span>#butMsg#</span></a></li>
|
||||
]]></_PAGE_>
|
||||
|
||||
<_PAGE_ id="calendarFrag"><![CDATA[
|
||||
<div id="calendar">
|
||||
<div class="main">
|
||||
<div class="head">
|
||||
<table width="100%" border="0" cellpadding="0" cellspacing="2">
|
||||
<tr>
|
||||
<td><select name="year"></select></td>
|
||||
<td><select name="month"></select></td>
|
||||
<td width="20"><span class="close">×</span></td>
|
||||
</tr>
|
||||
</table>
|
||||
</div>
|
||||
<div class="body">
|
||||
<dl class="dayNames"><dt>日</dt><dt>一</dt><dt>二</dt><dt>三</dt><dt>四</dt><dt>五</dt><dt>六</dt></dl>
|
||||
<dl class="days">日期列表选项</dl>
|
||||
<div style="clear:both;height:0;line-height:0"></div>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="foot">
|
||||
<table class="time">
|
||||
<tr>
|
||||
<td>
|
||||
<input type="text" class="hh" maxlength="2" start="0" end="23"/>:
|
||||
<input type="text" class="mm" maxlength="2" start="0" end="59"/>:
|
||||
<input type="text" class="ss" maxlength="2" start="0" end="59"/>
|
||||
</td>
|
||||
<td><ul><li class="up">∧</li><li class="down">∨</li></ul></td>
|
||||
</tr>
|
||||
</table>
|
||||
<button type="button" class="clearBut">清空</button>
|
||||
<button type="button" class="okBut">确定</button>
|
||||
<div>
|
||||
<div class="tm">
|
||||
<ul class="hh">
|
||||
<li>0</li>
|
||||
<li>1</li>
|
||||
<li>2</li>
|
||||
<li>3</li>
|
||||
<li>4</li>
|
||||
<li>5</li>
|
||||
<li>6</li>
|
||||
<li>7</li>
|
||||
<li>8</li>
|
||||
<li>9</li>
|
||||
<li>10</li>
|
||||
<li>11</li>
|
||||
<li>12</li>
|
||||
<li>13</li>
|
||||
<li>14</li>
|
||||
<li>15</li>
|
||||
<li>16</li>
|
||||
<li>17</li>
|
||||
<li>18</li>
|
||||
<li>19</li>
|
||||
<li>20</li>
|
||||
<li>21</li>
|
||||
<li>22</li>
|
||||
<li>23</li>
|
||||
</ul>
|
||||
<ul class="mm">
|
||||
<li>0</li>
|
||||
<li>5</li>
|
||||
<li>10</li>
|
||||
<li>15</li>
|
||||
<li>20</li>
|
||||
<li>25</li>
|
||||
<li>30</li>
|
||||
<li>35</li>
|
||||
<li>40</li>
|
||||
<li>45</li>
|
||||
<li>50</li>
|
||||
<li>55</li>
|
||||
</ul>
|
||||
<ul class="ss">
|
||||
<li>0</li>
|
||||
<li>10</li>
|
||||
<li>20</li>
|
||||
<li>30</li>
|
||||
<li>40</li>
|
||||
<li>50</li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
]]></_PAGE_>
|
||||
|
||||
<_PAGE_ id="navTabCM"><![CDATA[
|
||||
<ul id="navTabCM">
|
||||
<li rel="reload">刷新标签页</li>
|
||||
<li rel="closeCurrent">关闭标签页</li>
|
||||
<li rel="closeOther">关闭其它标签页</li>
|
||||
<li rel="closeAll">关闭全部标签页</li>
|
||||
</ul>
|
||||
]]></_PAGE_>
|
||||
<_PAGE_ id="dialogCM"><![CDATA[
|
||||
<ul id="dialogCM">
|
||||
<li rel="closeCurrent">关闭弹出窗口</li>
|
||||
<li rel="closeOther">关闭其它弹出窗口</li>
|
||||
<li rel="closeAll">关闭全部弹出窗口</li>
|
||||
</ul>
|
||||
]]></_PAGE_>
|
||||
<_PAGE_ id="externalFrag"><![CDATA[
|
||||
<iframe src="{url}" style="width:100%;height:{height};" frameborder="no" border="0" marginwidth="0" marginheight="0"></iframe>
|
||||
]]></_PAGE_>
|
||||
<_MSG_ id="statusCode_503"><![CDATA[服务器当前负载过大或者正在维护!]]></_MSG_>
|
||||
<_MSG_ id="validateFormError"><![CDATA[提交数据不完整,{0}个字段有错误,请改正后再提交!]]></_MSG_>
|
||||
<_MSG_ id="sessionTimout"><![CDATA[会话超时,请重新登录!]]></_MSG_>
|
||||
<_MSG_ id="alertSelectMsg"><![CDATA[请选择信息!]]></_MSG_>
|
||||
<_MSG_ id="forwardConfirmMsg"><![CDATA[继续下一步!]]></_MSG_>
|
||||
|
||||
<_MSG_ id="dwzTitle"><![CDATA[DWZ富客户端框架]]></_MSG_>
|
||||
<_MSG_ id="mainTabTitle"><![CDATA[我的主页]]></_MSG_>
|
||||
</_AJAX_>
|
||||
1
vendor/rulong/dwz-panel/resources/assets/js/dwz.min.js
vendored
Normal file
5
vendor/rulong/dwz-panel/resources/assets/js/jquery-1.11.3.min.js
vendored
Normal file
4
vendor/rulong/dwz-panel/resources/assets/js/jquery-2.1.4.min.js
vendored
Normal file
69
vendor/rulong/dwz-panel/resources/assets/js/jquery.bgiframe.js
vendored
Normal file
@@ -0,0 +1,69 @@
|
||||
/*! Copyright (c) 2013 Brandon Aaron (http://brandon.aaron.sh)
|
||||
* Licensed under the MIT License (LICENSE.txt).
|
||||
*
|
||||
* Version 3.0.1
|
||||
*
|
||||
* Requires jQuery >= 1.2.6
|
||||
*/
|
||||
|
||||
(function (factory) {
|
||||
if ( typeof define === 'function' && define.amd ) {
|
||||
// AMD. Register as an anonymous module.
|
||||
define(['jquery'], factory);
|
||||
} else if ( typeof exports === 'object' ) {
|
||||
// Node/CommonJS style for Browserify
|
||||
module.exports = factory;
|
||||
} else {
|
||||
// Browser globals
|
||||
factory(jQuery);
|
||||
}
|
||||
}(function ($) {
|
||||
$.fn.bgiframe = function(s) {
|
||||
s = $.extend({
|
||||
top : 'auto', // auto == borderTopWidth
|
||||
left : 'auto', // auto == borderLeftWidth
|
||||
width : 'auto', // auto == offsetWidth
|
||||
height : 'auto', // auto == offsetHeight
|
||||
opacity : true,
|
||||
src : 'javascript:false;',
|
||||
conditional : /MSIE 6\.0/.test(navigator.userAgent) // expression or function. return false to prevent iframe insertion
|
||||
}, s);
|
||||
|
||||
// wrap conditional in a function if it isn't already
|
||||
if ( !$.isFunction(s.conditional) ) {
|
||||
var condition = s.conditional;
|
||||
s.conditional = function() { return condition; };
|
||||
}
|
||||
|
||||
var $iframe = $('<iframe class="bgiframe" frameborder="0" tabindex="-1" src="'+s.src+'"'+
|
||||
'style="display:block;position:absolute;z-index:-1;"/>');
|
||||
|
||||
return this.each(function() {
|
||||
var $this = $(this);
|
||||
if ( s.conditional(this) === false ) { return; }
|
||||
var existing = $this.children('iframe.bgiframe');
|
||||
var $el = existing.length === 0 ? $iframe.clone() : existing;
|
||||
$el.css({
|
||||
'top': s.top == 'auto' ?
|
||||
((parseInt($this.css('borderTopWidth'),10)||0)*-1)+'px' : prop(s.top),
|
||||
'left': s.left == 'auto' ?
|
||||
((parseInt($this.css('borderLeftWidth'),10)||0)*-1)+'px' : prop(s.left),
|
||||
'width': s.width == 'auto' ? (this.offsetWidth + 'px') : prop(s.width),
|
||||
'height': s.height == 'auto' ? (this.offsetHeight + 'px') : prop(s.height),
|
||||
'opacity': s.opacity === true ? 0 : undefined
|
||||
});
|
||||
|
||||
if ( existing.length === 0 ) {
|
||||
$this.prepend($el);
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
// old alias
|
||||
$.fn.bgIframe = $.fn.bgiframe;
|
||||
|
||||
function prop(n) {
|
||||
return n && n.constructor === Number ? n + 'px' : n;
|
||||
}
|
||||
|
||||
}));
|
||||
92
vendor/rulong/dwz-panel/resources/assets/js/jquery.cookie.js
vendored
Normal file
@@ -0,0 +1,92 @@
|
||||
/**
|
||||
* Cookie plugin
|
||||
*
|
||||
* Copyright (c) 2006 Klaus Hartl (stilbuero.de)
|
||||
* Dual licensed under the MIT and GPL licenses:
|
||||
* http://www.opensource.org/licenses/mit-license.php
|
||||
* http://www.gnu.org/licenses/gpl.html
|
||||
*
|
||||
*/
|
||||
|
||||
/**
|
||||
* Create a cookie with the given name and value and other optional parameters.
|
||||
*
|
||||
* @example $.cookie('the_cookie', 'the_value');
|
||||
* @desc Set the value of a cookie.
|
||||
* @example $.cookie('the_cookie', 'the_value', {expires: 7, path: '/', domain: 'jquery.com', secure: true});
|
||||
* @desc Create a cookie with all available options.
|
||||
* @example $.cookie('the_cookie', 'the_value');
|
||||
* @desc Create a session cookie.
|
||||
* @example $.cookie('the_cookie', null);
|
||||
* @desc Delete a cookie by passing null as value.
|
||||
*
|
||||
* @param String name The name of the cookie.
|
||||
* @param String value The value of the cookie.
|
||||
* @param Object options An object literal containing key/value pairs to provide optional cookie attributes.
|
||||
* @option Number|Date expires Either an integer specifying the expiration date from now on in days or a Date object.
|
||||
* If a negative value is specified (e.g. a date in the past), the cookie will be deleted.
|
||||
* If set to null or omitted, the cookie will be a session cookie and will not be retained
|
||||
* when the the browser exits.
|
||||
* @option String path The value of the path atribute of the cookie (default: path of page that created the cookie).
|
||||
* @option String domain The value of the domain attribute of the cookie (default: domain of page that created the cookie).
|
||||
* @option Boolean secure If true, the secure attribute of the cookie will be set and the cookie transmission will
|
||||
* require a secure protocol (like HTTPS).
|
||||
* @type undefined
|
||||
*
|
||||
* @name $.cookie
|
||||
* @cat Plugins/Cookie
|
||||
* @author Klaus Hartl/klaus.hartl@stilbuero.de
|
||||
*/
|
||||
|
||||
/**
|
||||
* Get the value of a cookie with the given name.
|
||||
*
|
||||
* @example $.cookie('the_cookie');
|
||||
* @desc Get the value of a cookie.
|
||||
*
|
||||
* @param String name The name of the cookie.
|
||||
* @return The value of the cookie.
|
||||
* @type String
|
||||
*
|
||||
* @name $.cookie
|
||||
* @cat Plugins/Cookie
|
||||
* @author Klaus Hartl/klaus.hartl@stilbuero.de
|
||||
*/
|
||||
jQuery.cookie = function(name, value, options) {
|
||||
if (typeof value != 'undefined') { // name and value given, set cookie
|
||||
options = options || {};
|
||||
if (value === null) {
|
||||
value = '';
|
||||
options.expires = -1;
|
||||
}
|
||||
var expires = '';
|
||||
if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) {
|
||||
var date;
|
||||
if (typeof options.expires == 'number') {
|
||||
date = new Date();
|
||||
date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000));
|
||||
} else {
|
||||
date = options.expires;
|
||||
}
|
||||
expires = '; expires=' + date.toUTCString(); // use expires attribute, max-age is not supported by IE
|
||||
}
|
||||
var path = options.path ? '; path=' + options.path : '';
|
||||
var domain = options.domain ? '; domain=' + options.domain : '';
|
||||
var secure = options.secure ? '; secure' : '';
|
||||
document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join('');
|
||||
} else { // only name given, get cookie
|
||||
var cookieValue = null;
|
||||
if (document.cookie && document.cookie != '') {
|
||||
var cookies = document.cookie.split(';');
|
||||
for (var i = 0; i < cookies.length; i++) {
|
||||
var cookie = jQuery.trim(cookies[i]);
|
||||
// Does this cookie string begin with the name we want?
|
||||
if (cookie.substring(0, name.length + 1) == (name + '=')) {
|
||||
cookieValue = decodeURIComponent(cookie.substring(name.length + 1));
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
return cookieValue;
|
||||
}
|
||||
};
|
||||
5
vendor/rulong/dwz-panel/resources/assets/js/speedup.js
vendored
Normal file
@@ -0,0 +1,5 @@
|
||||
/**
|
||||
* @author Roger Wu
|
||||
*/
|
||||
/*@cc_on _d=document;eval('var document=_d')@*/
|
||||
/*@cc_on eval((function(props) {var code = [];for (var i = 0,l = props.length;i<l;i++){var prop = props[i];window['_'+prop]=window[prop];code.push(prop+'=_'+prop);}return 'var '+code.join(',');})('document self top parent alert setInterval clearInterval setTimeout clearTimeout'.split(' ')))@*/
|
||||
1
vendor/rulong/dwz-panel/resources/assets/themes/css/core.css
vendored
Normal file
1
vendor/rulong/dwz-panel/resources/assets/themes/css/ieHack.css
vendored
Normal file
@@ -0,0 +1 @@
|
||||
@charset "utf-8";html,body{*overflow:hidden}#header .nav li a{line-height:14px}#header .menu li a,#header .menu li span{line-height:37px}#taskbar li .taskbutton span{line-height:31px}.toggleCollapse h2{line-height:27px}.panel .panelHeaderContent h1{line-height:32px}.accordion .accordionHeader h2{line-height:27px}.tabsHeader li span{line-height:32px}.tabsPanel .panelHeader li span{line-height:30px}.tabsPanel .panelHeader li.selected span{line-height:32px}.tabsPage .tabsPageHeader{width:auto}.tabsPage .tabsPageHeader li span{_line-height:24px;font-family:"宋体"}.tabsPage .tabsRight{_right:16px}.tabsPage .tabsMore{_right:-1px}.tabsPage .tabsMoreList{_right:-1px}.tabsPage .tabsMoreList li a{line-height:23px}.alert h1,.alert h1{line-height:34px}.dialog .dialogHeader h1{line-height:32px}.shadow .shadow_h_l{_background:0;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true,sizingMethod=scale,src="themes/default/images/shadow/shadow_h_l.png")}.shadow .shadow_h_r{_background:0;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true,sizingMethod=scale,src="themes/default/images/shadow/shadow_h_r.png")}.shadow .shadow_h_c{_background:0;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true,sizingMethod=scale,src="themes/default/images/shadow/shadow_h_c.png")}.shadow .shadow_c_l{_background:0;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true,sizingMethod=scale,src="themes/default/images/shadow/shadow_c_l.png")}.shadow .shadow_c_r{_background:0;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true,sizingMethod=scale,src="themes/default/images/shadow/shadow_c_r.png")}.shadow .shadow_c_c{_background:0;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true,sizingMethod=scale,src="themes/default/images/shadow/shadow_c_c.png")}.shadow .shadow_f_l{_background:0;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true,sizingMethod=scale,src="themes/default/images/shadow/shadow_f_l.png")}.shadow .shadow_f_r{_background:0;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true,sizingMethod=scale,src="themes/default/images/shadow/shadow_f_r.png")}.shadow .shadow_f_c{_background:0;_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true,sizingMethod=scale,src="themes/default/images/shadow/shadow_f_c.png")}.tree a,.tree span{line-height:24px}.tree a{_margin-left:-3px}.panelBar .toolBar span,.panelBar .toolBar li.hover span,.panelBar .pagination span,.panelBar .pagination li.hover span{line-height:25px}.grid .gridCol{line-height:23px}.textInput,.textInputHover,.textInputRequired,.textInputInvalid,.textInputReadonly,.textInputDisabled,.textArea,.textAreaHover,.textAreaRequired,.textAreaInvalid,.textAreaReadonly,.textAreaDisabled{padding:3px 2px 1px 2px}.button span,.buttonDisabled span,.buttonActive span,.button button,.buttonActive button,.buttonDisabled button{line-height:27px}#calendar .time .hh,#calendar .time .mm,#calendar .time .ss{border:0}#calendar .time .up,#calendar .time .down{font-size:7px}textarea.required{background-position:104% 0}
|
||||
52
vendor/rulong/dwz-panel/resources/assets/themes/css/login.css
vendored
Normal file
@@ -0,0 +1,52 @@
|
||||
@charset "utf-8";
|
||||
|
||||
html, body, div, span, applet, object, iframe,
|
||||
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
|
||||
a, abbr, acronym, address, big, cite, code,
|
||||
del, dfn, em, font, img, ins, kbd, q, s, samp,
|
||||
small, strike, strong, sub, sup, tt, var,
|
||||
dl, dt, dd, ol, ul, li,
|
||||
fieldset, form, label, legend,
|
||||
table, caption, tbody, tfoot, thead, tr, th, td { padding:0; margin:0; font-size:12px; line-height:100%; font-family:Arial, sans-serif;}
|
||||
|
||||
ul, ol { list-style:none;}
|
||||
img { border:0;}
|
||||
|
||||
body { margin:0; text-align:center; background:#FFF url(../default/images/login_bg.png) repeat-x top;}
|
||||
|
||||
#login { display:block; width:950px; margin:0 auto; text-align:left;}
|
||||
#login_header { display:block; padding-top:40px; height:80px;}
|
||||
.login_logo { float:left; margin-top:10px;}
|
||||
.login_info { float:left; margin-left:10px; line-height:80px; font-size:18px; color:#0088cc; font-weight: bold;}
|
||||
.login_headerContent { float:right; display:block; width:280px; height:80px; padding:0 40px; background:url(../default/images/login_header_bg.png) no-repeat top right;}
|
||||
.navList { display:block; overflow:hidden; height:20px; padding-left:28px;}
|
||||
.navList ul { float:left; display:block; overflow:hidden;}
|
||||
.navList li { float:left; display:block; margin-left:-1px; padding:0 10px; background:url(../default/images/login_list.png) no-repeat 0 5px;}
|
||||
.navList a { display:block; white-space:nowrap; line-height:21px; color:#000; text-decoration:none;}
|
||||
.navList a:hover { text-decoration:underline;}
|
||||
|
||||
#login_content { display:block; position:relative;}
|
||||
.login_title { display:block; padding:25px 0 0 38px;}
|
||||
.loginForm { display:block; width:240px; padding:40px 20px 0 20px; position:absolute; right:40px;}
|
||||
.loginForm p { margin:10px 0;}
|
||||
.loginForm label { float:left; width:70px; padding:0 0 0 10px; line-height:25px; color:#4c4c4c; font-size:14px;}
|
||||
.loginForm input { padding:3px 2px; border-style:solid; border-width:1px; border-color:#80a5c4;}
|
||||
.loginForm .login_input {width: 145px}
|
||||
.loginForm .code { float:left; margin-right:5px;}
|
||||
.login_bar { padding-left:80px;}
|
||||
.login_bar .sub { display:block; width:75px; height:30px; border:none; background:url(../default/images/login_sub.png) no-repeat; cursor:pointer;}
|
||||
|
||||
.login_banner { display:block; height:270px;}
|
||||
.login_main { display:block; height:200px; padding-right:40px; background:url(../default/images/login_content_bg.png) no-repeat top;}
|
||||
|
||||
.helpList { float:right; width:200px;}
|
||||
.helpList li { display:block; padding-left:10px; background:url(../default/images/login_list.png) no-repeat 0 -40px;}
|
||||
.helpList a { line-height:21px; color:#333; text-decoration:none; }
|
||||
.helpList a:hover { text-decoration:underline;}
|
||||
|
||||
.login_inner { display:block; width:560px; padding:30px 20px 0 20px;}
|
||||
.login_inner p { margin:10px 0; line-height:150%; font-size:14px; color:#666;}
|
||||
|
||||
#login_footer { clear:both; display:block; margin-bottom:20px; padding:10px; border-top:solid 1px #e2e5e8; color:#666; text-align:center;}
|
||||
|
||||
.verify {cursor: pointer;}
|
||||
1
vendor/rulong/dwz-panel/resources/assets/themes/css/print.css
vendored
Normal file
@@ -0,0 +1 @@
|
||||
#layout,#footer,#splitBar,#splitBarProxy,#alertBackground,#dialogBackground,#background,.comboxop,.shadow,.panelBar{display:none}#printBox{display:block;font-family:Arial,sans-serif}table.list{border-collapse:collapse;width:100%}table.list thead tr{background-color:#f0eff0}table.list th{border:solid 1px #d0d0d0;font-weight:bold}table.list td{border:solid 1px #d0d0d0;white-space:nowrap}.grid table{border-collapse:collapse;width:100%}.grid table th{border:solid 1px #d0d0d0;font-weight:bold}.grid table td{border:solid 1px #d0d0d0;white-space:nowrap}.grid .gridTbody td div{display:block}.grid .left{text-align:left}.grid .right{text-align:right}.grid .center{text-align:center}
|
||||
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/accordion/accordion.png
vendored
Normal file
|
After Width: | Height: | Size: 1.5 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/account_info_bg.png
vendored
Normal file
|
After Width: | Height: | Size: 229 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/alert/alertpanel.png
vendored
Normal file
|
After Width: | Height: | Size: 238 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/alert/alertpanel_icon.png
vendored
Normal file
|
After Width: | Height: | Size: 1.8 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/button/button_s.png
vendored
Normal file
|
After Width: | Height: | Size: 3.3 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/button/imgX.gif
vendored
Normal file
|
After Width: | Height: | Size: 3.0 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/button/toleft.gif
vendored
Normal file
|
After Width: | Height: | Size: 880 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/button/toleftone.gif
vendored
Normal file
|
After Width: | Height: | Size: 859 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/button/toright.gif
vendored
Normal file
|
After Width: | Height: | Size: 863 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/button/torightone.gif
vendored
Normal file
|
After Width: | Height: | Size: 851 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/dialog/dialogpanel.png
vendored
Normal file
|
After Width: | Height: | Size: 1.2 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/dialog/dialogpanel_icon.png
vendored
Normal file
|
After Width: | Height: | Size: 4.1 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/form/input_bg.png
vendored
Normal file
|
After Width: | Height: | Size: 3.6 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/form/input_bt.png
vendored
Normal file
|
After Width: | Height: | Size: 4.2 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/grid/grid.png
vendored
Normal file
|
After Width: | Height: | Size: 4.0 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/grid/resizeCol.png
vendored
Normal file
|
After Width: | Height: | Size: 3.5 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/grid/tableth.png
vendored
Normal file
|
After Width: | Height: | Size: 221 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/header_bg.png
vendored
Normal file
|
After Width: | Height: | Size: 9.6 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/icon.png
vendored
Normal file
|
After Width: | Height: | Size: 372 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/layout/taskbar.png
vendored
Normal file
|
After Width: | Height: | Size: 1.8 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/layout/taskbar_control.png
vendored
Normal file
|
After Width: | Height: | Size: 1.0 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/layout/taskbar_icon.png
vendored
Normal file
|
After Width: | Height: | Size: 3.8 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/layout/toggleSidebar.png
vendored
Normal file
|
After Width: | Height: | Size: 916 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/listLine.png
vendored
Normal file
|
After Width: | Height: | Size: 148 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/login_banner.jpg
vendored
Normal file
|
After Width: | Height: | Size: 86 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/login_bg.png
vendored
Normal file
|
After Width: | Height: | Size: 211 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/login_content_bg.png
vendored
Normal file
|
After Width: | Height: | Size: 4.4 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/login_header_bg.png
vendored
Normal file
|
After Width: | Height: | Size: 4.7 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/login_list.png
vendored
Normal file
|
After Width: | Height: | Size: 161 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/login_logo.png
vendored
Normal file
|
After Width: | Height: | Size: 8.3 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/login_sub.png
vendored
Normal file
|
After Width: | Height: | Size: 4.2 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/login_title.png
vendored
Normal file
|
After Width: | Height: | Size: 5.3 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/logo.png
vendored
Normal file
|
After Width: | Height: | Size: 8.7 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/menu/menu.png
vendored
Normal file
|
After Width: | Height: | Size: 1.4 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/order_down.gif
vendored
Normal file
|
After Width: | Height: | Size: 850 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/order_up.gif
vendored
Normal file
|
After Width: | Height: | Size: 848 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/pageHeader_bg.png
vendored
Normal file
|
After Width: | Height: | Size: 182 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/panel/panel.png
vendored
Normal file
|
After Width: | Height: | Size: 1.3 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/panel/panel_icon.png
vendored
Normal file
|
After Width: | Height: | Size: 779 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/progressBar/progressBar_l.gif
vendored
Normal file
|
After Width: | Height: | Size: 5.7 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/progressBar/progressBar_m.gif
vendored
Normal file
|
After Width: | Height: | Size: 3.4 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/progressBar/progressBar_s.gif
vendored
Normal file
|
After Width: | Height: | Size: 2.5 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/search-bg.gif
vendored
Normal file
|
After Width: | Height: | Size: 598 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/search-bt.gif
vendored
Normal file
|
After Width: | Height: | Size: 2.1 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/shadow/shadow_c_c.png
vendored
Normal file
|
After Width: | Height: | Size: 118 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/shadow/shadow_c_l.png
vendored
Normal file
|
After Width: | Height: | Size: 133 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/shadow/shadow_c_r.png
vendored
Normal file
|
After Width: | Height: | Size: 130 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/shadow/shadow_f_c.png
vendored
Normal file
|
After Width: | Height: | Size: 130 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/shadow/shadow_f_l.png
vendored
Normal file
|
After Width: | Height: | Size: 176 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/shadow/shadow_f_r.png
vendored
Normal file
|
After Width: | Height: | Size: 167 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/shadow/shadow_h_c.png
vendored
Normal file
|
After Width: | Height: | Size: 126 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/shadow/shadow_h_l.png
vendored
Normal file
|
After Width: | Height: | Size: 171 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/shadow/shadow_h_r.png
vendored
Normal file
|
After Width: | Height: | Size: 169 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/tabs/tabscontrol.png
vendored
Normal file
|
After Width: | Height: | Size: 4.5 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/tabs/tabspage.png
vendored
Normal file
|
After Width: | Height: | Size: 1.5 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/tabs/tabspage_icon.png
vendored
Normal file
|
After Width: | Height: | Size: 370 B |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/tabs/tabspanel.png
vendored
Normal file
|
After Width: | Height: | Size: 1.9 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/themeButton.png
vendored
Normal file
|
After Width: | Height: | Size: 3.3 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/tree/check.png
vendored
Normal file
|
After Width: | Height: | Size: 4.0 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/tree/folder.png
vendored
Normal file
|
After Width: | Height: | Size: 1.4 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/tree/tree.png
vendored
Normal file
|
After Width: | Height: | Size: 3.9 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/wx.png
vendored
Normal file
|
After Width: | Height: | Size: 12 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/themes/default/images/zfb.png
vendored
Normal file
|
After Width: | Height: | Size: 32 KiB |
1
vendor/rulong/dwz-panel/resources/assets/themes/default/style.css
vendored
Normal file
40
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/anchor/anchor.html
vendored
Normal file
@@ -0,0 +1,40 @@
|
||||
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
|
||||
"http://www.w3.org/TR/html4/loose.dtd">
|
||||
<html>
|
||||
<head>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
|
||||
<title></title>
|
||||
<style type="text/css">
|
||||
*{color: #838383;margin: 0;padding: 0}
|
||||
html,body {font-size: 12px;overflow: hidden; }
|
||||
.content{padding:5px 0 0 15px;}
|
||||
input{width:210px;height:21px;line-height:21px;margin-left: 4px;}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="content">
|
||||
<span><var id="lang_input_anchorName"></var></span><input id="anchorName" value="" />
|
||||
</div>
|
||||
<script type="text/javascript" src="../internal.js"></script>
|
||||
<script type="text/javascript">
|
||||
var anchorInput = $G('anchorName'),
|
||||
node = editor.selection.getRange().getClosedNode();
|
||||
if(node && node.tagName == 'IMG' && (node = node.getAttribute('anchorname'))){
|
||||
anchorInput.value = node;
|
||||
}
|
||||
anchorInput.onkeydown = function(evt){
|
||||
evt = evt || window.event;
|
||||
if(evt.keyCode == 13){
|
||||
editor.execCommand('anchor', anchorInput.value);
|
||||
dialog.close();
|
||||
domUtils.preventDefault(evt)
|
||||
}
|
||||
};
|
||||
dialog.onok = function (){
|
||||
editor.execCommand('anchor', anchorInput.value);
|
||||
dialog.close();
|
||||
};
|
||||
$focus(anchorInput);
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
||||
681
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/attachment.css
vendored
Normal file
@@ -0,0 +1,681 @@
|
||||
@charset "utf-8";
|
||||
/* dialog样式 */
|
||||
.wrapper {
|
||||
zoom: 1;
|
||||
width: 630px;
|
||||
*width: 626px;
|
||||
height: 380px;
|
||||
margin: 0 auto;
|
||||
padding: 10px;
|
||||
position: relative;
|
||||
font-family: sans-serif;
|
||||
}
|
||||
|
||||
/*tab样式框大小*/
|
||||
.tabhead {
|
||||
float:left;
|
||||
}
|
||||
.tabbody {
|
||||
width: 100%;
|
||||
height: 346px;
|
||||
position: relative;
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.tabbody .panel {
|
||||
position: absolute;
|
||||
width: 0;
|
||||
height: 0;
|
||||
background: #fff;
|
||||
overflow: hidden;
|
||||
display: none;
|
||||
}
|
||||
|
||||
.tabbody .panel.focus {
|
||||
width: 100%;
|
||||
height: 346px;
|
||||
display: block;
|
||||
}
|
||||
|
||||
/* 上传附件 */
|
||||
.tabbody #upload.panel {
|
||||
width: 0;
|
||||
height: 0;
|
||||
overflow: hidden;
|
||||
position: absolute !important;
|
||||
clip: rect(1px, 1px, 1px, 1px);
|
||||
background: #fff;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.tabbody #upload.panel.focus {
|
||||
width: 100%;
|
||||
height: 346px;
|
||||
display: block;
|
||||
clip: auto;
|
||||
}
|
||||
|
||||
#upload .queueList {
|
||||
margin: 0;
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
position: absolute;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
#upload p {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.element-invisible {
|
||||
width: 0 !important;
|
||||
height: 0 !important;
|
||||
border: 0;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
overflow: hidden;
|
||||
position: absolute !important;
|
||||
clip: rect(1px, 1px, 1px, 1px);
|
||||
}
|
||||
|
||||
#upload .placeholder {
|
||||
margin: 10px;
|
||||
border: 2px dashed #e6e6e6;
|
||||
*border: 0px dashed #e6e6e6;
|
||||
height: 172px;
|
||||
padding-top: 150px;
|
||||
text-align: center;
|
||||
background: url(./images/image.png) center 70px no-repeat;
|
||||
color: #cccccc;
|
||||
font-size: 18px;
|
||||
position: relative;
|
||||
top:0;
|
||||
*top: 10px;
|
||||
}
|
||||
|
||||
#upload .placeholder .webuploader-pick {
|
||||
font-size: 18px;
|
||||
background: #00b7ee;
|
||||
border-radius: 3px;
|
||||
line-height: 44px;
|
||||
padding: 0 30px;
|
||||
*width: 120px;
|
||||
color: #fff;
|
||||
display: inline-block;
|
||||
margin: 0 auto 20px auto;
|
||||
cursor: pointer;
|
||||
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
|
||||
}
|
||||
|
||||
#upload .placeholder .webuploader-pick-hover {
|
||||
background: #00a2d4;
|
||||
}
|
||||
|
||||
|
||||
#filePickerContainer {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
#upload .placeholder .flashTip {
|
||||
color: #666666;
|
||||
font-size: 12px;
|
||||
position: absolute;
|
||||
width: 100%;
|
||||
text-align: center;
|
||||
bottom: 20px;
|
||||
}
|
||||
|
||||
#upload .placeholder .flashTip a {
|
||||
color: #0785d1;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
#upload .placeholder .flashTip a:hover {
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
#upload .placeholder.webuploader-dnd-over {
|
||||
border-color: #999999;
|
||||
}
|
||||
|
||||
#upload .filelist {
|
||||
list-style: none;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
overflow-x: hidden;
|
||||
overflow-y: auto;
|
||||
position: relative;
|
||||
height: 300px;
|
||||
}
|
||||
|
||||
#upload .filelist:after {
|
||||
content: '';
|
||||
display: block;
|
||||
width: 0;
|
||||
height: 0;
|
||||
overflow: hidden;
|
||||
clear: both;
|
||||
}
|
||||
|
||||
#upload .filelist li {
|
||||
width: 113px;
|
||||
height: 113px;
|
||||
background: url(./images/bg.png);
|
||||
text-align: center;
|
||||
margin: 9px 0 0 9px;
|
||||
*margin: 6px 0 0 6px;
|
||||
position: relative;
|
||||
display: block;
|
||||
float: left;
|
||||
overflow: hidden;
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
#upload .filelist li p.log {
|
||||
position: relative;
|
||||
top: -45px;
|
||||
}
|
||||
|
||||
#upload .filelist li p.title {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
overflow: hidden;
|
||||
white-space: nowrap;
|
||||
text-overflow: ellipsis;
|
||||
top: 5px;
|
||||
text-indent: 5px;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
#upload .filelist li p.progress {
|
||||
position: absolute;
|
||||
width: 100%;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
height: 8px;
|
||||
overflow: hidden;
|
||||
z-index: 50;
|
||||
margin: 0;
|
||||
border-radius: 0;
|
||||
background: none;
|
||||
-webkit-box-shadow: 0 0 0;
|
||||
}
|
||||
|
||||
#upload .filelist li p.progress span {
|
||||
display: none;
|
||||
overflow: hidden;
|
||||
width: 0;
|
||||
height: 100%;
|
||||
background: #1483d8 url(./images/progress.png) repeat-x;
|
||||
|
||||
-webit-transition: width 200ms linear;
|
||||
-moz-transition: width 200ms linear;
|
||||
-o-transition: width 200ms linear;
|
||||
-ms-transition: width 200ms linear;
|
||||
transition: width 200ms linear;
|
||||
|
||||
-webkit-animation: progressmove 2s linear infinite;
|
||||
-moz-animation: progressmove 2s linear infinite;
|
||||
-o-animation: progressmove 2s linear infinite;
|
||||
-ms-animation: progressmove 2s linear infinite;
|
||||
animation: progressmove 2s linear infinite;
|
||||
|
||||
-webkit-transform: translateZ(0);
|
||||
}
|
||||
|
||||
@-webkit-keyframes progressmove {
|
||||
0% {
|
||||
background-position: 0 0;
|
||||
}
|
||||
100% {
|
||||
background-position: 17px 0;
|
||||
}
|
||||
}
|
||||
|
||||
@-moz-keyframes progressmove {
|
||||
0% {
|
||||
background-position: 0 0;
|
||||
}
|
||||
100% {
|
||||
background-position: 17px 0;
|
||||
}
|
||||
}
|
||||
|
||||
@keyframes progressmove {
|
||||
0% {
|
||||
background-position: 0 0;
|
||||
}
|
||||
100% {
|
||||
background-position: 17px 0;
|
||||
}
|
||||
}
|
||||
|
||||
#upload .filelist li p.imgWrap {
|
||||
position: relative;
|
||||
z-index: 2;
|
||||
line-height: 113px;
|
||||
vertical-align: middle;
|
||||
overflow: hidden;
|
||||
width: 113px;
|
||||
height: 113px;
|
||||
|
||||
-webkit-transform-origin: 50% 50%;
|
||||
-moz-transform-origin: 50% 50%;
|
||||
-o-transform-origin: 50% 50%;
|
||||
-ms-transform-origin: 50% 50%;
|
||||
transform-origin: 50% 50%;
|
||||
|
||||
-webit-transition: 200ms ease-out;
|
||||
-moz-transition: 200ms ease-out;
|
||||
-o-transition: 200ms ease-out;
|
||||
-ms-transition: 200ms ease-out;
|
||||
transition: 200ms ease-out;
|
||||
}
|
||||
#upload .filelist li p.imgWrap.notimage {
|
||||
margin-top: 0;
|
||||
width: 111px;
|
||||
height: 111px;
|
||||
border: 1px #eeeeee solid;
|
||||
}
|
||||
#upload .filelist li p.imgWrap.notimage i.file-preview {
|
||||
margin-top: 15px;
|
||||
}
|
||||
|
||||
#upload .filelist li img {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
#upload .filelist li p.error {
|
||||
background: #f43838;
|
||||
color: #fff;
|
||||
position: absolute;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
height: 28px;
|
||||
line-height: 28px;
|
||||
width: 100%;
|
||||
z-index: 100;
|
||||
display:none;
|
||||
}
|
||||
|
||||
#upload .filelist li .success {
|
||||
display: block;
|
||||
position: absolute;
|
||||
left: 0;
|
||||
bottom: 0;
|
||||
height: 40px;
|
||||
width: 100%;
|
||||
z-index: 200;
|
||||
background: url(./images/success.png) no-repeat right bottom;
|
||||
background-image: url(./images/success.gif) \9;
|
||||
}
|
||||
|
||||
#upload .filelist li.filePickerBlock {
|
||||
width: 113px;
|
||||
height: 113px;
|
||||
background: url(./images/image.png) no-repeat center 12px;
|
||||
border: 1px solid #eeeeee;
|
||||
border-radius: 0;
|
||||
}
|
||||
#upload .filelist li.filePickerBlock div.webuploader-pick {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
opacity: 0;
|
||||
background: none;
|
||||
font-size: 0;
|
||||
}
|
||||
|
||||
#upload .filelist div.file-panel {
|
||||
position: absolute;
|
||||
height: 0;
|
||||
filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0, startColorstr='#80000000', endColorstr='#80000000') \0;
|
||||
background: rgba(0, 0, 0, 0.5);
|
||||
width: 100%;
|
||||
top: 0;
|
||||
left: 0;
|
||||
overflow: hidden;
|
||||
z-index: 300;
|
||||
}
|
||||
|
||||
#upload .filelist div.file-panel span {
|
||||
width: 24px;
|
||||
height: 24px;
|
||||
display: inline;
|
||||
float: right;
|
||||
text-indent: -9999px;
|
||||
overflow: hidden;
|
||||
background: url(./images/icons.png) no-repeat;
|
||||
background: url(./images/icons.gif) no-repeat \9;
|
||||
margin: 5px 1px 1px;
|
||||
cursor: pointer;
|
||||
-webkit-tap-highlight-color: rgba(0,0,0,0);
|
||||
-webkit-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
user-select: none;
|
||||
}
|
||||
|
||||
#upload .filelist div.file-panel span.rotateLeft {
|
||||
display:none;
|
||||
background-position: 0 -24px;
|
||||
}
|
||||
|
||||
#upload .filelist div.file-panel span.rotateLeft:hover {
|
||||
background-position: 0 0;
|
||||
}
|
||||
|
||||
#upload .filelist div.file-panel span.rotateRight {
|
||||
display:none;
|
||||
background-position: -24px -24px;
|
||||
}
|
||||
|
||||
#upload .filelist div.file-panel span.rotateRight:hover {
|
||||
background-position: -24px 0;
|
||||
}
|
||||
|
||||
#upload .filelist div.file-panel span.cancel {
|
||||
background-position: -48px -24px;
|
||||
}
|
||||
|
||||
#upload .filelist div.file-panel span.cancel:hover {
|
||||
background-position: -48px 0;
|
||||
}
|
||||
|
||||
#upload .statusBar {
|
||||
height: 45px;
|
||||
border-bottom: 1px solid #dadada;
|
||||
margin: 0 10px;
|
||||
padding: 0;
|
||||
line-height: 45px;
|
||||
vertical-align: middle;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
#upload .statusBar .progress {
|
||||
border: 1px solid #1483d8;
|
||||
width: 198px;
|
||||
background: #fff;
|
||||
height: 18px;
|
||||
position: absolute;
|
||||
top: 12px;
|
||||
display: none;
|
||||
text-align: center;
|
||||
line-height: 18px;
|
||||
color: #6dbfff;
|
||||
margin: 0 10px 0 0;
|
||||
}
|
||||
#upload .statusBar .progress span.percentage {
|
||||
width: 0;
|
||||
height: 100%;
|
||||
left: 0;
|
||||
top: 0;
|
||||
background: #1483d8;
|
||||
position: absolute;
|
||||
}
|
||||
#upload .statusBar .progress span.text {
|
||||
position: relative;
|
||||
z-index: 10;
|
||||
}
|
||||
|
||||
#upload .statusBar .info {
|
||||
display: inline-block;
|
||||
font-size: 14px;
|
||||
color: #666666;
|
||||
}
|
||||
|
||||
#upload .statusBar .btns {
|
||||
position: absolute;
|
||||
top: 7px;
|
||||
right: 0;
|
||||
line-height: 30px;
|
||||
}
|
||||
|
||||
#filePickerBtn {
|
||||
display: inline-block;
|
||||
float: left;
|
||||
}
|
||||
#upload .statusBar .btns .webuploader-pick,
|
||||
#upload .statusBar .btns .uploadBtn,
|
||||
#upload .statusBar .btns .uploadBtn.state-uploading,
|
||||
#upload .statusBar .btns .uploadBtn.state-paused {
|
||||
background: #ffffff;
|
||||
border: 1px solid #cfcfcf;
|
||||
color: #565656;
|
||||
padding: 0 18px;
|
||||
display: inline-block;
|
||||
border-radius: 3px;
|
||||
margin-left: 10px;
|
||||
cursor: pointer;
|
||||
font-size: 14px;
|
||||
float: left;
|
||||
-webkit-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
user-select: none;
|
||||
}
|
||||
#upload .statusBar .btns .webuploader-pick-hover,
|
||||
#upload .statusBar .btns .uploadBtn:hover,
|
||||
#upload .statusBar .btns .uploadBtn.state-uploading:hover,
|
||||
#upload .statusBar .btns .uploadBtn.state-paused:hover {
|
||||
background: #f0f0f0;
|
||||
}
|
||||
|
||||
#upload .statusBar .btns .uploadBtn,
|
||||
#upload .statusBar .btns .uploadBtn.state-paused{
|
||||
background: #00b7ee;
|
||||
color: #fff;
|
||||
border-color: transparent;
|
||||
}
|
||||
#upload .statusBar .btns .uploadBtn:hover,
|
||||
#upload .statusBar .btns .uploadBtn.state-paused:hover{
|
||||
background: #00a2d4;
|
||||
}
|
||||
|
||||
#upload .statusBar .btns .uploadBtn.disabled {
|
||||
pointer-events: none;
|
||||
filter:alpha(opacity=60);
|
||||
-moz-opacity:0.6;
|
||||
-khtml-opacity: 0.6;
|
||||
opacity: 0.6;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* 图片管理样式 */
|
||||
#online {
|
||||
width: 100%;
|
||||
height: 336px;
|
||||
padding: 10px 0 0 0;
|
||||
}
|
||||
#online #fileList{
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
overflow-x: hidden;
|
||||
overflow-y: auto;
|
||||
position: relative;
|
||||
}
|
||||
#online ul {
|
||||
display: block;
|
||||
list-style: none;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
#online li {
|
||||
float: left;
|
||||
display: block;
|
||||
list-style: none;
|
||||
padding: 0;
|
||||
width: 113px;
|
||||
height: 113px;
|
||||
margin: 0 0 9px 9px;
|
||||
*margin: 0 0 6px 6px;
|
||||
background-color: #eee;
|
||||
overflow: hidden;
|
||||
cursor: pointer;
|
||||
position: relative;
|
||||
}
|
||||
#online li.clearFloat {
|
||||
float: none;
|
||||
clear: both;
|
||||
display: block;
|
||||
width:0;
|
||||
height:0;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
#online li img {
|
||||
cursor: pointer;
|
||||
}
|
||||
#online li div.file-wrapper {
|
||||
cursor: pointer;
|
||||
position: absolute;
|
||||
display: block;
|
||||
width: 111px;
|
||||
height: 111px;
|
||||
border: 1px solid #eee;
|
||||
background: url("./images/bg.png") repeat;
|
||||
}
|
||||
#online li div span.file-title{
|
||||
display: block;
|
||||
padding: 0 3px;
|
||||
margin: 3px 0 0 0;
|
||||
font-size: 12px;
|
||||
height: 13px;
|
||||
color: #555555;
|
||||
text-align: center;
|
||||
width: 107px;
|
||||
white-space: nowrap;
|
||||
word-break: break-all;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
}
|
||||
#online li .icon {
|
||||
cursor: pointer;
|
||||
width: 113px;
|
||||
height: 113px;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
z-index: 2;
|
||||
border: 0;
|
||||
background-repeat: no-repeat;
|
||||
}
|
||||
#online li .icon:hover {
|
||||
width: 107px;
|
||||
height: 107px;
|
||||
border: 3px solid #1094fa;
|
||||
}
|
||||
#online li.selected .icon {
|
||||
background-image: url(images/success.png);
|
||||
background-image: url(images/success.gif) \9;
|
||||
background-position: 75px 75px;
|
||||
}
|
||||
#online li.selected .icon:hover {
|
||||
width: 107px;
|
||||
height: 107px;
|
||||
border: 3px solid #1094fa;
|
||||
background-position: 72px 72px;
|
||||
}
|
||||
|
||||
|
||||
/* 在线文件的文件预览图标 */
|
||||
i.file-preview {
|
||||
display: block;
|
||||
margin: 10px auto;
|
||||
width: 70px;
|
||||
height: 70px;
|
||||
background-image: url("./images/file-icons.png");
|
||||
background-image: url("./images/file-icons.gif") \9;
|
||||
background-position: -140px center;
|
||||
background-repeat: no-repeat;
|
||||
}
|
||||
i.file-preview.file-type-dir{
|
||||
background-position: 0 center;
|
||||
}
|
||||
i.file-preview.file-type-file{
|
||||
background-position: -140px center;
|
||||
}
|
||||
i.file-preview.file-type-filelist{
|
||||
background-position: -210px center;
|
||||
}
|
||||
i.file-preview.file-type-zip,
|
||||
i.file-preview.file-type-rar,
|
||||
i.file-preview.file-type-7z,
|
||||
i.file-preview.file-type-tar,
|
||||
i.file-preview.file-type-gz,
|
||||
i.file-preview.file-type-bz2{
|
||||
background-position: -280px center;
|
||||
}
|
||||
i.file-preview.file-type-xls,
|
||||
i.file-preview.file-type-xlsx{
|
||||
background-position: -350px center;
|
||||
}
|
||||
i.file-preview.file-type-doc,
|
||||
i.file-preview.file-type-docx{
|
||||
background-position: -420px center;
|
||||
}
|
||||
i.file-preview.file-type-ppt,
|
||||
i.file-preview.file-type-pptx{
|
||||
background-position: -490px center;
|
||||
}
|
||||
i.file-preview.file-type-vsd{
|
||||
background-position: -560px center;
|
||||
}
|
||||
i.file-preview.file-type-pdf{
|
||||
background-position: -630px center;
|
||||
}
|
||||
i.file-preview.file-type-txt,
|
||||
i.file-preview.file-type-md,
|
||||
i.file-preview.file-type-json,
|
||||
i.file-preview.file-type-htm,
|
||||
i.file-preview.file-type-xml,
|
||||
i.file-preview.file-type-html,
|
||||
i.file-preview.file-type-js,
|
||||
i.file-preview.file-type-css,
|
||||
i.file-preview.file-type-php,
|
||||
i.file-preview.file-type-jsp,
|
||||
i.file-preview.file-type-asp{
|
||||
background-position: -700px center;
|
||||
}
|
||||
i.file-preview.file-type-apk{
|
||||
background-position: -770px center;
|
||||
}
|
||||
i.file-preview.file-type-exe{
|
||||
background-position: -840px center;
|
||||
}
|
||||
i.file-preview.file-type-ipa{
|
||||
background-position: -910px center;
|
||||
}
|
||||
i.file-preview.file-type-mp4,
|
||||
i.file-preview.file-type-swf,
|
||||
i.file-preview.file-type-mkv,
|
||||
i.file-preview.file-type-avi,
|
||||
i.file-preview.file-type-flv,
|
||||
i.file-preview.file-type-mov,
|
||||
i.file-preview.file-type-mpg,
|
||||
i.file-preview.file-type-mpeg,
|
||||
i.file-preview.file-type-ogv,
|
||||
i.file-preview.file-type-webm,
|
||||
i.file-preview.file-type-rm,
|
||||
i.file-preview.file-type-rmvb{
|
||||
background-position: -980px center;
|
||||
}
|
||||
i.file-preview.file-type-ogg,
|
||||
i.file-preview.file-type-wav,
|
||||
i.file-preview.file-type-wmv,
|
||||
i.file-preview.file-type-mid,
|
||||
i.file-preview.file-type-mp3{
|
||||
background-position: -1050px center;
|
||||
}
|
||||
i.file-preview.file-type-jpg,
|
||||
i.file-preview.file-type-jpeg,
|
||||
i.file-preview.file-type-gif,
|
||||
i.file-preview.file-type-bmp,
|
||||
i.file-preview.file-type-png,
|
||||
i.file-preview.file-type-psd{
|
||||
background-position: -140px center;
|
||||
}
|
||||
60
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/attachment.html
vendored
Normal file
@@ -0,0 +1,60 @@
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>ueditor图片对话框</title>
|
||||
<script type="text/javascript" src="../internal.js"></script>
|
||||
|
||||
<!-- jquery -->
|
||||
<script type="text/javascript" src="../../third-party/jquery-1.10.2.min.js"></script>
|
||||
|
||||
<!-- webuploader -->
|
||||
<script src="../../third-party/webuploader/webuploader.min.js"></script>
|
||||
<link rel="stylesheet" type="text/css" href="../../third-party/webuploader/webuploader.css">
|
||||
|
||||
<!-- attachment dialog -->
|
||||
<link rel="stylesheet" href="attachment.css" type="text/css" />
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<div class="wrapper">
|
||||
<div id="tabhead" class="tabhead">
|
||||
<span class="tab focus" data-content-id="upload"><var id="lang_tab_upload"></var></span>
|
||||
<span class="tab" data-content-id="online"><var id="lang_tab_online"></var></span>
|
||||
</div>
|
||||
<div id="tabbody" class="tabbody">
|
||||
<!-- 上传图片 -->
|
||||
<div id="upload" class="panel focus">
|
||||
<div id="queueList" class="queueList">
|
||||
<div class="statusBar element-invisible">
|
||||
<div class="progress">
|
||||
<span class="text">0%</span>
|
||||
<span class="percentage"></span>
|
||||
</div><div class="info"></div>
|
||||
<div class="btns">
|
||||
<div id="filePickerBtn"></div>
|
||||
<div class="uploadBtn"><var id="lang_start_upload"></var></div>
|
||||
</div>
|
||||
</div>
|
||||
<div id="dndArea" class="placeholder">
|
||||
<div class="filePickerContainer">
|
||||
<div id="filePickerReady"></div>
|
||||
</div>
|
||||
</div>
|
||||
<ul class="filelist element-invisible">
|
||||
<li id="filePickerBlock" class="filePickerBlock"></li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 在线图片 -->
|
||||
<div id="online" class="panel">
|
||||
<div id="fileList"><var id="lang_imgLoading"></var></div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
<script type="text/javascript" src="attachment.js"></script>
|
||||
|
||||
</body>
|
||||
</html>
|
||||
754
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/attachment.js
vendored
Normal file
@@ -0,0 +1,754 @@
|
||||
/**
|
||||
* User: Jinqn
|
||||
* Date: 14-04-08
|
||||
* Time: 下午16:34
|
||||
* 上传图片对话框逻辑代码,包括tab: 远程图片/上传图片/在线图片/搜索图片
|
||||
*/
|
||||
|
||||
(function () {
|
||||
|
||||
var uploadFile,
|
||||
onlineFile;
|
||||
|
||||
window.onload = function () {
|
||||
initTabs();
|
||||
initButtons();
|
||||
};
|
||||
|
||||
/* 初始化tab标签 */
|
||||
function initTabs() {
|
||||
var tabs = $G('tabhead').children;
|
||||
for (var i = 0; i < tabs.length; i++) {
|
||||
domUtils.on(tabs[i], "click", function (e) {
|
||||
var target = e.target || e.srcElement;
|
||||
setTabFocus(target.getAttribute('data-content-id'));
|
||||
});
|
||||
}
|
||||
|
||||
setTabFocus('upload');
|
||||
}
|
||||
|
||||
/* 初始化tabbody */
|
||||
function setTabFocus(id) {
|
||||
if(!id) return;
|
||||
var i, bodyId, tabs = $G('tabhead').children;
|
||||
for (i = 0; i < tabs.length; i++) {
|
||||
bodyId = tabs[i].getAttribute('data-content-id')
|
||||
if (bodyId == id) {
|
||||
domUtils.addClass(tabs[i], 'focus');
|
||||
domUtils.addClass($G(bodyId), 'focus');
|
||||
} else {
|
||||
domUtils.removeClasses(tabs[i], 'focus');
|
||||
domUtils.removeClasses($G(bodyId), 'focus');
|
||||
}
|
||||
}
|
||||
switch (id) {
|
||||
case 'upload':
|
||||
uploadFile = uploadFile || new UploadFile('queueList');
|
||||
break;
|
||||
case 'online':
|
||||
onlineFile = onlineFile || new OnlineFile('fileList');
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* 初始化onok事件 */
|
||||
function initButtons() {
|
||||
|
||||
dialog.onok = function () {
|
||||
var list = [], id, tabs = $G('tabhead').children;
|
||||
for (var i = 0; i < tabs.length; i++) {
|
||||
if (domUtils.hasClass(tabs[i], 'focus')) {
|
||||
id = tabs[i].getAttribute('data-content-id');
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
switch (id) {
|
||||
case 'upload':
|
||||
list = uploadFile.getInsertList();
|
||||
var count = uploadFile.getQueueCount();
|
||||
if (count) {
|
||||
$('.info', '#queueList').html('<span style="color:red;">' + '还有2个未上传文件'.replace(/[\d]/, count) + '</span>');
|
||||
return false;
|
||||
}
|
||||
break;
|
||||
case 'online':
|
||||
list = onlineFile.getInsertList();
|
||||
break;
|
||||
}
|
||||
|
||||
editor.execCommand('insertfile', list);
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
/* 上传附件 */
|
||||
function UploadFile(target) {
|
||||
this.$wrap = target.constructor == String ? $('#' + target) : $(target);
|
||||
this.init();
|
||||
}
|
||||
UploadFile.prototype = {
|
||||
init: function () {
|
||||
this.fileList = [];
|
||||
this.initContainer();
|
||||
this.initUploader();
|
||||
},
|
||||
initContainer: function () {
|
||||
this.$queue = this.$wrap.find('.filelist');
|
||||
},
|
||||
/* 初始化容器 */
|
||||
initUploader: function () {
|
||||
var _this = this,
|
||||
$ = jQuery, // just in case. Make sure it's not an other libaray.
|
||||
$wrap = _this.$wrap,
|
||||
// 图片容器
|
||||
$queue = $wrap.find('.filelist'),
|
||||
// 状态栏,包括进度和控制按钮
|
||||
$statusBar = $wrap.find('.statusBar'),
|
||||
// 文件总体选择信息。
|
||||
$info = $statusBar.find('.info'),
|
||||
// 上传按钮
|
||||
$upload = $wrap.find('.uploadBtn'),
|
||||
// 上传按钮
|
||||
$filePickerBtn = $wrap.find('.filePickerBtn'),
|
||||
// 上传按钮
|
||||
$filePickerBlock = $wrap.find('.filePickerBlock'),
|
||||
// 没选择文件之前的内容。
|
||||
$placeHolder = $wrap.find('.placeholder'),
|
||||
// 总体进度条
|
||||
$progress = $statusBar.find('.progress').hide(),
|
||||
// 添加的文件数量
|
||||
fileCount = 0,
|
||||
// 添加的文件总大小
|
||||
fileSize = 0,
|
||||
// 优化retina, 在retina下这个值是2
|
||||
ratio = window.devicePixelRatio || 1,
|
||||
// 缩略图大小
|
||||
thumbnailWidth = 113 * ratio,
|
||||
thumbnailHeight = 113 * ratio,
|
||||
// 可能有pedding, ready, uploading, confirm, done.
|
||||
state = '',
|
||||
// 所有文件的进度信息,key为file id
|
||||
percentages = {},
|
||||
supportTransition = (function () {
|
||||
var s = document.createElement('p').style,
|
||||
r = 'transition' in s ||
|
||||
'WebkitTransition' in s ||
|
||||
'MozTransition' in s ||
|
||||
'msTransition' in s ||
|
||||
'OTransition' in s;
|
||||
s = null;
|
||||
return r;
|
||||
})(),
|
||||
// WebUploader实例
|
||||
uploader,
|
||||
actionUrl = editor.getActionUrl(editor.getOpt('fileActionName')),
|
||||
fileMaxSize = editor.getOpt('fileMaxSize'),
|
||||
acceptExtensions = (editor.getOpt('fileAllowFiles') || []).join('').replace(/\./g, ',').replace(/^[,]/, '');;
|
||||
|
||||
if (!WebUploader.Uploader.support()) {
|
||||
$('#filePickerReady').after($('<div>').html(lang.errorNotSupport)).hide();
|
||||
return;
|
||||
} else if (!editor.getOpt('fileActionName')) {
|
||||
$('#filePickerReady').after($('<div>').html(lang.errorLoadConfig)).hide();
|
||||
return;
|
||||
}
|
||||
|
||||
uploader = _this.uploader = WebUploader.create({
|
||||
pick: {
|
||||
id: '#filePickerReady',
|
||||
label: lang.uploadSelectFile
|
||||
},
|
||||
swf: '../../third-party/webuploader/Uploader.swf',
|
||||
server: actionUrl,
|
||||
fileVal: editor.getOpt('fileFieldName'),
|
||||
duplicate: true,
|
||||
fileSingleSizeLimit: fileMaxSize,
|
||||
compress: false
|
||||
});
|
||||
uploader.addButton({
|
||||
id: '#filePickerBlock'
|
||||
});
|
||||
uploader.addButton({
|
||||
id: '#filePickerBtn',
|
||||
label: lang.uploadAddFile
|
||||
});
|
||||
|
||||
setState('pedding');
|
||||
|
||||
// 当有文件添加进来时执行,负责view的创建
|
||||
function addFile(file) {
|
||||
var $li = $('<li id="' + file.id + '">' +
|
||||
'<p class="title">' + file.name + '</p>' +
|
||||
'<p class="imgWrap"></p>' +
|
||||
'<p class="progress"><span></span></p>' +
|
||||
'</li>'),
|
||||
|
||||
$btns = $('<div class="file-panel">' +
|
||||
'<span class="cancel">' + lang.uploadDelete + '</span>' +
|
||||
'<span class="rotateRight">' + lang.uploadTurnRight + '</span>' +
|
||||
'<span class="rotateLeft">' + lang.uploadTurnLeft + '</span></div>').appendTo($li),
|
||||
$prgress = $li.find('p.progress span'),
|
||||
$wrap = $li.find('p.imgWrap'),
|
||||
$info = $('<p class="error"></p>').hide().appendTo($li),
|
||||
|
||||
showError = function (code) {
|
||||
switch (code) {
|
||||
case 'exceed_size':
|
||||
text = lang.errorExceedSize;
|
||||
break;
|
||||
case 'interrupt':
|
||||
text = lang.errorInterrupt;
|
||||
break;
|
||||
case 'http':
|
||||
text = lang.errorHttp;
|
||||
break;
|
||||
case 'not_allow_type':
|
||||
text = lang.errorFileType;
|
||||
break;
|
||||
default:
|
||||
text = lang.errorUploadRetry;
|
||||
break;
|
||||
}
|
||||
$info.text(text).show();
|
||||
};
|
||||
|
||||
if (file.getStatus() === 'invalid') {
|
||||
showError(file.statusText);
|
||||
} else {
|
||||
$wrap.text(lang.uploadPreview);
|
||||
if ('|png|jpg|jpeg|bmp|gif|'.indexOf('|'+file.ext.toLowerCase()+'|') == -1) {
|
||||
$wrap.empty().addClass('notimage').append('<i class="file-preview file-type-' + file.ext.toLowerCase() + '"></i>' +
|
||||
'<span class="file-title" title="' + file.name + '">' + file.name + '</span>');
|
||||
} else {
|
||||
if (browser.ie && browser.version <= 7) {
|
||||
$wrap.text(lang.uploadNoPreview);
|
||||
} else {
|
||||
uploader.makeThumb(file, function (error, src) {
|
||||
if (error || !src) {
|
||||
$wrap.text(lang.uploadNoPreview);
|
||||
} else {
|
||||
var $img = $('<img src="' + src + '">');
|
||||
$wrap.empty().append($img);
|
||||
$img.on('error', function () {
|
||||
$wrap.text(lang.uploadNoPreview);
|
||||
});
|
||||
}
|
||||
}, thumbnailWidth, thumbnailHeight);
|
||||
}
|
||||
}
|
||||
percentages[ file.id ] = [ file.size, 0 ];
|
||||
file.rotation = 0;
|
||||
|
||||
/* 检查文件格式 */
|
||||
if (!file.ext || acceptExtensions.indexOf(file.ext.toLowerCase()) == -1) {
|
||||
showError('not_allow_type');
|
||||
uploader.removeFile(file);
|
||||
}
|
||||
}
|
||||
|
||||
file.on('statuschange', function (cur, prev) {
|
||||
if (prev === 'progress') {
|
||||
$prgress.hide().width(0);
|
||||
} else if (prev === 'queued') {
|
||||
$li.off('mouseenter mouseleave');
|
||||
$btns.remove();
|
||||
}
|
||||
// 成功
|
||||
if (cur === 'error' || cur === 'invalid') {
|
||||
showError(file.statusText);
|
||||
percentages[ file.id ][ 1 ] = 1;
|
||||
} else if (cur === 'interrupt') {
|
||||
showError('interrupt');
|
||||
} else if (cur === 'queued') {
|
||||
percentages[ file.id ][ 1 ] = 0;
|
||||
} else if (cur === 'progress') {
|
||||
$info.hide();
|
||||
$prgress.css('display', 'block');
|
||||
} else if (cur === 'complete') {
|
||||
}
|
||||
|
||||
$li.removeClass('state-' + prev).addClass('state-' + cur);
|
||||
});
|
||||
|
||||
$li.on('mouseenter', function () {
|
||||
$btns.stop().animate({height: 30});
|
||||
});
|
||||
$li.on('mouseleave', function () {
|
||||
$btns.stop().animate({height: 0});
|
||||
});
|
||||
|
||||
$btns.on('click', 'span', function () {
|
||||
var index = $(this).index(),
|
||||
deg;
|
||||
|
||||
switch (index) {
|
||||
case 0:
|
||||
uploader.removeFile(file);
|
||||
return;
|
||||
case 1:
|
||||
file.rotation += 90;
|
||||
break;
|
||||
case 2:
|
||||
file.rotation -= 90;
|
||||
break;
|
||||
}
|
||||
|
||||
if (supportTransition) {
|
||||
deg = 'rotate(' + file.rotation + 'deg)';
|
||||
$wrap.css({
|
||||
'-webkit-transform': deg,
|
||||
'-mos-transform': deg,
|
||||
'-o-transform': deg,
|
||||
'transform': deg
|
||||
});
|
||||
} else {
|
||||
$wrap.css('filter', 'progid:DXImageTransform.Microsoft.BasicImage(rotation=' + (~~((file.rotation / 90) % 4 + 4) % 4) + ')');
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
$li.insertBefore($filePickerBlock);
|
||||
}
|
||||
|
||||
// 负责view的销毁
|
||||
function removeFile(file) {
|
||||
var $li = $('#' + file.id);
|
||||
delete percentages[ file.id ];
|
||||
updateTotalProgress();
|
||||
$li.off().find('.file-panel').off().end().remove();
|
||||
}
|
||||
|
||||
function updateTotalProgress() {
|
||||
var loaded = 0,
|
||||
total = 0,
|
||||
spans = $progress.children(),
|
||||
percent;
|
||||
|
||||
$.each(percentages, function (k, v) {
|
||||
total += v[ 0 ];
|
||||
loaded += v[ 0 ] * v[ 1 ];
|
||||
});
|
||||
|
||||
percent = total ? loaded / total : 0;
|
||||
|
||||
spans.eq(0).text(Math.round(percent * 100) + '%');
|
||||
spans.eq(1).css('width', Math.round(percent * 100) + '%');
|
||||
updateStatus();
|
||||
}
|
||||
|
||||
function setState(val, files) {
|
||||
|
||||
if (val != state) {
|
||||
|
||||
var stats = uploader.getStats();
|
||||
|
||||
$upload.removeClass('state-' + state);
|
||||
$upload.addClass('state-' + val);
|
||||
|
||||
switch (val) {
|
||||
|
||||
/* 未选择文件 */
|
||||
case 'pedding':
|
||||
$queue.addClass('element-invisible');
|
||||
$statusBar.addClass('element-invisible');
|
||||
$placeHolder.removeClass('element-invisible');
|
||||
$progress.hide(); $info.hide();
|
||||
uploader.refresh();
|
||||
break;
|
||||
|
||||
/* 可以开始上传 */
|
||||
case 'ready':
|
||||
$placeHolder.addClass('element-invisible');
|
||||
$queue.removeClass('element-invisible');
|
||||
$statusBar.removeClass('element-invisible');
|
||||
$progress.hide(); $info.show();
|
||||
$upload.text(lang.uploadStart);
|
||||
uploader.refresh();
|
||||
break;
|
||||
|
||||
/* 上传中 */
|
||||
case 'uploading':
|
||||
$progress.show(); $info.hide();
|
||||
$upload.text(lang.uploadPause);
|
||||
break;
|
||||
|
||||
/* 暂停上传 */
|
||||
case 'paused':
|
||||
$progress.show(); $info.hide();
|
||||
$upload.text(lang.uploadContinue);
|
||||
break;
|
||||
|
||||
case 'confirm':
|
||||
$progress.show(); $info.hide();
|
||||
$upload.text(lang.uploadStart);
|
||||
|
||||
stats = uploader.getStats();
|
||||
if (stats.successNum && !stats.uploadFailNum) {
|
||||
setState('finish');
|
||||
return;
|
||||
}
|
||||
break;
|
||||
|
||||
case 'finish':
|
||||
$progress.hide(); $info.show();
|
||||
if (stats.uploadFailNum) {
|
||||
$upload.text(lang.uploadRetry);
|
||||
} else {
|
||||
$upload.text(lang.uploadStart);
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
state = val;
|
||||
updateStatus();
|
||||
|
||||
}
|
||||
|
||||
if (!_this.getQueueCount()) {
|
||||
$upload.addClass('disabled')
|
||||
} else {
|
||||
$upload.removeClass('disabled')
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
function updateStatus() {
|
||||
var text = '', stats;
|
||||
|
||||
if (state === 'ready') {
|
||||
text = lang.updateStatusReady.replace('_', fileCount).replace('_KB', WebUploader.formatSize(fileSize));
|
||||
} else if (state === 'confirm') {
|
||||
stats = uploader.getStats();
|
||||
if (stats.uploadFailNum) {
|
||||
text = lang.updateStatusConfirm.replace('_', stats.successNum).replace('_', stats.successNum);
|
||||
}
|
||||
} else {
|
||||
stats = uploader.getStats();
|
||||
text = lang.updateStatusFinish.replace('_', fileCount).
|
||||
replace('_KB', WebUploader.formatSize(fileSize)).
|
||||
replace('_', stats.successNum);
|
||||
|
||||
if (stats.uploadFailNum) {
|
||||
text += lang.updateStatusError.replace('_', stats.uploadFailNum);
|
||||
}
|
||||
}
|
||||
|
||||
$info.html(text);
|
||||
}
|
||||
|
||||
uploader.on('fileQueued', function (file) {
|
||||
fileCount++;
|
||||
fileSize += file.size;
|
||||
|
||||
if (fileCount === 1) {
|
||||
$placeHolder.addClass('element-invisible');
|
||||
$statusBar.show();
|
||||
}
|
||||
|
||||
addFile(file);
|
||||
});
|
||||
|
||||
uploader.on('fileDequeued', function (file) {
|
||||
fileCount--;
|
||||
fileSize -= file.size;
|
||||
|
||||
removeFile(file);
|
||||
updateTotalProgress();
|
||||
});
|
||||
|
||||
uploader.on('filesQueued', function (file) {
|
||||
if (!uploader.isInProgress() && (state == 'pedding' || state == 'finish' || state == 'confirm' || state == 'ready')) {
|
||||
setState('ready');
|
||||
}
|
||||
updateTotalProgress();
|
||||
});
|
||||
|
||||
uploader.on('all', function (type, files) {
|
||||
switch (type) {
|
||||
case 'uploadFinished':
|
||||
setState('confirm', files);
|
||||
break;
|
||||
case 'startUpload':
|
||||
/* 添加额外的GET参数 */
|
||||
var params = utils.serializeParam(editor.queryCommandValue('serverparam')) || '',
|
||||
url = utils.formatUrl(actionUrl + (actionUrl.indexOf('?') == -1 ? '?':'&') + 'encode=utf-8&' + params);
|
||||
uploader.option('server', url);
|
||||
setState('uploading', files);
|
||||
break;
|
||||
case 'stopUpload':
|
||||
setState('paused', files);
|
||||
break;
|
||||
}
|
||||
});
|
||||
|
||||
uploader.on('uploadBeforeSend', function (file, data, header) {
|
||||
//这里可以通过data对象添加POST参数
|
||||
header['X_Requested_With'] = 'XMLHttpRequest';
|
||||
});
|
||||
|
||||
uploader.on('uploadProgress', function (file, percentage) {
|
||||
var $li = $('#' + file.id),
|
||||
$percent = $li.find('.progress span');
|
||||
|
||||
$percent.css('width', percentage * 100 + '%');
|
||||
percentages[ file.id ][ 1 ] = percentage;
|
||||
updateTotalProgress();
|
||||
});
|
||||
|
||||
uploader.on('uploadSuccess', function (file, ret) {
|
||||
var $file = $('#' + file.id);
|
||||
try {
|
||||
var responseText = (ret._raw || ret),
|
||||
json = utils.str2json(responseText);
|
||||
if (json.state == 'SUCCESS') {
|
||||
_this.fileList.push(json);
|
||||
$file.append('<span class="success"></span>');
|
||||
} else {
|
||||
$file.find('.error').text(json.state).show();
|
||||
}
|
||||
} catch (e) {
|
||||
$file.find('.error').text(lang.errorServerUpload).show();
|
||||
}
|
||||
});
|
||||
|
||||
uploader.on('uploadError', function (file, code) {
|
||||
});
|
||||
uploader.on('error', function (code, file) {
|
||||
if (code == 'Q_TYPE_DENIED' || code == 'F_EXCEED_SIZE') {
|
||||
addFile(file);
|
||||
}
|
||||
});
|
||||
uploader.on('uploadComplete', function (file, ret) {
|
||||
});
|
||||
|
||||
$upload.on('click', function () {
|
||||
if ($(this).hasClass('disabled')) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (state === 'ready') {
|
||||
uploader.upload();
|
||||
} else if (state === 'paused') {
|
||||
uploader.upload();
|
||||
} else if (state === 'uploading') {
|
||||
uploader.stop();
|
||||
}
|
||||
});
|
||||
|
||||
$upload.addClass('state-' + state);
|
||||
updateTotalProgress();
|
||||
},
|
||||
getQueueCount: function () {
|
||||
var file, i, status, readyFile = 0, files = this.uploader.getFiles();
|
||||
for (i = 0; file = files[i++]; ) {
|
||||
status = file.getStatus();
|
||||
if (status == 'queued' || status == 'uploading' || status == 'progress') readyFile++;
|
||||
}
|
||||
return readyFile;
|
||||
},
|
||||
getInsertList: function () {
|
||||
var i, link, data, list = [],
|
||||
prefix = editor.getOpt('fileUrlPrefix');
|
||||
for (i = 0; i < this.fileList.length; i++) {
|
||||
data = this.fileList[i];
|
||||
link = data.url;
|
||||
list.push({
|
||||
title: data.original || link.substr(link.lastIndexOf('/') + 1),
|
||||
url: prefix + link
|
||||
});
|
||||
}
|
||||
return list;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
/* 在线附件 */
|
||||
function OnlineFile(target) {
|
||||
this.container = utils.isString(target) ? document.getElementById(target) : target;
|
||||
this.init();
|
||||
}
|
||||
OnlineFile.prototype = {
|
||||
init: function () {
|
||||
this.initContainer();
|
||||
this.initEvents();
|
||||
this.initData();
|
||||
},
|
||||
/* 初始化容器 */
|
||||
initContainer: function () {
|
||||
this.container.innerHTML = '';
|
||||
this.list = document.createElement('ul');
|
||||
this.clearFloat = document.createElement('li');
|
||||
|
||||
domUtils.addClass(this.list, 'list');
|
||||
domUtils.addClass(this.clearFloat, 'clearFloat');
|
||||
|
||||
this.list.appendChild(this.clearFloat);
|
||||
this.container.appendChild(this.list);
|
||||
},
|
||||
/* 初始化滚动事件,滚动到地步自动拉取数据 */
|
||||
initEvents: function () {
|
||||
var _this = this;
|
||||
|
||||
/* 滚动拉取图片 */
|
||||
domUtils.on($G('fileList'), 'scroll', function(e){
|
||||
var panel = this;
|
||||
if (panel.scrollHeight - (panel.offsetHeight + panel.scrollTop) < 10) {
|
||||
_this.getFileData();
|
||||
}
|
||||
});
|
||||
/* 选中图片 */
|
||||
domUtils.on(this.list, 'click', function (e) {
|
||||
var target = e.target || e.srcElement,
|
||||
li = target.parentNode;
|
||||
|
||||
if (li.tagName.toLowerCase() == 'li') {
|
||||
if (domUtils.hasClass(li, 'selected')) {
|
||||
domUtils.removeClasses(li, 'selected');
|
||||
} else {
|
||||
domUtils.addClass(li, 'selected');
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
/* 初始化第一次的数据 */
|
||||
initData: function () {
|
||||
|
||||
/* 拉取数据需要使用的值 */
|
||||
this.state = 0;
|
||||
this.listSize = editor.getOpt('fileManagerListSize');
|
||||
this.listIndex = 0;
|
||||
this.listEnd = false;
|
||||
|
||||
/* 第一次拉取数据 */
|
||||
this.getFileData();
|
||||
},
|
||||
/* 向后台拉取图片列表数据 */
|
||||
getFileData: function () {
|
||||
var _this = this;
|
||||
|
||||
if(!_this.listEnd && !this.isLoadingData) {
|
||||
this.isLoadingData = true;
|
||||
ajax.request(editor.getActionUrl(editor.getOpt('fileManagerActionName')), {
|
||||
timeout: 100000,
|
||||
data: utils.extend({
|
||||
start: this.listIndex,
|
||||
size: this.listSize
|
||||
}, editor.queryCommandValue('serverparam')),
|
||||
method: 'get',
|
||||
onsuccess: function (r) {
|
||||
try {
|
||||
var json = eval('(' + r.responseText + ')');
|
||||
if (json.state == 'SUCCESS') {
|
||||
_this.pushData(json.list);
|
||||
_this.listIndex = parseInt(json.start) + parseInt(json.list.length);
|
||||
if(_this.listIndex >= json.total) {
|
||||
_this.listEnd = true;
|
||||
}
|
||||
_this.isLoadingData = false;
|
||||
}
|
||||
} catch (e) {
|
||||
if(r.responseText.indexOf('ue_separate_ue') != -1) {
|
||||
var list = r.responseText.split(r.responseText);
|
||||
_this.pushData(list);
|
||||
_this.listIndex = parseInt(list.length);
|
||||
_this.listEnd = true;
|
||||
_this.isLoadingData = false;
|
||||
}
|
||||
}
|
||||
},
|
||||
onerror: function () {
|
||||
_this.isLoadingData = false;
|
||||
}
|
||||
});
|
||||
}
|
||||
},
|
||||
/* 添加图片到列表界面上 */
|
||||
pushData: function (list) {
|
||||
var i, item, img, filetype, preview, icon, _this = this,
|
||||
urlPrefix = editor.getOpt('fileManagerUrlPrefix');
|
||||
for (i = 0; i < list.length; i++) {
|
||||
if(list[i] && list[i].url) {
|
||||
item = document.createElement('li');
|
||||
icon = document.createElement('span');
|
||||
filetype = list[i].url.substr(list[i].url.lastIndexOf('.') + 1);
|
||||
|
||||
if ( "png|jpg|jpeg|gif|bmp".indexOf(filetype) != -1 ) {
|
||||
preview = document.createElement('img');
|
||||
domUtils.on(preview, 'load', (function(image){
|
||||
return function(){
|
||||
_this.scale(image, image.parentNode.offsetWidth, image.parentNode.offsetHeight);
|
||||
};
|
||||
})(preview));
|
||||
preview.width = 113;
|
||||
preview.setAttribute('src', urlPrefix + list[i].url + (list[i].url.indexOf('?') == -1 ? '?noCache=':'&noCache=') + (+new Date()).toString(36) );
|
||||
} else {
|
||||
var ic = document.createElement('i'),
|
||||
textSpan = document.createElement('span');
|
||||
textSpan.innerHTML = list[i].url.substr(list[i].url.lastIndexOf('/') + 1);
|
||||
preview = document.createElement('div');
|
||||
preview.appendChild(ic);
|
||||
preview.appendChild(textSpan);
|
||||
domUtils.addClass(preview, 'file-wrapper');
|
||||
domUtils.addClass(textSpan, 'file-title');
|
||||
domUtils.addClass(ic, 'file-type-' + filetype);
|
||||
domUtils.addClass(ic, 'file-preview');
|
||||
}
|
||||
domUtils.addClass(icon, 'icon');
|
||||
item.setAttribute('data-url', urlPrefix + list[i].url);
|
||||
if (list[i].original) {
|
||||
item.setAttribute('data-title', list[i].original);
|
||||
}
|
||||
|
||||
item.appendChild(preview);
|
||||
item.appendChild(icon);
|
||||
this.list.insertBefore(item, this.clearFloat);
|
||||
}
|
||||
}
|
||||
},
|
||||
/* 改变图片大小 */
|
||||
scale: function (img, w, h, type) {
|
||||
var ow = img.width,
|
||||
oh = img.height;
|
||||
|
||||
if (type == 'justify') {
|
||||
if (ow >= oh) {
|
||||
img.width = w;
|
||||
img.height = h * oh / ow;
|
||||
img.style.marginLeft = '-' + parseInt((img.width - w) / 2) + 'px';
|
||||
} else {
|
||||
img.width = w * ow / oh;
|
||||
img.height = h;
|
||||
img.style.marginTop = '-' + parseInt((img.height - h) / 2) + 'px';
|
||||
}
|
||||
} else {
|
||||
if (ow >= oh) {
|
||||
img.width = w * ow / oh;
|
||||
img.height = h;
|
||||
img.style.marginLeft = '-' + parseInt((img.width - w) / 2) + 'px';
|
||||
} else {
|
||||
img.width = w;
|
||||
img.height = h * oh / ow;
|
||||
img.style.marginTop = '-' + parseInt((img.height - h) / 2) + 'px';
|
||||
}
|
||||
}
|
||||
},
|
||||
getInsertList: function () {
|
||||
var i, lis = this.list.children, list = [];
|
||||
for (i = 0; i < lis.length; i++) {
|
||||
if (domUtils.hasClass(lis[i], 'selected')) {
|
||||
var url = lis[i].getAttribute('data-url');
|
||||
var title = lis[i].getAttribute('data-title') || url.substr(url.lastIndexOf('/') + 1);
|
||||
list.push({
|
||||
title: title,
|
||||
url: url
|
||||
});
|
||||
}
|
||||
}
|
||||
return list;
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
})();
|
||||
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_chm.gif
vendored
Normal file
|
After Width: | Height: | Size: 923 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_default.png
vendored
Normal file
|
After Width: | Height: | Size: 841 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_doc.gif
vendored
Normal file
|
After Width: | Height: | Size: 1012 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_exe.gif
vendored
Normal file
|
After Width: | Height: | Size: 949 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_jpg.gif
vendored
Normal file
|
After Width: | Height: | Size: 950 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_mp3.gif
vendored
Normal file
|
After Width: | Height: | Size: 986 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_mv.gif
vendored
Normal file
|
After Width: | Height: | Size: 1001 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_pdf.gif
vendored
Normal file
|
After Width: | Height: | Size: 996 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_ppt.gif
vendored
Normal file
|
After Width: | Height: | Size: 1001 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_psd.gif
vendored
Normal file
|
After Width: | Height: | Size: 1009 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_rar.gif
vendored
Normal file
|
After Width: | Height: | Size: 1007 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_txt.gif
vendored
Normal file
|
After Width: | Height: | Size: 970 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/fileTypeImages/icon_xls.gif
vendored
Normal file
|
After Width: | Height: | Size: 1005 B |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/images/alignicon.gif
vendored
Normal file
|
After Width: | Height: | Size: 1.0 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/images/alignicon.png
vendored
Normal file
|
After Width: | Height: | Size: 3.6 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/images/bg.png
vendored
Normal file
|
After Width: | Height: | Size: 2.7 KiB |
BIN
vendor/rulong/dwz-panel/resources/assets/ueditor/dialogs/attachment/images/file-icons.gif
vendored
Normal file
|
After Width: | Height: | Size: 20 KiB |