351 lines
24 KiB
HTML
351 lines
24 KiB
HTML
|
<style>
|
|||
|
.upload-image {
|
|||
|
background: url('__CDN__/assets/addons/example/img/plus.png') no-repeat center center;
|
|||
|
background-size: 30px 30px;
|
|||
|
height: 30px;
|
|||
|
width: 30px;
|
|||
|
border: 1px solid #ccc;
|
|||
|
}
|
|||
|
|
|||
|
textarea.form-control {
|
|||
|
background: #eee;
|
|||
|
}
|
|||
|
</style>
|
|||
|
<div class="row">
|
|||
|
<div class="col-md-6">
|
|||
|
<div class="box box-success">
|
|||
|
<div class="panel-heading">
|
|||
|
{:__('自定义图片描述')}
|
|||
|
</div>
|
|||
|
<div class="panel-body">
|
|||
|
<div class="alert alert-success-light">
|
|||
|
<b>温馨提示</b><br>
|
|||
|
默认我们的多图是没有图片描述的,如果我们需要自定义描述,可以使用以下的自定义功能<br>
|
|||
|
特别注意的是图片的url和描述是分开储存的,也就是说图片一个字段,描述一个字段,你在前台使用时需要自己匹配映射关系<br>
|
|||
|
<b>下面的演示textarea为了便于调试,设置为可见的,实际使用中应该添加个hidden的class进行隐藏</b>
|
|||
|
</div>
|
|||
|
<form id="first-form" role="form" data-toggle="validator" method="POST" action="">
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">{:__('一维数组示例')}:</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<div class="input-group">
|
|||
|
<input id="c-files" data-rule="required" class="form-control" size="50" name="row[files]" type="text" value="https://cdn.fastadmin.net/uploads/addons/blog.png,https://cdn.fastadmin.net/uploads/addons/cms.png,https://cdn.fastadmin.net/uploads/addons/vote.png">
|
|||
|
<div class="input-group-addon no-border no-padding">
|
|||
|
<span><button type="button" id="plupload-files" class="btn btn-danger plupload" data-input-id="c-files" data-mimetype="*" data-multiple="true" data-preview-id="p-files"><i class="fa fa-upload"></i> {:__('Upload')}</button></span>
|
|||
|
<span><button type="button" id="fachoose-files" class="btn btn-primary fachoose" data-input-id="c-files" data-mimetype="*" data-multiple="true"><i class="fa fa-list"></i> {:__('Choose')}</button></span>
|
|||
|
</div>
|
|||
|
<span class="msg-box n-right" for="c-files"></span>
|
|||
|
</div>
|
|||
|
|
|||
|
<!--ul需要添加 data-template和data-name属性,并一一对应且唯一 -->
|
|||
|
<ul class="row list-inline plupload-preview" id="p-files" data-template="introtpl" data-name="row[intro]"></ul>
|
|||
|
|
|||
|
<!--请注意 ul和textarea间不能存在其它任何元素,实际开发中textarea应该添加个hidden进行隐藏-->
|
|||
|
<textarea name="row[intro]" class="form-control" style="margin-top:5px;">["简洁响应式博客","CMS内容管理系统","在线投票系统"]</textarea>
|
|||
|
|
|||
|
<!--这里自定义图片预览的模板 开始-->
|
|||
|
<script type="text/html" id="introtpl">
|
|||
|
<li class="col-xs-3">
|
|||
|
<a href="<%=fullurl%>" data-url="<%=url%>" target="_blank" class="thumbnail">
|
|||
|
<img src="<%=fullurl%>" class="img-responsive">
|
|||
|
</a>
|
|||
|
<input type="text" name="row[intro][<%=index%>]" class="form-control mb-1" placeholder="请输入文件描述" value="<%=value?value:''%>"/>
|
|||
|
<a href="javascript:;" class="btn btn-danger btn-xs btn-trash"><i class="fa fa-trash"></i></a>
|
|||
|
</li>
|
|||
|
</script>
|
|||
|
<!--这里自定义图片预览的模板 结束-->
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">{:__('二维数组示例')}:</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<div class="input-group">
|
|||
|
<input id="c-images" data-rule="required" class="form-control" size="50" name="row[images]" type="text" value="https://cdn.fastadmin.net/uploads/addons/example.png,https://cdn.fastadmin.net/uploads/addons/upyun.png,https://cdn.fastadmin.net/uploads/addons/alioss.png">
|
|||
|
<div class="input-group-addon no-border no-padding">
|
|||
|
<span><button type="button" id="plupload-images" class="btn btn-danger plupload" data-input-id="c-images" data-mimetype="image/gif,image/jpeg,image/png,image/jpg,image/bmp,image/webp" data-multiple="true" data-preview-id="p-images"><i class="fa fa-upload"></i> {:__('Upload')}</button></span>
|
|||
|
<span><button type="button" id="fachoose-images" class="btn btn-primary fachoose" data-input-id="c-images" data-mimetype="image/*" data-multiple="true"><i class="fa fa-list"></i> {:__('Choose')}</button></span>
|
|||
|
</div>
|
|||
|
<span class="msg-box n-right" for="c-images"></span>
|
|||
|
</div>
|
|||
|
|
|||
|
<!--ul需要添加 data-template和data-name属性,并一一对应且唯一 -->
|
|||
|
<ul class="row list-inline plupload-preview" id="p-images" data-template="desctpl" data-name="row[desc]"></ul>
|
|||
|
|
|||
|
<!--请注意 ul和textarea间不能存在其它任何元素,实际开发中textarea应该添加个hidden进行隐藏-->
|
|||
|
<textarea name="row[desc]" class="form-control" style="margin-top:5px;">[{"info":"开发者示例插件","size":"1M"},{"info":"又拍云储存整合","size":"2M"},{"info":"阿里OSS云储存","size":"1M"}]</textarea>
|
|||
|
|
|||
|
<!--这里自定义图片预览的模板 开始-->
|
|||
|
<script type="text/html" id="desctpl">
|
|||
|
<li class="col-xs-3">
|
|||
|
<a href="<%=fullurl%>" data-url="<%=url%>" target="_blank" class="thumbnail">
|
|||
|
<img src="<%=fullurl%>" class="img-responsive">
|
|||
|
</a>
|
|||
|
<input type="text" name="row[desc][<%=index%>][info]" class="form-control mb-1" placeholder="请输入插件描述" value="<%=value?value['info']:''%>"/>
|
|||
|
<input type="text" name="row[desc][<%=index%>][size]" class="form-control mb-1" placeholder="请输入插件大小" value="<%=value?value['size']:''%>"/>
|
|||
|
<a href="javascript:;" class="btn btn-danger btn-xs btn-trash"><i class="fa fa-trash"></i></a>
|
|||
|
</li>
|
|||
|
</script>
|
|||
|
<!--这里自定义图片预览的模板 结束-->
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12"></label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<button type="submit" class="btn btn-success btn-embossed">{:__('OK')}</button>
|
|||
|
<button type="reset" class="btn btn-default btn-embossed">{:__('Reset')}</button>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
|
|||
|
</form>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
|
|||
|
</div>
|
|||
|
<div class="col-md-6">
|
|||
|
<div class="box box-info">
|
|||
|
<div class="panel-heading">
|
|||
|
{:__('自定义Fieldlist示例')}
|
|||
|
</div>
|
|||
|
<div class="panel-body">
|
|||
|
<div class="alert alert-danger-light">
|
|||
|
<b>温馨提示</b><br>
|
|||
|
默认的fieldlist为键值形式,如果需要一维数组或二维数组,可使用下面的自定义模板来实现<br>
|
|||
|
默认追加的元素是没有进行事件绑定的,我们需要监听btn-append这个按钮的fa.event.appendfieldlist事件<br>
|
|||
|
<b>下面的演示textarea为了便于调试,设置为可见的,实际使用中应该添加个hidden的class进行隐藏</b>
|
|||
|
</div>
|
|||
|
<form id="second-form" role="form" data-toggle="validator" method="POST" action="">
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">
|
|||
|
{:__('Fieldlist一维示例')}:
|
|||
|
<span style="font-weight: normal"><font color="red">只支持FastAdmin1.5.0+</font> {if version_compare($Think.config.fastadmin.version, '1.5.0')<0}<span class="label label-danger">你当前FastAdmin版本不支持</span>{/if}</span>
|
|||
|
</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<dl class="list-unstyled fieldlist" data-template="singletpl" data-name="row[single]" id="single-table">
|
|||
|
<dd>
|
|||
|
<ins>{:__('标题')}</ins>
|
|||
|
</dd>
|
|||
|
<dd>
|
|||
|
<ins><a href="javascript:;" class="btn btn-sm btn-success btn-append"><i class="fa fa-plus"></i> {:__('Append')}</a></ins>
|
|||
|
</dd>
|
|||
|
</dl>
|
|||
|
|
|||
|
<!--请注意实际开发中textarea应该添加个hidden进行隐藏-->
|
|||
|
<textarea name="row[single]" class="form-control" cols="30" rows="5">["你好","世界"]</textarea>
|
|||
|
<script id="singletpl" type="text/html">
|
|||
|
<dd class="form-inline">
|
|||
|
<ins><input type="text" name="<%=name%>[<%=index%>][value]" class="form-control" size="15" value="<%=row%>" placeholder="标题"/></ins>
|
|||
|
<ins>
|
|||
|
<!--下面的两个按钮务必保留-->
|
|||
|
<span class="btn btn-sm btn-danger btn-remove"><i class="fa fa-times"></i></span>
|
|||
|
<span class="btn btn-sm btn-primary btn-dragsort"><i class="fa fa-arrows"></i></span>
|
|||
|
</ins>
|
|||
|
</dd>
|
|||
|
</script>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">{:__('Fieldlist一维键值示例')}:</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<dl class="list-unstyled fieldlist" data-name="row[keyvalue]" id="keyvalue-table">
|
|||
|
<dd>
|
|||
|
<ins>{:__('标题')}</ins>
|
|||
|
</dd>
|
|||
|
<dd>
|
|||
|
<ins><a href="javascript:;" class="btn btn-sm btn-success btn-append"><i class="fa fa-plus"></i> {:__('Append')}</a></ins>
|
|||
|
</dd>
|
|||
|
</dl>
|
|||
|
|
|||
|
<!--请注意实际开发中textarea应该添加个hidden进行隐藏-->
|
|||
|
<textarea name="row[keyvalue]" class="form-control" cols="30" rows="5">{"2":"Hello", "1":"World"}</textarea>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">{:__('Fieldlist二维数组示例')}:</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<table class="table fieldlist" data-template="basictpl" data-name="row[basic]" id="first-table">
|
|||
|
<tr>
|
|||
|
<td>{:__('标题')}</td>
|
|||
|
<td>{:__('介绍')}</td>
|
|||
|
<td>{:__('大小')}</td>
|
|||
|
<td>{:__('状态')}</td>
|
|||
|
<td width="100"></td>
|
|||
|
</tr>
|
|||
|
<tr>
|
|||
|
<td colspan="5"><a href="javascript:;" class="btn btn-sm btn-success btn-append"><i class="fa fa-plus"></i> {:__('Append')}</a></td>
|
|||
|
</tr>
|
|||
|
</table>
|
|||
|
|
|||
|
<!--请注意实际开发中textarea应该添加个hidden进行隐藏-->
|
|||
|
<textarea name="row[basic]" class="form-control" cols="30" rows="5">[{"title":"开发者示例插件","intro":"开发者必备","size":"1M","state":1},{"title":"又拍云储存整合","intro":"一款云储存插件","size":"2M","state":0},{"title":"阿里OSS云储存","intro":"一款云储存插件","size":"1M","state":1}]</textarea>
|
|||
|
<script id="basictpl" type="text/html">
|
|||
|
<tr class="form-inline">
|
|||
|
<td><input type="text" name="<%=name%>[<%=index%>][title]" class="form-control" size="15" value="<%=row.title||'fast'%>" placeholder="标题"/></td>
|
|||
|
<td><input type="text" name="<%=name%>[<%=index%>][intro]" class="form-control" size="15" value="<%=row.intro%>" placeholder="介绍"/></td>
|
|||
|
<td><input type="text" name="<%=name%>[<%=index%>][size]" class="form-control" style="width:50px" value="<%=row.size%>" placeholder="大小"/></td>
|
|||
|
<td>
|
|||
|
<input type="hidden" name="<%=name%>[<%=index%>][state]" id="c-state-<%=index%>" class="form-control" style="width:50px" value="<%=row.state%>" placeholder="状态"/>
|
|||
|
<a href="javascript:;" data-toggle="switcher" class="btn-switcher" data-input-id="c-state-<%=index%>" data-yes="1" data-no="0">
|
|||
|
<i class="fa fa-toggle-on text-success <%if(row.state!=1){%>fa-flip-horizontal text-gray<%}%> fa-2x"></i>
|
|||
|
</a>
|
|||
|
</td>
|
|||
|
<td>
|
|||
|
<!--下面的两个按钮务必保留-->
|
|||
|
<span class="btn btn-sm btn-danger btn-remove"><i class="fa fa-times"></i></span>
|
|||
|
<span class="btn btn-sm btn-primary btn-dragsort"><i class="fa fa-arrows"></i></span>
|
|||
|
</td>
|
|||
|
</tr>
|
|||
|
</script>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">{:__('Fieldlist绑定事件示例')}:</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<table class="table fieldlist" data-template="eventtpl" data-name="row[event]" id="second-table">
|
|||
|
<tr>
|
|||
|
<td>{:__('管理员')}</td>
|
|||
|
<td>{:__('图片')}</td>
|
|||
|
<td>{:__('登录时间')}</td>
|
|||
|
<td width="100"></td>
|
|||
|
</tr>
|
|||
|
<tr>
|
|||
|
<td colspan="4"><a href="javascript:;" class="btn btn-sm btn-success btn-append"><i class="fa fa-plus"></i> {:__('Append')}</a></td>
|
|||
|
</tr>
|
|||
|
</table>
|
|||
|
|
|||
|
<!--请注意实际开发中textarea应该添加个hidden进行隐藏-->
|
|||
|
<textarea name="row[event]" class="form-control" cols="30" rows="5">[{"id":"1","image":"/assets/addons/example/img/200x200.png","time":"2019-06-28 12:05:03"}]</textarea>
|
|||
|
<script id="eventtpl" type="text/html">
|
|||
|
<tr class="form-inline">
|
|||
|
<td><input type="text" name="<%=name%>[<%=index%>][id]" class="form-control selectpage" data-source="auth/admin/selectpage" data-field="username" value="<%=row.id%>" placeholder="管理员"/></td>
|
|||
|
<td>
|
|||
|
<input type="hidden" name="<%=name%>[<%=index%>][image]" id="c-image-<%=index%>" value="<%=row.image%>">
|
|||
|
<!--@formatter:off-->
|
|||
|
<button type="button" id="faupload-image" class="btn btn-danger faupload upload-image" data-input-id="c-image-<%=index%>" data-mimetype="image/gif,image/jpeg,image/png,image/jpg,image/bmp,image/webp" data-multiple="false" <%if(row.image){%>style="background-image: url('<%=Fast.api.cdnurl(row.image)%>')"<%}%>></button>
|
|||
|
<!--@formatter:on-->
|
|||
|
</td>
|
|||
|
<td><input type="text" name="<%=name%>[<%=index%>][time]" class="form-control datetimepicker" style="width:120px" value="<%=row.time%>" placeholder="时间"/></td>
|
|||
|
<td>
|
|||
|
<!--下面的两个按钮务必保留-->
|
|||
|
<span class="btn btn-sm btn-danger btn-remove"><i class="fa fa-times"></i></span>
|
|||
|
<span class="btn btn-sm btn-primary btn-dragsort"><i class="fa fa-arrows"></i></span>
|
|||
|
</td>
|
|||
|
</tr>
|
|||
|
</script>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12"></label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<button type="submit" class="btn btn-success btn-embossed">{:__('OK')}</button>
|
|||
|
<button type="reset" class="btn btn-default btn-embossed">{:__('Reset')}</button>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
|
|||
|
</form>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
|
|||
|
</div>
|
|||
|
<div class="col-md-6">
|
|||
|
<div class="box box-warning">
|
|||
|
<div class="panel-heading">
|
|||
|
自动完成+标签输入示例,<font color="red">只支持FastAdmin1.3.0+</font> {if version_compare($Think.config.fastadmin.version, '1.3.0')<0}<span class="label label-danger">你当前FastAdmin版本不支持</span>{/if}
|
|||
|
</div>
|
|||
|
<div class="panel-body">
|
|||
|
<div class="alert alert-danger-light">
|
|||
|
<b>温馨提示</b><br>
|
|||
|
</div>
|
|||
|
<form id="third-form" role="form" data-toggle="validator" method="POST" action="">
|
|||
|
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">自动完成</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<input type="text" class="form-control" data-role="autocomplete" data-autocomplete-options='{"url":"example/customform/get_title_list", "minChars":1}'/>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">标签输入 <span class="text-muted small">输入后<code>回车</code>或<code>,</code>确认</span></label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<input type="text" class="form-control" data-role="tagsinput"/>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">自动完成+标签输入</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<input type="text" class="form-control" data-role="tagsinput" data-tagsinput-options='{"minChars":1, "autocomplete":{"url":"example/customform/get_title_list"}}'/>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</form>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="col-md-6">
|
|||
|
<div class="box box-danger">
|
|||
|
<div class="panel-heading">
|
|||
|
动态显示,<font color="red">只支持FastAdmin1.3.3+</font> {if version_compare($Think.config.fastadmin.version, '1.3.3')<0}<span class="label label-danger">你当前FastAdmin版本不支持</span>{/if}
|
|||
|
</div>
|
|||
|
<div class="panel-body">
|
|||
|
<form id="fourth-form" role="form" data-toggle="validator" method="POST" action="">
|
|||
|
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">常规使用</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<input type="radio" name="row[type]" value="value1" checked/> 类型1
|
|||
|
<input type="radio" name="row[type]" value="value2"/> 类型2
|
|||
|
<div data-favisible="type=value1" class="p-3">显示内容1</div>
|
|||
|
<div data-favisible="type=value2" class="p-3">显示内容2</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<hr>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">使用开关组件</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
|
|||
|
<input id="c-switch" name="row[switch]" type="hidden" value="0">
|
|||
|
<a href="javascript:;" data-toggle="switcher" class="btn-switcher" data-input-id="c-switch" data-yes="1" data-no="0">
|
|||
|
<i class="fa fa-toggle-on text-success fa-flip-horizontal text-gray fa-2x"></i>
|
|||
|
</a>
|
|||
|
|
|||
|
<div data-favisible="switch=1" class="p-3">显示内容隐藏的内容</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<hr>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">组件嵌套</label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<input type="radio" name="row[mode]" value="value1"/> 模式1
|
|||
|
<input type="radio" name="row[mode]" value="value2"/> 模式2
|
|||
|
<div data-favisible="mode=value1" class="p-3">
|
|||
|
<h4>显示内容1</h4>
|
|||
|
<input id="c-switch1" name="row[switch1]" type="hidden" value="0">
|
|||
|
<a href="javascript:;" data-toggle="switcher" class="btn-switcher" data-input-id="c-switch1" data-yes="1" data-no="0">
|
|||
|
<i class="fa fa-toggle-on text-success fa-flip-horizontal text-gray fa-2x"></i>
|
|||
|
</a>
|
|||
|
|
|||
|
<div data-favisible="switch1=1" class="p-3">显示内容隐藏的内容1</div>
|
|||
|
</div>
|
|||
|
<div data-favisible="mode=value2" class="p-3">
|
|||
|
<h4>显示内容2</h4>
|
|||
|
<input id="c-switch2" name="row[switch2]" type="hidden" value="0">
|
|||
|
<a href="javascript:;" data-toggle="switcher" class="btn-switcher" data-input-id="c-switch2" data-yes="1" data-no="0">
|
|||
|
<i class="fa fa-toggle-on text-success fa-flip-horizontal text-gray fa-2x"></i>
|
|||
|
</a>
|
|||
|
|
|||
|
<div data-favisible="switch2=1" class="p-3">显示内容隐藏的内容2</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<hr>
|
|||
|
<div class="form-group row">
|
|||
|
<label class="control-label col-xs-12">使用内容判断 <span class="text-muted small">只有输入指定的内容才显示</span></label>
|
|||
|
<div class="col-xs-12">
|
|||
|
<input type="text" class="form-control" name="row[title]" placeholder="请输入abc三个字母">
|
|||
|
<div data-favisible="title=abc" class="p-3">显示内容隐藏的内容</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</form>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|