0.2.19-beta.8 • Published 5 months ago

@tongfun/tf-widget v0.2.19-beta.8

Weekly downloads
-
License
MIT
Repository
-
Last release
5 months ago

TF-Widget

文档地址:组件库文档

表格组件:umy-ui

1. TfInput

  • 此组件为ElementUi 组件二次封装,支持ElementUi控件所有属性
  • 包含除了基础资料外的常见基本组件,提供统一的样式,和统一入口,基本配置
  • 组件默认在el-form表单中使用,也可以在表单之外使用需传入not-form属性

1.1 基本使用

<el-form :model="form">
  <!-- 文本输入框 -->
  <TfInput v-model="form.test1" title="输入框" type="input" />
  <!-- 文本输入框 input可以省略 -->
  <TfInput v-model="form.test1" title="输入框" />

  <!-- 文本域输入 -->
  <TfInput v-model="form.test2" title="文本" type="textarea" />
  <TfInput v-model="form.test2" title="文本" type="textarea" :rows="4" />

  <!-- 日期和日期时间输入 -->
  <TfInput v-model="form.test3" title="日期" type="date" />
  <TfInput v-model="form.test4" title="日期时间" type="dateTime" />

  <!-- 数字输入 -->
  <TfInput v-model="form.test5" title="整数" type="integer" />
  <TfInput v-model="form.test6" title="小数" type="decimal" :percision='4' />

  <!-- enumType/id 是获取下拉选项的参数 可从租户管理枚举配置中获取(或者联系后端) -->
  <TfInput v-model="form.test7" title="下拉选择框" type="select" enumType='UP_DOWN' />
  <TfInput v-model="form.test7" title="下拉选择框" type="select" id='2022523' />
  <!-- 下拉选择框 默认绑定的对象是 { name: null, id: null } 格式-->
  <!-- 可以通过传入showFields修改格式 -->
  <TfInput v-model="form.test7" title="下拉选择框" type="select" :show-fields="{ value: 'id', label: 'label' }" />
  <!-- 支持自定义传入下拉数组options -->
  <TfInput v-model="form.test7" title="下拉选择框" type="select" :options="optionList" />
  
  <!--基础资料,需要提供code-->
  <TfInput v-model="form.test8" title="基础资料" type="basicData" code="20220506141102" />
  <!-- 基础资料遇见弹框嵌套问题时,传入append-to-body属性 -->
  <TfInput v-model="form.test8" title="基础资料" type="basicData" code="20220506141102" append-to-body />

  <!--基础资料展示字段  用于创建人,创建时间等永远不会被更改的基础资料字段,可以节省性能和内存-->
  <TfInput v-model="form.test9" title="基础资料展示字段" type="basicDisplay" />
</el-form>

1.2 在表单中加入校验

使用方式与Element一致(添加prop属性)

<el-form model="form" :rules="formRules">
  <TfInput v-model="form.test1" title="输入框" prop="test" type="input"/>
  <TfInput v-model="form.test2" title="文本" prop="test2" type="text"/>
  <TfInput v-model="form.test3" title="日期" type="date"/>
  <TfInput v-model="form.test4" title="日期时间" type="datetime"/>
  <TfInput v-model="form.test5" title="整数" type="integer"/>
  <TfInput v-model="form.test6" title="小数" type="decimal"/>
</el-form>    

1.3 Props

属性作用类型默认值
type控件类型input / select / integer / decimal / date / datetime / basicData / basicDataDisplayinput
title表单模式下的labelstring
prop表单模式下校验绑定的字段string
id用于type为select时获取下拉数组的参数string
enumType用于type为select时获取下拉数组的参数string
options用于type为select时自定义的下拉数组array
show-fields用于type为select时自定义的下拉数据格式{ value: string, label: string }
append-to-body用于解决type为basicData引起的弹窗嵌套问题booleanfalse
notForm为true时表示不在表单中使用,仅仅是使用控件,忽略prop title等属性booleanfalse
labelWidthelform中的label宽度string150px
fullBorder为true时表示input的边框完全显示,而非只显示下边框booleanfalse

