{ "meta": { "instanceId": "408f9fb9940c3cb18ffdef0e0150fe342d6e655c3a9fac21f0f644e8bedabcd9", "templateCredsSetupCompleted": true }, "nodes": [ { "id": "ed993205-977a-43cd-8d0b-4faef216d766", "name": "Split Out", "type": "n8n-nodes-base.splitOut", "position": [ 360, -120 ], "parameters": { "options": {}, "fieldToSplitOut": "predictions" }, "typeVersion": 1 }, { "id": "67f2bb16-ee38-4bc8-9cc7-50a44614cc3b", "name": "Imagen 3.0", "type": "n8n-nodes-base.httpRequest", "position": [ 140, -120 ], "parameters": { "url": "https://generativelanguage.googleapis.com/v1beta/models/imagen-3.0-generate-002:predict", "method": "POST", "options": {}, "jsonBody": "={{\n{\n \"instances\": [\n {\n \"prompt\": [\n $json.candidates[0].content.parts[0].text,\n `Generate the following image: ${$('Variables').first().json.targetPrompt}`\n ].join(' ')\n }\n ],\n \"parameters\": {\n \"sampleCount\": $('Variables').first().json.numberSamples.toNumber()\n }\n}\n}}", "sendBody": true, "specifyBody": "json", "authentication": "predefinedCredentialType", "nodeCredentialType": "googlePalmApi" }, "credentials": { "googlePalmApi": { "id": "dSxo6ns5wn658r8N", "name": "Google Gemini(PaLM) Api account" } }, "typeVersion": 4.2 }, { "id": "b1730c97-8c5c-48a5-90cf-7940f6c9e2d0", "name": "Variables", "type": "n8n-nodes-base.set", "position": [ -940, -120 ], "parameters": { "options": {}, "assignments": { "assignments": [ { "id": "7616f991-76d0-4dd0-9385-f08ed14e8dfa", "name": "sourceStyleUrl", "type": "string", "value": "={{ $json.SourceImage }}" }, { "id": "126cb06e-4d69-4163-ba76-c694103bf5bb", "name": "targetPrompt", "type": "string", "value": "={{ $json.TargetPrompt }}" }, { "id": "055d247b-586d-4bb8-a319-262c241df48c", "name": "numberSamples", "type": "string", "value": "={{\n(function(numSamples) {\n if (!numSamples) return 1;\n if (numSamples < 0) return 1;\n if (numSamples > 4) return 4;\n return numSamples;\n}($json['Number of Images']))\n}}" }, { "id": "77a27e0e-24f4-4358-8cdc-84552be6c0b5", "name": "email", "type": "string", "value": "={{ $json['Your Email (Optional)'] }}" } ] } }, "typeVersion": 3.4 }, { "id": "5c26062c-74cf-4140-8dcb-8688c8daec67", "name": "Download Image", "type": "n8n-nodes-base.httpRequest", "position": [ -620, -120 ], "parameters": { "url": "={{ $json.sourceStyleUrl }}", "options": {} }, "typeVersion": 4.2 }, { "id": "20744adb-cdf5-4558-b6e6-4206d7c1f356", "name": "On form submission", "type": "n8n-nodes-base.formTrigger", "position": [ -1400, -120 ], "webhookId": "51f74db1-ffb4-491f-83b0-a44a7124be12", "parameters": { "options": { "path": "style-copy-with-imagen3", "ignoreBots": true, "buttonLabel": "Generate!", "appendAttribution": true }, "formTitle": "Style Copy with Imagen 3.0", "formFields": { "values": [ { "fieldLabel": "SourceImage", "placeholder": "The image URL to copy the style from", "requiredField": true }, { "fieldLabel": "TargetPrompt", "placeholder": "The new image to generate", "requiredField": true }, { "fieldType": "number", "fieldLabel": "Number of Images", "placeholder": "Default 1. Max. 4 images" }, { "fieldType": "email", "fieldLabel": "Your Email (Optional)", "placeholder": "The results will be sent to this email" } ] }, "responseMode": "lastNode", "formDescription": "Use this form to generate an image using another image as a style reference." }, "typeVersion": 2.2 }, { "id": "917db247-1be3-4814-a96d-145957aa5db3", "name": "Form Validation", "type": "n8n-nodes-base.if", "position": [ -1180, -120 ], "parameters": { "options": {}, "conditions": { "options": { "version": 2, "leftValue": "", "caseSensitive": true, "typeValidation": "strict" }, "combinator": "and", "conditions": [ { "id": "1b440b81-06c9-4133-bfd2-8ec07c7c3734", "operator": { "type": "boolean", "operation": "true", "singleValue": true }, "leftValue": "={{ $json.SourceImage.isUrl() }}", "rightValue": "" } ] } }, "typeVersion": 2.2 }, { "id": "65a8b617-318c-429a-b37e-45ead00dbb7e", "name": "Retry Form", "type": "n8n-nodes-base.form", "position": [ -940, 60 ], "webhookId": "0b4c88ed-d28b-4df4-abe6-4579e17c672d", "parameters": { "options": { "formTitle": "Retry Submission", "buttonLabel": "Generate!", "formDescription": "Please enter a URL for the source image." }, "formFields": { "values": [ { "fieldLabel": "SourceImage", "placeholder": "The image URL to copy the style from", "requiredField": true }, { "fieldLabel": "TargetPrompt", "placeholder": "The new image to generate", "requiredField": true }, { "fieldType": "number", "fieldLabel": "Number of Images", "placeholder": "Max. 4 images" }, { "fieldLabel": "Your Email (Optional)", "placeholder": "The results will be sent to this email" } ] }, "limitWaitTime": true }, "typeVersion": 1 }, { "id": "8a0e8dae-9f6f-488e-9977-fd89e885f30e", "name": "Upload to Cloudinary", "type": "n8n-nodes-base.httpRequest", "position": [ 880, -120 ], "parameters": { "url": "https://api.cloudinary.com/v1_1/daglih2g8/image/upload", "method": "POST", "options": {}, "sendBody": true, "sendQuery": true, "contentType": "multipart-form-data", "authentication": "genericCredentialType", "bodyParameters": { "parameters": [ { "name": "file", "parameterType": "formBinaryData", "inputDataFieldName": "data" } ] }, "genericAuthType": "httpQueryAuth", "queryParameters": { "parameters": [ { "name": "upload_preset", "value": "n8n-workflows-preset" } ] } }, "credentials": { "httpQueryAuth": { "id": "sT9jeKzZiLJ3bVPz", "name": "Cloudinary API" } }, "typeVersion": 4.2 }, { "id": "525725ea-effe-410b-8f39-ad01ae755d1a", "name": "Sticky Note", "type": "n8n-nodes-base.stickyNote", "position": [ -1480, -340 ], "parameters": { "color": 7, "width": 760, "height": 640, "content": "## 1. Ask for Source Style and Target Image\n[Learn more about the Form Trigger](https://docs.n8n.io/integrations/builtin/core-nodes/n8n-nodes-base.formtrigger/)\n\nWe'll use a form interface for this template which allows the users to specify an image whose style we'll use as reference and a prompt to generate the target image. Form validation loop can be achieved by combining another form node with the IF node." }, "typeVersion": 1 }, { "id": "ba9d4bdc-b695-4acf-9593-2ce979053744", "name": "Sticky Note1", "type": "n8n-nodes-base.stickyNote", "position": [ -700, -340 ], "parameters": { "color": 7, "width": 720, "height": 440, "content": "## 2. Visual Style Description using Gemini 2.0\n[Read more about Gemini Image Understanding](https://ai.google.dev/gemini-api/docs/image-understanding)\n\nThe trick to copying the style of an image is to get a multimodal LLM to describe it in detail. Using Gemini's image understanding capabilities, it can do a pretty good job to provide the comprehensive description we need." }, "typeVersion": 1 }, { "id": "455f7956-6e39-4d84-af7e-d5908d4e5307", "name": "Sticky Note2", "type": "n8n-nodes-base.stickyNote", "position": [ 40, -340 ], "parameters": { "color": 7, "width": 720, "height": 440, "content": "## 3. Image Generation using Imagen 3.0\n[Read more about Imagen Image Generation](https://ai.google.dev/gemini-api/docs/image-generation#imagen)\n\nTo generate the image, we'll be using Google's Imagen 3.0 model. We'll combine the visual style description generated in the previous Gemini model with the user's target image prompt and pass this to Imagen to do its magic! The result is something very close to style transfer which produces quite convincing and impressive results." }, "typeVersion": 1 }, { "id": "0c1d5a7f-9102-4558-a830-ed558f72c086", "name": "Sticky Note3", "type": "n8n-nodes-base.stickyNote", "position": [ 780, -340 ], "parameters": { "color": 7, "width": 980, "height": 600, "content": "## 4. Render Results to HTML Page\n[Learn more about the HTML node](https://docs.n8n.io/integrations/builtin/core-nodes/n8n-nodes-base.html)\n\nFinally for presentation, we'll render the generated images as a webpage for easier viewing using the HTML node. This page can then be sent to the user's email if provided and downloaded as a file once we land on the form ending node." }, "typeVersion": 1 }, { "id": "ccc1ff65-0416-4dae-9557-ba2f98c5ac80", "name": "Convert to File1", "type": "n8n-nodes-base.convertToFile", "position": [ 1320, 60 ], "parameters": { "options": { "encoding": "utf8", "fileName": "={{ $('Variables').item.json.targetPrompt.toSnakeCase().urlEncode() }}.html" }, "operation": "toText", "sourceProperty": "html" }, "typeVersion": 1.1 }, { "id": "0252d373-3678-4851-819d-d36efb40dfb2", "name": "Generate HTML", "type": "n8n-nodes-base.html", "position": [ 1080, -120 ], "parameters": { "html": "