/* Were tälking UTF8 */ // GLOBALS var LOG = false; //false; // ENABLE LOGGING var PRLOG = false; //false; /** PRICE LOG - REMOVE COMMENTS **/ var INPUTDELAY = 650; // MilliseconCs var FLOATDELAY = 1300 // Milliseconds for Float Inputs var SCONFIG = ''; var PHPCALC = false; /** ENABLES PHP + JS CALC COMPARE MODE - MUST BE OFF IN LIVE MODE **/ var xhr = ''; var canvas = new Object(); var bgLayer = new Object(); var WORKSPACE = { width: 550, height: 300, color:'#000000', bgcolor:'#ffffff', border: 0, borderDistance: 20, selectorPadding: 0, selectorCornerSize: 10, selectorBorderColor: '#007fe1', selectorCornerColor: '#007fe1', selectorCornerStyle: 'circle', selectorCornerTransparent: false, selectorSerienText : '#673086', selectBorderStrokeWidth: 1.5, selectBorderStrokeColor: '#007fe1', //'rgba(200,0,0,1)', selectBorderStrokeDashWidth: 5, veredelungDefault: 0, // 0=Gravur, 1=Druck scale:'1:1', scaleFac:1, dimMax:600, dimMin:300, //cutFormColor: 'rgba(220,220,220,1)', //'rgba(241,241,241,1)' cornerRadius: 3, // in mmm }; var delay = (function(){ var timer = 0; return function(callback, ms){ clearTimeout (timer); timer = setTimeout(callback, ms); }; })(); $.ajaxSetup({ cache: false }); /** ---------------------------------------------------------------------------*/ /** INIT EVENTS */ /** ---------------------------------------------------------------------------*/ $(document).ready(function() { SCONFIG = $('#JSCONFIG').val(); fabric.Object.NUM_FRACTION_DIGITS = 17; fabric.textureSize = 4096; //if (fabric.isWebglSupported()) fabric.textureSize = 65536; if(document.getElementById('lcWorkSpace')===null) { } else { canvas = this.__canvas = new fabric.Canvas('lcWorkSpace'); // CANVAS EVENTS canvas.on({ //'object:moving': function () { updateObjControls('obj_moving')}, //'object:scaling': function () { updateObjControls('obj_scaling')}, //'object:resizing': function () { updateObjControls('obj_resizing')}, //'object:rotating': function () { updateObjControls('obj_rotating')}, //'object:selected': function () { updateObjControls('obj_selected')}, //'object:modified': function () { updateObjControls('obj_modified')}, 'selection:created': function () { var obj = canvas.getActiveObject(); if(obj) { obj.set({'strokeWidth': WORKSPACE.selectBorderStrokeWidth}); } //updateObjControls('selection:created') }, //'selection:updated': function () { updateObjControls('selection:updated')}, //'selection:cleared': function () { updateObjControls('selection:cleared')}, 'before:selection:cleared': function () { var obj = canvas.getActiveObject(); if(obj) { obj.set({'strokeWidth': 0}); } //hideObjControls }, //'text:editing:entered': function () { LOG && console.log('Event: text_editing_entered'); }, //'text:editing:exited': function () { LOG && console.log('Event: text_editing_exited'); }, //'text:selection:changed': function () { LOG && console.log('Event: text_editing_changed'); }, //'text:changed': function () { LOG && console.log('Event: text_changed'); }, //'mouse:up': function() // { // var obj = canvas.getActiveObject(); // if(obj) { calculateSign('Event: mouse up',0); } // }, 'after:render': function(){ this.calcOffset(); } }); canvas.stateful = false; // Increases speed (if undone function not needed) /** canvas.selection = false; **/ canvas.controlsAboveOverlay = true; //canvas.renderOnAddRemove = false; // better? canvas.setWidth($('#lcWorkSpace').width()); canvas.setHeight($('#lcWorkSpace').height()); } // BEFOREUNLOAD $(window).on('beforeunload', function(){ // SAVE SIGNS IN TMP //if(SIGN.calculateOnUnload==1) //{ // if(window.location.href== '') // { // $.when(calculateSign('fromUnloadEvent()',1)).done(function(ev) { // return true; // }); // } //} console.log('FROM WINDOW UNLOAD: SAVE ENTWURF OR NOT!?!?'); //return 'Are you sure you want to leave?'; }); /** REMOVE OBJ ON DEL KEY **/ $('html').keyup(function(e) { if(e.keyCode == 46) { var hasFocus=0; $("input").each(function() { if($(this).is(':focus')) { hasFocus=1; }}); $("textarea").each(function() { if($(this).is(':focus')) { hasFocus=1; }}); if(hasFocus==0) { removeLastObj('Remove from KeyEvent'); } } }); // INIT IMAGE UPLOADER $('#lcwork').on('change','#image-upload', function() { //var file =this.files[0]; var ext = this.files[0].name.substr((this.files[0].name.lastIndexOf('.') +1)).toLowerCase(); //var ext = file.name.substr((file.name.lastIndexOf('.') +1)); // size check //if(this.files[0].size>8388608) if(this.files[0].size > 16777216) //if(this.files[0].size>2097152) { alert('Die angegebene Datei ist größer als 16MB.\nBitte beachten Sie die maximale Dateigröße.'); //parent.scroll(0,0); //showModalInfoWin("Dateigröß überschritten","Das Bild konnte nicht heraufgeladen werden. Die maximale Dateigröße; beträgt 8MB."); } else if(ext!='svg' && ext!='jpg' && ext!='jpeg' && ext!='png' && ext!='eps') { alert('Derzeit können nur Dateien vom Typ "SVG","JPEG","PNG" und "EPS" heraufgeladen werden.'); //parent.scroll(0,0); //showModalInfoWin("Dateiformat ungültig","Derzeit können nur Dateien vom Typ \"SVG\", \"JPEG\" und \"EPS\" heraufgeladen werden."); } else { uploadWin.open(); uploadImage(this.files[0],1); } // reset upload input $('#image-upload').val(''); }); // IMAGE Remover (AJAX) $('#lcwork').on('click','.imgDBRemove', function() { var id = $(this).data('id'); var parent = $(this).parent().closest('.imgDB'); var active = $(this).next('div.imgDBActive'); $(parent).css({'background-image':'url("https://www.werbekollektion.de/xshop/icons/ajax-loader.gif")','background-size':'20px'}); $.ajax({ url: 'https://www.werbekollektion.de/scripts/shop.warenkorb-io.php', type: 'GET', cache: false, dataType: "text", data: {'com': 'removeUploads', id: id}, error: function(em) { //return true; }, success: function(em) { //alert(em) if($(active).is(':hidden')) { } else { removeLastObj('ImageRemover'); lcWorkFileHide(); } $(parent).remove(); return false; } }); return false; }); // IMAGE Adder $('#lcwork').on('click','.imgDB', function() { $('.uploadLogoArea').each(function() { $('.imgDBActive').hide(); }); $(this).find('.imgDBActive').show(); resetCanvas(); var img = $(this).data('img'); //$.when(addImage(img,1)).done(function(ev) { recalcImageContainer(); showHideContainer(); initWorkspace('',0); }); $.when(addImage(img,1)).done(function(ev) { initWorkspace('',0); }); }); // Remove Entwurf $('#lcremoveDesign').on('click',function() { canvas.clear(); $('.uploadLogoArea').each(function() { $('.imgDBActive').hide(); }); $('#lcWorkSpaceContainer').hide(); // SET LCWORKFILE lcWorkFileHide(); }); // FILTER $('#gravur').on('click',function() { $(this).addClass('active'); $(this).data('active',1); $('#cmyk').removeClass('active'); $('#cmyk').data('active',0); $('#lcremoveBG').addClass('active'); refreshFilter(); }); $('#cmyk').on('click',function() { $(this).addClass('active'); $(this).data('active',1); $('#gravur').removeClass('active'); $('#gravur').data('active',0); refreshFilter(); }); $('#lcscaleBG').on('click',function() { if($('.vsliderContainer').is(':hidden')) { $(this).addClass('active'); $('.vsliderContainer').show(); } else { $(this).removeClass('active'); $('.vsliderContainer').hide(); } }); $('.verticalSlider').on('input',function() { zoomLevel = ($(this).val() / 20) + 1; canvas.zoomToPoint(new fabric.Point(canvas.width / 2, canvas.height / 2), zoomLevel); //canvas.getZoom() / zoom }); $('#lcremoveBG').on('click',function() { var obj = canvas.item(0); if(obj) { obj.filters.push(filterRemoveWhite()); obj.applyFilters() canvas.renderAll(); $(this).addClass('active'); } }); $('#lcreset').on('click',function() { //$('.uploadLogoArea').each(function() { if($('.imgDBActive').is(':visible')) { $(this).trigger('click'); }} ) $('.imgDBActive:visible').trigger('click'); }); }); function recalcImageContainer() { var cWidth = $('.stdShopImageLarge').width(); var cHeight = $('.stdShopImageLarge').height(); //console.log('IMG_REAL_SIZE:' + $('#prodImage').width() + ',' + $('#prodImage').height()); //console.log('CONTAINER_SIZE:' + cWidth + ',' + cHeight); // CHEIGHT ALWAYS = 400 $('#lcWorkSpaceContainer').css({'width':$('.stdShopImageLarge').width()}); } /* RESIZE ACTION */ var resizeIcon = ""; var imgResize = document.createElement('img'); imgResize.src = resizeIcon; fabric.Object.prototype.controls.mbr = new fabric.Control({ x: 0.5, y: 0.5, offsetY: 0, cursorStyle: 'pointer', actionHandler: fabric.controlsUtils.scalingEqually, actionName: 'scale', render: renderIcon(imgResize), cornerSize: 40, /*padding:200,*/ withConnection: true }); /* ROTATE ICON */ var rotateIcon = ""; var imgRotate = document.createElement('img'); imgRotate.src = rotateIcon; fabric.Object.prototype.controls.mtr = new fabric.Control({ x: 0.5, y: -0.5, offsetY: 0, cursorStyle: 'pointer', actionHandler: fabric.controlsUtils.rotationWithSnapping, actionName: 'rotate', render: renderIcon(imgRotate), cornerSize: 40, withConnection: true }); function deleteObject(eventData, transform) { var target = transform.target; var canvas = target.canvas; canvas.remove(target); canvas.requestRenderAll(); } function skewObject(eventData, transform) { var target = transform.target; var canvas = target.canvas; var pointer = canvas.getPointer(event.e); var posX = pointer.x; var posY = pointer.y; console.log(posX+", "+posY); //console.log(eventData); //canvas.remove(target); canvas.requestRenderAll(); } function renderIcon(icon) { return function renderIcon(ctx, left, top, styleOverride, fabricObject) { var size = this.cornerSize; ctx.save(); ctx.translate(left, top); ctx.rotate(fabric.util.degreesToRadians(fabricObject.angle)); ctx.drawImage(icon, -size/2, -size/2, size, size); ctx.restore(); } } /** ---------------------------------------------------------------------------*/ /** */ /** INIT WORKSPACE */ /** */ /** ---------------------------------------------------------------------------*/ function initWorkspace(json,reloadFromJS) { LOG && console.log('initWorkspace'); if(reloadFromJS!=1) { canvas.clear(); } $('#lcWorkSpace').hide(); recalcImageContainer(); canvas.setWidth($('#lcWorkSpaceContainer').width()); canvas.setHeight($('#lcWorkSpaceContainer').height()); resetCanvas(); //$('.uploadLogoArea').each(function() { $('.imgDBActive').hide(); }); if(json.length > 0) { json = json.replace(/'/g,"\'"); //json = json.replace(/"/g,'\\"'); json = json.replace(/\n/g, "\\n"); //json=replace json = json.replace(/\r/g, "\\r"); //json=replace LOG && console.log('initSign from JSON (PHP)'); //console.log(json); //var start = timer(0); // canvas.loadFromJSON(json, canvas.renderAll.bind(canvas), function(o, object) { // var start = timer(0); // var tdiff = timer(start); // LOG && console.log(o,object); // 'Object loaded in: ' +tdiff + ', Object:' + fabric.log(o, object)); // }); canvas.loadFromJSON(json, function () { //canvas.forEachObject(function(o) { //console.log('JSON: ObjType: ' + o.type); //console.log(o.type); //if (o.type === 'image' && o.filters.length !== 0) { // o.applyFilters(canvas2.renderAll.bind(canvas2)); //} // }); }); //var tdiff = timer(start); //LOG && console.log('JSON loads in: ' +tdiff); //canvas.loadFromDatalessJSON(json, canvas.renderAll.bind(canvas), function(o, object) { // fabric.log(o, object); //}); } else { LOG && console.log('init from JS'); } delay(function() { // CAUSE IMAGES IN JSON ARE NOT LOADED PROPERLY var startdelay = timer(0); //for(x=2; x 0) { if(toCanvas==1) { addImage(xhr.responseText,0); //showHideContainer(); initWorkspace('',0); } //$.when(addImageFunction()).done(function(ev) { showHideContainer(); }); uploadWin.enable(); uploadWin.close(); if(toCanvas==0) // IMAGE UPLOAD IN WK { return xhr.responseText; } } else { if(xhr.responseText.length > 0) { resultError = xhr.responseText.split('|'); } if(resultError[0]) { errorMessage= 'File/Reason: ' + resultError[0] + '
'; } if(resultError[1]) { errorMessage= errorMessage + 'Error: ' + resultError[1] + ''; } uploadWin.enable(); $('.loaderError').show(); $('.loader2').hide(); $('.loaderError').html('Es ist ein Fehler bei der Übertragung aufgetreten:
' + errorMessage + '

