Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(n8n Form Trigger Node): New node #7130

Merged
merged 109 commits into from
Oct 17, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
109 commits
Select commit Hold shift + click to select a range
65d30ac
:zap: setup
michael-radency Sep 7, 2023
3e7c760
:zap: added entry in tab panel
michael-radency Sep 7, 2023
7cded45
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 7, 2023
da8407d
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 8, 2023
bee0067
:zap: FE webhook accordion update
michael-radency Sep 8, 2023
7b85384
:zap: node structure update
michael-radency Sep 8, 2023
093043b
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 11, 2023
2fab6ff
:zap: form template
michael-radency Sep 11, 2023
6925de0
:zap: form groups generator
michael-radency Sep 11, 2023
1c68ab9
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 12, 2023
834c5a5
:zap: page update
michael-radency Sep 12, 2023
319d1e3
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 12, 2023
ce2e986
:zap: getInstanceId setup
michael-radency Sep 12, 2023
6dff9f7
:zap: execute button label update
michael-radency Sep 12, 2023
f50022c
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 13, 2023
d3dc354
:zap: error pages for n8n-form
michael-radency Sep 13, 2023
a521b53
:zap:removed hardcoded path
michael-radency Sep 13, 2023
519bb72
:zap: validation update, auto open test url
michael-radency Sep 13, 2023
b845bb2
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 13, 2023
c69e90a
:zap: fixed failing test
michael-radency Sep 13, 2023
c7e5f80
:zap: open test from in pop-up for screens smaler then 800
michael-radency Sep 13, 2023
8787d1f
:zap: item index display option
michael-radency Sep 13, 2023
0f1cb3f
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 13, 2023
f73b897
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 14, 2023
dd1ad1d
:zap: reverted displayIndex changes
michael-radency Sep 14, 2023
73bad1b
:zap: styles update, replace some harcoded values with const
michael-radency Sep 14, 2023
88f060b
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 14, 2023
fe5d44a
:zap: listening pane update, added icon to test btn, validation update
michael-radency Sep 14, 2023
2435b3f
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 14, 2023
c827400
:zap: form tweaks
michael-radency Sep 14, 2023
576be93
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 14, 2023
5195f46
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 14, 2023
de8c852
:zap: fixes
michael-radency Sep 15, 2023
4d92f56
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 15, 2023
804f36a
:zap: form field default fix
michael-radency Sep 15, 2023
57d510e
:zap: text fix
michael-radency Sep 15, 2023
140ab70
:zap: undo last changes
michael-radency Sep 15, 2023
436eace
Minor copy tweaks.
gandreini Sep 18, 2023
9a57a1c
Minor copy tweak.
gandreini Sep 19, 2023
3a7241a
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 20, 2023
b3a50df
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 21, 2023
ccd742b
:zap: respond mode, respond with, error message in page, date format …
michael-radency Sep 21, 2023
cff1eee
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 21, 2023
26d8cd1
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 21, 2023
9f5e15a
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 21, 2023
19488fc
:zap: styles update
michael-radency Sep 22, 2023
4ab43ea
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 22, 2023
781f00d
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 22, 2023
e01dc9c
:zap: select style fix, quotes escaping, remove error toast on input
michael-radency Sep 22, 2023
b9b0242
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 22, 2023
11dceba
:zap: submited page update
michael-radency Sep 22, 2023
4663688
:zap: spinner
michael-radency Sep 22, 2023
6b09b0d
:zap: import update
michael-radency Sep 22, 2023
f9c82b9
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 22, 2023
469085e
:zap: replaced fields escaping by mapping
michael-radency Sep 25, 2023
4f43d44
:zap: multiselect html+styles setup
michael-radency Sep 25, 2023
7de0175
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 25, 2023
6af5121
:zap: multiselect template and logic
michael-radency Sep 25, 2023
d2ada53
:zap: icon fix
michael-radency Sep 25, 2023
3fae066
:zap: custom checkboxes
michael-radency Sep 26, 2023
29d37dd
:zap: fixed collection first child dashed border fix
michael-radency Sep 26, 2023
28b3042
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 26, 2023
b273a6a
Minor copy tweaks.
gandreini Sep 26, 2023
cdecae8
Form SVG icon update.
gandreini Sep 26, 2023
d5f7d06
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 27, 2023
0e4207e
:zap: second round review updates
michael-radency Sep 27, 2023
2e6ca31
:zap: multiselect input changed from dropdown list of checkboxes, rem…
michael-radency Sep 27, 2023
cd3e5ef
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 27, 2023
dd3cb20
:zap: border top dashed fix
michael-radency Sep 27, 2023
5cf93fa
:zap: styles fixes
michael-radency Sep 27, 2023
090399b
:zap: styles fixes
michael-radency Sep 27, 2023
e86675b
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Sep 27, 2023
6ccf710
:zap: multiselect option font-weight update
michael-radency Sep 27, 2023
84847b3
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 2, 2023
f10a3bd
:zap: UI updates
michael-radency Oct 2, 2023
0975039
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 2, 2023
0074df8
:zap: form options update
michael-radency Oct 2, 2023
da18a90
A couple of copy tweaks.
gandreini Oct 4, 2023
3e5b9ba
:zap: include open sans fonts in html
michael-radency Oct 4, 2023
fa095c0
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 4, 2023
4d19acc
:zap: fallback font
michael-radency Oct 4, 2023
b4acd92
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 4, 2023
79972ac
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 4, 2023
586c487
:zap: 404 page fix
michael-radency Oct 4, 2023
239d23e
:zap: removed utm from 404
michael-radency Oct 4, 2023
5319aca
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 4, 2023
b8f80a2
:zap: validation fix
michael-radency Oct 4, 2023
aadef9f
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 10, 2023
6e20bc7
:zap: review fixes
michael-radency Oct 10, 2023
2b2eb61
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 10, 2023
cf3b36b
:zap: 404 template update
michael-radency Oct 10, 2023
460a894
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 10, 2023
fe0f088
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 11, 2023
065ab6e
:zap: review fixes
michael-radency Oct 11, 2023
0b25c8b
:zap: always open pop-up for trigger node
michael-radency Oct 11, 2023
7551ffb
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 11, 2023
6dc3276
:zap: cleanup
michael-radency Oct 11, 2023
cf63e12
:zap: do not trigger popup on inactive node
michael-radency Oct 11, 2023
8721c25
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 11, 2023
416a00c
:zap: no fields page warning
michael-radency Oct 11, 2023
e0b264e
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 11, 2023
75a51c2
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 12, 2023
adc2286
:zap: form trigger e2e test
michael-radency Oct 12, 2023
1185dfc
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 12, 2023
ef286db
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 12, 2023
7b8ef3c
:zap: fixes for popup opening, disabled duplication of form trigger node
michael-radency Oct 13, 2023
841f26d
:zap: assign new webhookId to form trigger on paste if duplicate
michael-radency Oct 13, 2023
7c15103
:zap: render page with handlebars
michael-radency Oct 14, 2023
1da64e2
Merge branch 'master' of https://github.com/n8n-io/n8n into node-749-…
michael-radency Oct 14, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .prettierignore
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,6 @@ package.json
pnpm-lock.yaml
packages/editor-ui/index.html
packages/nodes-base/nodes/**/test
packages/cli/templates/form-trigger.handlebars
cypress/fixtures
CHANGELOG.md
88 changes: 88 additions & 0 deletions cypress/e2e/16-form-trigger-node.cy.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
import { WorkflowPage, NDV } from '../pages';
import { v4 as uuid } from 'uuid';
import { getPopper, getVisiblePopper, getVisibleSelect } from '../utils';
import { META_KEY } from '../constants';

