UNPKG

framework7

Version:

Full featured mobile HTML framework for building iOS & Android apps

198 lines (184 loc) 7.33 kB
"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;