123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- <!--components/form/form.wxml-->
- <wxs module="format">
- // wxs中不能写ES6的语法: 例如箭头函数
- function isHide(hide, arr) {
- var rs = true
- arr.forEach(function (e) {
- hide.forEach(function (h) {
- if (e.id === h.id) {
- e.force = false
- h.value.forEach(function (v) {
- if (e.inputValue === v) {
- rs = false
- }
- })
- }
- })
- })
- return rs
- }
- // 需要导出函数, 导出只能使用CommonJs规范
- module.exports = {
- // 对象中也不能使用对象的增强写法
- isHide: isHide
- }
- </wxs>
- <view>
- <view wx:for="{{formLayoutData.formInfo}}" wx:key="{{index}}">
- <t-cell required="{{item.force}}" wx:if="{{item.type == 'cell'}}" title="{{language[item.label]||item.label}}" note="{{item.inputValue}}" url="{{item.url}}" hover>
- </t-cell>
- <!-- 输入 -->
- <t-input wx:if="{{item.type == 'text'}}" value="{{item.inputValue}}" data-value="{{item.id}}" data-index="{{index}}" layout="horizontal" status="error" data-item="{{item}}" tips="{{language[item.errorMsg]||item.errorMsg}}" placeholder="{{language[item.placeholder]||item.placeholder}}" align="right" bind:blur="onBlur" bind:clear="onClear" clearable>
- <view slot="label">
- {{language[item.label]||item.label}} <text wx:if="{{item.force}}" style="color:#e34d59">*</text>
- </view>
- </t-input>
- <!-- 选择 -->
- <t-cell wx:if="{{item.type == 'picker'}}" required="{{item.force}}" note="{{item.inputValue >= 1?language['是']||'是':item.inputValue >= 0? language['否']||'否' :(language[item.inputValue]||item.inputValue||language['请选择']||'请选择')}}" class="block" title="{{language[item.label]||item.label}}" data-index="{{index}}" data-item="{{item}}" arrow hover bind:click="onPicker">
- <text slot="description" class="t-class-description">{{item.errorMsg?language[item.errorMsg]||item.errorMsg:''}}</text>
- </t-cell>
- <!-- 上传 -->
- <view wx:if="{{item.type == 'upload'}}" style="padding:10px">
- <view class="uploadPanel">
- {{language['附件上传']||'附件上传'}}
- </view>
- <slot style="flex:1" name="attinfos"></slot>
- <upload id="upload" originFiles='{{item.originFiles||[]}}' />
- </view>
- <!-- 时间选择 -->
- <t-cell wx:if="{{item.type == 'datepicker'}}" title="{{language[item.label]||item.label}}" hover note="{{item.inputValue}}" arrow data-item="{{item}}" data-index="{{index}}" data-mode="date" bindtap="showDatePicker" t-class="pannel-item" />
- <!-- 选择省市县 -->
- <t-cell required="{{item.force}}" wx:if="{{item.type == 'cascader'}}" title="{{language[item.label]||item.label}}" data-index="{{index}}" note="{{item.inputValue}}" bind:click="showCascader">
- <text slot="description" class="t-class-description">{{item.errorMsg?language['']||item.errorMsg:''}}</text>
- </t-cell>
- <!-- 跳转链接 -->
- <t-cell required="{{item.force}}" wx:if="{{item.type == 'link' && format.isHide(item.hide,formLayoutData.formInfo)}}" title="{{language[item.label]||item.label}}" note="{{item.inputValue}}" url="{{item.url}}" hover arrow>
- <text slot="description" class="t-class-description">{{item.errorMsg?language['']||item.errorMsg:''}}</text>
- </t-cell>
- </view>
- <view wx:if="{{!hideBtn}}" style="padding:30px">
- <t-button theme="primary" size="medium" disabled="{{disabledStatus}}" bind:tap="formSubmit" block>{{language['提交']||'提 交'}}</t-button>
- </view>
- <t-picker visible="{{pickerVisible}}" data-key="id" title="{{(language['选择']||'选择') + (language[actPicker.label]||actPicker.label)}}" cancelBtn="{{language['取消']||'取消'}}" confirmBtn="{{language['确认']||'确认'}}" bindconfirm="onPickerConfirm" bindchange="onPickerChange">
- <t-picker-item options="{{actPicker.data}}"></t-picker-item>
- </t-picker>
- <t-date-time-picker title="{{language['选择日期']||'选择日期'}}" visible="{{dateVisible}}" mode="date" value="{{timePickerValue}}" format="YYYY-MM-DD" bindchange="onTimePickerConfirm" />
- <t-cascader visible="{{cascaderVisible}}" theme="step" options="{{options}}" value='' title="{{language['请选择地址']||'请选择地址'}}" bind:change="onChange"></t-cascader>
- </view>
|