const workflowPage = new WorkflowPage();
const ndv = new NDV();

describe('n8n Form Trigger', () => {
beforeEach(() => {
workflowPage.actions.visit();
});

it("add node by clicking on 'On form submission'", () => {
workflowPage.getters.canvasPlusButton().click();
cy.get('#node-view-root > div:nth-child(2) > div > div > aside ')
.find('span')
.contains('On form submission')
.click();
ndv.getters.parameterInput('formTitle').type('Test Form');
ndv.getters.parameterInput('formDescription').type('Test Form Description');
ndv.getters.parameterInput('fieldLabel').type('Test Field 1');
ndv.getters.backToCanvas().click();
workflowPage.getters.nodeIssuesByName('n8n Form Trigger').should('not.exist');
});

it('should fill up form fields', () => {
workflowPage.actions.addInitialNodeToCanvas('n8n Form Trigger');
workflowPage.getters.canvasNodes().first().dblclick();
ndv.getters.parameterInput('formTitle').type('Test Form');
ndv.getters.parameterInput('formDescription').type('Test Form Description');
//fill up first field of type number
ndv.getters.parameterInput('fieldLabel').type('Test Field 1');
ndv.getters.parameterInput('fieldType').click();
getVisibleSelect().contains('Number').click();
cy.get(
'[data-test-id="parameter-input-requiredField"] > .parameter-input > .el-switch > .el-switch__core',
).click();
//fill up second field of type text
cy.get('.fixed-collection-parameter > :nth-child(2) > .button > span').click();
cy.get('.border-top-dashed > .parameter-input-list-wrapper > :nth-child(1) > .parameter-item')
.find('input[placeholder*="e.g. What is your name?"]')
.type('Test Field 2');
//fill up second field of type date
cy.get('.fixed-collection-parameter > :nth-child(2) > .button > span').click();
cy.get(
':nth-child(3) > .border-top-dashed > .parameter-input-list-wrapper > :nth-child(1) > .parameter-item',
)
.find('input[placeholder*="e.g. What is your name?"]')
.type('Test Field 3');
cy.get(
':nth-child(3) > .border-top-dashed > .parameter-input-list-wrapper > :nth-child(2) > .parameter-item',
).click();
getVisibleSelect().contains('Date').click();
// fill up second field of type dropdown
cy.get('.fixed-collection-parameter > :nth-child(2) > .button').click();
cy.get(
':nth-child(4) > .border-top-dashed > .parameter-input-list-wrapper > :nth-child(1) > .parameter-item',
)
.find('input[placeholder*="e.g. What is your name?"]')
.type('Test Field 4');
cy.get(
':nth-child(4) > .border-top-dashed > .parameter-input-list-wrapper > :nth-child(2) > .parameter-item',
).click();
getVisibleSelect().contains('Dropdown').click();
cy.get(
'.border-top-dashed > :nth-child(2) > :nth-child(3) > .multi-parameter > .fixed-collection-parameter > :nth-child(2) > .button',
).click();
cy.get(
':nth-child(4) > :nth-child(1) > :nth-child(2) > :nth-child(3) > .multi-parameter > .fixed-collection-parameter > .fixed-collection-parameter-property > :nth-child(1) > :nth-child(1)',
)
.find('input')
.type('Option 1');
cy.get(
':nth-child(4) > :nth-child(1) > :nth-child(2) > :nth-child(3) > .multi-parameter > .fixed-collection-parameter > .fixed-collection-parameter-property > :nth-child(1) > :nth-child(2)',
)
.find('input')
.type('Option 2');
//add optionall submitted message
cy.get('.param-options > .button').click();
cy.get('.indent > .parameter-item')
.find('input')
.clear()
.type('Your test form was successfully submitted');
ndv.getters.backToCanvas().click();
workflowPage.getters.nodeIssuesByName('n8n Form Trigger').should('not.exist');
});
});
12 changes: 11 additions & 1 deletion packages/cli/src/WebhookHelpers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ import {
BINARY_ENCODING,
createDeferredPromise,
ErrorReporterProxy as ErrorReporter,
FORM_TRIGGER_PATH_IDENTIFIER,
LoggerProxy as Logger,
NodeHelpers,
} from 'n8n-workflow';
Expand Down Expand Up @@ -109,7 +110,16 @@ export const webhookRequestHandler =
try {
response = await webhookManager.executeWebhook(req, res);
} catch (error) {
return ResponseHelper.sendErrorResponse(res, error as Error);
if (
error.errorCode === 404 &&
(error.message as string).includes(FORM_TRIGGER_PATH_IDENTIFIER)
) {
const isTestWebhook = req.originalUrl.includes('webhook-test');
res.status(404);
return res.render('form-trigger-404', { isTestWebhook });
michael-radency marked this conversation as resolved.
Show resolved Hide resolved
} else {
return ResponseHelper.sendErrorResponse(res, error as Error);
}
}