1.4 其他说明

有问题及时提出,联系@YSL

2. TfFormBody

2.1 案例

    <TfFormBody
      ref="formBodyRef"
      :data="data"
      :calculations="calculations"
      :before-add-row="beforeAddRow"
      :after-add-row="afterAddRow"
    >
      <TfFormBodyItem
        title="物料名称"
        field="materialInfo"
        prop="materialInfo"
        type="basicData"
        code="5a281b7db87c406b83616986f40e0846"
        @selected="selectedaterial"
      />
      <TfFormBodyItem
        title="仓位"
        field="warehousePositionInfo"
        prop="warehousePositionInfo"
        type="basicData"
        code="20220506141103"
        :before-input="judgeMaterial"
        :limitation="[{ field: 'warehouseInfo', value: 'warehouseInfo', type:'field' }]"
      />
      <!-- precision默认值是2 -->
      <TfFormBodyItem title="数量" field="number" type="decimal" :percision="4" />
      <TfFormBodyItem title="单价" field="price" type="decimal" :percision="2" />
      <TfFormBodyItem title="总额" field="amount" type="decimal" :percision="2" />
      <TfFormBodyItem title="是否启用" field="isActive" type="select" enum-type='YES_OR_NO'/>
      <!-- 默认类型就是input,可以省略 -->
      <TfFormBodyItem title="姓名" field="name" type="input" />
      <TfFormBodyItem title="出生日期" field="birthDate" type="date" />
      <TfFormBodyItem title="审核时间" field="auditTime" type="datetime" />
    </TfFormBody>
export default {
  data(){
    return {
      caculations:{
        amount:'#{number} * #{price}'
      }
    }
  },
  methods:{

    /** 新增行之前的钩子 */
    beforeAddRow(done) {
      // some check
      done()
    },

    /** 新增行之后的钩子 */
    afterAddRow() {
      // some data change
    },

    /** 物料名称选择后的方法 */
    selectedaterial(row, $event){
      // some data change
    },

    /** 仓位基础资料输入前的校验 */
    judgeMaterial(done){
      // some check
      done()
    }

  }
}

2.2 Props

属性作用类型默认值
data表格数据Array[]
rules校验对象,可参考ElementUiObjectnull
calculations列表行字段之间的计算关联Objectnull
disableButtons禁用(新增行,删除行,批量填充按钮时使用), 可选'add', 'del', 'batchFill'Array[]
modelAdditionalProperties单据体中有个字段是不显示的字段,但是操作的时候会用到,需要用此属性初始化该字段:{ field:'active',default:false }Array[]
before-add-row添加数据行(点击单据体新增按钮)之前执行Functionnull
after-add-row添加数据行之后执行Functionnull

2.3 Methods

方法名作用
validate校验表格数据,返回值为true时表示校验通过
getFormatData(filter)输出格式化之后的数据, filter为可选自定义过滤函数
calculate(row)针对某一行,重新进行列之间的数学表达式计算
calculateRow(rows)批量进行计算

3. TfFormBodyItem

3.1 Props

属性作用类型默认值
title列表的列标题string
field数据模型的字段string
width列的默认宽度string'150px'
readOnly不可编辑列Booleanfalse
precision小数保留位数Number2
limitation限定基础资料的查询范围Array[]
default列字段的默认值String, Number, Object, Boolean
showMessage编辑列的自定义显示值的方法Function
  • 方式一:(province = '江苏' 的数据)

    [{ field: 'province', type:'value', value:'江苏' }]
  • 方式二:(取字段值,province = scope.row.province)

    [{ field: 'province', type:'field', value:'province' }]

3.2 Event

方法名作用
changefunction({ row, value }) 值发生改变
selectedfunction({ row, value }) 基础资料选中事件

4 关于标准化之后的基础资料表单

4.1 说明

