{ "meta": { "instanceId": "workflow-7c50a561", "versionId": "1.0.0", "createdAt": "2025-09-29T07:07:53.508319", "updatedAt": "2025-09-29T07:07:53.508329", "owner": "n8n-user", "license": "MIT", "category": "automation", "status": "active", "priority": "high", "environment": "production" }, "nodes": [ { "id": "ed993205-977a-43cd-8d0b-4faef216d766", "name": "Split Out", "type": "n8n-nodes-base.splitOut", "position": [ 360, -120 ], "parameters": { "options": {}, "fieldToSplitOut": "predictions" }, "typeVersion": 1, "notes": "This splitOut node performs automated tasks as part of the workflow." }, { "id": "67f2bb16-ee38-4bc8-9cc7-50a44614cc3b", "name": "Imagen 3.0", "type": "n8n-nodes-base.httpRequest", "position": [ 140, -120 ], "parameters": { "url": "{{ $env.API_BASE_URL }}", "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": "{{ $credentials.predefinedCredentialType }}", "nodeCredentialType": "YOUR_CREDENTIAL_HERE" }, "credentials": { "googlePalmApi": { "id": "dSxo6ns5wn658r8N", "name": "Google Gemini(PaLM) Api account" } }, "typeVersion": 4.2, "notes": "This httpRequest node performs automated tasks as part of the workflow." }, { "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, "notes": "This set node performs automated tasks as part of the workflow." }, { "id": "5c26062c-74cf-4140-8dcb-8688c8daec67", "name": "Download Image", "type": "n8n-nodes-base.httpRequest", "position": [ -620, -120 ], "parameters": { "url": "{{ $env.BASE_URL }}", "options": {} }, "typeVersion": 4.2, "notes": "This httpRequest node performs automated tasks as part of the workflow." }, { "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, "notes": "This formTrigger node performs automated tasks as part of the workflow." }, { "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, "notes": "This if node performs automated tasks as part of the workflow." }, { "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, "notes": "This form node performs automated tasks as part of the workflow." }, { "id": "8a0e8dae-9f6f-488e-9977-fd89e885f30e", "name": "Upload to Cloudinary", "type": "n8n-nodes-base.httpRequest", "position": [ 880, -120 ], "parameters": { "url": "{{ $env.API_BASE_URL }}", "method": "POST", "options": {}, "sendBody": true, "sendQuery": true, "contentType": "multipart-form-data", "authentication": "{{ $credentials.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, "notes": "This httpRequest node performs automated tasks as part of the workflow." }, { "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]({{ $env.WEBHOOK_URL }}\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, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "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]({{ $env.API_BASE_URL }}\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, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "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]({{ $env.API_BASE_URL }}\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, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "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]({{ $env.WEBHOOK_URL }}\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, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "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, "notes": "This convertToFile node performs automated tasks as part of the workflow." }, { "id": "0252d373-3678-4851-819d-d36efb40dfb2", "name": "Generate HTML", "type": "n8n-nodes-base.html", "position": [ 1080, -120 ], "parameters": { "html": "