// Don't respond, if already responded
Expand Down
86 changes: 86 additions & 0 deletions packages/cli/templates/form-trigger-404.handlebars
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
<html lang='en'>

<head>
<meta charset='UTF-8' />
<meta name='viewport' content='width=device-width, initial-scale=1.0' />
<link rel='icon' type='image/png' href='https://n8n.io/favicon.ico' />
<link
href='http://fonts.googleapis.com/css?family=Open+Sans'
rel='stylesheet'
type='text/css'
/>
{{#if isTestWebhook}}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah nice to see handlebars

<title>Form Trigger isn't listening yet</title>
{{else}}
<title>Problem loading form</title>
{{/if}}
<style>
*, ::after, ::before { box-sizing: border-box; margin: 0; padding: 0; } body { font-family:
Open Sans, sans-serif; font-weight: 400; font-size: 12px; display: flex; flex-direction:
column; justify-content: start; background-color: #FBFCFE; } .container { margin: auto;
text-align: center; padding-top: 24px; width: 448px; } .card { padding: 24px;
background-color: white; border: 1px solid #DBDFE7; border-radius: 8px; box-shadow: 0px 4px
16px 0px #634DFF0F; margin-bottom: 16px; } .n8n-link a { color: #7E8186; font-weight: 600;
font-size: 12px; text-decoration: none; } .n8n-link svg { display: inline-block;
vertical-align: middle; } .header h1 { color: #525356; font-size: 20px; font-weight: 400;
padding-bottom: 8px; } .header p { color: #7E8186; font-size: 14px; font-weight: 400; }
</style>
</head>

<body>
<div class='container'>
<section>
<div class='card'>
{{#if isTestWebhook}}
<div class='header'>
<h1>Form Trigger isn't listening yet</h1>
<p>Click the <strong>"Test Step"</strong> button in your form trigger</p>
</div>
{{else}}
<div class='header'>
<h1>Problem loading form</h1>
<p>This usually occurs if the n8n workflow serving this form is deactivated or no
longer exist</p>
</div>
{{/if}}
</div>
<div class='n8n-link'>
<a
href='https://n8n.io/?utm_source=n8n-internal&amp;utm_medium=form-trigger&amp'
target='_blank'
>
Form automated with
<svg
width='73'
height='20'
viewBox='0 0 73 20'
fill='none'
xmlns='http://www.w3.org/2000/svg'
>
<path
fill-rule='evenodd'
clip-rule='evenodd'
d='M40.2373 4C40.2373 6.20915 38.4464 8 36.2373 8C34.3735 8 32.8074 6.72525 32.3633 5H26.7787C25.801 5 24.9666 5.70685 24.8059 6.6712L24.6415 7.6576C24.4854 8.59415 24.0116 9.40925 23.3417 10C24.0116 10.5907 24.4854 11.4058 24.6415 12.3424L24.8059 13.3288C24.9666 14.2931 25.801 15 26.7787 15H28.3633C28.8074 13.2747 30.3735 12 32.2373 12C34.4464 12 36.2373 13.7908 36.2373 16C36.2373 18.2092 34.4464 20 32.2373 20C30.3735 20 28.8074 18.7253 28.3633 17H26.7787C24.8233 17 23.1546 15.5864 22.8331 13.6576L22.6687 12.6712C22.508 11.7069 21.6736 11 20.6959 11H19.0645C18.5652 12.64 17.0406 13.8334 15.2373 13.8334C13.434 13.8334 11.9094 12.64 11.4101 11H9.06449C8.56519 12.64 7.04059 13.8334 5.2373 13.8334C3.02817 13.8334 1.2373 12.0424 1.2373 9.83335C1.2373 7.6242 3.02817 5.83335 5.2373 5.83335C7.16069 5.83335 8.76699 7.19085 9.15039 9H11.3242C11.7076 7.19085 13.3139 5.83335 15.2373 5.83335C17.1607 5.83335 18.767 7.19085 19.1504 9H20.6959C21.6736 9 22.508 8.29315 22.6687 7.3288L22.8331 6.3424C23.1546 4.41365 24.8233 3 26.7787 3H32.3633C32.8074 1.27478 34.3735 0 36.2373 0C38.4464 0 40.2373 1.79086 40.2373 4ZM38.2373 4C38.2373 5.10455 37.3419 6 36.2373 6C35.1327 6 34.2373 5.10455 34.2373 4C34.2373 2.89543 35.1327 2 36.2373 2C37.3419 2 38.2373 2.89543 38.2373 4ZM5.2373 11.8334C6.34189 11.8334 7.23729 10.9379 7.23729 9.83335C7.23729 8.72875 6.34189 7.83335 5.2373 7.83335C4.13273 7.83335 3.2373 8.72875 3.2373 9.83335C3.2373 10.9379 4.13273 11.8334 5.2373 11.8334ZM15.2373 11.8334C16.3419 11.8334 17.2373 10.9379 17.2373 9.83335C17.2373 8.72875 16.3419 7.83335 15.2373 7.83335C14.1327 7.83335 13.2373 8.72875 13.2373 9.83335C13.2373 10.9379 14.1327 11.8334 15.2373 11.8334ZM32.2373 18C33.3419 18 34.2373 17.1045 34.2373 16C34.2373 14.8954 33.3419 14 32.2373 14C31.1327 14 30.2373 14.8954 30.2373 16C30.2373 17.1045 31.1327 18 32.2373 18Z'
fill='#EA4B71'
></path>
<path
d='M44.2393 15.0007H46.3277V10.5791C46.3277 9.12704 47.2088 8.49074 48.204 8.49074C49.183 8.49074 49.9498 9.14334 49.9498 10.4812V15.0007H52.038V10.057C52.038 7.91969 50.798 6.67969 48.8567 6.67969C47.633 6.67969 46.9477 7.16914 46.4582 7.80544H46.3277L46.1482 6.84284H44.2393V15.0007Z'
fill='#101330'
></path>
<path
d='M60.0318 9.50205V9.40415C60.7498 9.0452 61.4678 8.4252 61.4678 7.20155C61.4678 5.43945 60.0153 4.37891 58.0088 4.37891C55.9528 4.37891 54.4843 5.5047 54.4843 7.23415C54.4843 8.4089 55.1698 9.0452 55.9203 9.40415V9.50205C55.0883 9.79575 54.0928 10.6768 54.0928 12.1452C54.0928 13.9237 55.5613 15.1637 57.9923 15.1637C60.4233 15.1637 61.8428 13.9237 61.8428 12.1452C61.8428 10.6768 60.8638 9.81205 60.0318 9.50205ZM57.9923 5.87995C58.8083 5.87995 59.4118 6.40205 59.4118 7.2831C59.4118 8.16415 58.7918 8.6863 57.9923 8.6863C57.1928 8.6863 56.5238 8.16415 56.5238 7.2831C56.5238 6.38575 57.1603 5.87995 57.9923 5.87995ZM57.9923 13.5974C57.0458 13.5974 56.2793 12.9937 56.2793 11.9658C56.2793 11.0358 56.9153 10.3342 57.9758 10.3342C59.0203 10.3342 59.6568 11.0195 59.6568 11.9984C59.6568 12.9937 58.9223 13.5974 57.9923 13.5974Z'
fill='#101330'
></path>
<path
d='M63.9639 15.0007H66.0524V10.5791C66.0524 9.12704 66.9334 8.49074 67.9289 8.49074C68.9079 8.49074 69.6744 9.14334 69.6744 10.4812V15.0007H71.7629V10.057C71.7629 7.91969 70.5229 6.67969 68.5814 6.67969C67.3579 6.67969 66.6724 7.16914 66.1829 7.80544H66.0524L65.8729 6.84284H63.9639V15.0007Z'
fill='#101330'
></path>
</svg>

</a>
</div>
</section>
</div>
</body>

</html>
Loading
Loading