标准化,是按照金蝶的控件功能来实现基础资料的弹窗列表中,可以直接打开表单新增和修改的数据的功能原型 因为缺少通用表单的功能,所以现在将全部的用作基础资料的表单迁移到本包中 在基础资料的通用控件中,通过动态的异步组件,以code为依据,加载对应的表单组件,达到效果 如果要添加新的基础资料,按照遗下步骤进行操作

  • 1 在basic-datas目录添加子目录,添加表单组件
  • 2 在@enums中registerSheet文件中,添加code到目录名的映射关系
  • 3 在@components/basic-form-edit中componets选项中异步的引入相关的基础资料表单组件
0.2.19-beta.8

5 months ago

0.2.19-beta.7

5 months ago

0.2.19-beta.3

7 months ago

0.2.19-beta.4

6 months ago

0.2.19-beta.5

6 months ago

0.2.19-beta.6

6 months ago

0.2.19-beta.1

8 months ago

0.2.19-beta.2

7 months ago

0.2.18-beta.10

8 months ago

0.2.18-beta.7

9 months ago

0.2.18-beta.6

9 months ago

0.2.18-beta.9

8 months ago

0.2.18-beta.8

9 months ago

0.2.18-beta.3

11 months ago

0.2.18-beta.5

11 months ago

0.2.18-beta.4

11 months ago

0.2.17-beta.0

11 months ago

0.2.17

11 months ago

0.2.16

11 months ago

0.2.15

11 months ago

0.2.14

12 months ago

0.2.13

12 months ago

0.2.12

12 months ago

0.2.11

12 months ago

0.2.10

12 months ago

0.2.18-beta.1

11 months ago

0.2.18-beta.0

11 months ago

0.2.18-beta.2

11 months ago

0.2.15-beta.3

12 months ago

0.2.15-beta.0

12 months ago

0.2.15-beta.2

12 months ago

0.2.15-beta.1

12 months ago

0.2.9

12 months ago

0.2.8

12 months ago

0.2.7

1 year ago

0.1.190

1 year ago

0.1.192

1 year ago

0.1.191

1 year ago

0.1.194

1 year ago

0.1.193

1 year ago

0.1.195

1 year ago

0.2.1

1 year ago

0.2.0

1 year ago

0.1.187

1 year ago

0.2.6

1 year ago

0.1.189

1 year ago

0.1.188

1 year ago

0.2.3

1 year ago

0.2.2

1 year ago

0.2.5

1 year ago

0.2.4

1 year ago

0.1.186

1 year ago

0.1.183

1 year ago

0.1.182

1 year ago

0.1.185

1 year ago

0.1.184

1 year ago

0.1.179

1 year ago

0.1.181

1 year ago

0.1.180

1 year ago

0.1.176

1 year ago

0.1.175

1 year ago

0.1.178

1 year ago

0.1.177

1 year ago

0.1.172

1 year ago

0.1.171

1 year ago

0.1.174

1 year ago

0.1.173

1 year ago

0.1.139

2 years ago

0.1.136

2 years ago

0.1.135

2 years ago

0.1.138

2 years ago

0.1.137

2 years ago

0.1.134

2 years ago

0.1.147

2 years ago

0.1.146

2 years ago

0.1.149

2 years ago

0.1.148

2 years ago

0.1.143

2 years ago

0.1.142

2 years ago

0.1.145

2 years ago

0.1.144

2 years ago

0.1.141

2 years ago

0.1.140

2 years ago

0.1.158

2 years ago

0.1.157

2 years ago

0.1.159

2 years ago

0.1.154

2 years ago

0.1.153

2 years ago

0.1.156

2 years ago

0.1.155

2 years ago

0.1.150

2 years ago

0.1.152

2 years ago

0.1.151

2 years ago

0.1.169

1 year ago

0.1.168

1 year ago

0.1.165

1 year ago

0.1.164

1 year ago

0.1.167

1 year ago

0.1.166

1 year ago

0.1.161

1 year ago

0.1.160

2 years ago

0.1.163

1 year ago

0.1.162

1 year ago

0.1.170

1 year ago

0.1.118

2 years ago

0.1.117

2 years ago

0.1.119

