85 lines
1.7 KiB
Vue
85 lines
1.7 KiB
Vue
<script>
|
|
import Align from '../index'
|
|
import BaseMixin from '../../_util/BaseMixin'
|
|
|
|
export default {
|
|
mixins: [BaseMixin],
|
|
data () {
|
|
return {
|
|
monitor: true,
|
|
align: {
|
|
points: ['tl', 'tc'],
|
|
},
|
|
}
|
|
},
|
|
methods: {
|
|
getTarget () {
|
|
const ref = this.$refs.container
|
|
if (!ref) {
|
|
// parent ref not attached
|
|
return document.getElementById('container')
|
|
}
|
|
return ref
|
|
},
|
|
|
|
toggleMonitor () {
|
|
this.setState({
|
|
monitor: !this.$data.monitor,
|
|
})
|
|
},
|
|
|
|
forceAlign () {
|
|
this.$refs.align.forceAlign()
|
|
},
|
|
},
|
|
|
|
render () {
|
|
return (
|
|
<div
|
|
style={{
|
|
margin: '50px',
|
|
}}
|
|
>
|
|
<p>
|
|
<button onClick={this.forceAlign}>Force align</button>
|
|
|
|
<label>
|
|
<input type='checkbox' checked={this.monitor} onInput={this.toggleMonitor} />
|
|
|
|
Monitor window resize
|
|
</label>
|
|
</p>
|
|
<div
|
|
ref='container'
|
|
id='container'
|
|
style={{
|
|
width: '80%',
|
|
height: '500px',
|
|
border: '1px solid red',
|
|
}}
|
|
>
|
|
<Align
|
|
ref='align'
|
|
target={this.getTarget}
|
|
monitorWindowResize={this.$data.monitor}
|
|
align={this.$data.align}
|
|
>
|
|
<div
|
|
style={{
|
|
position: 'absolute',
|
|
width: '50px',
|
|
height: '50px',
|
|
background: 'yellow',
|
|
}}
|
|
>
|
|
source
|
|
</div>
|
|
</Align>
|
|
</div>
|
|
</div>
|
|
)
|
|
},
|
|
}
|
|
|
|
</script>
|