framework7
Version:
Full featured mobile HTML framework for building iOS & Android apps
173 lines (158 loc) • 6.21 kB
JavaScript
import $ from 'dom7';
export default {
render(self) {
const { sliderLabel, sliderValue, sliderValueEditable, redLabelText, greenLabelText, blueLabelText } = self.params;
return `
<div class="color-picker-module color-picker-module-rgb-sliders">
<div class="color-picker-slider-wrap">
${sliderLabel ? `
<div class="color-picker-slider-label">${redLabelText}</div>
` : ''}
<div class="range-slider color-picker-slider color-picker-slider-red"></div>
${sliderValue ? `
<div class="color-picker-slider-value">
${sliderValueEditable ? `
<input type="number" step="1" min="0" max="255" class="color-picker-value-red" data-color-index="0">
` : `
<span class="color-picker-value-red"></span>
`}
</div>
` : ''}
</div>
<div class="color-picker-slider-wrap">
${sliderLabel ? `
<div class="color-picker-slider-label">${greenLabelText}</div>
` : ''}
<div class="range-slider color-picker-slider color-picker-slider-green"></div>
${sliderValue ? `
<div class="color-picker-slider-value">
${sliderValueEditable ? `
<input type="number" step="1" min="0" max="255" class="color-picker-value-green" data-color-index="1">
` : `
<span class="color-picker-value-green"></span>
`}
</div>
` : ''}
</div>
<div class="color-picker-slider-wrap">
${sliderLabel ? `
<div class="color-picker-slider-label">${blueLabelText}</div>
` : ''}
<div class="range-slider color-picker-slider color-picker-slider-blue"></div>
${sliderValue ? `
<div class="color-picker-slider-value">
${sliderValueEditable ? `
<input type="number" step="1" min="0" max="255" class="color-picker-value-blue" data-color-index="2">
` : `
<span class="color-picker-value-blue"></span>
`}
</div>
` : ''}
</div>
</div>
`;
},
init(self) {
self.redRangeSlider = self.app.range.create({
el: self.$el.find('.color-picker-slider-red'),
min: 0,
max: 255,
step: 1,
value: 0,
on: {
change(range, value) {
self.setValue({ rgb: [value, self.value.rgb[1], self.value.rgb[2]] });
},
},
});
self.greenRangeSlider = self.app.range.create({
el: self.$el.find('.color-picker-slider-green'),
min: 0,
max: 255,
step: 1,
value: 0,
on: {
change(range, value) {
self.setValue({ rgb: [self.value.rgb[0], value, self.value.rgb[2]] });
},
},
});
self.blueRangeSlider = self.app.range.create({
el: self.$el.find('.color-picker-slider-blue'),
min: 0,
max: 255,
step: 1,
value: 0,
on: {
change(range, value) {
self.setValue({ rgb: [self.value.rgb[0], self.value.rgb[1], value] });
},
},
});
function handleInputChange(e) {
const rgb = [...self.value.rgb];
const index = parseInt($(e.target).attr('data-color-index'), 10);
let value = parseInt(e.target.value, 10);
if (Number.isNaN(value)) {
e.target.value = rgb[index];
return;
}
value = Math.max(0, Math.min(255, value));
rgb[index] = value;
self.setValue({ rgb });
}
self.$el.on('change', '.color-picker-module-rgb-sliders input', handleInputChange);
self.destroyRgbSlidersEvents = function destroyRgbSlidersEvents() {
self.$el.off('change', '.color-picker-module-rgb-sliders input', handleInputChange);
};
},
update(self) {
const {
app,
value,
redRangeSlider,
greenRangeSlider,
blueRangeSlider,
} = self;
const { sliderValue, sliderValueEditable } = self.params;
const { rgb } = value;
redRangeSlider.value = rgb[0];
greenRangeSlider.value = rgb[1];
blueRangeSlider.value = rgb[2];
redRangeSlider.layout();
greenRangeSlider.layout();
blueRangeSlider.layout();
redRangeSlider.$el[0].style.setProperty('--f7-range-knob-color', `rgb(${rgb[0]}, ${rgb[1]}, ${rgb[2]})`);
greenRangeSlider.$el[0].style.setProperty('--f7-range-knob-color', `rgb(${rgb[0]}, ${rgb[1]}, ${rgb[2]})`);
blueRangeSlider.$el[0].style.setProperty('--f7-range-knob-color', `rgb(${rgb[0]}, ${rgb[1]}, ${rgb[2]})`);
const direction = app.rtl ? 'to left' : 'to right';
redRangeSlider.$el.find('.range-bar').css('background-image', `linear-gradient(${direction}, rgb(0, ${rgb[1]}, ${rgb[2]}), rgb(255, ${rgb[1]}, ${rgb[2]}))`);
greenRangeSlider.$el.find('.range-bar').css('background-image', `linear-gradient(${direction}, rgb(${rgb[0]}, 0, ${rgb[2]}), rgb(${rgb[0]}, 255, ${rgb[2]}))`);
blueRangeSlider.$el.find('.range-bar').css('background-image', `linear-gradient(${direction}, rgb(${rgb[0]}, ${rgb[1]}, 0), rgb(${rgb[0]}, ${rgb[1]}, 255))`);
if (sliderValue && sliderValueEditable) {
self.$el.find('input.color-picker-value-red').val(rgb[0]);
self.$el.find('input.color-picker-value-green').val(rgb[1]);
self.$el.find('input.color-picker-value-blue').val(rgb[2]);
} else if (sliderValue) {
self.$el.find('span.color-picker-value-red').text(rgb[0]);
self.$el.find('span.color-picker-value-green').text(rgb[1]);
self.$el.find('span.color-picker-value-blue').text(rgb[2]);
}
},
destroy(self) {
if (self.redRangeSlider && self.redRangeSlider.destroy) {
self.redRangeSlider.destroy();
}
if (self.greenRangeSlider && self.greenRangeSlider.destroy) {
self.greenRangeSlider.destroy();
}
if (self.blueRangeSlider && self.blueRangeSlider.destroy) {
self.blueRangeSlider.destroy();
}
delete self.redRangeSlider;
delete self.greenRangeSlider;
delete self.blueRangeSlider;
if (self.destroyRgbSlidersEvents) self.destroyRgbSlidersEvents();
delete self.destroyRgbSlidersEvents;
},
};