framework7
Version:
Full featured mobile HTML framework for building iOS & Android apps
75 lines • 1.87 kB
JavaScript
import $ from '../../shared/dom7.js';
import { extend } from '../../shared/utils.js';
import Range from './range-class.js';
import ConstructorMethods from '../../shared/constructor-methods.js';
export default {
name: 'range',
create() {
const app = this;
app.range = extend(ConstructorMethods({
defaultSelector: '.range-slider',
constructor: Range,
app,
domProp: 'f7Range'
}), {
getValue(el) {
if (el === void 0) {
el = '.range-slider';
}
const range = app.range.get(el);
if (range) return range.getValue();
return undefined;
},
setValue(el, value) {
if (el === void 0) {
el = '.range-slider';
}
const range = app.range.get(el);
if (range) return range.setValue(value);
return undefined;
}
});
},
static: {
Range
},
on: {
tabMounted(tabEl) {
const app = this;
$(tabEl).find('.range-slider-init').each(rangeEl => new Range(app, {
el: rangeEl
}));
},
tabBeforeRemove(tabEl) {
$(tabEl).find('.range-slider-init').each(rangeEl => {
if (rangeEl.f7Range) rangeEl.f7Range.destroy();
});
},
pageInit(page) {
const app = this;
page.$el.find('.range-slider-init').each(rangeEl => new Range(app, {
el: rangeEl
}));
},
pageBeforeRemove(page) {
page.$el.find('.range-slider-init').each(rangeEl => {
if (rangeEl.f7Range) rangeEl.f7Range.destroy();
});
}
},
vnode: {
'range-slider-init': {
insert(vnode) {
const rangeEl = vnode.elm;
const app = this;
app.range.create({
el: rangeEl
});
},
destroy(vnode) {
const rangeEl = vnode.elm;
if (rangeEl.f7Range) rangeEl.f7Range.destroy();
}
}
}
};