提交 c10aeccc 编写于 作者: ibizdev's avatar ibizdev

zhujiamin 发布系统代码 [TrainSys,网页端]

上级 01626366
...@@ -13,13 +13,13 @@ ...@@ -13,13 +13,13 @@
"dependencies": { "dependencies": {
"@floating-ui/dom": "^1.0.11", "@floating-ui/dom": "^1.0.11",
"@ibiz-template/command": "^0.0.1-beta.50", "@ibiz-template/command": "^0.0.1-beta.50",
"@ibiz-template/controller": "^0.0.1-beta.129", "@ibiz-template/controller": "^0.0.1-beta.130",
"@ibiz-template/core": "^0.0.1-beta.129", "@ibiz-template/core": "^0.0.1-beta.130",
"@ibiz-template/model": "^0.0.1-beta.129", "@ibiz-template/model": "^0.0.1-beta.130",
"@ibiz-template/runtime": "^0.0.1-beta.129", "@ibiz-template/runtime": "^0.0.1-beta.130",
"@ibiz-template/service": "^0.0.1-beta.129", "@ibiz-template/service": "^0.0.1-beta.130",
"@ibiz-template/theme": "^0.0.1-beta.129", "@ibiz-template/theme": "^0.0.1-beta.130",
"@ibiz-template/vue-util": "^0.0.1-beta.129", "@ibiz-template/vue-util": "^0.0.1-beta.130",
"@ibiz/dynamic-model-api": "^2.1.28", "@ibiz/dynamic-model-api": "^2.1.28",
"@riophae/vue-treeselect": "^0.4.0", "@riophae/vue-treeselect": "^0.4.0",
"dayjs": "^1.11.7", "dayjs": "^1.11.7",
......
此差异已折叠。
...@@ -119,7 +119,12 @@ export const ViewToolbar = defineComponent({ ...@@ -119,7 +119,12 @@ export const ViewToolbar = defineComponent({
return ( return (
<div <div
key={item.id} key={item.id}
class={[this.ns.e('item'), this.ns.e('item-deuiaction')]} class={[
this.ns.e('item'),
this.ns.e('item-deuiaction'),
this.ns.is('loading', this.toolbarState[item.id].loading),
this.ns.is('caption', !!(item.showCaption && item.caption)),
]}
> >
<i-button <i-button
title={item.tooltip} title={item.tooltip}
......
...@@ -137,9 +137,10 @@ export const IBizCheckbox = defineComponent({ ...@@ -137,9 +137,10 @@ export const IBizCheckbox = defineComponent({
selectArray, selectArray,
valueText, valueText,
onSelectArrayChange, onSelectArrayChange,
c,
}; };
}, },
render() { render(h) {
return ( return (
<div <div
class={[ class={[
...@@ -148,24 +149,33 @@ export const IBizCheckbox = defineComponent({ ...@@ -148,24 +149,33 @@ export const IBizCheckbox = defineComponent({
this.readonly ? this.ns.m('readonly') : '', this.readonly ? this.ns.m('readonly') : '',
]} ]}
> >
{this.readonly ? ( {[
this.valueText this.readonly && this.valueText,
) : ( !this.readonly &&
<i-checkbox-group h(
value={this.selectArray} 'ICheckboxGroup',
on-on-change={this.onSelectArrayChange} {
> props: {
{this.items.map((item, index: number) => ( ...this.c.customProps,
<i-checkbox value: this.selectArray,
key={index} },
label={item.value} on: {
disabled={this.disabled} 'on-change': this.onSelectArrayChange,
> },
<span class={this.ns.e('text')}>{item.text}</span> },
</i-checkbox> [
))} this.items.map((item, index: number) => (
</i-checkbox-group> <i-checkbox
)} key={index}
label={item.value}
disabled={this.disabled}
>
<span class={this.ns.e('text')}>{item.text}</span>
</i-checkbox>
)),
],
),
]}
</div> </div>
); );
}, },
......
...@@ -199,7 +199,7 @@ export const IBizMPicker = defineComponent({ ...@@ -199,7 +199,7 @@ export const IBizMPicker = defineComponent({
setDefaultOptions, setDefaultOptions,
}; };
}, },
render() { render(h) {
return ( return (
<div <div
class={[ class={[
...@@ -209,34 +209,42 @@ export const IBizMPicker = defineComponent({ ...@@ -209,34 +209,42 @@ export const IBizMPicker = defineComponent({
]} ]}
> >
{this.readonly && this.valueText} {this.readonly && this.valueText}
{!this.readonly && ( {!this.readonly &&
<i-select h(
ref='selectRef' 'iSelect',
value={this.curValue} {
filterable ref: 'selectRef',
transfer props: {
multiple ...this.c.customProps,
default-label={this.defaultLabel} value: this.curValue,
loading={this.loading} filterable: true,
placeholder={this.c.placeHolder} transfer: true,
remote-method={this.onSearch} multiple: true,
on-on-open-change={this.onOpenChange} defaultLabel: this.defaultLabel,
on-on-change={this.onSelect} loading: this.loading,
disabled={this.disabled} placeholder: this.c.placeHolder,
> disabled: this.disabled,
{this.items.map(item => { remoteMethod: this.onSearch,
return ( },
<i-option on: {
key={item.srfkey} 'on-change': this.onSelect,
value={item.srfkey} 'on-open-change': this.onOpenChange,
label={item.srfmajortext} },
> },
{item.srfmajortext} [
</i-option> this.items.map(item => {
); return (
})} <i-option
</i-select> key={item.srfkey}
)} value={item.srfkey}
label={item.srfmajortext}
>
{item.srfmajortext}
</i-option>
);
}),
],
)}
{!this.readonly && ( {!this.readonly && (
<div class={this.ns.e('buns-position')}> <div class={this.ns.e('buns-position')}>
<div class={this.ns.e('btns')}> <div class={this.ns.e('btns')}>
......
...@@ -182,7 +182,7 @@ export const IBizPickerDropDown = defineComponent({ ...@@ -182,7 +182,7 @@ export const IBizPickerDropDown = defineComponent({
onSearch, onSearch,
}; };
}, },
render() { render(h) {
if (this.readonly) { if (this.readonly) {
return ( return (
<div class={(this.ns.b(), this.ns.m('readonly'))}>{this.value}</div> <div class={(this.ns.b(), this.ns.m('readonly'))}>{this.value}</div>
...@@ -190,34 +190,43 @@ export const IBizPickerDropDown = defineComponent({ ...@@ -190,34 +190,43 @@ export const IBizPickerDropDown = defineComponent({
} }
return ( return (
<div class={[this.ns.b(), this.disabled ? this.ns.m('disabled') : '']}> <div class={[this.ns.b(), this.disabled ? this.ns.m('disabled') : '']}>
{this.readonly ? ( {[
this.value this.readonly && this.value,
) : ( !this.readonly &&
<i-select h(
value={this.refValue} 'iSelect',
filterable {
remote props: {
allow-clear ...this.c.customProps,
clearable value: this.refValue,
transfer filterable: true,
loading={this.loading} remote: true,
placeholder={this.c.placeHolder} allowClear: true,
remote-method={this.onSearch} clearable: true,
on-on-open-change={this.onOpenChange} transfer: true,
on-on-query-change={this.onQueryChange} loading: this.loading,
on-on-change={this.onSelect} placeholder: this.c.placeHolder,
on-on-clear={this.onClear} remoteMethod: this.onSearch,
disabled={this.disabled} disabled: this.disabled,
> },
{this.items.map((item, index) => { on: {
return ( 'on-change': this.onSelect,
<i-option value={item[this.c.keyName]} key={index}> 'on-open-change': this.onOpenChange,
{item[this.c.textName]} 'on-query-change': this.onQueryChange,
</i-option> 'on-on-clear': this.onClear,
); },
})} },
</i-select> [
)} this.items.map((item, index) => {
return (
<i-option value={item[this.c.keyName]} key={index}>
{item[this.c.textName]}
</i-option>
);
}),
],
),
]}
</div> </div>
); );
}, },
......
...@@ -141,7 +141,7 @@ export const IBizPicker = defineComponent({ ...@@ -141,7 +141,7 @@ export const IBizPicker = defineComponent({
onBlur, onBlur,
}; };
}, },
render() { render(h) {
if (this.readonly) { if (this.readonly) {
return ( return (
<div class={(this.ns.b(), this.ns.m('readonly'))}>{this.value}</div> <div class={(this.ns.b(), this.ns.m('readonly'))}>{this.value}</div>
...@@ -149,84 +149,106 @@ export const IBizPicker = defineComponent({ ...@@ -149,84 +149,106 @@ export const IBizPicker = defineComponent({
} }
return ( return (
<div class={[this.ns.b(), this.disabled ? this.ns.m('disabled') : '']}> <div class={[this.ns.b(), this.disabled ? this.ns.m('disabled') : '']}>
{this.c.noAC ? ( {[
<i-input this.c.noAC &&
value={this.curValue} h(
clearable 'IInput',
placeholder={this.c.placeHolder} {
on-on-clear={this.onClear} props: {
disabled={this.disabled} ...this.c.customProps,
> value: this.curValue,
{this.$slots.append} clearable: true,
{!this.$slots.append && this.c.pickupView ? ( placeholder: this.c.placeHolder,
<i-button disabled: this.disabled,
key='ios-search' },
icon='ios-search' on: {
on-click={this.openPickUpView} 'on-clear': this.onClear,
></i-button> },
) : null} },
{!this.$slots.append && this.c.linkView ? ( [
<i-button this.$slots.append,
key='ios-search-outline' !this.$slots.append && this.c.pickupView && (
icon='ios-search-outline'
on-click='openLinkView'
></i-button>
) : null}
</i-input>
) : (
<div
class={[
this.ns.e('autocomplete'),
this.ns.m(this.closeCircle.toString()),
]}
>
<i-auto-complete
value={this.curValue}
placeholder={this.c.placeHolder}
placement='bottom'
clearable
transfer-class-name={this.ns.e('transfer')}
on-on-focus={this.onFocus}
on-on-search={this.onSearch}
on-on-clear={this.onClear}
on-on-blur={this.onBlur}
disabled={this.disabled}
>
{this.items.map(item => {
return (
<div
class={this.ns.e('transfer-item')}
on-click={() => {
this.onACSelect(item);
}}
>
{item[this.c.textName]}
</div>
);
})}
</i-auto-complete>
<div class={this.ns.e('buns-position')}>
<div class={this.ns.e('btns')}>
{this.c.pickupView ? (
<i-button <i-button
key='ios-search'
icon='ios-search' icon='ios-search'
on-click={this.openPickUpView} on-click={this.openPickUpView}
type={'text'}
></i-button> ></i-button>
) : null} ),
{this.c.linkView ? ( !this.$slots.append && this.c.linkView && (
<i-button <i-button
on-click={this.openLinkView} key='ios-search-outline'
type={'text'} icon='ios-search-outline'
class={this.ns.e('link')} on-click='openLinkView'
> ></i-button>
<ion-icon src={'./assets/img/link.svg'}></ion-icon> ),
</i-button> ],
) : null} ),
</div> !this.c.noAC && (
<div
class={[
this.ns.e('autocomplete'),
this.ns.m(this.closeCircle.toString()),
]}
>
{[
h(
'IAutoComplete',
{
props: {
...this.c.customProps,
value: this.curValue,
placeholder: this.c.placeHolder,
placement: 'bottom',
clearable: true,
transferClassName: this.ns.e('transfer'),
disabled: this.disabled,
},
on: {
'on-focus': this.onFocus,
'on-search': this.onSearch,
'on-clear': this.onClear,
'on-blur': this.onBlur,
},
},
[
this.items.map(item => {
return (
<div
class={this.ns.e('transfer-item')}
on-click={() => {
this.onACSelect(item);
}}
>
{item[this.c.textName]}
</div>
);
}),
],
),
<div class={this.ns.e('buns-position')}>
<div class={this.ns.e('btns')}>
{this.c.pickupView ? (
<i-button
icon='ios-search'
on-click={this.openPickUpView}
type={'text'}
></i-button>
) : null}
{this.c.linkView ? (
<i-button
on-click={this.openLinkView}
type={'text'}
class={this.ns.e('link')}
>
<ion-icon src={'./assets/img/link.svg'}></ion-icon>
</i-button>
) : null}
</div>
</div>,
]}
</div> </div>
</div> ),
)} ]}
</div> </div>
); );
}, },
......
...@@ -99,7 +99,7 @@ export const IBizDatePicker = defineComponent({ ...@@ -99,7 +99,7 @@ export const IBizDatePicker = defineComponent({
isTimePicker, isTimePicker,
}; };
}, },
render() { render(h) {
return ( return (
<div <div
class={[ class={[
...@@ -108,33 +108,45 @@ export const IBizDatePicker = defineComponent({ ...@@ -108,33 +108,45 @@ export const IBizDatePicker = defineComponent({
this.readonly ? this.ns.m('readonly') : '', this.readonly ? this.ns.m('readonly') : '',
]} ]}
> >
{this.readonly ? ( {[
this.formatValue this.readonly && this.formatValue,
) : this.isTimePicker ? ( !this.readonly &&
<i-time-picker this.isTimePicker &&
ref='inputRef' h('ITimePicker', {
transfer ref: 'inputRef',
type={this.type} props: {
format={this.format} ...this.c.customProps,
placeholder={this.c!.placeHolder} value: this.value,
value={this.value} type: this.type,
on-on-open-change={this.onOpenChange} format: this.format,
on-on-change={this.handleChange} placeholder: this.c!.placeHolder,
disabled={this.disabled} disabled: this.disabled,
></i-time-picker> transfer: true,
) : ( },
<i-CalendarPicker on: {
ref='inputRef' 'on-change': this.handleChange,
transfer 'on-open-change': this.onOpenChange,
type={this.type} },
format={this.format} }),
placeholder={this.c!.placeHolder} !this.readonly &&
value={this.value} !this.isTimePicker &&
on-on-open-change={this.onOpenChange} h('ICalendarPicker', {
on-on-change={this.handleChange} ref: 'inputRef',
disabled={this.disabled} props: {
></i-CalendarPicker> ...this.c.customProps,
)} value: this.value,
type: this.type,
format: this.format,
placeholder: this.c!.placeHolder,
disabled: this.disabled,
transfer: true,
},
on: {
'on-change': this.handleChange,
'on-open-change': this.onOpenChange,
},
}),
]}
</div> </div>
); );
}, },
......
...@@ -141,7 +141,7 @@ export const IBizDateRange = defineComponent({ ...@@ -141,7 +141,7 @@ export const IBizDateRange = defineComponent({
unlinkPanels, unlinkPanels,
}; };
}, },
render() { render(h) {
return ( return (
<div <div
class={[ class={[
...@@ -150,20 +150,25 @@ export const IBizDateRange = defineComponent({ ...@@ -150,20 +150,25 @@ export const IBizDateRange = defineComponent({
this.readonly ? this.ns.m('readonly') : '', this.readonly ? this.ns.m('readonly') : '',
]} ]}
> >
<i-date-picker {h('IDatePicker', {
ref='inputRef' ref: 'inputRef',
value={this.curValue} props: {
transfer ...this.c.customProps,
type={this.type} value: this.curValue,
format={this.format} transfer: true,
placeholder={this.c!.placeHolder} type: this.type,
disabled={this.disabled} format: this.format,
readonly={this.readonly} placeholder: this.c!.placeHolder,
separator={this.rangeSeparator} disabled: this.disabled,
split-panels={this.unlinkPanels} readonly: this.readonly,
on-on-open-change={this.onOpenChange} // 弹出日历和关闭日历时触发 separator: this.rangeSeparator,
on-on-change={this.handleChange} // 日期发生变化时触发 splitPanels: this.unlinkPanels,
></i-date-picker> },
on: {
'on-change': this.handleChange,
'on-open-change': this.onOpenChange,
},
})}
</div> </div>
); );
}, },
......
...@@ -69,6 +69,10 @@ export const IBizDropdown = defineComponent({ ...@@ -69,6 +69,10 @@ export const IBizDropdown = defineComponent({
}); });
} }
const onSelect = (value: string | Array<string> | undefined) => {
curValue.value = value;
};
const onOpenChange = (isOpen: boolean) => { const onOpenChange = (isOpen: boolean) => {
emit('operate', isOpen); emit('operate', isOpen);
}; };
...@@ -82,37 +86,11 @@ export const IBizDropdown = defineComponent({ ...@@ -82,37 +86,11 @@ export const IBizDropdown = defineComponent({
hasChildren, hasChildren,
onOpenChange, onOpenChange,
inputRef, inputRef,
onSelect,
}; };
}, },
render() { render(h) {
// 编辑态内容
const editContent = this.hasChildren ? (
<app-select-tree
class={[this.ns.e('tree-select')]}
value={this.curValue}
nodes-data={this.items}
disabled={this.disabled}
multiple={this.c!.multiple}
></app-select-tree>
) : (
<i-select
ref='inputRef'
v-model={this.curValue}
allow-clear
transfer
clearable
class={[this.ns.e('select')]}
multiple={this.c!.multiple}
placeholder={this.c!.placeHolder}
disabled={this.disabled}
on-on-open-change={this.onOpenChange}
>
{this.items.map(item => {
return <i-option value={item.value}>{item.text}</i-option>;
})}
</i-select>
);
return ( return (
<div <div
class={[ class={[
...@@ -121,7 +99,46 @@ export const IBizDropdown = defineComponent({ ...@@ -121,7 +99,46 @@ export const IBizDropdown = defineComponent({
this.readonly ? this.ns.m('readonly') : '', this.readonly ? this.ns.m('readonly') : '',
]} ]}
> >
{this.readonly ? this.valueText : editContent} {[
this.readonly && this.valueText,
!this.readonly && this.hasChildren && (
<app-select-tree
class={[this.ns.e('tree-select')]}
value={this.curValue}
nodes-data={this.items}
disabled={this.disabled}
multiple={this.c!.multiple}
></app-select-tree>
),
!this.readonly &&
!this.hasChildren &&
h(
'iSelect',
{
ref: 'inputRef',
class: this.ns.e('select'),
props: {
...this.c.customProps,
value: this.curValue,
allowClear: true,
transfer: true,
clearable: true,
multiple: this.c!.multiple,
placeholder: this.c.placeHolder,
disabled: this.disabled,
},
on: {
'on-change': this.onSelect,
'on-open-change': this.onOpenChange,
},
},
[
this.items.map(item => {
return <i-option value={item.value}>{item.text}</i-option>;
}),
],
),
]}
</div> </div>
); );
}, },
......
...@@ -38,9 +38,10 @@ export const IBizRadio = defineComponent({ ...@@ -38,9 +38,10 @@ export const IBizRadio = defineComponent({
items, items,
valueText, valueText,
onSelectValueChange, onSelectValueChange,
c,
}; };
}, },
render() { render(h) {
return ( return (
<div <div
class={[ class={[
...@@ -49,21 +50,34 @@ export const IBizRadio = defineComponent({ ...@@ -49,21 +50,34 @@ export const IBizRadio = defineComponent({
this.readonly ? this.ns.m('readonly') : '', this.readonly ? this.ns.m('readonly') : '',
]} ]}
> >
{this.readonly ? ( {[
this.valueText this.readonly && this.valueText,
) : ( !this.readonly &&
<i-radio-group h(
class={this.ns.e('group')} 'IRadioGroup',
value={this.value} {
on-on-change={this.onSelectValueChange} class: this.ns.e('group'),
> props: {
{this.items.map((_item, index: number) => ( ...this.c.customProps,
<i-radio key={index} label={_item.value} disabled={this.disabled}> value: this.value,
<span class={this.ns.e('text')}>{_item.text}</span> },
</i-radio> on: {
))} 'on-change': this.onSelectValueChange,
</i-radio-group> },
)} },
[
this.items.map((_item, index: number) => (
<i-radio
key={index}
label={_item.value}
disabled={this.disabled}
>
<span class={this.ns.e('text')}>{_item.text}</span>
</i-radio>
)),
],
),
]}
</div> </div>
); );
}, },
......
...@@ -28,6 +28,18 @@ export const IBizInputNumber = defineComponent({ ...@@ -28,6 +28,18 @@ export const IBizInputNumber = defineComponent({
{ immediate: true }, { immediate: true },
); );
let hiddenupdownbutton = false;
if (c.editorParams) {
if (c.editorParams.hiddenupdownbutton) {
try {
hiddenupdownbutton = JSON.parse(c.editorParams.hiddenupdownbutton);
} catch {
hiddenupdownbutton = false;
}
}
}
const handleChange = (e: number | null) => { const handleChange = (e: number | null) => {
emit('change', e); emit('change', e);
}; };
...@@ -49,35 +61,48 @@ export const IBizInputNumber = defineComponent({ ...@@ -49,35 +61,48 @@ export const IBizInputNumber = defineComponent({
currentVal, currentVal,
handleChange, handleChange,
inputRef, inputRef,
hiddenupdownbutton,
}; };
}, },
render() { render(h) {
return ( return (
<div <div
class={[ class={[
this.ns.b(), this.ns.b(),
this.disabled ? this.ns.m('disabled') : '', this.disabled ? this.ns.m('disabled') : '',
this.readonly ? this.ns.m('readonly') : '', this.readonly ? this.ns.m('readonly') : '',
this.hiddenupdownbutton ? this.ns.m('hiddenupdownbutton') : '',
]} ]}
> >
{this.readonly ? ( {[
this.currentVal this.readonly && this.currentVal,
) : ( !this.readonly &&
<i-input-number h(
ref='inputRef' 'IInputNumber',
value={this.currentVal} {
placeholder={this.c.placeHolder} ref: 'inputRef',
precision={this.c.model.precision} props: {
disabled={this.disabled} ...this.c.customProps,
on-on-change={this.handleChange} value: this.currentVal,
> placeholder: this.controller.placeHolder,
{this.c.model.unitName && ( precision:
<i class={this.ns.e('unit')} slot='suffix'> this.c.model.precision === -1
{this.c.model.unitName} ? undefined
</i> : this.c.model.precision,
)} disabled: this.disabled,
</i-input-number> },
)} on: {
'on-change': this.handleChange,
},
},
[
this.controller.model.unitName &&
h('i', { class: this.ns.e('unit'), slot: 'suffix' }, [
this.controller.model.unitName,
]),
],
),
]}
</div> </div>
); );
}, },
......
...@@ -173,9 +173,10 @@ export const IBizInput = defineComponent({ ...@@ -173,9 +173,10 @@ export const IBizInput = defineComponent({
handleBlur, handleBlur,
inputRef, inputRef,
autoSize, autoSize,
c,
}; };
}, },
render() { render(h) {
return ( return (
<div <div
class={[ class={[
...@@ -185,29 +186,39 @@ export const IBizInput = defineComponent({ ...@@ -185,29 +186,39 @@ export const IBizInput = defineComponent({
this.readonly ? this.ns.m('readonly') : '', this.readonly ? this.ns.m('readonly') : '',
]} ]}
> >
{this.readonly ? ( {[
this.currentVal this.readonly && this.currentVal,
) : ( !this.readonly &&
<i-input h(
ref='inputRef' 'IInput',
value={this.currentVal} {
placeholder={this.controller.placeHolder} ref: 'inputRef',
type={this.type} class: this.ns.b('input'),
rows={this.rows} props: {
on-on-change={this.handleChange} ...this.c.customProps,
on-on-blur={this.handleBlur} value: this.currentVal,
nativeOnkeyup={this.handleKeyUp} placeholder: this.controller.placeHolder,
class={this.ns.b('input')} type: this.type,
disabled={this.disabled} rows: this.rows,
autosize={this.autoSize} disabled: this.disabled,
> autosize: this.autoSize,
{this.controller.model.unitName && ( },
<i class={this.ns.e('unit')} slot='suffix'> on: {
{this.controller.model.unitName} 'on-change': this.handleChange,
</i> 'on-blur': this.handleBlur,
)} },
</i-input> nativeOn: {
)} keyup: this.handleKeyUp,
},
},
[
this.controller.model.unitName &&
h('i', { class: this.ns.e('unit'), slot: 'suffix' }, [
this.controller.model.unitName,
]),
],
),
]}
</div> </div>
); );
}, },
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册