You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
1.8 KiB
TypeScript
61 lines
1.8 KiB
TypeScript
2 years ago
|
import { assign } from 'lodash';
|
||
|
import React from 'react';
|
||
|
import ReactDOM from 'react-dom/client';
|
||
|
import DOMAttachedObject from 'vj/components/DOMAttachedObject';
|
||
|
import AutoComplete, { AutoCompleteOptions } from '.';
|
||
|
import CustomSelectAutoCompleteFC from './components/CustomSelectAutoComplete';
|
||
|
|
||
|
interface CustomSelectOptions {
|
||
|
data: any[]
|
||
|
}
|
||
|
|
||
|
const Component = React.forwardRef<any, any>((props, ref) => {
|
||
|
const [value, setValue] = React.useState(props.value);
|
||
|
return (
|
||
|
<CustomSelectAutoCompleteFC
|
||
|
ref={ref as any}
|
||
|
height="auto"
|
||
|
selectedKeys={value.split(',').map((i) => i.trim()).filter((i) => i)}
|
||
|
onChange={(v) => {
|
||
|
setValue(v);
|
||
|
props.onChange(v);
|
||
|
}}
|
||
|
data={props.data}
|
||
|
multi={props.multi}
|
||
|
/>
|
||
|
);
|
||
|
});
|
||
|
|
||
|
export default class CustomSelectAutoComplete<Multi extends boolean> extends AutoComplete {
|
||
|
static DOMAttachKey = 'ucwCustomSelectAutoCompleteInstance';
|
||
|
options: CustomSelectOptions & AutoCompleteOptions;
|
||
|
|
||
|
constructor($dom, options: CustomSelectOptions & AutoCompleteOptions<Multi>) {
|
||
|
super($dom, {
|
||
|
classes: 'custom-select',
|
||
|
...options,
|
||
|
});
|
||
|
}
|
||
|
|
||
|
value(): Multi extends true ? number[] : string {
|
||
|
if (this.options.multi) return this.ref?.getSelectedItemKeys().map((i) => +i) ?? this.$dom.val();
|
||
|
return this.ref?.getSelectedItems()[0] ?? null;
|
||
|
}
|
||
|
|
||
|
attach() {
|
||
|
const value = this.$dom.val();
|
||
|
ReactDOM.createRoot(this.container).render(
|
||
|
<Component
|
||
|
ref={(ref) => { this.ref = ref; }}
|
||
|
data={this.options.data}
|
||
|
value={value}
|
||
|
multi={this.options.multi}
|
||
|
onChange={this.onChange}
|
||
|
/>,
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
assign(CustomSelectAutoComplete, DOMAttachedObject);
|
||
|
window.Hydro.components.CustomSelectAutoComplete = CustomSelectAutoComplete;
|