'); //xhr.abort(); } } } var formData = new FormData(); formData.append('file', file); xhr.send(formData); } function setBackgroundImage() { var timestamp = new Date().getTime(); var bgimage = $('.stdShopImageLarge').css('background-image'); bgimage = bgimage.replace('url(','').replace(')','').replace(/\"/gi, ""); var ext = bgimage.substr( (bgimage.lastIndexOf('.') +1) ).toLowerCase(); if(ext=='jpg' || ext=='jpeg' || ext=='png') { fabric.Image.fromURL(bgimage+'?'+timestamp, function(obj) // FORCE BGIMAGE LOADED AGAIN (NOT FROM CACHE -> CHROMIUM BUG) { //fabric.util.loadImage(bgimage+'?'+timestamp, function (img) //{ //var obj = new fabric.Image(img); /* RESIZE TO WORKCONTAINER */ if(obj.width >= canvas.width) { /** CALC NEW RATIO BY WIDTH */ var scaleRatio = canvas.width/obj.width; if((scaleRatio * obj.height) > canvas.height) { scaleRatio= canvas.height/obj.height; } //console.log('scaleRatio:' + scaleRatio); } else { /** CALC NEW RATIO BY HEIGHT */ var scaleRatio = canvas.height/obj.height; if((scaleRatio * obj.width) > canvas.width) { scaleRatio= canvas.width/obj.width; } //console.log('scaleRatio:' + scaleRatio); } canvas.setBackgroundImage(obj, canvas.renderAll.bind(canvas), { scaleX: scaleRatio, scaleY: scaleRatio }); obj.set({centeredScaling: 1, crossOrigin: "anonymous", selectable: false}); //obj.set({lcFilename: image }); //obj.set({centeredScaling: 1, crossOrigin: "anonymous", clipPath: bgLayer, clip_target: 'bgLayer'}); obj.setCoords(); obj.center(); canvas.renderAll.bind(canvas); }, { crossOrigin:'anonymous'}); } else { //alert('not available'); } } function addImage(image,restore) { canvas.clear() setBackgroundImage(); var im = image.split('|'); //console.log('adding image: ' + restore); if(restore==1) { /** NO NEED TO CHECK RESOLUTION */ var resolution = 150; var image=im[0]; } else { tmp = im[0].replace(/\.\.\/\.\.\/.*\/\//,''); image = tmp.replace('..//',''); image = 'https://www.edelstahlbecher.de/' + image; var resolution = parseInt(im[1]); } var timestamp = new Date().getTime(); var ext = image.substr( (image.lastIndexOf('.') +1) ).toLowerCase(); var scaleFactor = 0.8; if(ext=='jpg' || ext=='jpeg' || ext=='png') { fabric.Image.fromURL(image+'?'+timestamp, function(obj) // FORCE IMAGE LOADED AGAIN (NOT FROM CACHE -> CHROMIUM BUG) { //fabric.util.loadImage(image,function (img) //{ //var obj = new fabric.Image(img); formatObjControls(obj,1); removeLastObj('Add Image JPEG/PNG'); if(obj.width >= canvas.width) { /** CALC NEW RATIO BY WIDTH */ var scaleRatio = (canvas.width/obj.width) * scaleFactor; if((scaleRatio * obj.height) > (canvas.height * scaleFactor)) { scaleRatio = (canvas.height/obj.height) * scaleFactor; } //console.log('scaleRatio:' + scaleRatio); } else { /** CALC NEW RATIO BY HEIGHT */ var scaleRatio = (canvas.height/obj.height) * scaleFactor; if((scaleRatio * obj.width) > (canvas.width * scaleFactor)) { scaleRatio= (canvas.width/obj.width) * scaleFactor; } //console.log('scaleRatio:' + scaleRatio); } obj.set({centeredScaling: 1, scaleX: scaleRatio, scaleY: scaleRatio}); obj.set({lcFilename: image }); obj.setCoords(); canvas.add(obj); canvas.renderAll.bind(canvas); canvas.setActiveObject(obj); refreshFilter('jpg'); /* ENABLE REMOVE WHITE FILTER */ $('#lcremoveBG').removeClass('inactive'); $('#lcremoveBG').css('background-image','url(https://www.werbekollektion.de/xshop/icons/lc_removeBg.png)'); /* IS FULL COLOR DIGITALDRUCK FALSE ? */ // if($('#gravur').data('active')==1) { // SET FILTERS // obj.filters.push(filterRemoveWhite()); // obj.filters.push(filterBlendColor(WORKSPACE.color)); // obj.applyFilters() // canvas.renderAll(); // obj.set({ mmkTrueColor: 0 }); } //else //{ obj.set({ mmkTrueColor: 1 }); } //register_mmkTrueColor(obj); centerObjHV(); //if(resolution<150) //{ // alert('inactive for now'); // $('#errorbar').html('Das heraufgeladene Bild ist sehr gering in der Auflösung und kann daher zu Qualitätseinbußen führen.'); // $('#errorbar').show(); //} }, {crossOrigin: 'anonymous'}); } if(ext=='svg') { fabric.loadSVGFromURL(image, function(objects, options) { var obj = fabric.util.groupSVGElements(objects, options); formatObjControls(obj,1); obj.set({ centeredScaling: 1}); obj.set({lcFilename: image }); refreshFilter('svg'); //obj.set({ centeredScaling: 1, clipPath: bgLayer, clip_target: 'bgLayer'}); obj.width>=obj.height ? obj.scaleToWidth(initialWidth) : obj.scaleToWidth(initialHeight); removeLastObj('Add Image SVG'); canvas.add(obj); canvas.renderAll.bind(canvas); canvas.setActiveObject(obj); centerObjHV(); /* DISABLE REMOVE WHITE FILTER */ $('#lcremoveBG').addClass('inactive'); $('#lcremoveBG').css('background-image','url(https://www.werbekollektion.de/xshop/icons/lc_removeBg_inactive.png)'); }); } resetCanvas(); canvas.renderAll(); /** RESTORE IMAGE UPLOAD AREA IF NOT SHOWN ALREADY **/ /** $('.uploadButton').hide(); **/ var uid = guidGenerator(); url = 'http://localhost/eb4/xuser/uploads/test.png?' + '?q=tdiff'; // SET LCWORKFILE $('#lcWorkFile').val(image); $('#userChoiceUploadImage').hide(); $('#userChoiceUploadDesign').show(); $('#userUploadDesignMode').val(1); $('.imgDBAnfrage').css('background-image','url('+url+')'); $('.uploadLogoArea').show(); if(restore==0) { $('.uploadLogoArea').each(function() { $('.imgDBActive').hide(); }); $('.uploadLogoArea').append('
'); } return true; } function formatObjControls(obj,mode) { obj['setControlVisible']('tl',0); //obj['setControlVisible']('mtl',0); //obj['setControlVisible']('mb',0); obj['setControlVisible']('bl',0); //obj['setControlVisible']('mbr',0); // obj['setControlVisible']('mr',0); //obj['setControlVisible']('mt',0); obj['hasBorders']= 0; //WORKSPACE.selectorPadding; //4; obj['padding']= WORKSPACE.selectorPadding; //4; obj['cornerSize']=WORKSPACE.selectorCornerSize; //8 obj['borderColor']=WORKSPACE.selectorBorderColor; obj['cornerColor']=WORKSPACE.selectorCornerColor; obj['cornerStyle']=WORKSPACE.selectorCornerStyle; obj['transparentCorners'] = WORKSPACE.selectorCornerTransparent; obj['stroke'] = WORKSPACE.selectBorderStrokeColor; obj['strokeDashArray'] = [WORKSPACE.selectBorderStrokeDashWidth,WORKSPACE.selectBorderStrokeDashWidth]; obj['strokeWidth'] = WORKSPACE.selectBorderStrokeWidth; obj['strokeUniform'] = true; // RE-REGISTER OWN VARS // OR THEY WILL DISAPEAR //if(typeof obj['mmkObjectID'] !== 'undefined') { obj.set({ mmkObjectID: obj['mmkObjectID'] }); register_mmkObjectID(obj); } //if((obj['mmkLayerFill']) && $('#ENGRAVEFILLABLE').val()==1) //=='layerFillColor' //{ obj.set({ mmkLayerFill: 1 }); register_mmkLayerFill(obj); } // UNREGISTER VARS //if((obj['mmkLayerFill']) && $('#ENGRAVEFILLABLE').val()==0) //=='layerFillColor' //{ obj.set({ mmkLayerFill: '' }); register_mmkLayerFill(obj); } // TRUE COLOR //if((obj['mmkTrueColor'])==1) { obj.set({ mmkTrueColor: 1 }); register_mmkTrueColor(obj); } LOG && console.log('FormatObjControls: Obj: '+obj+ ', Mode: ' +mode); } function resetCanvas() { //canvas.setZoom(1); canvas.zoomToPoint(new fabric.Point(canvas.width / 2, canvas.height / 2), 1); canvas.renderAll(); $('#lcscaleBG').removeClass('active'); $('#lcremoveBG').removeClass('active'); $('.vsliderContainer').hide(); $('.verticalSlider').val(0); } function removeLastObj(from) { /* SKIP BACKGROUND IMAGE */ if(canvas.getObjects().length==2) { var last = canvas.item(canvas.getObjects().length-1); canvas.remove(last); canvas.renderAll(); } //console.log('removing last img obj:' + from + ', Layers: ' + canvas.getObjects().length); if(canvas.getObjects().length==0) // 1 WITH BACKGROUND IMAGE { //$('#lcWorkSpaceContainer').hide(); } } function showHideContainer() { /** CHECK IF AN IMAGE IS SELECTED */ if($('#lcWorkSpaceContainer').is(':hidden')) { $('#lcWorkSpaceContainer').show(); //console.log('restoring spaceContainer'); } } function refreshFilter(filetype) { var obj = canvas.item(0); //canvas.getObjects().length-1); //console.log('refreshing filter...') //console.log(obj); if(obj) { if(filetype===undefined) { var ext = obj.lcFilename.substr( (obj.lcFilename.lastIndexOf('.') +1) ).toLowerCase(); LOG && console.log('Extension restored from Filename:' + ext); } else { var ext=filetype; LOG && console.log('Extension restored by given Filename'); } /** RESTORE FILTER & COLORS **/ if($('#gravur').data('active')==1) { // SET FILTERS if(ext=='jpg' ||ext=='jpeg' || ext=='png') { obj.filters.push(filterRemoveWhite()); obj.filters.push(filterBlendColor(WORKSPACE.color)); obj.applyFilters() canvas.renderAll(); } if(ext=='svg') { if (obj.type == 'group' || obj.type == 'path-group') { var group = obj; for (var i=0; i < group.getObjects().length; i++) { group.item(i).set({'fill': '#000000'}); console.log('filling group'); }} else { obj.fill = '#000000'; console.log('filling single'); } canvas.renderAll(); } // obj.set({ mmkTrueColor: 0 }); } else { if(ext=='jpg' || ext=='jpeg' || ext=='png') { obj.filters = []; obj.applyFilters() canvas.renderAll(); } if(ext=='svg') { /* RESTORE FILL */ // if (obj.type == 'group' || obj.type == 'path-group') { var group = obj; for (var i=0; i < group.getObjects().length; i++) { group.item(i).set({'fill': '#ff0000'}); console.log('filling group'); }} // else { obj.fill = '#ff0000'; console.log('filling single'); } // canvas.renderAll(); } } } } function filterRemoveWhite() { var filter = new fabric.Image.filters.RemoveColor({ color:'#FFFFFF', distance: 0.1 }); return filter; } function filterBlendColor(color) { var filter = new fabric.Image.filters.BlendColor({ color: color, mode: 'tint', alpha: 1 }); return filter; } function centerObjHV () { var obj = canvas.getActiveObject(); obj.center(); obj.setCoords(); canvas.renderAll();} //updateObjControls('func_centerObjHV'); canvas.renderAll(); } function centerObjH () { var obj = canvas.getActiveObject(); obj.centerH(); obj.setCoords(); canvas.renderAll();} //updateObjControls('func_centerObjH'); canvas.renderAll(); } function centerObjV () { var obj = canvas.getActiveObject(); obj.centerV(); obj.setCoords(); canvas.renderAll();} //updateObjControls('func_centerObjV'); canvas.renderAll(); } // * SAVE ENTWURF TO DISK **/ function lcWorkFileHide() { $('#lcWorkFile').val(''); $('#userChoiceUploadImage').show(); $('#userChoiceUploadDesign').hide(); $('#userUploadDesignMode').val(0); $('.imgDBAnfrage').css('background-image',''); $('.imgDBAnfrage').data('fileraw',''); // $('#lcremoveDesign').trigger('click'); } function saveLcDesign() { var jsondata = JSON.stringify(canvas); var svgdata = ''; //saveImageAs('svg'); var pngdata = saveImageAs('png'); var parent = $('.imgDBActive:visible').closest('div'); var uploadfile = $(parent).prev('div').data('id'); $.ajax({type: "POST", url: "https://www.werbekollektion.de/scripts/shop.warenkorb-io.php", data: { com: 'saveLcDesign', uploadfile: uploadfile, pngdata: pngdata, jsondata: jsondata }}).done(function(ex) { //console.log('FILENAME: ' +ex ); data= ex.split('|'); //var previewFile = 'https://www.werbekollektion.de/xuser/uploads/' + ex +'_entwurf.png'; //$('.imgDBAnfrage').css('background-image','url("' + previewFile + '")'); //$('.imgDBAnfrage').data('fileraw',ex); var ts = timer(0); var previewFile = data[0] + 'xuser/uploads/' + data[1] +'_entwurf.png?'+ ts; $('.imgDBAnfrage').css('background-image','url("' + previewFile + '")'); $('.imgDBAnfrage').data('fileraw',data[1]); anfrageWin.open(); $('#create-anfrage').attr('disabled',false); $('.loader3').hide(); $('.anfrageButtonText').show(); }).fail(function(err) { console.log(err); }); } // * WRITE IMAGE DATA *// function saveImageAs(format) { var dataURL=''; //$('#schild').css('visibility','hidden'); // better display // DESELECT ALL OBJECTS //canvas.deactivateAll().renderAll(); // NOT WORKING IN 2.x canvas.discardActiveObject(); var addID = new Array(); var removeID=new Array(); switch(format) { case 'png': dataURL = canvas.toDataURL('image/png'); break; case 'jpeg': dataURL = buffer.toDataURL('image/png'); // PNG OUTPUT var ctx = canvas.getContext("2d"); var myImageData = ctx.getImageData(canvas.item(0).getLeft(), canvas.item(0).getTop(), canvas.item(0).get('width'), canvas.item(0).get('height')); buffer = document.createElement('canvas'); var bufferCtx = buffer.getContext("2d"); buffer.width = canvas.item(0).get('width'); buffer.height = canvas.item(0).get('height'); bufferCtx.putImageData(myImageData, 0, 0); break; case 'json': dataURL = canvas.toJSON(); break; case 'svg': // GROUPS //var engraveGroup = new Array(); //var cutGroup = new Array(); var imageScale = ''; var imageGroup = new Array(); var w,imgScaleFac,i,items,groupX,groupY; // XY CORRECT var objX= canvas.item(0).get('left'); var objY= canvas.item(0).get('top'); // FORMAT OBJECTS TO CSVG LOG && console.log('Create SVG WorkingFile:'); LOG && console.log('------------------------------------------------------------------'); for(x=0; x canvas.item(x).get('height')) // { //xcorrect=0; //ycorrect= $('#HEIGHT').val() - dy; // ty = $('#HEIGHT').val() - ty; // dy = $('#HEIGHT').val() - dy; // } // else // { //xcorrect= $('#WIDTH').val() - dx; //ycorrect= 0; // tx = $('#WIDTH').val() - tx; // dx = $('#WIDTH').val() - dx; // } // console.log('XCORR: '+ canvas.item(x).get('scaleX') +'/'+ sx +', YCORR: '+ canvas.item(x).get('scaleY') + '/' + sy); // BORDER STUFF HERE //if(x==1) //{ // console.log('BORDERID: ' + $('#BORDERID').val()); // alert('hold it'); //} if(x==1) { switch($('#BORDERID').val()) { //case '2': dx=dx - 2; dy = dy - 2; break; //Thin (2mm vom Rand) //case '3': dx=dx - 5; dy = dy - 5; break; //Thick (5mm vom Rand) } //console.log('Layer: ' + x+' Type: '+type+', '+'tx|ty: ' +tx+','+ty+ ' dx|dy: ' +dx+ ',' +dy+ ' sx|sy: ' +sx+ ',' +sy+ ' width/height: ' + obj.get('width')+',' + obj.get('height')+ ' scaleFac: '+SIGN.scaleFac + ' sdx|sdy: ' +sdx+ ',' +sdy); //console.log('DIM: ' +dx+ ',' +dy+ ',' +tx+ ',' +ty); //alert('hold it'); } switch(type) { case 'rect' : obj.set({ width: dx, height: dy, left: tx, top: ty, }); if($('#FORMDATA').val()=='rounded' && x==0) { obj.set({ rx: SIGN.cornerRadius, // * SIGN.scaleFac, ry: SIGN.cornerRadius, // * SIGN.scaleFac, }); } break; case 'ellipse': obj.set({ top: ty, left: tx, rx: canvas.item(x).getRx()/SIGN.scaleFac, ry: canvas.item(x).getRy()/SIGN.scaleFac, //scaleX: sx/2, //scaleY: sy/2, }); break; case 'circle' : obj.set({ left: tx, top: ty, scaleX: sx, scaleY: sy, }); break; case 'image' : w = canvas.item(x).get('width') * canvas.item(x).get('scaleX') / SIGN.scaleFac; imgScaleFac = w/canvas.item(x).get('width'); obj.set({ top: ty, left: tx, scaleX: 1, scaleY: 1, }); // push original file name + imgScaleFac to array(); imageScale=imageScale + "" + imgScaleFac +'|'; imageGroup.push(obj.getSrc()); break; case 'polygon': case 'triangle': case 'path' : case 'path-group': case 'group' : if(obj.mmkLayerType=='layerComponent') { /** HAS 2 Objects Fixation + Overlay **/ i=0; items = obj._objects; var groupX = obj.get('left'); var groupY = obj.get('top'); var groupScaleX = obj.get('scaleX'); var groupScaleY = obj.get('scaleY'); var groupWidth = obj.get('width'); var groupHeight = obj.get('height'); removeID.push(x); while (i < items.length) { LOG && console.log('I: ' + i + ', GROUP Left/Top: ' + obj.left + ',' + obj.top + ', Item Left/Top: ' + items[i].left + ',' + items[i].top + ', Group Width/Height ' + obj.width +',' + obj.height + ', ScaleX/ScaleY ' + obj.scaleX +',' + obj.scaleY +', LAYERDATA: ' + items[i].mmkLayerType + ', OBJECTID: ' + items[i].mmkObjectID); LOG && console.log('WIDTH/HEIGHT: ' + canvas.width + ', ' + canvas.height); varx = obj._objects[i].get('left') * groupScaleX + groupX + (groupWidth/2) * groupScaleX; vary = obj._objects[i].get('top') * groupScaleY + groupY + (groupHeight/2) * groupScaleY; if(i==0) { items[i].set({left: varx, top: vary, scaleX: groupScaleX, scaleY: groupScaleY, fill:'', selectable : true, mmkLayerType: 'layerCompFixation' }); canvas.add(items[i]); canvas.renderAll(); } i++; } } else { obj.set({ top: ty, left: tx, scaleX: sx, scaleY: sy, }); } break; case 'i-text': obj.set({ top: ty, left: tx, scaleX: sx, scaleY: sy, }); break; } // BG LAYER if(x==0 || obj.mmkLayerType=='layerCutForm' || obj.mmkLayerType=='layerFixation' || obj.mmkLayerType=='layerCompFixation') { if(x==0) { obj.set({ shadow:'none' }); } obj.set({strokeWidth: 0.001, stroke: '#ff0000', fill:'', strokeDashArray: []}); //, shadow: 'none' //cutGroup.push(canvas.item(x).clone()); } else if(obj.mmkLayerType=='layerOverlay') { removeID.push(x); } else { if(obj.mmkLayerFill && obj.mmkLayerFill==1) // layerFillColor { //ist ein LayerFill auf dem Obj. -> tue nichts } else { if(obj.get('type')=='image') { if($('#ENGRAVEMETHOD option:selected').val()!=8) { // delay(function() { //alert($('#ENGRAVEMETHOD option:selected').val()); //alert('Image'); //var filter2 = new fabric.Image.filters.BlendColor({ //color: '#000000', //, //'rgba(0,0,0,1)', //mode:'tint', //alpha: 1//opacity: 1 //}); //fabric.util.removeFromArray(obj.filters,'Tint'); obj.filters.push(filterBlendColor('#000000')); //LOG && console.log('FILTERS:'); //LOG && console.log(obj.filters); //obj.set({ fill: '#222222' }); obj.applyFilters(); canvas.renderAll; // }, FLOATDELAY ); // 1350 } } else { fillObjWithColor(obj, 'rgba(0,0,0,1)'); //if($('#ENGRAVEMETHOD option:selected').val()!=8) //{ // obj.set({ fill: 'rgba(0,0,0,1)' }); //} } } } // obj.setCoords(); //canvas.renderAll(); } //alert('Hold it!'); //notAFunction(); // REMOVE BORDER LAYER IF NOT PRESENT if($('#BORDERID').val()>1 && $('#BORDERID').val()<4) { var bw = canvas.item(1).get('width'); var bh = canvas.item(1).get('height'); var bwt = 0; switch($('#BORDERID').val()) { case '2': bwt=2; break; //Thin case '3': bwt=5; break; //Thick } //var bwt = 5; //parseInt(5 * SIGN.scaleFac); canvas.item(1).set({ strokeWidth: bwt, stroke: '#000000', fill:'rgba(255,255,255,0)'}); if($('#FORMDATA').val()=='rounded') { canvas.item(1).set({ rx: SIGN.cornerRadius, // * SIGN.scaleFac, ry: SIGN.cornerRadius, // * SIGN.scaleFac, }); } } else { //canvas.item(1).remove(); removeID.unshift(1); } obj.setCoords(); canvas.renderAll(); // REMOVE OVERLAYS // BORDER // GROUPS LAYERS ETC. for(var x = removeID.length; x--;) { fx=removeID[x]; canvas.remove(canvas.item(fx)); } // ADD COMPONENT FIXATIONS // ADD ORIGINAL IMAGES var fileList=''; var fileObj=''; for (index = 0; index < imageGroup.length; ++index) { fileList = fileList + imageGroup[index] +'\n'; file = imageGroup[index].replace('https://www.werbekollektion.de/xuser/uploads/',''); fileObj = fileObj + file +','; } if(fileList.length>0) { //var text = new fabric.Text('Originaldateien/URL\n' + fileList, { left: 0, top: -80, fontFamily: 'Arial', fontSize: 7 }); //canvas.add(text); //obj.setCoords(); //canvas.renderAll(); } obj.setCoords(); canvas.renderAll(); // WRITE SVG DATA var dim= new Array(); if($('#DIMMODE0').is(':checked')) { dim = $('#DIMSTD').val().split('x'); } if($('#DIMMODE1').is(':checked')) { dim = [$('#WIDTH').val(),$('#HEIGHT').val()]; } dataURL = canvas.toSVG({suppressPreamble: 1, viewBox: { x: 0, y: 0, width: dim[0], height: dim[1]}}); //dataURL = canvas.toSVG(); //alert(dataURL); //alert('Berechne...'); break; } return [dataURL,fileObj,imageScale]; } function guidGenerator() { var S4 = function() { return (((1+Math.random())*0x10000)|0).toString(16).substring(1); }; return (S4()+S4()+"-"+S4()+"-"+S4()+"-"+S4()+"-"+S4()+S4()+S4()); } function timer(time) { var d = new Date(); var now = d.getTime(); if(time==0) { return now; } else { var ntime = now - time +' ms'; return ntime; } }