framework7
Version:
Full featured mobile HTML framework for building iOS & Android apps
198 lines (184 loc) • 7.33 kB
JavaScript
"use strict";
exports.__esModule = true;
exports.default = void 0;
var _dom = _interopRequireDefault(require("../../../shared/dom7"));
var _$jsx = _interopRequireDefault(require("../../../shared/$jsx"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
/** @jsx $jsx */
var _default = {
render: function render(self) {
var _self$params = self.params,
sliderLabel = _self$params.sliderLabel,
sliderValue = _self$params.sliderValue,
sliderValueEditable = _self$params.sliderValueEditable,
redLabelText = _self$params.redLabelText,
greenLabelText = _self$params.greenLabelText,
blueLabelText = _self$params.blueLabelText;
return (0, _$jsx.default)("div", {
class: "color-picker-module color-picker-module-rgb-sliders"
}, (0, _$jsx.default)("div", {
class: "color-picker-slider-wrap"
}, sliderLabel && (0, _$jsx.default)("div", {
class: "color-picker-slider-label"
}, redLabelText), (0, _$jsx.default)("div", {
class: "range-slider color-picker-slider color-picker-slider-red"
}), sliderValue && (0, _$jsx.default)("div", {
class: "color-picker-slider-value"
}, sliderValueEditable ? (0, _$jsx.default)("input", {
type: "number",
step: "1",
min: "0",
max: "255",
class: "color-picker-value-red",
"data-color-index": "0"
}) : (0, _$jsx.default)("span", {
class: "color-picker-value-red"
}))), (0, _$jsx.default)("div", {
class: "color-picker-slider-wrap"
}, sliderLabel && (0, _$jsx.default)("div", {
class: "color-picker-slider-label"
}, greenLabelText), (0, _$jsx.default)("div", {
class: "range-slider color-picker-slider color-picker-slider-green"
}), sliderValue && (0, _$jsx.default)("div", {
class: "color-picker-slider-value"
}, sliderValueEditable ? (0, _$jsx.default)("input", {
type: "number",
step: "1",
min: "0",
max: "255",
class: "color-picker-value-green",
"data-color-index": "1"
}) : (0, _$jsx.default)("span", {
class: "color-picker-value-green"
}))), (0, _$jsx.default)("div", {
class: "color-picker-slider-wrap"
}, sliderLabel && (0, _$jsx.default)("div", {
class: "color-picker-slider-label"
}, blueLabelText), (0, _$jsx.default)("div", {
class: "range-slider color-picker-slider color-picker-slider-blue"
}), sliderValue && (0, _$jsx.default)("div", {
class: "color-picker-slider-value"
}, sliderValueEditable ? (0, _$jsx.default)("input", {
type: "number",
step: "1",
min: "0",
max: "255",
class: "color-picker-value-blue",
"data-color-index": "2"
}) : (0, _$jsx.default)("span", {
class: "color-picker-value-blue"
}))));
},
init: function 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: function 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: function 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: function change(range, value) {
self.setValue({
rgb: [self.value.rgb[0], self.value.rgb[1], value]
});
}
}
});
function handleInputChange(e) {
var rgb = [].concat(self.value.rgb);
var index = parseInt((0, _dom.default)(e.target).attr('data-color-index'), 10);
var 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: 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: function update(self) {
var app = self.app,
value = self.value,
redRangeSlider = self.redRangeSlider,
greenRangeSlider = self.greenRangeSlider,
blueRangeSlider = self.blueRangeSlider;
var _self$params2 = self.params,
sliderValue = _self$params2.sliderValue,
sliderValueEditable = _self$params2.sliderValueEditable;
var rgb = value.rgb;
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] + ")");
var 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: function 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;
}
};
exports.default = _default;