framework7
Version:
Full featured mobile HTML framework for building iOS & Android apps
183 lines • 5.57 kB
JavaScript
import $ from '../../../shared/dom7.js';
/** @jsx $jsx */
import $jsx from '../../../shared/$jsx.js';
export default {
render(self) {
const {
barLabel,
barValue,
barValueEditable,
redLabelText,
greenLabelText,
blueLabelText
} = self.params;
return $jsx("div", {
class: "color-picker-module color-picker-module-rgb-bars"
}, $jsx("div", {
class: "color-picker-bar-wrap"
}, barLabel && $jsx("div", {
class: "color-picker-bar-label"
}, redLabelText), $jsx("div", {
class: "range-slider color-picker-bar color-picker-bar-red"
}), barValue && $jsx("div", {
class: "color-picker-bar-value"
}, barValueEditable ? $jsx("input", {
type: "number",
step: "1",
min: "0",
max: "255",
class: "color-picker-value-bar-red",
"data-color-index": "0"
}) : $jsx("span", {
class: "color-picker-value-bar-red"
}))), $jsx("div", {
class: "color-picker-bar-wrap"
}, barLabel && $jsx("div", {
class: "color-picker-bar-label"
}, greenLabelText), $jsx("div", {
class: "range-slider color-picker-bar color-picker-bar-green"
}), barValue && $jsx("div", {
class: "color-picker-bar-value"
}, barValueEditable ? $jsx("input", {
type: "number",
step: "1",
min: "0",
max: "255",
class: "color-picker-value-bar-green",
"data-color-index": "1"
}) : $jsx("span", {
class: "color-picker-value-bar-green"
}))), $jsx("div", {
class: "color-picker-bar-wrap"
}, barLabel && $jsx("div", {
class: "color-picker-bar-label"
}, blueLabelText), $jsx("div", {
class: "range-slider color-picker-bar color-picker-bar-blue"
}), barValue && $jsx("div", {
class: "color-picker-bar-value"
}, barValueEditable ? $jsx("input", {
type: "number",
step: "1",
min: "0",
max: "255",
class: "color-picker-value-bar-blue",
"data-color-index": "2"
}) : $jsx("span", {
class: "color-picker-value-bar-blue"
}))));
},
init(self) {
self.redBar = self.app.range.create({
el: self.$el.find('.color-picker-bar-red'),
min: 0,
max: 255,
step: 1,
value: 0,
vertical: true,
on: {
change(range, value) {
self.setValue({
rgb: [value, self.value.rgb[1], self.value.rgb[2]]
});
}
}
});
self.greenBar = self.app.range.create({
el: self.$el.find('.color-picker-bar-green'),
min: 0,
max: 255,
step: 1,
value: 0,
vertical: true,
on: {
change(range, value) {
self.setValue({
rgb: [self.value.rgb[0], value, self.value.rgb[2]]
});
}
}
});
self.blueBar = self.app.range.create({
el: self.$el.find('.color-picker-bar-blue'),
min: 0,
max: 255,
step: 1,
value: 0,
vertical: true,
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-bars input', handleInputChange);
self.destroyRgbBarsEvents = function destroyRgbBarsEvents() {
self.$el.off('change', '.color-picker-module-rgb-bars input', handleInputChange);
};
},
update(self) {
const {
value,
redBar,
greenBar,
blueBar
} = self;
const {
barValue,
barValueEditable
} = self.params;
const {
rgb
} = value;
redBar.value = rgb[0];
greenBar.value = rgb[1];
blueBar.value = rgb[2];
redBar.layout();
greenBar.layout();
blueBar.layout();
redBar.$el.find('.range-bar').css('background-image', `linear-gradient(to top, rgb(0, ${rgb[1]}, ${rgb[2]}), rgb(255, ${rgb[1]}, ${rgb[2]}))`);
greenBar.$el.find('.range-bar').css('background-image', `linear-gradient(to top, rgb(${rgb[0]}, 0, ${rgb[2]}), rgb(${rgb[0]}, 255, ${rgb[2]}))`);
blueBar.$el.find('.range-bar').css('background-image', `linear-gradient(to top, rgb(${rgb[0]}, ${rgb[1]}, 0), rgb(${rgb[0]}, ${rgb[1]}, 255))`);
if (barValue && barValueEditable) {
self.$el.find('input.color-picker-value-bar-red').val(rgb[0]);
self.$el.find('input.color-picker-value-bar-green').val(rgb[1]);
self.$el.find('input.color-picker-value-bar-blue').val(rgb[2]);
} else if (barValue) {
self.$el.find('span.color-picker-value-bar-red').text(rgb[0]);
self.$el.find('span.color-picker-value-bar-green').text(rgb[1]);
self.$el.find('span.color-picker-value-bar-blue').text(rgb[2]);
}
},
destroy(self) {
if (self.redBar && self.redBar.destroy) {
self.redBar.destroy();
}
if (self.greenBar && self.greenBar.destroy) {
self.greenBar.destroy();
}
if (self.blueBar && self.blueBar.destroy) {
self.blueBar.destroy();
}
delete self.redBar;
delete self.greenBar;
delete self.blueBar;
if (self.destroyRgbBarsEvents) self.destroyRgbBarsEvents();
delete self.destroyRgbBarsEvents;
}
};