提交 3c609cf3 编写于 作者: Mosher's avatar Mosher

update:更新

上级 0e167c54
......@@ -24,31 +24,112 @@ export class MPickupView extends PickupView {
*/
public declare props: MPickupViewProps;
public onMoveRight() {
/**
* 初始化选中数据
*
* @protected
* @memberof MPickupView
*/
protected initSelectedData() {
const { viewParams } = this.state;
const { selectedData, selections} = toRefs(this.state);
const selected: IParam = viewParams?.selectedData?.[0] || {};
const keys = selected.srfkey?.split(',') || [];
const texts = selected.srfmajortext?.split(',') || [];
if (keys.length && texts.length) {
keys.forEach((key: string, index: number) => {
selectedData.value.push({ srfkey: key, srfmajortext: texts[index] });
});
}
selections.value = [...selectedData.value];
}
/**
* 将选中数据移动到右侧
*
* @protected
* @memberof MPickupView
*/
protected onMoveRight() {
const { selections, selectedData } = toRefs(this.state);
selections.value = selectedData.value;
}
public onMoveLeft() {
const { selections } = toRefs(this.state);
const index = selections.value.findIndex((selection: any) => Object.is(this.select.srfkey, selection.srfkey));
/**
* 移动到左侧
*
* @protected
* @memberof MPickupView
*/
protected onMoveLeft() {
const { selections, rightPanelSelections } = toRefs(this.state);
if (rightPanelSelections.value && rightPanelSelections.value.length) {
rightPanelSelections.value.forEach((pickItem: IParam) => {
const index = selections.value.findIndex((select: IParam) => select.srfkey === pickItem.srfkey);
if (index !== -1) {
selections.value.splice(index, 1);
}
});
}
public onAllMoveRight() {
//todo
}
public onAllMoveLeft() {
/**
* 全部移到右侧(选中)
*
* @protected
* @memberof MPickupView
*/
protected onAllMoveRight() {
if (this.xDataControl && this.xDataControl.state) {
const items = this.xDataControl.state.items || [];
const { selections, selectedData } = toRefs(this.state);
selectedData.value = [...items];
selections.value = [...items];
}
}
/**
* 全部移到左侧(取消选中)
*
* @protected
* @memberof MPickupView
*/
protected onAllMoveLeft() {
const { selections } = toRefs(this.state);
selections.value = [];
selectedData.value = [];
}
/**
* 右侧面板项点击
*
* @protected
* @param {IParam} item
* @param {MouseEvent} event
* @memberof MPickupView
*/
protected onRightPanelClick(item: IParam, event: MouseEvent) {
console.log("选中右侧面板数据", item, event);
const { rightPanelSelections } = toRefs(this.state);
}
/**
* 确认
*
* @memberof MPickupView
*/
public onConfirm(): void {
const { selections } = this.state;
const data: IParam[] = [];
if (selections && selections.length) {
let srfkey: string = '';
let srfmajortext: string = '';
selections.forEach((select: IParam, index: number) => {
srfkey += `${select.srfkey}${index !== selections.length - 1 ? ',' : ''}`;
srfmajortext += `${select.srfmajortext}${index !== selections.length - 1 ? ',' : ''}`;
});
data.push({ srfkey: srfkey, srfmajortext: srfmajortext });
}
this.emit('viewEvent', { tag: this.state.viewName, action: 'viewDataChange', data: data });
this.emit('viewEvent', { tag: this.state.viewName, action: 'viewClose', data: null });
}
/**
......
import { IActionParam } from "@core";
import { IParam } from "@core/interface";
import { MainView } from "../main-view";
import { PickupViewProps } from "./pickup-view-prop";
import { PickupViewState } from "./pickup-view-state";
......@@ -25,6 +26,14 @@ export class PickupView extends MainView {
*/
public declare props: PickupViewProps;
/**
* 选择视图面板引用
*
* @type {IParam}
* @memberof PickupView
*/
public declare pickupViewPanel: IParam;
/**
* 使用视图初始化模块
*
......@@ -32,8 +41,22 @@ export class PickupView extends MainView {
*/
public useViewInit() {
super.useViewInit();
this.pickupViewPanel = ref(null);
this.initSelectedData();
onMounted(() => {
this.xDataControl = unref(this.pickupViewPanel);
});
}
/**
* 初始化选中数据
*
* @protected
* @memberof PickupView
*/
protected initSelectedData() {
const { viewParams } = this.state;
this.state.selectedData = ref(viewParams.selectedData) || ref([]);
this.state.selectedData = viewParams?.selectedData ? ref(viewParams.selectedData) : ref([]);
}
/**
......@@ -79,6 +102,7 @@ export class PickupView extends MainView {
const superParams = super.moduleInstall();
return {
...superParams,
pickupViewPanel: this.pickupViewPanel,
onCancel: this.onCancel.bind(this),
onConfirm: this.onConfirm.bind(this)
};
......
......@@ -28,4 +28,11 @@ export interface PickupViewPanelControlState extends MainControlState {
* @memberof PickupViewPanelControlState
*/
selectedData: IParam[];
/**
* @description 多数据视图数据集合
* @type {IParam[]}
* @memberof PickupViewPanelControlState
*/
items: IParam[];
}
\ No newline at end of file
......@@ -18,28 +18,6 @@ export class PickupViewPanelControl extends MainControl {
*/
public declare state: PickupViewPanelControlState;
/**
* @description
* @param {PickupViewPanelControlProps} props
* @memberof PickupViewPanelControl
*/
public useLoad(props: PickupViewPanelControlProps) {
const { viewSubject, controlName, context, viewParams } = this.state;
// 订阅viewSubject,监听load行为
if (viewSubject) {
let subscription = viewSubject.subscribe(({ tag, action, data }: IActionParam) => {
if (Object.is(controlName, tag) && Object.is("load", action)) {
viewSubject.next({ tag: tag, action: "load", data: data });
}
})
// 部件卸载时退订viewSubject
onUnmounted(() => {
subscription.unsubscribe();
})
}
}
/**
* 部件事件
*
......@@ -52,6 +30,9 @@ export class PickupViewPanelControl extends MainControl {
if (Object.is("selectionChange", action)) {
this.handleSelectionChange(data);
}
if (Object.is("viewLoad", action)) {
this.handleViewLoad(data);
}
}
/**
......@@ -66,7 +47,7 @@ export class PickupViewPanelControl extends MainControl {
if (items && items.length) {
const { appDeKeyFieldName, appDeMajorFieldName } = this.state;
const _items: IParam[] = [];
items.forEach((item: IParam, index: number) => {
items.forEach((item: IParam) => {
_items.push({
srfkey: item.srfkey ? item.srfkey : item[appDeKeyFieldName.toLowerCase()],
srfmajortext: item.srfmajortext ? item.srfmajortext : item[appDeMajorFieldName.toLowerCase()]
......@@ -78,6 +59,26 @@ export class PickupViewPanelControl extends MainControl {
this.emit("onCtrlEvent", { tag: this.props.name, action: 'selectionChange', data: [] });
}
/**
* 处理视图加载完成事件
*
* @private
* @param {IParam[]} [data=[]]
* @memberof PickupViewPanelControl
*/
private handleViewLoad(data: IParam[] = []) {
const { items } = toRefs(this.state);
const { appDeKeyFieldName, appDeMajorFieldName } = this.state;
const _items: IParam[] = [];
data.forEach((item: any) => {
_items.push({
srfkey: item.srfkey ? item.srfkey : item[appDeKeyFieldName.toLowerCase()],
srfmajortext: item.srfmajortext ? item.srfmajortext : item[appDeMajorFieldName.toLowerCase()]
});
});
items.value = [..._items];
}
/**
* @description 安装部件所有功能模块的方法
* @return {*}
......@@ -87,7 +88,6 @@ export class PickupViewPanelControl extends MainControl {
const superParams = super.moduleInstall();
return {
...superParams,
load:this.useLoad.bind(this),
onViewEvent: this.onViewEvent.bind(this)
};
}
......
export const viewState = {
// 实际选中数据
selections: [],
selectedData: [],
// 右侧面板选中数据
rightPanelSelections: [],
{{> @macro/front-end/views/view-base-config.hbs}}
......
......@@ -30,7 +30,7 @@ const emit = defineEmits<ViewEmit>();
// 安装功能模块,提供状态和能力方法
const mpickupView = new MPickupView(viewState, props, emit).moduleInstall();
const { state, onCancel, onConfirm, onCtrlEvent, onMoveRight, onMoveLeft, onAllMoveRight, onAllMoveLeft, onRightPanelClick } = mpickupView;
const { state, pickupViewPanel, onCancel, onConfirm, onCtrlEvent, onMoveRight, onMoveLeft, onAllMoveRight, onAllMoveLeft, onRightPanelClick } = mpickupView;
</script>
<template>
......@@ -55,6 +55,7 @@ const { state, onCancel, onConfirm, onCtrlEvent, onMoveRight, onMoveLeft, onAllM
{{#eq controlType "PICKUPVIEWPANEL"}}
<{{codeName}}PickupViewPanel
name="{{name}}"
ref="pickupViewPanel"
:context="state.context"
:rowEditState="state.rowEditState"
:rowActiveMode="state.gridRowActiveMode"
......@@ -79,7 +80,11 @@ const { state, onCancel, onConfirm, onCtrlEvent, onMoveRight, onMoveLeft, onAllM
</a-space>
</a-col>
<a-col :span="5" class="split__right">
<div v-for="(item, index) in state.selections" :key="index" class="selection-item" @click="(event) => onRightPanelClick(item, event)">
<div
v-for="(item, index) in state.selections"
:key="index"
:class="['picker-item', state.rightPanelSelections.includes((panel) => panel.srfkey === item.srfkey)]"
@click="(event) => onRightPanelClick(item, event)">
<span class="text">\{{item.srfmajortext}}</span>
</div>
</a-col>
......
......@@ -40,7 +40,7 @@ const emit = defineEmits <CtrlEmit> ();
const { name, state, onViewEvent } = new PickupViewPanelControl(ctrlState, props, emit).moduleInstall();
// 暴露内部状态及能力
defineExpose({ name, state});
defineExpose({ name, state });
</script>
<template>
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册