ant-design-vue/components/vc-trigger/demo/simple.vue

281 lines
6.2 KiB
Vue
Raw Normal View History

2017-12-26 11:04:28 +00:00
<script>
2019-01-12 03:33:27 +00:00
import Trigger from '../index';
import '../assets/index.less';
import { Input, Button } from 'ant-design-vue';
2017-12-26 11:04:28 +00:00
function getPopupAlign (state) {
return {
offset: [state.offsetX, state.offsetY],
overflow: {
adjustX: 1,
adjustY: 1,
},
2019-01-12 03:33:27 +00:00
};
2017-12-26 11:04:28 +00:00
}
const builtinPlacements = {
left: {
points: ['cr', 'cl'],
},
right: {
points: ['cl', 'cr'],
},
top: {
points: ['bc', 'tc'],
},
bottom: {
points: ['tc', 'bc'],
},
topLeft: {
points: ['bl', 'tl'],
},
topRight: {
points: ['br', 'tr'],
},
bottomRight: {
points: ['tr', 'br'],
},
bottomLeft: {
points: ['tl', 'bl'],
},
2019-01-12 03:33:27 +00:00
};
2017-12-26 11:04:28 +00:00
function preventDefault (e) {
2019-01-12 03:33:27 +00:00
e.preventDefault();
2017-12-26 11:04:28 +00:00
}
function getPopupContainer (trigger) {
2019-01-12 03:33:27 +00:00
return trigger.parentNode;
2017-12-26 11:04:28 +00:00
}
export default {
data () {
return {
mask: false,
maskClosable: false,
placement: 'right',
trigger: {
hover: 1,
},
offsetX: undefined,
offsetY: undefined,
2018-02-03 11:48:03 +00:00
transitionName: 'rc-trigger-popup-zoom',
2017-12-26 11:04:28 +00:00
destroyPopupOnHide: false,
2018-05-30 06:11:36 +00:00
destroyed: false,
2019-01-12 03:33:27 +00:00
};
2017-12-26 11:04:28 +00:00
},
methods: {
setState (state, callback) {
2019-01-12 03:33:27 +00:00
Object.assign(this.$data, state);
2017-12-26 11:04:28 +00:00
this.$nextTick(() => {
2019-01-12 03:33:27 +00:00
callback && callback();
});
2017-12-26 11:04:28 +00:00
},
onPlacementChange (e) {
this.setState({
placement: e.target.value,
2019-01-12 03:33:27 +00:00
});
2017-12-26 11:04:28 +00:00
},
onTransitionChange (e) {
this.setState({
transitionName: e.target.checked ? e.target.value : '',
2019-01-12 03:33:27 +00:00
});
2017-12-26 11:04:28 +00:00
},
onTriggerChange (e) {
2019-01-12 03:33:27 +00:00
const trigger = Object.assign({}, this.$data.trigger);
2017-12-26 11:04:28 +00:00
if (e.target.checked) {
2019-01-12 03:33:27 +00:00
trigger[e.target.value] = 1;
2017-12-26 11:04:28 +00:00
} else {
2019-01-12 03:33:27 +00:00
delete trigger[e.target.value];
2017-12-26 11:04:28 +00:00
}
this.setState({
trigger,
2019-01-12 03:33:27 +00:00
});
2017-12-26 11:04:28 +00:00
},
onOffsetXChange (e) {
2019-01-12 03:33:27 +00:00
const targetValue = e.target.value;
2017-12-26 11:04:28 +00:00
this.setState({
offsetX: targetValue || undefined,
2019-01-12 03:33:27 +00:00
});
2017-12-26 11:04:28 +00:00
},
onOffsetYChange (e) {
2019-01-12 03:33:27 +00:00
const targetValue = e.target.value;
2017-12-26 11:04:28 +00:00
this.setState({
offsetY: targetValue || undefined,
2019-01-12 03:33:27 +00:00
});
2017-12-26 11:04:28 +00:00
},
onVisibleChange (visible) {
2019-01-12 03:33:27 +00:00
console.log('tooltip', visible);
2017-12-26 11:04:28 +00:00
},
onMask (e) {
this.setState({
mask: e.target.checked,
2019-01-12 03:33:27 +00:00
});
2017-12-26 11:04:28 +00:00
},
onMaskClosable (e) {
this.setState({
maskClosable: e.target.checked,
2019-01-12 03:33:27 +00:00
});
2017-12-26 11:04:28 +00:00
},
destroy () {
this.setState({
destroyed: true,
2019-01-12 03:33:27 +00:00
});
2017-12-26 11:04:28 +00:00
},
handleDestroyPopupOnHide (e) {
this.setState({
destroyPopupOnHide: e.target.checked,
2019-01-12 03:33:27 +00:00
});
2017-12-26 11:04:28 +00:00
},
},
render () {
2019-01-12 03:33:27 +00:00
const state = this.$data;
const trigger = state.trigger;
2017-12-26 11:04:28 +00:00
if (state.destroyed) {
2019-01-12 03:33:27 +00:00
return null;
2017-12-26 11:04:28 +00:00
}
return (<div >
<div style={{ margin: '10px 20px' }}>
<label>
placement:
<select value={state.placement} onChange={this.onPlacementChange}>
<option>right</option>
<option>left</option>
<option>top</option>
<option>bottom</option>
<option>topLeft</option>
<option>topRight</option>
<option>bottomRight</option>
<option>bottomLeft</option>
</select>
</label>
&nbsp;&nbsp;&nbsp;&nbsp;
<label>
2018-02-03 11:48:03 +00:00
<a-checkbox
2017-12-26 11:04:28 +00:00
value='rc-trigger-popup-zoom'
onChange={this.onTransitionChange}
checked={state.transitionName === 'rc-trigger-popup-zoom'}
/>
transitionName
</label>
&nbsp;&nbsp;&nbsp;&nbsp;
trigger:
<label>
2018-02-03 11:48:03 +00:00
<a-checkbox
2017-12-26 11:04:28 +00:00
value='hover'
checked={!!trigger.hover}
onChange={this.onTriggerChange}
/>
hover
</label>
<label>
2018-02-03 11:48:03 +00:00
<a-checkbox
2017-12-26 11:04:28 +00:00
value='focus'
checked={!!trigger.focus}
onChange={this.onTriggerChange}
/>
focus
</label>
<label>
2018-02-03 11:48:03 +00:00
<a-checkbox
2017-12-26 11:04:28 +00:00
value='click'
checked={!!trigger.click}
onChange={this.onTriggerChange}
/>
click
</label>
<label>
2018-02-03 11:48:03 +00:00
<a-checkbox
2017-12-26 11:04:28 +00:00
value='contextMenu'
checked={!!trigger.contextMenu}
onChange={this.onTriggerChange}
/>
contextMenu
</label>
&nbsp;&nbsp;&nbsp;&nbsp;
<label>
2018-02-03 11:48:03 +00:00
<a-checkbox
2017-12-26 11:04:28 +00:00
checked={!!state.destroyPopupOnHide}
onChange={this.handleDestroyPopupOnHide}
/>
destroyPopupOnHide
</label>
&nbsp;&nbsp;&nbsp;&nbsp;
<label>
2018-02-03 11:48:03 +00:00
<a-checkbox
2017-12-26 11:04:28 +00:00
checked={!!state.mask}
onChange={this.onMask}
/>
mask
</label>
&nbsp;&nbsp;&nbsp;&nbsp;
<label>
2018-02-03 11:48:03 +00:00
<a-checkbox
2017-12-26 11:04:28 +00:00
checked={!!state.maskClosable}
onChange={this.onMaskClosable}
/>
maskClosable
</label>
<br />
<label>
offsetX:
<Input
type='text'
onChange={this.onOffsetXChange}
style={{ width: '50px' }}
/>
</label>
&nbsp;&nbsp;&nbsp;&nbsp;
<label>
offsetY:
<Input
type='text'
onChange={this.onOffsetYChange}
style={{ width: '50px' }}
/>
</label>
&nbsp;&nbsp;&nbsp;&nbsp;
<Button onClick={this.destroy}>destroy</Button>
</div>
<div style={{ margin: '100px', position: 'relative' }}>
<Trigger
getPopupContainer={undefined && getPopupContainer}
popupAlign={getPopupAlign(state)}
popupPlacement={state.placement}
destroyPopupOnHide={state.destroyPopupOnHide}
// zIndex={40}
mask={state.mask}
maskClosable={state.maskClosable}
// maskAnimation="fade"
// mouseEnterDelay={0.1}
// mouseLeaveDelay={0.1}
action={Object.keys(state.trigger)}
builtinPlacements={builtinPlacements}
2018-01-04 11:06:54 +00:00
popupAnimation={state.transitionName}
2017-12-26 11:04:28 +00:00
>
<div slot='popup' style={{ border: '1px solid red', padding: '10px', background: 'white' }}>
i am a popup
</div>
2018-02-03 11:48:03 +00:00
<a-button onClick={preventDefault}>trigger</a-button>
2017-12-26 11:04:28 +00:00
</Trigger>
</div>
2019-01-12 03:33:27 +00:00
</div>);
2017-12-26 11:04:28 +00:00
},
2019-01-12 03:33:27 +00:00
};
2017-12-26 11:04:28 +00:00
</script>