2 years ago

0.1.114

2 years ago

0.1.113

2 years ago

0.1.116

2 years ago

0.1.115

2 years ago

0.1.110

2 years ago

0.1.112

2 years ago

0.1.111

2 years ago

0.1.129

2 years ago

0.1.128

2 years ago

0.1.125

2 years ago

0.1.124

2 years ago

0.1.127

2 years ago

0.1.126

2 years ago

0.1.121

2 years ago

0.1.120

2 years ago

0.1.123

2 years ago

0.1.122

2 years ago

0.1.132

2 years ago

0.1.131

2 years ago

0.1.133

2 years ago

0.1.130

2 years ago

0.1.109

2 years ago

0.1.96

2 years ago

0.1.97

2 years ago

0.1.98

2 years ago

0.1.99

2 years ago

0.1.90

2 years ago

0.1.91

2 years ago

0.1.92

2 years ago

0.1.93

2 years ago

0.1.94

2 years ago

0.1.95

2 years ago

0.1.85

2 years ago

0.1.86

2 years ago

0.1.87

2 years ago

0.1.88

2 years ago

0.1.89

2 years ago

0.1.80

2 years ago

0.1.81

2 years ago

0.1.82

2 years ago

0.1.83

2 years ago

0.1.84

2 years ago

0.1.74

2 years ago

0.1.75

2 years ago

0.1.76

2 years ago

0.1.77

2 years ago

0.1.78

2 years ago

0.1.79

2 years ago

0.1.72

2 years ago

0.1.73

2 years ago

0.1.107

2 years ago

0.1.106

2 years ago

0.1.108

2 years ago

0.1.103

2 years ago

0.1.102

2 years ago

0.1.105

2 years ago

0.1.104

2 years ago

0.1.101

2 years ago

0.1.100

2 years ago

0.1.52

2 years ago

0.1.53

2 years ago

0.1.54

2 years ago

0.1.55

2 years ago

0.1.56

2 years ago

0.1.57

2 years ago

0.1.58

2 years ago

0.1.59

2 years ago

0.1.50

2 years ago

0.1.51

2 years ago

0.1.49

2 years ago

0.1.41

2 years ago

0.1.42

2 years ago

0.1.43

2 years ago

0.1.44

2 years ago

0.1.45

2 years ago

0.1.46

2 years ago

0.1.47

2 years ago

0.1.48

2 years ago

0.1.40

2 years ago

0.1.38

2 years ago

0.1.39

2 years ago

0.1.33

2 years ago

0.1.34

2 years ago

0.1.35

2 years ago

0.1.36

2 years ago

0.1.37

2 years ago

0.1.70

2 years ago

0.1.71

2 years ago

0.1.63

2 years ago

0.1.64

2 years ago

0.1.65

2 years ago

0.1.66

2 years ago

0.1.67

2 years ago

0.1.68

2 years ago

0.1.69

2 years ago

0.1.60

2 years ago

0.1.61

2 years ago

0.1.62

2 years ago

0.1.30

2 years ago

0.1.31

2 years ago

0.1.32

2 years ago

0.1.28

2 years ago

0.1.29

2 years ago

0.1.27

2 years ago

0.1.26

2 years ago

0.1.20

2 years ago

0.1.21

2 years ago

0.1.22

2 years ago

0.1.23

2 years ago

0.1.24

2 years ago

0.1.25

2 years ago

0.1.17

2 years ago

0.1.18

2 years ago

0.1.19

2 years ago

0.1.10

2 years ago

0.1.11

2 years ago

0.1.12

2 years ago

0.1.13

2 years ago

0.1.14

2 years ago

0.1.15

2 years ago

0.1.16

2 years ago

0.1.8

2 years ago

0.1.9

2 years ago

0.1.8-beta

2 years ago

0.1.7

3 years ago

0.1.6

3 years ago

0.1.5

3 years ago

0.1.4

3 years ago

0.1.3

3 years ago

0.1.2

3 years ago

0.1.1

3 years ago

0.1.0

3 years ago