import Mixins from '../utils/mixins';
import Utils from '../utils/utils';
/* phenome-dts-imports
import { Popover as PopoverNamespace } from 'framework7/components/popover/popover';
*/
/* phenome-dts-instance
f7Popover: PopoverNamespace.Popover
*/
export default {
name: 'f7-popover',
props: {
id: [String, Number],
className: String, // phenome-react-line
style: Object, // phenome-react-line
opened: Boolean,
target: [String, Object],
closeByBackdropClick: Boolean,
closeByOutsideClick: Boolean,
...Mixins.colorProps,
},
render() {
const self = this;
const props = self.props;
const {
className,
id,
style,
} = props;
const classes = Utils.classNames(
className,
'popover',
Mixins.colorClasses(props),
);
return (
);
},
watch: {
'props.opened': function watchOpened(opened) {
const self = this;
if (!self.f7Popover) return;
if (opened) {
self.f7Popover.open();
} else {
self.f7Popover.close();
}
},
},
componentDidMount() {
const self = this;
const el = self.refs.el;
if (!el) return;
self.onOpenBound = self.onOpen.bind(self);
self.onOpenedBound = self.onOpened.bind(self);
self.onCloseBound = self.onClose.bind(self);
self.onClosedBound = self.onClosed.bind(self);
el.addEventListener('popover:open', self.onOpenBound);
el.addEventListener('popover:opened', self.onOpenedBound);
el.addEventListener('popover:close', self.onCloseBound);
el.addEventListener('popover:closed', self.onClosedBound);
const props = self.props;
const {
target,
opened,
closeByBackdropClick,
closeByOutsideClick,
} = props;
const popoverParams = { el };
if (target) popoverParams.targetEl = target;
if (process.env.COMPILER === 'vue') {
if (typeof self.$options.propsData.closeByBackdropClick !== 'undefined') popoverParams.closeByBackdropClick = closeByBackdropClick;
if (typeof self.$options.propsData.closeByOutsideClick !== 'undefined') popoverParams.closeByOutsideClick = closeByOutsideClick;
}
if (process.env.COMPILER === 'react') {
if ('closeByBackdropClick' in props) popoverParams.closeByBackdropClick = closeByBackdropClick;
if ('closeByOutsideClick' in props) popoverParams.closeByOutsideClick = closeByOutsideClick;
}
self.$f7ready(() => {
self.f7Popover = self.$f7.popover.create(popoverParams);
if (opened && target) {
self.f7Popover.open(target, false);
}
});
},
componentWillUnmount() {
const self = this;
if (self.f7Popover) self.f7Popover.destroy();
const el = self.refs.el;
if (!el) return;
el.removeEventListener('popover:open', self.onOpenBound);
el.removeEventListener('popover:opened', self.onOpenedBound);
el.removeEventListener('popover:close', self.onCloseBound);
el.removeEventListener('popover:closed', self.onClosedBound);
},
methods: {
onOpen(event) {
this.dispatchEvent('popover:open popoverOpen', event);
},
onOpened(event) {
this.dispatchEvent('popover:opened popoverOpened', event);
},
onClose(event) {
this.dispatchEvent('popover:close popoverClose', event);
},
onClosed(event) {
this.dispatchEvent('popover:closed popoverClosed', event);
},
open(target, animate) {
const self = this;
if (!self.$f7) return undefined;
return self.$f7.popover.open(self.refs.el, target, animate);
},
close(animate) {
const self = this;
if (!self.$f7) return undefined;
return self.$f7.sheet.close(self.refs.el, animate);
},
},
};