Grunt - BugFixes
1
.gitignore
vendored
@ -1,3 +1,4 @@
|
|||||||
*.swp
|
*.swp
|
||||||
*.swo
|
*.swo
|
||||||
*~
|
*~
|
||||||
|
node_modules
|
||||||
|
127
Gruntfile.js
Normal file
@ -0,0 +1,127 @@
|
|||||||
|
var which;
|
||||||
|
module.exports = function(grunt) {
|
||||||
|
|
||||||
|
grunt.initConfig({
|
||||||
|
pkg: grunt.file.readJSON('package.json'),
|
||||||
|
uglify: {
|
||||||
|
main: {
|
||||||
|
files: [
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Shared/js/',
|
||||||
|
src: '**',
|
||||||
|
dest: 'build/mobile/js/',
|
||||||
|
filter: 'isFile'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Shared/js',
|
||||||
|
src: '**',
|
||||||
|
dest: 'build/web/js',
|
||||||
|
filter: 'isFile'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Mobile/js/',
|
||||||
|
src: '*',
|
||||||
|
dest: 'build/mobile/js',
|
||||||
|
filter: 'isFile'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Web/js/',
|
||||||
|
src: '*',
|
||||||
|
dest: 'build/web/js',
|
||||||
|
filter: 'isFile'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
less: {
|
||||||
|
production: {
|
||||||
|
files: {
|
||||||
|
'build/mobile/css/main.css': 'Shared/css/main.less',
|
||||||
|
'build/web/css/main.css': 'Shared/css/main.less'
|
||||||
|
},
|
||||||
|
compress: true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
copy: {
|
||||||
|
'main files': {
|
||||||
|
files: [
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Shared',
|
||||||
|
src: 'img',
|
||||||
|
dest: 'build/mobile'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Shared',
|
||||||
|
src: 'img',
|
||||||
|
dest: 'build/web'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Mobile',
|
||||||
|
src: ['index.html', 'manifest.webapp'],
|
||||||
|
dest: 'build/mobile'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Web',
|
||||||
|
src: ['index.html', 'manifest.webapp', 'cache.appcache'],
|
||||||
|
dest: 'build/web'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
'css assets': {
|
||||||
|
files: [
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Shared/css',
|
||||||
|
src: '*/**',
|
||||||
|
dest: 'build/mobile/css'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'Shared/css',
|
||||||
|
src: '*/**',
|
||||||
|
dest: 'build/web/css'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
watch: {
|
||||||
|
js: {
|
||||||
|
files: ['Shared/js/**', 'Mobile/js/**', 'Web/js/**'],
|
||||||
|
tasks: 'uglify',
|
||||||
|
options: {
|
||||||
|
spawn: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
less: {
|
||||||
|
files: 'Shared/css/**',
|
||||||
|
tasks: 'less',
|
||||||
|
options: {
|
||||||
|
spawn: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
copy: {
|
||||||
|
files: 'Shared/**',
|
||||||
|
tasks: 'copy',
|
||||||
|
options: {
|
||||||
|
spawn: false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-uglify');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-less');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-copy');
|
||||||
|
grunt.loadNpmTasks('grunt-contrib-watch');
|
||||||
|
grunt.registerTask('default', ['uglify','copy', 'less'])
|
||||||
|
|
||||||
|
}
|
@ -253,8 +253,9 @@
|
|||||||
<script src='js/libs/touch.js'></script>
|
<script src='js/libs/touch.js'></script>
|
||||||
<script src='js/libs/color-picker-touch.js'></script>
|
<script src='js/libs/color-picker-touch.js'></script>
|
||||||
<script src='js/functions.js'></script>
|
<script src='js/functions.js'></script>
|
||||||
<script src='js/main.js'></script>
|
<script src='js/shared.js'></script>
|
||||||
<script src='js/mobile.js'></script>
|
<script src='js/events.js'></script>
|
||||||
|
<script src='js/diff.js'></script>
|
||||||
|
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
|
103
Mobile/js/diff.js
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
$(document).ready(function() {
|
||||||
|
|
||||||
|
$('*').off('click mousemove mousedown mouseup mouseleave').on('click mousemove mousedown mouseup mouseleave', function(e) {
|
||||||
|
e.preventDefault;
|
||||||
|
return false;
|
||||||
|
})
|
||||||
|
|
||||||
|
$('a[href^="http"]').tap(function(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
var href = $(this).attr('href');
|
||||||
|
var view = new MozActivity({
|
||||||
|
name: 'view',
|
||||||
|
data: {
|
||||||
|
type: 'url',
|
||||||
|
url: href
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
$('a[href^="mailto"]').tap(function(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
var mail = /mailto:(.*)/.exec($(this).attr('href'))[1];
|
||||||
|
var mail = new MozActivity({
|
||||||
|
name: 'new',
|
||||||
|
data: {
|
||||||
|
type: 'mail',
|
||||||
|
url: mail
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
window.save = function() {
|
||||||
|
switch(save.background) {
|
||||||
|
case 'white': {
|
||||||
|
c.fillStyle = 'white';
|
||||||
|
c.globalCompositeOperation = 'destination-over';
|
||||||
|
c.fillRect(0, 0, width(), height());
|
||||||
|
c.fillStyle = settings.color;
|
||||||
|
c.globalCompositeOperation = settings.composite;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 'current color': {
|
||||||
|
c.fillStyle = settings.bg;
|
||||||
|
c.globalCompositeOperation = 'destination-over';
|
||||||
|
c.fillRect(0, 0, width(), height());
|
||||||
|
c.globalCompositeOperation = settings.composite;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var data = $c[0].toDataURL();
|
||||||
|
if( save.type == 'sketchy project' ) {
|
||||||
|
var list = JSON.parse(localStorage.getItem('projects'));
|
||||||
|
var index;
|
||||||
|
if( list && list.some(function(a, i) { if( a.name == save['file name'] ) {index = i; return true} return false }) ) {
|
||||||
|
if( confirm('A sketch with this name already exists. Do you want to overwrite ' + save['file name']) + '?' ) {
|
||||||
|
console.log(index);
|
||||||
|
list[index] = {
|
||||||
|
name: save['file name'],
|
||||||
|
data: data,
|
||||||
|
points: window.points,
|
||||||
|
settings: settings
|
||||||
|
}
|
||||||
|
localStorage.setItem('projects', JSON.stringify(list));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
list ? list.push({
|
||||||
|
name: save['file name'],
|
||||||
|
data: data,
|
||||||
|
points: window.points
|
||||||
|
}) : list = [{
|
||||||
|
name: save['file name'],
|
||||||
|
data: data,
|
||||||
|
points: window.points
|
||||||
|
}];
|
||||||
|
localStorage.setItem('projects', JSON.stringify(list));
|
||||||
|
} else {
|
||||||
|
window.open(data, '_blank').focus();
|
||||||
|
}
|
||||||
|
|
||||||
|
c.putImageData(window.points.history[window.points.history.last].data, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
window.load = function() {
|
||||||
|
var file = JSON.parse(localStorage.getItem('projects')).filter(function(a) { return a.name == load.file })[0];
|
||||||
|
var img = document.createElement('img');
|
||||||
|
img.src = file.data;
|
||||||
|
img.onload = function() {
|
||||||
|
c.clearRect(0, 0, width(), height());
|
||||||
|
c.drawImage(img, 0, 0);
|
||||||
|
window.points = file.points;
|
||||||
|
window.points.history = [{ data: c.createImageData($c.width(), $c.height()), points: []}, { data: c.getImageData(0, 0, width(), height()), points: file.points}];
|
||||||
|
$c.first().css('background', file.settings.bg);
|
||||||
|
window.settings.bg = file.settings.bg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if( localStorage.getItem('sawTips') != settings.version ) {
|
||||||
|
$('.tour').removeClass('hidden');
|
||||||
|
localStorage.setItem('sawTips', settings.version);
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
@ -1,239 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
/*** ESSENTIALS ***/
|
|
||||||
|
|
||||||
function sizeAndPos() {
|
|
||||||
|
|
||||||
var data = c.getImageData(0,0, $c.width(), $c.height());
|
|
||||||
var w = $(window).width(),
|
|
||||||
h = $(window).height() - 53;
|
|
||||||
$c.attr('width', w * window.devicePixelRatio);
|
|
||||||
$c.attr('height',h * window.devicePixelRatio);
|
|
||||||
$c.css({
|
|
||||||
'width' : w,
|
|
||||||
'height' : h
|
|
||||||
});
|
|
||||||
c.clearRect(0,0, width(), height());
|
|
||||||
c.putImageData(data, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
function relative(x,y, el) {
|
|
||||||
var el = el || $c[0];
|
|
||||||
return {
|
|
||||||
x : x*window.devicePixelRatio - el.offset().left,
|
|
||||||
y : (y - 53) * window.devicePixelRatio - el.offset().top
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function threshold(x1, y1, x2, y2, threshold) {
|
|
||||||
var tr = threshold || 5;
|
|
||||||
if( x1 <= x2 + tr && x1 >= x2 - tr && y1 <= y2 + tr && y1 >= y2 - tr ) return true;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function draw(x1, y1, x2, y2, opts, overlay) {
|
|
||||||
opts = opts || {};
|
|
||||||
var c = window.c;
|
|
||||||
if( overlay ) var c = window.o;
|
|
||||||
c.beginPath();
|
|
||||||
if( settings.type == 'eraser' ) c.globalCompositeOperation = 'destination-out';
|
|
||||||
else c.globalCompositeOperation = opts.composite || settings.composite;
|
|
||||||
c.lineCap = opts.lineCap || settings.lineCap;
|
|
||||||
c.lineJoin = opts.lineJoin || settings.lineJoin;
|
|
||||||
c.strokeStyle = opts.color || settings.color;
|
|
||||||
c.fillStyle = opts.color || settings.color;
|
|
||||||
c.lineWidth = ( opts.lineWidth || settings.lineWidth ) / 10;
|
|
||||||
c.moveTo(x1, y1);
|
|
||||||
c.lineTo(x2, y2);
|
|
||||||
if( !opts.noStroke ) c.stroke();
|
|
||||||
if( opts.fill ) c.fill();
|
|
||||||
}
|
|
||||||
|
|
||||||
function shape(opts, overlay) {
|
|
||||||
if(overlay) var c = window.o;
|
|
||||||
else var c = window.c;
|
|
||||||
c.beginPath();
|
|
||||||
c.fillStyle = opts.color || settings.color;
|
|
||||||
switch(opts.type) {
|
|
||||||
|
|
||||||
case 'circle': {
|
|
||||||
c.arc(opts.x, opts.y, opts.radius, 0, 2*Math.PI);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 'rectangle': {
|
|
||||||
c.rect(opts.x, opts.y, opts.width, opts.height);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 'square': {
|
|
||||||
c.rect(opts.x, opts.y, opts.width, opts.width);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 'triangle': {
|
|
||||||
c.fillStyle = opts
|
|
||||||
c.moveTo(opts.x1, opts.y1);
|
|
||||||
c.lineTo(opts.x2, opts.y2);
|
|
||||||
c.lineTo(opts.x3, opts.y3);
|
|
||||||
c.lineTo(opts.x1, opts.y1);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
c.fill();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function undo() {
|
|
||||||
var history = window.points.history;
|
|
||||||
if( history.last > 1 ) {
|
|
||||||
var step = history[history.last-1];
|
|
||||||
c.putImageData(step.data, 0, 0);
|
|
||||||
window.points = step.points.slice(0);
|
|
||||||
window.points.history = history;
|
|
||||||
window.points.history.last = history.last-1;
|
|
||||||
} else {
|
|
||||||
c.clearRect(0,0, width(), height());
|
|
||||||
window.points = [];
|
|
||||||
window.points.history = history;
|
|
||||||
window.points.history.last = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
function redo() {
|
|
||||||
var history = window.points.history;
|
|
||||||
if( history.last < history.length-1 ) {
|
|
||||||
var step = history[history.last+1];
|
|
||||||
c.putImageData(step.data, 0, 0);
|
|
||||||
window.points = step.points.slice(0);
|
|
||||||
window.points.history = history;
|
|
||||||
window.points.history.last = history.last+1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function width() {
|
|
||||||
return +$c.attr('width');
|
|
||||||
}
|
|
||||||
|
|
||||||
function height() {
|
|
||||||
return +$c.attr('height');
|
|
||||||
}
|
|
||||||
|
|
||||||
function dataToBlob(data) {
|
|
||||||
var binary = atob(data.split(',')[1]), array = [];
|
|
||||||
var type = data.split(',')[0].split(':')[1].split(';')[0];
|
|
||||||
for(var i = 0; i < binary.length; i++) array.push(binary.charCodeAt(i));
|
|
||||||
return new Blob([new Uint8Array(array)], {type: type});
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*** END ***/
|
|
||||||
|
|
||||||
function startPoint(x, y) {
|
|
||||||
|
|
||||||
// If no previous point exists, make the first one.
|
|
||||||
if( !points.length ) points.push({x: x, y: y, type: '', start: {x: x, y: y}});
|
|
||||||
|
|
||||||
var old = points[points.length-1],
|
|
||||||
start = old.start,
|
|
||||||
current = {
|
|
||||||
x : x,
|
|
||||||
y : y,
|
|
||||||
start : old.start || {x: x, y: y},
|
|
||||||
type : settings.type
|
|
||||||
}
|
|
||||||
// Line
|
|
||||||
if( old.type !== 'line' && current.type == 'line' ) {
|
|
||||||
window.o.beginPath();
|
|
||||||
window.o.fillStyle = 'red';
|
|
||||||
window.o.arc(x,y, 3, 0, 2*Math.PI);
|
|
||||||
window.o.fill();
|
|
||||||
}
|
|
||||||
|
|
||||||
if( old.type == 'line' && current.type == 'line' ) {
|
|
||||||
if( points[points.indexOf(old)-1].type !== 'line' ) {
|
|
||||||
o.clearRect(old.x-3, old.y-3, 6, 6, true);
|
|
||||||
draw(old.x, old.y, x, y);
|
|
||||||
} else
|
|
||||||
draw(old.x, old.y, x, y);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Shapes
|
|
||||||
|
|
||||||
if( old.type !== 'shape' && current.type == 'shape' ) {
|
|
||||||
settings.shape.
|
|
||||||
}
|
|
||||||
|
|
||||||
var thresholds = window.mobile ? [10, 5] : [5, 2];
|
|
||||||
if( points.length > 1 && ((start && threshold(start.x, start.y, x, y, thresholds[0])) || threshold(old.x, old.y, x, y, thresholds[1])) ) {
|
|
||||||
window.active = false;
|
|
||||||
points[points.length-1].type = '';
|
|
||||||
points[points.length-1].start = undefined;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
points.push(current);
|
|
||||||
}
|
|
||||||
|
|
||||||
function drawPoint(x,y) {
|
|
||||||
var capture = points[points.length-1];
|
|
||||||
|
|
||||||
switch(capture.type) {
|
|
||||||
case 'eraser': {
|
|
||||||
capture.type = 'pen';
|
|
||||||
}
|
|
||||||
case 'pen': {
|
|
||||||
draw(capture.x, capture.y, x, y);
|
|
||||||
|
|
||||||
var current = {
|
|
||||||
x : x,
|
|
||||||
y : y,
|
|
||||||
start : capture.start,
|
|
||||||
type : capture.type
|
|
||||||
}
|
|
||||||
|
|
||||||
points.push(current);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 'sketch': {
|
|
||||||
draw(capture.x, capture.y, x, y);
|
|
||||||
var current = {
|
|
||||||
x : x,
|
|
||||||
y : y,
|
|
||||||
start : capture.start,
|
|
||||||
type : capture.type
|
|
||||||
}
|
|
||||||
points.push(current);
|
|
||||||
|
|
||||||
for( var i = 0, len = points.length-1; i < len; i++ ) {
|
|
||||||
if(threshold(points[i].x, points[i].y, current.x, current.y, settings.connectTelorance)) {
|
|
||||||
var x = points[i].x - current.x,
|
|
||||||
y = points[i].y - current.y;
|
|
||||||
var w = settings.lineWidth/20 > 0.2 ? settings.lineWidth/20 : 0.2;
|
|
||||||
|
|
||||||
draw(points[i].x - x*0.2, points[i].y - y*0.2, current.x + x*0.2, current.y + y*0.2, {strokeStyle: 'rgba(0,0,0,0.4)', lineWidth: w})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 'fur': {
|
|
||||||
draw(capture.x, capture.y, x, y);
|
|
||||||
var current = {
|
|
||||||
x : x,
|
|
||||||
y : y,
|
|
||||||
start : capture.start,
|
|
||||||
type : capture.type
|
|
||||||
}
|
|
||||||
points.push(current);
|
|
||||||
|
|
||||||
for( var i = 0, len = points.length-1; i < len; i++ ) {
|
|
||||||
if(threshold(points[i].x, points[i].y, current.x, current.y, settings.connectTelorance)) {
|
|
||||||
var x = points[i].x - current.x,
|
|
||||||
y = points[i].y - current.y;
|
|
||||||
var l = settings.furLength / 100 || 0.2;
|
|
||||||
var w = settings.lineWidth/20 > 0.2 ? settings.lineWidth/20 : 0.2;
|
|
||||||
|
|
||||||
draw(points[i].x + x*l, points[i].y + y*l, current.x - x*l, current.y - y*l, {strokeStyle: 'rgba(0,0,0,0.4)', lineWidth: w})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
13
Mobile/js/less-1.5.0.min.js
vendored
@ -1,348 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
|
|
||||||
$(document).ready(function() {
|
|
||||||
|
|
||||||
// Open External Links in browser
|
|
||||||
|
|
||||||
$('*').click(function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
})
|
|
||||||
|
|
||||||
$('a[href^="http"]').tap(function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
var href = $(this).attr('href');
|
|
||||||
var view = new MozActivity({
|
|
||||||
name: 'view',
|
|
||||||
data: {
|
|
||||||
type: 'url',
|
|
||||||
url: href
|
|
||||||
}
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
$('a[href^="mailto"]').tap(function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
var mail = /mailto:(.*)/.exec($(this).attr('href'))[1];
|
|
||||||
var mail = new MozActivity({
|
|
||||||
name: 'new',
|
|
||||||
data: {
|
|
||||||
type: 'mail',
|
|
||||||
url: mail
|
|
||||||
}
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
window.save = function() {
|
|
||||||
switch(save.background) {
|
|
||||||
case 'white': {
|
|
||||||
c.fillStyle = 'white';
|
|
||||||
c.globalCompositeOperation = 'destination-over';
|
|
||||||
c.fillRect(0, 0, width(), height());
|
|
||||||
c.fillStyle = settings.color;
|
|
||||||
c.globalCompositeOperation = settings.composite;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 'current color': {
|
|
||||||
c.fillStyle = settings.bg;
|
|
||||||
c.globalCompositeOperation = 'destination-over';
|
|
||||||
c.fillRect(0, 0, width(), height());
|
|
||||||
c.globalCompositeOperation = settings.composite;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var data = $c[0].toDataURL();
|
|
||||||
if( save.type == 'sketchy project' ) {
|
|
||||||
var list = JSON.parse(localStorage.getItem('projects'));
|
|
||||||
var index;
|
|
||||||
if( list && list.some(function(a, i) { if( a.name == save['file name'] ) {index = i; return true} return false }) ) {
|
|
||||||
if( confirm('A sketch with this name already exists. Do you want to overwrite ' + save['file name']) + '?' ) {
|
|
||||||
console.log(index);
|
|
||||||
list[index] = {
|
|
||||||
name: save['file name'],
|
|
||||||
data: data,
|
|
||||||
points: window.points,
|
|
||||||
settings: settings
|
|
||||||
}
|
|
||||||
localStorage.setItem('projects', JSON.stringify(list));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
list ? list.push({
|
|
||||||
name: save['file name'],
|
|
||||||
data: data,
|
|
||||||
points: window.points
|
|
||||||
}) : list = [{
|
|
||||||
name: save['file name'],
|
|
||||||
data: data,
|
|
||||||
points: window.points
|
|
||||||
}];
|
|
||||||
localStorage.setItem('projects', JSON.stringify(list));
|
|
||||||
} else {
|
|
||||||
window.open(data, '_blank').focus();
|
|
||||||
}
|
|
||||||
|
|
||||||
c.putImageData(window.points.history[window.points.history.last].data, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
window.load = function() {
|
|
||||||
var file = JSON.parse(localStorage.getItem('projects')).filter(function(a) { return a.name == load.file })[0];
|
|
||||||
var img = document.createElement('img');
|
|
||||||
img.src = file.data;
|
|
||||||
img.onload = function() {
|
|
||||||
c.clearRect(0, 0, width(), height());
|
|
||||||
c.drawImage(img, 0, 0);
|
|
||||||
window.points = file.points;
|
|
||||||
window.points.history = [{ data: c.createImageData($c.width(), $c.height()), points: []}, { data: c.getImageData(0, 0, width(), height()), points: file.points}];
|
|
||||||
$c.first().css('background', file.settings.bg);
|
|
||||||
window.settings.bg = file.settings.bg;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if( localStorage.getItem('sawTips') != settings.version ) {
|
|
||||||
$('.tour').removeClass('hidden');
|
|
||||||
localStorage.setItem('sawTips', settings.version);
|
|
||||||
}
|
|
||||||
|
|
||||||
$('.menu').tap(function() {
|
|
||||||
$('#menu').toggleClass('pulled');
|
|
||||||
})
|
|
||||||
$('.save').tap(function() {
|
|
||||||
$('#save').removeClass('hidden');
|
|
||||||
})
|
|
||||||
$('.load').tap(function() {
|
|
||||||
$('#load').removeClass('hidden');
|
|
||||||
$('#load li').remove();
|
|
||||||
var list = JSON.parse(localStorage.getItem('projects'));
|
|
||||||
if( !list || list.length < 1 ) {
|
|
||||||
$('#load ol').append(
|
|
||||||
$('<p>No Sketch found.</p>')
|
|
||||||
);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for( var i = 0, len = list.length; i < len; i++ ) {
|
|
||||||
$('#load ol').append(
|
|
||||||
$('<li><label><span>' + list[i].name + '</span></label></li>')
|
|
||||||
);
|
|
||||||
}
|
|
||||||
$confirm.find('li').off('tap').tap(function(e) {
|
|
||||||
$(this).parent().find('li[aria-selected]').removeAttr('aria-selected');
|
|
||||||
$(this).attr('aria-selected', 'true');
|
|
||||||
})
|
|
||||||
})
|
|
||||||
$('#pro').tap(function() {
|
|
||||||
$('#save ol:nth-of-type(2) li').each(function() {
|
|
||||||
if( $(this).find('span').html() !== 'Transparent' ) {
|
|
||||||
$(this).addClass('hidden');
|
|
||||||
$(this).removeAttr('aria-selected');
|
|
||||||
}
|
|
||||||
else $(this).attr('aria-selected', 'true');
|
|
||||||
})
|
|
||||||
})
|
|
||||||
$('#exp').tap(function() {
|
|
||||||
$('#save ol:nth-of-type(2) li').removeClass('hidden');
|
|
||||||
})
|
|
||||||
$c.last().on('touchstart', function(e) {
|
|
||||||
var xy = relative(e.changedTouches[0].pageX, e.changedTouches[0].pageY);
|
|
||||||
startPoint(xy.x, xy.y);
|
|
||||||
window.active = true;
|
|
||||||
}).on('touchmove', function(e) {
|
|
||||||
if (!window.active || settings.type == 'line') return;
|
|
||||||
var xy = relative(e.changedTouches[0].pageX, e.changedTouches[0].pageY);
|
|
||||||
drawPoint(xy.x, xy.y);
|
|
||||||
}).on('touchend', function(e) {
|
|
||||||
window.active = false;
|
|
||||||
if( settings.type == 'eraser' ) return;
|
|
||||||
|
|
||||||
if( settings.type == 'shape' ) {
|
|
||||||
var s = settings.comShape;
|
|
||||||
o.clear();
|
|
||||||
c.beginPath();
|
|
||||||
c.fillStyle = settings.color;
|
|
||||||
c.strokeStyle = settings.color;
|
|
||||||
c.lineWidth = settings.lineWidth / 20;
|
|
||||||
switch(s.type) {
|
|
||||||
case 'circle': {
|
|
||||||
c.arc(s.x, s.y, s.radius, 0, 2*Math.PI);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 'rectangle': {
|
|
||||||
c.rect(s.x, s.y, s.w, s.h)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 'triangle': {
|
|
||||||
c.moveTo(s.start.x + s.dix, s.start.y);
|
|
||||||
c.lineTo(s.x, s.y);
|
|
||||||
c.lineTo(s.start.x, s.y);
|
|
||||||
c.lineTo(s.start.x + s.dix, s.start.y);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if( settings.fill ) c.fill();
|
|
||||||
if( settings.stroke ) c.stroke();
|
|
||||||
}
|
|
||||||
|
|
||||||
if( settings.type == 'line' ) return;
|
|
||||||
|
|
||||||
if(window.points.history.last < window.points.history.length-1) {
|
|
||||||
window.points.history.splice(window.points.history.last+1);
|
|
||||||
}
|
|
||||||
|
|
||||||
window.points.history.push({
|
|
||||||
data: c.getImageData(0, 0, width(), height()),
|
|
||||||
points: window.points.slice(0)
|
|
||||||
})
|
|
||||||
window.points.history.last = window.points.history.length-1;
|
|
||||||
}).on('longTap', function(e) {
|
|
||||||
if( points[points.length-1].type == 'line' ) {
|
|
||||||
window.active = false;
|
|
||||||
points[points.length-1].type = '';
|
|
||||||
points[points.length-1].start = undefined;
|
|
||||||
finishLine();
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
// Value Selector
|
|
||||||
|
|
||||||
var $single = $('form[data-type="value-selector"].single');
|
|
||||||
|
|
||||||
$single.find('li').tap(function(e) {
|
|
||||||
$(this).parent().find('li[aria-selected]').removeAttr('aria-selected');
|
|
||||||
$(this).attr('aria-selected', 'true');
|
|
||||||
var key = $(this).parents('form').attr('id'),
|
|
||||||
value = $(this).find('label span').html().toLowerCase(),
|
|
||||||
target = $(this).attr('data-target');
|
|
||||||
window.settings[key] = value;
|
|
||||||
|
|
||||||
$('button[id="set' + key + '"] span').html(value[0].toUpperCase() + value.substr(1));
|
|
||||||
if( target ) {
|
|
||||||
$('#menu div.options > div').addClass('hidden');
|
|
||||||
$('#menu div.options > .general, #menu div.options > .'+target).removeClass('hidden');
|
|
||||||
}
|
|
||||||
$(this).parents('form').addClass('hidden');
|
|
||||||
})
|
|
||||||
$single.find('button').tap(function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
$(this).parents('form').addClass('hidden');
|
|
||||||
})
|
|
||||||
|
|
||||||
// Confirm
|
|
||||||
|
|
||||||
var $confirm = $('form[data-type="value-selector"].confirm');
|
|
||||||
|
|
||||||
$confirm.each(function() {
|
|
||||||
|
|
||||||
$(this).find('li').tap(function(e) {
|
|
||||||
$(this).parent().find('li[aria-selected]').removeAttr('aria-selected');
|
|
||||||
$(this).attr('aria-selected', 'true');
|
|
||||||
})
|
|
||||||
$(this).find('button').last().tap(function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
var v = $(this).parents('form').attr('id');
|
|
||||||
$(this).parents('form').find('h1').each(function(i) {
|
|
||||||
if( i > 0 ) {
|
|
||||||
var key = $(this).html().toLowerCase();
|
|
||||||
var value = $(this).parent().find('ol:nth-of-type('+i+') li[aria-selected] span').html();
|
|
||||||
if( key !== 'file name' && key !== 'file' ) value = value.toLowerCase();
|
|
||||||
window[v][key] = value;
|
|
||||||
}
|
|
||||||
})
|
|
||||||
$(this).parents('form').addClass('hidden');
|
|
||||||
window[v]();
|
|
||||||
})
|
|
||||||
$(this).find('button').first().tap(function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
$(this).parents('form').addClass('hidden');
|
|
||||||
})
|
|
||||||
|
|
||||||
})
|
|
||||||
|
|
||||||
// Value Selector Callers
|
|
||||||
|
|
||||||
var $btn = $('button[id^="set"]');
|
|
||||||
$btn.each(function() {
|
|
||||||
var target = /set(.*)/.exec($(this).attr('id'))[1];
|
|
||||||
// Exception for Color
|
|
||||||
if( target == 'color' || target == 'bg' ) {
|
|
||||||
return $(this).tap(function() {
|
|
||||||
$('.picker').removeClass('hidden');
|
|
||||||
$('.picker').attr('data-caller', target);
|
|
||||||
})
|
|
||||||
}
|
|
||||||
$(this).tap(function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
$('form[id="' + target + '"]').removeClass('hidden');
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
// Seekbar
|
|
||||||
|
|
||||||
var sliderLeft;
|
|
||||||
$('div[role="slider"] button').on('touchstart', function() {
|
|
||||||
$(this).attr('data-moving','true');
|
|
||||||
if( !sliderLeft ) sliderLeft = $('div[role="slider"] button').offset().left;
|
|
||||||
}).on('touchmove', function(e) {
|
|
||||||
if( $(this).attr('data-moving') ) {
|
|
||||||
var x = parseInt(e.changedTouches[0].pageX - sliderLeft - 15);
|
|
||||||
var $c = $('.'+$(this).parents('div[role="slider"]').attr('class'));
|
|
||||||
var progress = $c.find('progress');
|
|
||||||
var max = +progress.attr('max');
|
|
||||||
var min = +progress.attr('min');
|
|
||||||
if( x <= max && x >= min ) {
|
|
||||||
$c.find('button').css('left', x+'%');
|
|
||||||
progress.attr('value', x);
|
|
||||||
var key = $c.attr('class');
|
|
||||||
settings[key] = x;
|
|
||||||
$('#'+ key +' span').html(x);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}).on('touchend', function() {
|
|
||||||
$(this).removeAttr('data-moving');
|
|
||||||
})
|
|
||||||
|
|
||||||
$('.fill, .stroke').tap(function() {
|
|
||||||
var s = $('.'+$(this).attr('class')).find('span');
|
|
||||||
if( s.html() == 'Yes' ) {
|
|
||||||
s.html('No');
|
|
||||||
settings[$(this).attr('class')] = false;
|
|
||||||
} else {
|
|
||||||
s.html('Yes');
|
|
||||||
settings[$(this).attr('class')] = true;
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
$('.close, .tour button').tap(function() {
|
|
||||||
$(this).parent().addClass('hidden');
|
|
||||||
})
|
|
||||||
|
|
||||||
// Color Picker
|
|
||||||
|
|
||||||
$('.close').tap(function() {
|
|
||||||
$(this).parent().addClass('hidden');
|
|
||||||
})
|
|
||||||
|
|
||||||
// Bottom
|
|
||||||
|
|
||||||
$('#clear').tap(function() {
|
|
||||||
c.clearRect(0, 0, width(), height());
|
|
||||||
var h = window.points.history;
|
|
||||||
window.points = [];
|
|
||||||
window.points.history = h;
|
|
||||||
if(window.points.history.last < window.points.history.length-1) {
|
|
||||||
window.points.history.splice(window.points.history.last+1);
|
|
||||||
}
|
|
||||||
|
|
||||||
window.points.history.push({
|
|
||||||
data: c.getImageData(0, 0, width(), height()),
|
|
||||||
points: []
|
|
||||||
})
|
|
||||||
window.points.history.last = window.points.history.length-1;
|
|
||||||
})
|
|
||||||
|
|
||||||
$('#undo').tap(undo);
|
|
||||||
$('#redo').tap(redo);
|
|
||||||
|
|
||||||
$('#about').tap(function() {
|
|
||||||
$('.about').removeClass('hidden');
|
|
||||||
})
|
|
||||||
|
|
||||||
});
|
|
19
README.md
@ -1,14 +1,17 @@
|
|||||||
Sketchy
|
Sketchy
|
||||||
=======
|
=======
|
||||||
|
|
||||||
Free Sketch / Paint application for Firefox OS with a lot of features.
|
Free Sketch / Paint application for Firefox with a lot of features.
|
||||||
|
|
||||||
Key features:
|
Key features:
|
||||||
* Different types of brushes
|
* Different types of brushes
|
||||||
* Customizable brushes
|
* Customizable brushes
|
||||||
* Colorpicker
|
* Colorpicker
|
||||||
* Unlimited Undo/Redo
|
* Unlimited Undo/Redo
|
||||||
* Save your sketch to sdcard
|
* Save your sketch to sdcard / PC
|
||||||
|
* Save your sketch as a "Sketchy Project" and edit it later
|
||||||
|
* Different shapes ( Circle, Rectangle, Square, Triangle )
|
||||||
|
* Fill / Stroke
|
||||||
|
|
||||||
New features are coming soon! Contact and tell us what feature you would like to see in next version ( you can make an issue ).
|
New features are coming soon! Contact and tell us what feature you would like to see in next version ( you can make an issue ).
|
||||||
|
|
||||||
@ -18,6 +21,18 @@ Web version: https://mdibaiee.github.io/Sketchy/Web/
|
|||||||
|
|
||||||
Firefox Marketplace: https://marketplace.firefox.com/app/sketchy/
|
Firefox Marketplace: https://marketplace.firefox.com/app/sketchy/
|
||||||
|
|
||||||
|
Start
|
||||||
|
=====
|
||||||
|
|
||||||
|
To start working on:
|
||||||
|
|
||||||
|
git clone https://github.com/mdibaiee/Sketchy
|
||||||
|
cd Sketchy
|
||||||
|
npm install
|
||||||
|
grunt
|
||||||
|
|
||||||
|
Sketchy will be built to "build" folder, you can run `grunt watch` to automatically re-run tasks when you modify files.
|
||||||
|
|
||||||
Changelog
|
Changelog
|
||||||
=========
|
=========
|
||||||
|
|
||||||
|
Before Width: | Height: | Size: 93 B After Width: | Height: | Size: 93 B |
Before Width: | Height: | Size: 94 B After Width: | Height: | Size: 94 B |
Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.7 KiB |
Before Width: | Height: | Size: 1.0 KiB After Width: | Height: | Size: 1.0 KiB |
Before Width: | Height: | Size: 1.0 KiB After Width: | Height: | Size: 1.0 KiB |
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 413 B After Width: | Height: | Size: 413 B |
Before Width: | Height: | Size: 182 B After Width: | Height: | Size: 182 B |
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 1.8 KiB |
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 636 B After Width: | Height: | Size: 636 B |
Before Width: | Height: | Size: 960 B After Width: | Height: | Size: 960 B |
Before Width: | Height: | Size: 938 B After Width: | Height: | Size: 938 B |
Before Width: | Height: | Size: 583 B After Width: | Height: | Size: 583 B |
Before Width: | Height: | Size: 946 B After Width: | Height: | Size: 946 B |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 583 B After Width: | Height: | Size: 583 B |
Before Width: | Height: | Size: 946 B After Width: | Height: | Size: 946 B |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 578 B After Width: | Height: | Size: 578 B |
Before Width: | Height: | Size: 893 B After Width: | Height: | Size: 893 B |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 575 B After Width: | Height: | Size: 575 B |
Before Width: | Height: | Size: 889 B After Width: | Height: | Size: 889 B |
Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 755 B After Width: | Height: | Size: 755 B |
Before Width: | Height: | Size: 1.0 KiB After Width: | Height: | Size: 1.0 KiB |
Before Width: | Height: | Size: 475 B After Width: | Height: | Size: 475 B |
Before Width: | Height: | Size: 616 B After Width: | Height: | Size: 616 B |
Before Width: | Height: | Size: 177 B After Width: | Height: | Size: 177 B |
Before Width: | Height: | Size: 392 B After Width: | Height: | Size: 392 B |
Before Width: | Height: | Size: 601 B After Width: | Height: | Size: 601 B |
Before Width: | Height: | Size: 101 B After Width: | Height: | Size: 101 B |
Before Width: | Height: | Size: 82 B After Width: | Height: | Size: 82 B |
Before Width: | Height: | Size: 3.4 KiB After Width: | Height: | Size: 3.4 KiB |
Before Width: | Height: | Size: 7.7 KiB After Width: | Height: | Size: 7.7 KiB |
Before Width: | Height: | Size: 6.7 KiB After Width: | Height: | Size: 6.7 KiB |
Before Width: | Height: | Size: 83 B After Width: | Height: | Size: 83 B |
Before Width: | Height: | Size: 154 B After Width: | Height: | Size: 154 B |
Before Width: | Height: | Size: 86 B After Width: | Height: | Size: 86 B |
Before Width: | Height: | Size: 82 B After Width: | Height: | Size: 82 B |
Before Width: | Height: | Size: 154 B After Width: | Height: | Size: 154 B |
Before Width: | Height: | Size: 87 B After Width: | Height: | Size: 87 B |
Before Width: | Height: | Size: 4.3 KiB After Width: | Height: | Size: 4.3 KiB |
Before Width: | Height: | Size: 8.0 KiB After Width: | Height: | Size: 8.0 KiB |
Before Width: | Height: | Size: 8.9 KiB After Width: | Height: | Size: 8.9 KiB |
Before Width: | Height: | Size: 738 B After Width: | Height: | Size: 738 B |
Before Width: | Height: | Size: 7.2 KiB After Width: | Height: | Size: 7.2 KiB |
Before Width: | Height: | Size: 6.6 KiB After Width: | Height: | Size: 6.6 KiB |
Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB |
Before Width: | Height: | Size: 2.7 KiB After Width: | Height: | Size: 2.7 KiB |
Before Width: | Height: | Size: 3.7 KiB After Width: | Height: | Size: 3.7 KiB |
Before Width: | Height: | Size: 4.0 KiB After Width: | Height: | Size: 4.0 KiB |
Before Width: | Height: | Size: 6.0 KiB After Width: | Height: | Size: 6.0 KiB |
@ -1,14 +1,14 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
|
|
||||||
$(window).resize(sizeAndPos);
|
$(window).resize(sizeAndPos);
|
||||||
|
$(document).ready(function() {
|
||||||
$('.menu').click(function() {
|
$('.menu').on('click tap', function() {
|
||||||
$('#menu').toggleClass('pulled');
|
$('#menu').toggleClass('pulled');
|
||||||
})
|
})
|
||||||
$('.save').click(function() {
|
$('.save').on('click tap', function() {
|
||||||
$('#save').removeClass('hidden');
|
$('#save').removeClass('hidden');
|
||||||
})
|
})
|
||||||
$('.load').click(function() {
|
$('.load').on('click tap', function() {
|
||||||
$('#load').removeClass('hidden');
|
$('#load').removeClass('hidden');
|
||||||
$('#load li').remove();
|
$('#load li').remove();
|
||||||
var list = JSON.parse(localStorage.getItem('projects'));
|
var list = JSON.parse(localStorage.getItem('projects'));
|
||||||
@ -24,11 +24,11 @@ $(window).resize(sizeAndPos);
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$confirm.find('li').off('click').click(function(e) {
|
$confirm.find('li').off('click').on('click tap', function(e) {
|
||||||
$(this).parent().find('li[aria-selected]').removeAttr('aria-selected');
|
$(this).parent().find('li[aria-selected]').removeAttr('aria-selected');
|
||||||
$(this).attr('aria-selected', 'true');
|
$(this).attr('aria-selected', 'true');
|
||||||
})
|
})
|
||||||
$('#pro').click(function() {
|
$('#pro').on('click tap', function() {
|
||||||
$('#save ol:nth-of-type(2) li').each(function() {
|
$('#save ol:nth-of-type(2) li').each(function() {
|
||||||
if( $(this).find('span').html() !== 'Transparent' ) {
|
if( $(this).find('span').html() !== 'Transparent' ) {
|
||||||
$(this).addClass('hidden');
|
$(this).addClass('hidden');
|
||||||
@ -37,11 +37,11 @@ $(window).resize(sizeAndPos);
|
|||||||
else $(this).attr('aria-selected', 'true');
|
else $(this).attr('aria-selected', 'true');
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
$('#exp').click(function() {
|
$('#exp').on('click tap', function() {
|
||||||
$('#save ol:nth-of-type(2) li').removeClass('hidden');
|
$('#save ol:nth-of-type(2) li').removeClass('hidden');
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
$('#pro').click(function() {
|
$('#pro').on('click tap', function() {
|
||||||
$('#save ol:nth-of-type(2) li').each(function() {
|
$('#save ol:nth-of-type(2) li').each(function() {
|
||||||
if( $(this).find('span').html() !== 'Transparent' ) {
|
if( $(this).find('span').html() !== 'Transparent' ) {
|
||||||
$(this).addClass('hidden');
|
$(this).addClass('hidden');
|
||||||
@ -50,20 +50,24 @@ $(window).resize(sizeAndPos);
|
|||||||
else $(this).attr('aria-selected', 'true');
|
else $(this).attr('aria-selected', 'true');
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
$('#exp').click(function() {
|
$('#exp').on('click tap', function() {
|
||||||
$('#save ol:nth-of-type(2) li').removeClass('hidden');
|
$('#save ol:nth-of-type(2) li').removeClass('hidden');
|
||||||
})
|
})
|
||||||
$c.last().on('mousedown', function(e) {
|
$c.last().on('mousedown touchstart', function(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
if( e.changedTouches )
|
||||||
|
e = e.changedTouches[0];
|
||||||
var xy = relative(e.pageX, e.pageY);
|
var xy = relative(e.pageX, e.pageY);
|
||||||
startPoint(xy.x, xy.y);
|
startPoint(xy.x, xy.y);
|
||||||
window.active = true;
|
window.active = true;
|
||||||
}).on('mousemove', function(e) {
|
}).on('mousemove touchmove', function(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
if( e.changedTouches )
|
||||||
|
e = e.changedTouches[0];
|
||||||
if (!window.active || settings.type == 'line') return;
|
if (!window.active || settings.type == 'line') return;
|
||||||
var xy = relative(e.pageX, e.pageY);
|
var xy = relative(e.pageX, e.pageY);
|
||||||
drawPoint(xy.x, xy.y);
|
drawPoint(xy.x, xy.y);
|
||||||
}).on('mouseup', function(e) {
|
}).on('mouseup touchend', function(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
window.active = false;
|
window.active = false;
|
||||||
|
|
||||||
@ -116,7 +120,7 @@ $(window).resize(sizeAndPos);
|
|||||||
|
|
||||||
var $single = $('form.single');
|
var $single = $('form.single');
|
||||||
|
|
||||||
$single.find('li').click(function(e) {
|
$single.find('li').on('click tap', function(e) {
|
||||||
$(this).parent().find('li[aria-selected]').removeAttr('aria-selected');
|
$(this).parent().find('li[aria-selected]').removeAttr('aria-selected');
|
||||||
$(this).attr('aria-selected', 'true');
|
$(this).attr('aria-selected', 'true');
|
||||||
var key = $(this).parents('form').attr('id'),
|
var key = $(this).parents('form').attr('id'),
|
||||||
@ -142,11 +146,11 @@ $(window).resize(sizeAndPos);
|
|||||||
|
|
||||||
$confirm.each(function() {
|
$confirm.each(function() {
|
||||||
|
|
||||||
$(this).find('li').click(function(e) {
|
$(this).find('li').on('click tap', function(e) {
|
||||||
$(this).parent().find('li[aria-selected]').removeAttr('aria-selected');
|
$(this).parent().find('li[aria-selected]').removeAttr('aria-selected');
|
||||||
$(this).attr('aria-selected', 'true');
|
$(this).attr('aria-selected', 'true');
|
||||||
})
|
})
|
||||||
$(this).find('button').last().click(function(e) {
|
$(this).find('button').last().on('click tap', function(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
var v = $(this).parents('form').attr('id');
|
var v = $(this).parents('form').attr('id');
|
||||||
$(this).parents('form').find('h1').each(function(i) {
|
$(this).parents('form').find('h1').each(function(i) {
|
||||||
@ -160,7 +164,7 @@ $(window).resize(sizeAndPos);
|
|||||||
$(this).parents('form').addClass('hidden');
|
$(this).parents('form').addClass('hidden');
|
||||||
window[v]();
|
window[v]();
|
||||||
})
|
})
|
||||||
$(this).find('button').first().click(function(e) {
|
$(this).find('button').first().on('click tap', function(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
$(this).parents('form').addClass('hidden');
|
$(this).parents('form').addClass('hidden');
|
||||||
})
|
})
|
||||||
@ -174,12 +178,12 @@ $(window).resize(sizeAndPos);
|
|||||||
var target = /set(.*)/.exec($(this).attr('id'))[1];
|
var target = /set(.*)/.exec($(this).attr('id'))[1];
|
||||||
// Exception for Color
|
// Exception for Color
|
||||||
if( target == 'color' || target == 'bg' ) {
|
if( target == 'color' || target == 'bg' ) {
|
||||||
return $(this).click(function() {
|
return $(this).on('click tap', function() {
|
||||||
$('.picker').removeClass('hidden');
|
$('.picker').removeClass('hidden');
|
||||||
$('.picker').attr('data-caller', target);
|
$('.picker').attr('data-caller', target);
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
$(this).click(function(e) {
|
$(this).on('click tap', function(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
$('form[id="' + target + '"]').removeClass('hidden');
|
$('form[id="' + target + '"]').removeClass('hidden');
|
||||||
})
|
})
|
||||||
@ -188,11 +192,13 @@ $(window).resize(sizeAndPos);
|
|||||||
// Seekbar
|
// Seekbar
|
||||||
|
|
||||||
var sliderLeft;
|
var sliderLeft;
|
||||||
$('div[role="slider"] button').on('mousedown', function() {
|
$('div[role="slider"] button').on('mousedown touchstart', function() {
|
||||||
$(this).attr('data-moving','true');
|
$(this).attr('data-moving','true');
|
||||||
if( !sliderLeft ) sliderLeft = $('div[role="slider"] button').offset().left;
|
if( !sliderLeft ) sliderLeft = $('div[role="slider"] button').offset().left;
|
||||||
}).on('mousemove', function(e) {
|
}).on('mousemove touchmove', function(e) {
|
||||||
if( $(this).attr('data-moving') ) {
|
if( $(this).attr('data-moving') ) {
|
||||||
|
if( e.changedTouches )
|
||||||
|
e = e.changedTouches[0];
|
||||||
var x = parseInt(e.pageX - sliderLeft - 15);
|
var x = parseInt(e.pageX - sliderLeft - 15);
|
||||||
var $c = $('.'+$(this).parents('div[role="slider"]').attr('class'));
|
var $c = $('.'+$(this).parents('div[role="slider"]').attr('class'));
|
||||||
var progress = $c.find('progress');
|
var progress = $c.find('progress');
|
||||||
@ -206,11 +212,11 @@ $(window).resize(sizeAndPos);
|
|||||||
$('#'+ key +' span').html(x);
|
$('#'+ key +' span').html(x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}).on('mouseup mouseleave', function() {
|
}).on('mouseup mouseleave touchend', function() {
|
||||||
$(this).removeAttr('data-moving');
|
$(this).removeAttr('data-moving');
|
||||||
})
|
})
|
||||||
|
|
||||||
$('.fill, .stroke').click(function() {
|
$('.fill, .stroke').on('click tap', function() {
|
||||||
var s = $('.'+$(this).attr('class')).find('span');
|
var s = $('.'+$(this).attr('class')).find('span');
|
||||||
if( s.html() == 'Yes' ) {
|
if( s.html() == 'Yes' ) {
|
||||||
s.html('No');
|
s.html('No');
|
||||||
@ -221,13 +227,13 @@ $(window).resize(sizeAndPos);
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
$('.close, .tour button').click(function() {
|
$('.close, .tour button').on('click tap', function() {
|
||||||
$(this).parent().addClass('hidden');
|
$(this).parent().addClass('hidden');
|
||||||
})
|
})
|
||||||
|
|
||||||
// Bottom
|
// Bottom
|
||||||
|
|
||||||
$('#clear').click(function() {
|
$('#clear').on('click tap', function() {
|
||||||
c.clear();
|
c.clear();
|
||||||
var h = window.points.history;
|
var h = window.points.history;
|
||||||
window.points = [];
|
window.points = [];
|
||||||
@ -243,11 +249,16 @@ $(window).resize(sizeAndPos);
|
|||||||
window.points.history.last = window.points.history.length-1;
|
window.points.history.last = window.points.history.length-1;
|
||||||
})
|
})
|
||||||
|
|
||||||
$('#undo').click(undo);
|
$('#undo').on('click tap', undo);
|
||||||
$('#redo').click(redo);
|
$('#redo').on('click tap', redo);
|
||||||
|
|
||||||
$('#about').click(function() {
|
$('#about').on('click tap', function() {
|
||||||
$('.about').removeClass('hidden');
|
$('.about').removeClass('hidden');
|
||||||
})
|
})
|
||||||
|
|
||||||
|
if( window.mobile ) $('*').on('click mousemove mousedown mouseup mouseleave', function() {return false;});
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
5
Mobile/js/main.js → Shared/js/shared.js
Executable file → Normal file
@ -1,5 +1,3 @@
|
|||||||
"use strict";
|
|
||||||
|
|
||||||
$(document).ready(function() {
|
$(document).ready(function() {
|
||||||
window.c = $('canvas')[0].getContext('2d');
|
window.c = $('canvas')[0].getContext('2d');
|
||||||
window.o = $('canvas')[1].getContext('2d');
|
window.o = $('canvas')[1].getContext('2d');
|
||||||
@ -40,10 +38,9 @@ $(document).ready(function() {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
$('.color').val('#000000');
|
$('.color').val('#000000');
|
||||||
|
|
||||||
if( localStorage.getItem('sawTips') != settings.version ) {
|
if( localStorage.getItem('sawTips') != settings.version ) {
|
||||||
$('.tour').removeClass('hidden');
|
$('.tour').removeClass('hidden');
|
||||||
localStorage.setItem('sawTips', settings.version);
|
localStorage.setItem('sawTips', settings.version);
|
||||||
}
|
}
|
||||||
|
|
||||||
})
|
})
|
@ -1,90 +0,0 @@
|
|||||||
/* Purty Picker Copyright 2013 Jayden Seric (MIT license): https://github.com/jaydenseric/Purty-Picker */
|
|
||||||
/* Core: No touchy! */
|
|
||||||
.color-picker .spectrum {
|
|
||||||
position: relative;
|
|
||||||
/* To position pin, luminosity filter */
|
|
||||||
background: linear-gradient(gray, transparent), linear-gradient(90deg, red, #ff2b00, #ff5500, #ff8000, #ffaa00, #ffd500, yellow, #d4ff00, #aaff00, #80ff00, #55ff00, #2bff00, lime, #00ff2b, #00ff55, #00ff80, #00ffaa, #00ffd5, cyan, #00d4ff, #00aaff, #007fff, #0055ff, #002bff, blue, #2a00ff, #5500ff, #7f00ff, #aa00ff, #d400ff, magenta, #ff00d4, #ff00aa, #ff0080, #ff0055, #ff002b, red);
|
|
||||||
-webkit-user-select: none;
|
|
||||||
-moz-user-select: none;
|
|
||||||
-ms-user-select: none;
|
|
||||||
user-select: none;
|
|
||||||
/* Prevent pin interaction causing content selection */
|
|
||||||
cursor: crosshair;
|
|
||||||
}
|
|
||||||
.color-picker .spectrum.active {
|
|
||||||
cursor: none;
|
|
||||||
}
|
|
||||||
.color-picker .spectrum.active .pin {
|
|
||||||
cursor: none;
|
|
||||||
}
|
|
||||||
.color-picker .spectrum > div {
|
|
||||||
/* Luminosity filter */
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
top: 0;
|
|
||||||
bottom: 0;
|
|
||||||
}
|
|
||||||
.color-picker .spectrum .pin {
|
|
||||||
position: absolute;
|
|
||||||
cursor: move;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Customization: Default skin */
|
|
||||||
.color-picker {
|
|
||||||
margin: 20px;
|
|
||||||
padding: 11px;
|
|
||||||
border: 1px solid #e3e3e3;
|
|
||||||
border-radius: 4px;
|
|
||||||
background-color: #f5f5f5;
|
|
||||||
}
|
|
||||||
.color-picker .color,
|
|
||||||
.color-picker .luminosity {
|
|
||||||
-moz-box-sizing: border-box;
|
|
||||||
box-sizing: border-box;
|
|
||||||
display: block;
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
.color-picker .format {
|
|
||||||
display: block;
|
|
||||||
margin: 0 auto 10px auto;
|
|
||||||
}
|
|
||||||
.color-picker .color {
|
|
||||||
-webkit-appearance: none;
|
|
||||||
border: 0;
|
|
||||||
border-radius: 2px;
|
|
||||||
padding: 10px;
|
|
||||||
text-align: center;
|
|
||||||
font-size: 11px;
|
|
||||||
letter-spacing: 1px;
|
|
||||||
font-family: Consolas, Monaco, 'Andale Mono', monospace;
|
|
||||||
color: rgba(0, 0, 0, 0.6);
|
|
||||||
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.2);
|
|
||||||
transition: color 0.2s;
|
|
||||||
}
|
|
||||||
.color-picker .color.dark {
|
|
||||||
color: rgba(255, 255, 255, 0.7);
|
|
||||||
}
|
|
||||||
.color-picker .spectrum {
|
|
||||||
height: 150px;
|
|
||||||
/* Arbitary but required */
|
|
||||||
overflow: hidden;
|
|
||||||
/* Prevent pin overflowing container */
|
|
||||||
border-radius: 2px;
|
|
||||||
margin: 10px 0;
|
|
||||||
}
|
|
||||||
.color-picker .spectrum > div {
|
|
||||||
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.2);
|
|
||||||
}
|
|
||||||
.color-picker .spectrum .pin {
|
|
||||||
margin-left: -4px;
|
|
||||||
margin-top: -4px;
|
|
||||||
width: 4px;
|
|
||||||
height: 4px;
|
|
||||||
border: 2px solid white;
|
|
||||||
box-shadow: 0 1px 1px rgba(0, 0, 0, 0.4);
|
|
||||||
border-radius: 100%;
|
|
||||||
}
|
|
||||||
.color-picker .luminosity {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
@ -1,16 +0,0 @@
|
|||||||
@font-face {
|
|
||||||
font-family: 'MozTT-Regular';
|
|
||||||
src: url('fonts/MozTT-Regular.ttf');
|
|
||||||
}
|
|
||||||
@font-face {
|
|
||||||
font-family: 'MozTT-Light';
|
|
||||||
src: url('fonts/MozTT-Light.ttf');
|
|
||||||
}
|
|
||||||
@font-face {
|
|
||||||
font-family: 'MozTT-Medium';
|
|
||||||
src: url('fonts/MozTT-Medium.ttf');
|
|
||||||
}
|
|
||||||
@font-face {
|
|
||||||
font-family: 'MozTT-Bold';
|
|
||||||
src: url('fonts/MozTT-Bold.ttf');
|
|
||||||
}
|
|
@ -1,292 +0,0 @@
|
|||||||
@import 'fonts';
|
|
||||||
@import 'color-picker';
|
|
||||||
@import 'seekbars';
|
|
||||||
@import 'value_selector';
|
|
||||||
|
|
||||||
html, body {
|
|
||||||
margin: 0;
|
|
||||||
font-size: 10px;
|
|
||||||
overflow: hidden;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
*::-moz-focus-inner {
|
|
||||||
border: none;
|
|
||||||
}
|
|
||||||
*:focus {
|
|
||||||
outline: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.hidden {
|
|
||||||
display: none !important;
|
|
||||||
visibility: none !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
div#container {
|
|
||||||
position: absolute;
|
|
||||||
}
|
|
||||||
|
|
||||||
canvas {
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.separator {
|
|
||||||
display: block;
|
|
||||||
height: 4.8rem;
|
|
||||||
width: 0.1rem;
|
|
||||||
&.long {
|
|
||||||
background: url('imgs/div_line_lg_black.png');
|
|
||||||
}
|
|
||||||
&.small {
|
|
||||||
background: url('imgs/div_line_sm_black.png');
|
|
||||||
}
|
|
||||||
&.left {
|
|
||||||
float: left;
|
|
||||||
}
|
|
||||||
&.right {
|
|
||||||
float: right;
|
|
||||||
}
|
|
||||||
&.menu {
|
|
||||||
position: relative;
|
|
||||||
left: -3rem;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.overlay {
|
|
||||||
z-index: 9999;
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
top: 5.3rem;;
|
|
||||||
}
|
|
||||||
|
|
||||||
button {
|
|
||||||
-moz-appearance: none;
|
|
||||||
z-index: 1;
|
|
||||||
position: relative;
|
|
||||||
border: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.close {
|
|
||||||
display: block;
|
|
||||||
width: 2rem;
|
|
||||||
height: 2rem;
|
|
||||||
padding: 0 0 0.2rem 0.2rem;
|
|
||||||
font-size: 10pt;
|
|
||||||
border: 1px solid rgb(227, 227, 227);
|
|
||||||
border-radius: 50%;
|
|
||||||
position: absolute;
|
|
||||||
text-align: center;
|
|
||||||
top: -2%;
|
|
||||||
left: 97%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.picker, .about, .tour {
|
|
||||||
font-family: 'MozTT-Light';
|
|
||||||
width: 30rem;
|
|
||||||
height: 24.6rem;
|
|
||||||
position: absolute;
|
|
||||||
left: 50%;
|
|
||||||
top: 50%;
|
|
||||||
margin-top: -12.3rem;
|
|
||||||
margin-left: -15rem;
|
|
||||||
|
|
||||||
.color-picker {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.about, .tour {
|
|
||||||
background: #262626;
|
|
||||||
padding: 1rem 2rem;;
|
|
||||||
height: 23rem;
|
|
||||||
margin-top: -11.5rem;
|
|
||||||
margin-left: -17rem;
|
|
||||||
border-radius: 0.2rem;
|
|
||||||
color: white;
|
|
||||||
box-shadow: 0 0 0.3rem black;
|
|
||||||
|
|
||||||
a, a:link, a:visited, a:active {
|
|
||||||
color: white;
|
|
||||||
}
|
|
||||||
|
|
||||||
.close {
|
|
||||||
background: #262626;
|
|
||||||
color: white;
|
|
||||||
border: 1px solid gray;
|
|
||||||
}
|
|
||||||
|
|
||||||
p {
|
|
||||||
font-size: 11pt;
|
|
||||||
}
|
|
||||||
span {
|
|
||||||
font-size: 8pt;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.tour {
|
|
||||||
.button {
|
|
||||||
width: 30rem;
|
|
||||||
position: absolute;
|
|
||||||
bottom: 1rem;
|
|
||||||
left: 1.8rem;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
header {
|
|
||||||
width: 100%;
|
|
||||||
height: 5.3rem;
|
|
||||||
background: url('imgs/header_bg_black.png');
|
|
||||||
|
|
||||||
button {
|
|
||||||
width: 5rem;
|
|
||||||
height: 5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.menu {
|
|
||||||
background: url('imgs/menu.png') -12px center no-repeat;
|
|
||||||
float: left;
|
|
||||||
&:active {
|
|
||||||
background: url('imgs/menu.png') -12px center no-repeat, url('imgs/bg_overlay_pressed_1.png') left no-repeat;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.save {
|
|
||||||
background: url('imgs/download.png') center center no-repeat;
|
|
||||||
float: right;
|
|
||||||
&:active {
|
|
||||||
background: url('imgs/download.png') center center no-repeat, url('imgs/bg_overlay_pressed_2.png') center center;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.load {
|
|
||||||
background: url('imgs/load.png') center center no-repeat;
|
|
||||||
float: right;
|
|
||||||
&:active {
|
|
||||||
background: url('imgs/load.png') center center no-repeat, url('imgs/bg_overlay_pressed_2.png') center center;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#title {
|
|
||||||
color: white;
|
|
||||||
font-size: 11pt;
|
|
||||||
font-family: 'MozTT-Regular';
|
|
||||||
float: left;
|
|
||||||
margin: 1.5rem 0;
|
|
||||||
position: relative;
|
|
||||||
left: -2rem;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#menu {
|
|
||||||
width: 15rem;
|
|
||||||
height: 100%;
|
|
||||||
display: block;
|
|
||||||
background: #262626;
|
|
||||||
position: absolute;
|
|
||||||
left: -15rem;
|
|
||||||
top: 5rem;
|
|
||||||
color: white;
|
|
||||||
font-family: 'MozTT-Light';
|
|
||||||
font-size: 8pt;
|
|
||||||
transition: left 0.2s ease-out;
|
|
||||||
border-collapse: collapse;
|
|
||||||
overflow-y: auto;
|
|
||||||
|
|
||||||
&.pulled {
|
|
||||||
left: 0;
|
|
||||||
transition: left 0.2s ease-out;
|
|
||||||
}
|
|
||||||
|
|
||||||
button[id^='set'], p, .bottom button {
|
|
||||||
background: none;
|
|
||||||
display: block;
|
|
||||||
width: 75%;
|
|
||||||
color: white;
|
|
||||||
text-align: left;
|
|
||||||
margin: 1rem 2.5rem;
|
|
||||||
font-family: 'MozTT-Light';
|
|
||||||
font-size: 8pt;
|
|
||||||
padding: 0 0.6rem;
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
||||||
p {
|
|
||||||
width: 65%;
|
|
||||||
}
|
|
||||||
span {
|
|
||||||
float: right;
|
|
||||||
font-size: 7pt;
|
|
||||||
}
|
|
||||||
div[role='slider'] {
|
|
||||||
width: 60%;
|
|
||||||
float: right;
|
|
||||||
margin: 0 2rem 0 0;
|
|
||||||
|
|
||||||
div {
|
|
||||||
overflow: visible;
|
|
||||||
button {
|
|
||||||
margin-top: -3.4rem;
|
|
||||||
left: 0%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
hr {
|
|
||||||
clear: both;
|
|
||||||
padding: 0.7rem 0;
|
|
||||||
margin-bottom: 0.7rem;
|
|
||||||
border: none;
|
|
||||||
border-bottom: 1px solid rgba(255,255,255,0.3);
|
|
||||||
}
|
|
||||||
*[class^='icon'] {
|
|
||||||
display: block;
|
|
||||||
margin: 1rem 0.5rem;
|
|
||||||
|
|
||||||
&:nth-of-type(2) {
|
|
||||||
padding-top: 0.5rem;
|
|
||||||
}
|
|
||||||
&:before {
|
|
||||||
content: '';
|
|
||||||
background-size: 2rem;
|
|
||||||
width: 2rem;
|
|
||||||
height: 2rem;
|
|
||||||
display: block;
|
|
||||||
float: left;
|
|
||||||
margin: -0.3rem 0.5rem 0 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.icon-settings:before {
|
|
||||||
background-image: url('imgs/settings.png');
|
|
||||||
}
|
|
||||||
.icon-clear:before {
|
|
||||||
background-image: url('imgs/clear.png');
|
|
||||||
}
|
|
||||||
.icon-undo:before {
|
|
||||||
background-image: url('imgs/undo.png');
|
|
||||||
}
|
|
||||||
.icon-redo:before {
|
|
||||||
background-image: url('imgs/redo.png');
|
|
||||||
}
|
|
||||||
|
|
||||||
.options {
|
|
||||||
display: table-row;
|
|
||||||
vertical-align: top;
|
|
||||||
margin-top: 1rem;
|
|
||||||
}
|
|
||||||
.bottom {
|
|
||||||
width: 100%;
|
|
||||||
position: absolute;
|
|
||||||
bottom: 5rem;
|
|
||||||
button[class^='icon'] {
|
|
||||||
margin-left: 3.5rem;
|
|
||||||
}
|
|
||||||
button {
|
|
||||||
margin-left: 5rem;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
@ -1,94 +0,0 @@
|
|||||||
/* ----------------------------------
|
|
||||||
* CHECKBOXES / RADIOS
|
|
||||||
* ---------------------------------- */
|
|
||||||
|
|
||||||
label.pack-checkbox,
|
|
||||||
label.pack-radio,
|
|
||||||
label.pack-switch {
|
|
||||||
display: inline-block;
|
|
||||||
vertical-align: middle;
|
|
||||||
width: 5rem;
|
|
||||||
height: 5rem;
|
|
||||||
position: relative;
|
|
||||||
background: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
label.pack-checkbox input,
|
|
||||||
label.pack-radio input,
|
|
||||||
label.pack-switch input {
|
|
||||||
margin: 0;
|
|
||||||
opacity: 0;
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
label.pack-checkbox input ~ span:after,
|
|
||||||
label.pack-radio input ~ span:after {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
|
||||||
left: 50%;
|
|
||||||
top: 50%;
|
|
||||||
margin: -1.1rem 0 0 -1.1rem;
|
|
||||||
width: 2.2rem;
|
|
||||||
height: 2.2rem;
|
|
||||||
pointer-events: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
label.pack-checkbox input ~ span:after {
|
|
||||||
background: url(switches/images/check/default.png) no-repeat center top / 2.2rem auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
label.pack-radio input ~ span:after {
|
|
||||||
background: url(switches/images/radio/default.png) no-repeat center top / 2.2rem auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
label.pack-checkbox input:checked ~ span:after,
|
|
||||||
label.pack-radio input:checked ~ span:after,
|
|
||||||
label.pack-switch input:checked ~ span:after {
|
|
||||||
background-position: center bottom;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* 'Dangerous' switches */
|
|
||||||
|
|
||||||
label.pack-checkbox.danger input ~ span:after {
|
|
||||||
background-image: url(switches/images/check/danger.png);
|
|
||||||
}
|
|
||||||
|
|
||||||
label.pack-radio.danger input ~ span:after {
|
|
||||||
background-image: url(switches/images/radio/danger.png);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* ----------------------------------
|
|
||||||
* ON/OFF SWITCHES
|
|
||||||
* ---------------------------------- */
|
|
||||||
|
|
||||||
label.pack-switch input ~ span:after {
|
|
||||||
content: '';
|
|
||||||
position: absolute;
|
|
||||||
right: 0;
|
|
||||||
top: 50%;
|
|
||||||
width: 6rem;
|
|
||||||
margin: -1.4rem 0rem 0rem;
|
|
||||||
height: 2.7rem;
|
|
||||||
pointer-events: none;
|
|
||||||
border-radius: 1.35rem;
|
|
||||||
overflow: hidden;
|
|
||||||
background: #e6e6e6 url(switches/images/switch/background_off.png) no-repeat -3.2rem 0rem / 9.2rem 2.7rem;
|
|
||||||
transition: background 0.2s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* switch: 'ON' state */
|
|
||||||
label.pack-switch input:checked ~ span:after {
|
|
||||||
background: #e6e6e6 url(switches/images/switch/background.png) no-repeat 0rem 0rem / 9.2rem 2.7rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* switch: disabled state */
|
|
||||||
label.pack-switch input:disabled ~ span:after {
|
|
||||||
opacity: 0.4;
|
|
||||||
}
|
|
||||||
|
|
||||||
label.pack-switch input.uninit ~ span:after {
|
|
||||||
transition: none;
|
|
||||||
}
|
|
@ -1,204 +0,0 @@
|
|||||||
/* ----------------------------------
|
|
||||||
* Value selector (Single & Multiple)
|
|
||||||
* ---------------------------------- */
|
|
||||||
|
|
||||||
/* Main dialog setup */
|
|
||||||
form[role="dialog"][data-type="value-selector"] {
|
|
||||||
background: url(value_selector/images/ui/pattern.png) repeat left top, url(value_selector/images/ui/gradient.png) no-repeat left top / 100% 100%;
|
|
||||||
overflow: hidden;
|
|
||||||
position: absolute;
|
|
||||||
z-index: 100;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
padding: 0 0 7rem;
|
|
||||||
color: #fff;
|
|
||||||
font-family: sans-serif;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] > section {
|
|
||||||
padding: 0 1.5rem 0;
|
|
||||||
-moz-box-sizing: padding-box;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
overflow: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] h1 {
|
|
||||||
font-weight: 400;
|
|
||||||
font-size: 1.9rem;
|
|
||||||
line-height: 4.8rem;
|
|
||||||
color: #fff;
|
|
||||||
border-bottom: 0.1rem solid #616262;
|
|
||||||
background: rgba(0 ,0, 0, .2);
|
|
||||||
margin: 0 -1.5rem;
|
|
||||||
padding: 0 3rem 1rem;
|
|
||||||
height: 4.8rem;
|
|
||||||
-moz-box-sizing: border-box;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Specific component code */
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] {
|
|
||||||
position: relative;
|
|
||||||
padding: 0;
|
|
||||||
margin: 0 -1.5rem;
|
|
||||||
max-height: calc(100% - 5rem);
|
|
||||||
overflow: auto;
|
|
||||||
border-top: solid 0.1rem #222323;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] .scrollable:before {
|
|
||||||
content: "";
|
|
||||||
display: block;
|
|
||||||
position: absolute;
|
|
||||||
pointer-events: none;
|
|
||||||
top: 4.8rem;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
bottom: 6.9rem;
|
|
||||||
background: url(value_selector/images/ui/shadow.png) repeat-x left top, url(value_selector/images/ui/shadow-invert.png) repeat-x left bottom;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0 1.5rem;
|
|
||||||
height: auto;
|
|
||||||
list-style: none;
|
|
||||||
position: relative;
|
|
||||||
font-weight: lighter;
|
|
||||||
font-size: 2.2rem;
|
|
||||||
line-height: 3.9rem;
|
|
||||||
color: #fff;
|
|
||||||
transition: background-color 0.2s ease;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li:first-child label {
|
|
||||||
border-top-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li label {
|
|
||||||
outline: none;
|
|
||||||
display: block;
|
|
||||||
color: #fff;
|
|
||||||
border-top: 0.1rem solid #666;
|
|
||||||
border-bottom: 0.1rem solid #000;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li:last-child label {
|
|
||||||
border-bottom-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li label span {
|
|
||||||
display: block;
|
|
||||||
padding: 1rem 1.5rem;
|
|
||||||
line-height: 4rem;
|
|
||||||
word-wrap: break-word;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Pressed status */
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li:active {
|
|
||||||
background-color: #00ABCC;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li:active label {
|
|
||||||
border-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li:active + li label {
|
|
||||||
border-top-color: #000;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li:active label span {
|
|
||||||
color: #fff !important;
|
|
||||||
background-image: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Checked status */
|
|
||||||
form[role="dialog"][data-type="value-selector"] [role="listbox"] li[aria-selected="true"]:not([data-input]) span {
|
|
||||||
padding-right: 2.6rem;
|
|
||||||
margin-right: 1.2rem;
|
|
||||||
color: #00abcd;
|
|
||||||
background: transparent url(value_selector/images/icons/checked.png) no-repeat 100% 50%;
|
|
||||||
background-size: 2rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* Menu & buttons setup */
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu {
|
|
||||||
white-space: nowrap;
|
|
||||||
margin: 0;
|
|
||||||
padding: 1.5rem;
|
|
||||||
border-top: solid 0.1rem rgba(255, 255, 255, 0.1);
|
|
||||||
background: #2d2d2d url(value_selector/images/ui/pattern.png) repeat left top;
|
|
||||||
display: block;
|
|
||||||
overflow: hidden;
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu button::-moz-focus-inner {
|
|
||||||
border: none;
|
|
||||||
outline: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu button, .button {
|
|
||||||
width: calc((100% - 1rem) / 2);
|
|
||||||
height: 3.8rem;
|
|
||||||
margin: 0 0 1rem;
|
|
||||||
padding: 0 1.5rem;
|
|
||||||
-moz-box-sizing: border-box;
|
|
||||||
display: inline-block;
|
|
||||||
vertical-align: middle;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
white-space: nowrap;
|
|
||||||
overflow: hidden;
|
|
||||||
background: #fafafa url(value_selector/images/ui/default.png) repeat-x left bottom/ auto 100%;
|
|
||||||
border: 0.1rem solid #a6a6a6;
|
|
||||||
border-radius: 0.3rem;
|
|
||||||
font-weight: 500;
|
|
||||||
font-size: 1.6rem;
|
|
||||||
line-height: 3.8rem;
|
|
||||||
color: #333;
|
|
||||||
text-align: center;
|
|
||||||
text-shadow: 0.1rem 0.1rem 0 rgba(255,255,255,0.3);
|
|
||||||
text-decoration: none;
|
|
||||||
outline: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Press (default & affirmative) */
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu button:active,
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu button.affirmative:active, .button:active {
|
|
||||||
border-color: #008aaa;
|
|
||||||
background: #008aaa;
|
|
||||||
color: #333;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* affirmative */
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu button.affirmative, .button.affirmative {
|
|
||||||
background-image: url(value_selector/images/ui/affirmative.png);
|
|
||||||
background-color: #00caf2;
|
|
||||||
border-color: #008eab;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu button:last-child {
|
|
||||||
margin-left: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu button,
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu button:first-child {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
form[role="dialog"][data-type="value-selector"] menu button.full, .button.full {
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Right to left tweaks */
|
|
||||||
html[dir="rtl"] #value-selector li input:checked + span,
|
|
||||||
html[dir="rtl"] #value-selector li[aria-selected="true"] span {
|
|
||||||
padding-left: 2.6rem;
|
|
||||||
margin-left: 1.2rem;
|
|
||||||
}
|
|
Before Width: | Height: | Size: 4.3 KiB |
Before Width: | Height: | Size: 8.0 KiB |
Before Width: | Height: | Size: 8.9 KiB |
Before Width: | Height: | Size: 738 B |
Before Width: | Height: | Size: 7.2 KiB |
@ -1,102 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
|
||||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
|
||||||
|
|
||||||
<svg
|
|
||||||
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
|
||||||
xmlns:cc="http://creativecommons.org/ns#"
|
|
||||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
|
||||||
xmlns:svg="http://www.w3.org/2000/svg"
|
|
||||||
xmlns="http://www.w3.org/2000/svg"
|
|
||||||
xmlns:xlink="http://www.w3.org/1999/xlink"
|
|
||||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
|
||||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
|
||||||
width="60"
|
|
||||||
height="60"
|
|
||||||
id="svg3029"
|
|
||||||
version="1.1"
|
|
||||||
inkscape:version="0.48.4 r9939"
|
|
||||||
sodipodi:docname="icon2.svg"
|
|
||||||
inkscape:export-filename="/home/mahdi/Documents/Workshop/Mobile Editor/img/icons/icon128.png"
|
|
||||||
inkscape:export-xdpi="192"
|
|
||||||
inkscape:export-ydpi="192">
|
|
||||||
<defs
|
|
||||||
id="defs3031" />
|
|
||||||
<sodipodi:namedview
|
|
||||||
id="base"
|
|
||||||
pagecolor="#ffffff"
|
|
||||||
bordercolor="#666666"
|
|
||||||
borderopacity="1.0"
|
|
||||||
inkscape:pageopacity="0.0"
|
|
||||||
inkscape:pageshadow="2"
|
|
||||||
inkscape:zoom="1"
|
|
||||||
inkscape:cx="-103.49318"
|
|
||||||
inkscape:cy="83.371075"
|
|
||||||
inkscape:current-layer="layer1"
|
|
||||||
showgrid="true"
|
|
||||||
inkscape:grid-bbox="true"
|
|
||||||
inkscape:document-units="px"
|
|
||||||
inkscape:window-width="1600"
|
|
||||||
inkscape:window-height="876"
|
|
||||||
inkscape:window-x="0"
|
|
||||||
inkscape:window-y="24"
|
|
||||||
inkscape:window-maximized="1" />
|
|
||||||
<metadata
|
|
||||||
id="metadata3034">
|
|
||||||
<rdf:RDF>
|
|
||||||
<cc:Work
|
|
||||||
rdf:about="">
|
|
||||||
<dc:format>image/svg+xml</dc:format>
|
|
||||||
<dc:type
|
|
||||||
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
|
||||||
<dc:title />
|
|
||||||
</cc:Work>
|
|
||||||
</rdf:RDF>
|
|
||||||
</metadata>
|
|
||||||
<g
|
|
||||||
id="layer1"
|
|
||||||
inkscape:label="Layer 1"
|
|
||||||
inkscape:groupmode="layer"
|
|
||||||
transform="translate(0,12)">
|
|
||||||
<path
|
|
||||||
sodipodi:type="arc"
|
|
||||||
style="fill:#636363;fill-opacity:1;stroke:none"
|
|
||||||
id="path3037"
|
|
||||||
sodipodi:cx="31.428572"
|
|
||||||
sodipodi:cy="29.285715"
|
|
||||||
sodipodi:rx="26.428572"
|
|
||||||
sodipodi:ry="26.428572"
|
|
||||||
d="m 57.857143,29.285715 c 0,14.596097 -11.832474,26.428572 -26.428571,26.428572 C 16.832475,55.714287 5,43.881812 5,29.285715 5,14.689618 16.832475,2.8571434 31.428572,2.8571434 c 14.596097,0 26.428571,11.8324746 26.428571,26.4285716 z"
|
|
||||||
transform="matrix(1.0972973,0,0,1.0972973,-4.4864869,-14.135136)" />
|
|
||||||
<path
|
|
||||||
style="fill:#dedede;fill-opacity:1;stroke:#383838;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1"
|
|
||||||
d="m 40.415998,-0.2045792 c 0,0 -22.715805,23.0693572 -23.422911,25.0139012 -0.707107,1.944544 -2.740039,7.601398 -2.032932,8.485281 0.707106,0.883883 7.689786,-1.502602 9.015611,-2.828427 C 25.301591,29.140351 47.60072,6.06032 47.840618,4.833556 48.06427,3.68987 41.877086,-1.6684275 40.415998,-0.2045792 z"
|
|
||||||
id="path3054"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="cssssc" />
|
|
||||||
<path
|
|
||||||
style="fill:#9e9e9e;fill-opacity:1;stroke:none"
|
|
||||||
d="m 44.875383,3.203193 c 0,0 -23.929105,24.058149 -24.015804,24.932991 -0.0867,0.874841 1.387194,2.71201 1.820692,2.187104 C 23.11377,29.798383 46.435977,5.9152018 46.522677,5.0403605 46.609378,4.1655182 45.222182,3.2906768 44.875383,3.203193 z"
|
|
||||||
id="path3841"
|
|
||||||
inkscape:connector-curvature="0" />
|
|
||||||
<path
|
|
||||||
style="fill:#c0c0c0;fill-opacity:1;stroke:none"
|
|
||||||
d="m 42.401427,1.6217284 c 0,0 -23.399153,24.3933116 -23.394823,24.6432736 0.0043,0.249963 1.094444,1.292086 1.650364,0.907398 0.55592,-0.384687 23.207727,-24.0757977 23.264805,-24.3893335 0.05708,-0.3135357 -1.2693,-1.1031781 -1.520346,-1.1613381 z"
|
|
||||||
id="path3861"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
sodipodi:nodetypes="ccssc" />
|
|
||||||
<path
|
|
||||||
style="fill:#494949;fill-opacity:1;stroke:none"
|
|
||||||
d="m 15.695313,42.429687 c 0,0 -0.515625,1.960938 -0.359375,2.539063 0.0078,0 0.141085,0.342965 2.430147,-0.344535 -0.01563,0.0078 -0.647057,-2.041553 -2.070772,-2.194528 z"
|
|
||||||
id="path3865"
|
|
||||||
inkscape:connector-curvature="0"
|
|
||||||
transform="translate(0,-12)"
|
|
||||||
sodipodi:nodetypes="cccc" />
|
|
||||||
<image
|
|
||||||
y="-11.715099"
|
|
||||||
x="0.21543235"
|
|
||||||
id="image3962"
|
|
||||||
xlink:href=" aIHlm01MG+kZx3/vjIevNTEfNhvA3RqWbmirqKcGlMKlbZRL0kMPrSqUgIxCyIVISc45IUWRckmv vVXNIWqVNjRqN60qVZuqXdE0yiZebdRslV3YJSZmiw3YgzHD9PB6YuPYMLbHHqT+pUfGlud9n5+f 93nejxmEaZr8P0lx24F6y1ODNkWJz/cbSpVeV5acAhZ5ZuZZOSr8vtWeUkWbb0hUmcOWQwLYccqp In3kg1v9VNZYFcBq1okdwKi0kXr3WQmwADTkr7yN8xG1078n+5opt/9ygVUk7HbW3JQnaxnKiHY5 wB4kbBo5pA6CFKARCW0rAHbn4YasHSRYkL6kyfm3r+wAW43pHCxYSzu3bt3afPbsWfPc3Fzzfl/e b0hrQDOwwQGBFUJYRUvLvqqAEggExNmzZ72apsWuXbuWLHX9XhFWgbeAFAcAVgjRIIRoBToAH9CC HHkqIGKxGHNzc7qmaW/Pzs6WHN6lgAXQCmziYjUWUi1CiE4kZBO5hc4b9vz58535+fktRVF6rl69 WnSpWgq4Jfu66SiBTVmgQCfgJRtFO3b//v2tly9fehobG/3F2i4GbA3ldadB7EgI0YAEbaUM0Hy7 c+dOUlGUrps3b74xtIsB+5AVuV7LReB1VH3IHLVWUhXZ0tKSGYlENtPpdG9hP4XAVlUuWeVqISGE B/AjU6li0Hy7e/eurqpq2/Xr15vy+yoE9iFh61aVhRCNQAD5YzsCC4hkMkkkEkl5vd5dUVYK/vZS x9zNFiY/uV2Qo3bv3j0d8M/Pz6tWn/nAXmRVrkvu5lXhktNMtbaysmJGo9HMw4cPA1a/+cDWcK65 hBDNyMg6HtVCe/z4sa4oymGrbwtYIAtGzYGz004XNYxsvj148CCtqmr77du3FcidabUgt1g1LVZC CAV4G5mzdVEikWB1ddU0DKMd+MqK8FvUZ1UVQO5faz6U8y0ajW4h53fqBiyE8CLrRF1hAWVxcTGj adqhfOBmYKuGsAKZt67o1atXr4GtHG6khsDI6cfWiUQttLi4aGRH2C7gmmwDs4XKmm9d0fLysqko ShPkgDVqV6E7s+27plQqZS1hXwNb2zBHz5izuRvAxegCaJomFEXxQA7YJHfG66R8uJi7ltra2jxm 9vDOAt6hNsAduBxdgI6ODs0wjF3AGWTh0p3qJFusfMhUcVWHDx9uUFV1E3LAm8jFR9zBfqwjGtcV DAZbDMNYgxzwBjIaXzrYj48DAhwKhXymaX4OufyKI6cPJ9VKHXZDdqynp6dN1/Uo5CL8X6At+96p BYiXA1CwfD6f6vf7W6PR6Bewu0onkFu3qoe1EELD5cWGpRMnTnSaprk8MzOTgd3PeHwJfB1n8ti6 Q+C6jh071qPr+iPrfb5Ti0AvcnqqVg24sA0stK6ursa+vj5/Op1+Ugx4C1gC3nMAuKqDdKdsbGys d3t7+9Pz58+nigEDfAx8m+rzz/Xoer1ez9DQUH88Hv8g37HC57TiwDLwTeAJ1cnVHD537lzIMIyF 6enpL/I/L+bUQ+AouTuIlcjExaEcCoWaRkdH+3Rdv1voWDHgdeATYKQK4AwuDudLly4dTaVSH05O TsbsAAN8hFwaDlYInHYLNhwOv9Pb2+tJJpN/LOZYKWAD+BNwHHmHoFzpbsAODw+3nT59ejAej/9i amqq6FZ3r8KSAD4ATiGXibZlmqaB3IHVLW8HBgaar1y5ciyRSPw6HA6/LOXbfpX0U+AR8GPkUW45 WqsXbDAYbJqdnf1eKpV6f3x8/B97OWVn6ngC/Bv4KXDIPi+r9YAdHBxsuXHjxohpmn8/c+bM+/s5 Zfd56Q+RK7GfAb8FXtm4JkaN5+Ljx4/7Ll++PKTr+h/GxsZ+b+each4Qf4Q8KPgJ8ABZyUvKNM24 EGKT8lPBli5cuBA6derUe7FY7Ffj4+N/s3tdJY8PdwA/Qha1vyBztXjjQnwH+Ea5HeylI0eOtMzM zBwNBoPEYrGfT05OLpZzfaUPiKvAEPBdYB65OntjGhBCtAM/rKSDQvl8PnV6evrdkZGRd9fX1/+8 vr7+m1JTz16q9l8A2oDvA18D/pW1XSefQogfUMXxUXd3d8PExET/8PBwv2EYz1ZXV38ZDoeXKm2v WmBLXciIHwE+B54CL4C0EKKXMpepnZ2dnpMnT3aNjo6+EwqFOjc2Nj7a2Nj43cTExH+qddQpYEvN wLeQS9JeYAVYuHjx4sDTp0+VhYUFPRqNbiWTSUPTNNHR0aG1t7d7uru7m0KhkLevr+9Qf3+/PxAI eHVd/2xtbe2fuq7/dWpqKuGUg04D50sFgkAwEokMvHjx4qimaa2qqrYoitIAsLOzs2UYRiqTySQz mcxKOp1e0HX9k+3t7SeV5Kcd1RL4QOp/GtofUQrANYgAAAAASUVORK5CYII= "
|
|
||||||
height="60"
|
|
||||||
width="60" />
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
Before Width: | Height: | Size: 6.6 KiB |
Before Width: | Height: | Size: 1.6 KiB |
Before Width: | Height: | Size: 2.7 KiB |
Before Width: | Height: | Size: 3.7 KiB |