windy
3 years ago
76 changed files with 508 additions and 119 deletions
@ -0,0 +1,100 @@
|
||||
/** |
||||
* @author windy |
||||
* @version 2.0 |
||||
* Created by windy on 2022/1/11 |
||||
*/ |
||||
Demo.Form = BI.inherit(BI.Widget, { |
||||
props: { |
||||
baseCls: "demo-form" |
||||
}, |
||||
render: function () { |
||||
var widget = BI.createWidget({ |
||||
type: "bi.custom_form", |
||||
width: 300, |
||||
labelWidth: 100, |
||||
items: [{ |
||||
validate: function (v) { |
||||
return v !== "a" && v !== ""; |
||||
}, |
||||
tip: function (v) { |
||||
if (BI.isEmpty(v)) { |
||||
return "不能为空"; |
||||
} |
||||
return "不合法格式" |
||||
}, |
||||
label: "E-mail", |
||||
el: { |
||||
type: 'bi.text_editor', |
||||
watermark: "输入a报错", |
||||
allowBlank: true, |
||||
} |
||||
}, { |
||||
validate: function (v) { |
||||
return BI.isNotEmptyArray(v); |
||||
}, |
||||
tip: function () { |
||||
return "不能为空"; |
||||
}, |
||||
label: "性别", |
||||
el: { |
||||
type: 'bi.text_value_combo', |
||||
text: "请选择", |
||||
items: [{ |
||||
text: "男", |
||||
value: 1 |
||||
}, { |
||||
text: "女", |
||||
value: 2 |
||||
}] |
||||
} |
||||
}, { |
||||
validate: function (v) { |
||||
return v !== ""; |
||||
}, |
||||
tip: function () { |
||||
return "不能为空"; |
||||
}, |
||||
label: "姓名", |
||||
el: { |
||||
type: 'bi.text_editor', |
||||
watermark: "输入姓名", |
||||
allowBlank: true, |
||||
} |
||||
}, { |
||||
validate: function (v) { |
||||
return v !== ""; |
||||
}, |
||||
tip: function () { |
||||
return "不能为空"; |
||||
}, |
||||
label: "姓名", |
||||
el: { |
||||
type: 'bi.textarea_editor', |
||||
cls: 'bi-border', |
||||
watermark: "输入简介", |
||||
allowBlank: true, |
||||
height: 200, |
||||
} |
||||
}], |
||||
layout: { |
||||
type: "bi.vertical", |
||||
vgap: 30 |
||||
} |
||||
}); |
||||
return { |
||||
type: "bi.vertical", |
||||
hgap: 200, |
||||
vgap: 10, |
||||
items: [widget, { |
||||
type: "bi.button", |
||||
text: "提交", |
||||
handler: function () { |
||||
widget.validate(); |
||||
|
||||
console.log(widget.getValue()); |
||||
} |
||||
}] |
||||
}; |
||||
} |
||||
}); |
||||
BI.shortcut("demo.form", Demo.Form); |
@ -0,0 +1,85 @@
|
||||
/** |
||||
* @author windy |
||||
* @version 2.0 |
||||
* Created by windy on 2022/1/11 |
||||
*/ |
||||
BI.FormField = BI.inherit(BI.Widget, { |
||||
|
||||
props: { |
||||
baseCls: "bi-form-field", |
||||
label: "", |
||||
el: {}, |
||||
validate: BI.emptyFn |
||||
}, |
||||
|
||||
render: function () { |
||||
var self = this, o = this.options; |
||||
|
||||
var field = { |
||||
type: "bi.absolute", |
||||
items: [{ |
||||
el: BI.extend({}, o.el, { |
||||
ref: function (_ref) { |
||||
self.field = _ref; |
||||
o.el.ref && o.el.ref.call(this, _ref); |
||||
}, |
||||
height: o.el.height || 28, |
||||
listeners: [{ |
||||
eventName: "EVENT_CHANGE", |
||||
action: function () { |
||||
self.fireEvent("EVENT_CHANGE"); |
||||
} |
||||
}] |
||||
}), |
||||
left: 0, |
||||
bottom: 0, |
||||
right: 0, |
||||
top: 0 |
||||
}, { |
||||
el: { |
||||
type: "bi.label", |
||||
cls: "error-tip bi-error", |
||||
ref: function (_ref) { |
||||
self.error = _ref; |
||||
}, |
||||
invisible: true |
||||
}, |
||||
bottom: -20, |
||||
left: 0, |
||||
right: 0, |
||||
height: 20 |
||||
}] |
||||
}; |
||||
|
||||
return { |
||||
type: "bi.vertical_adapt", |
||||
columnSize: ["auto", "fill"], |
||||
verticalAlign: BI.VerticalAlign.Stretch, |
||||
hgap: 5, |
||||
items: BI.isKey(o.label) ? [{ |
||||
type: "bi.label", |
||||
text: o.label + ":", |
||||
width: o.labelWidth |
||||
}, field] : [field] |
||||
}; |
||||
}, |
||||
|
||||
getValue: function () { |
||||
return this.field.getValue(); |
||||
}, |
||||
|
||||
validate: function () { |
||||
var isValid = this.validateWithNoTip(); |
||||
!isValid && this.error.setText(this.options.tip(this.field.getValue(), this.field)); |
||||
this.error.setVisible(!isValid); |
||||
this.element[isValid ? "removeClass" : "addClass"]("error"); |
||||
|
||||
return isValid; |
||||
}, |
||||
|
||||
validateWithNoTip: function () { |
||||
return this.options.validate(this.field.getValue(), this.field); |
||||
} |
||||
}); |
||||
|
||||
BI.shortcut("bi.form_field", BI.FormField); |
@ -0,0 +1,89 @@
|
||||
/** |
||||
* @author windy |
||||
* @version 2.0 |
||||
* Created by windy on 2022/1/11 |
||||
*/ |
||||
BI.Form = BI.inherit(BI.Widget, { |
||||
|
||||
props: { |
||||
baseCls: "bi-form", |
||||
layout: { |
||||
type: "bi.vertical", |
||||
vgap: 20 |
||||
}, |
||||
items: [{ |
||||
validate: BI.emptyFn, |
||||
tip: BI.emptyFn, |
||||
label: "", |
||||
el: {} |
||||
}], |
||||
labelWidth: "" |
||||
}, |
||||
|
||||
render: function () { |
||||
var self = this, o = this.options; |
||||
|
||||
return { |
||||
type: "bi.button_group", |
||||
items: this._createItems(), |
||||
layouts: [o.layout], |
||||
ref: function (ref) { |
||||
self.group = ref; |
||||
} |
||||
}; |
||||
}, |
||||
|
||||
_createItems: function () { |
||||
var o = this.options; |
||||
|
||||
return BI.map(o.items, function (idx, item) { |
||||
return { |
||||
type: "bi.form_field", |
||||
height: item.el.height || 28, |
||||
labelWidth: o.labelWidth, |
||||
el: item.el, |
||||
label: item.label, |
||||
tip: item.tip, |
||||
validate: item.validate, |
||||
listeners: [{ |
||||
eventName: "EVENT_CHANGE", |
||||
action: function () { |
||||
this.validate(); |
||||
} |
||||
}] |
||||
}; |
||||
}); |
||||
}, |
||||
|
||||
isAllValid: function () { |
||||
return !BI.some(this.validateWithNoTip(), function (idx, v) { |
||||
return !v; |
||||
}); |
||||
}, |
||||
|
||||
validateWithNoTip: function () { |
||||
var validInfo = []; |
||||
BI.each(this.group.getAllButtons(), function (idx, button) { |
||||
validInfo.push(button.validateWithNoTip()); |
||||
}); |
||||
|
||||
return validInfo; |
||||
}, |
||||
|
||||
validate: function () { |
||||
var validInfo = []; |
||||
BI.each(this.group.getAllButtons(), function (idx, button) { |
||||
validInfo.push(button.validate()); |
||||
}); |
||||
|
||||
return validInfo; |
||||
}, |
||||
|
||||
getValue: function () { |
||||
return !this.isAllValid() ? null : BI.map(this.group.getAllButtons(), function (idx, button) { |
||||
return button.getValue(); |
||||
}); |
||||
} |
||||
}); |
||||
|
||||
BI.shortcut("bi.custom_form", BI.Form); |
@ -0,0 +1,14 @@
|
||||
@import "../../index"; |
||||
|
||||
.bi-form { |
||||
& .bi-form-field.error { |
||||
& .bi-border, & .bi-border-bottom { |
||||
border-color: @border-color-negative; |
||||
} |
||||
} |
||||
& .bi-form-field { |
||||
& .error-tip { |
||||
background-color: @color-bi-background-error-form; |
||||
} |
||||
} |
||||
} |
Loading…
Reference in new issue