Notion receiver data Immunizations from Nodejs

Today we will learning send data to Notion by API

Setup new project

At here I use “Express application generator” for fastest setup new project

Steps:

1/ Install express-generator

npm install -g express-generator

2/ New project w…

Today we will learning send data to Notion by API



Setup new project

At here I use “Express application generator” for fastest setup new project

Steps:

1/ Install express-generator

npm install -g express-generator

2/ New project with name InjectionRegistrationNotion

express **--view=ejs** **InjectionRegistrationNotion**

image

cd InjectionRegistrationNotion
npm install

image

3/ Start server and get ready for write code

npm start // for start server this project

Access to localhost:3000

image

Great! Everything ready for next step



Let’s make a Form Injection Registration

For write User Interface, I used ejs engine because it friendly with HTML native

Let’s make a Form Injection Registration

At file index.jes in views folder

<!DOCTYPE html>
<html>
<head>
  <title><%= title %></title>
  <link href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700" rel="stylesheet">
  <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.5.0/css/all.css">
  <link rel="stylesheet" href="./stylesheets/style.css">
</head>
<body>
<div class="testbox">
  <form action="/" method="post">
    <div class="banner">
      <h1><%= title %></h1>
    </div>
    <div class="item">
      <p>Name</p>
      <div class="name-item">
        <input type="text" name="name"/>
      </div>
    </div>
    <div class="item">
      <p>Email</p>
      <input type="text" name="email"/>
    </div>
    <div class="item">
      <p>Phone</p>
      <input type="text" name="phone"/>
    </div>
    <div class="item">
      <p>Address</p>
      <input type="text" name="address"/>
    </div>
    <div class="question">
      <p>Gender</p>
      <div class="question-answer">
        <div>
          <input type="radio" value="0" id="radio_2" name="sex"/>
          <label for="radio_2" class="radio"><span>Female</span></label>
        </div>
        <div>
          <input type="radio" value="1" id="radio_1" name="sex"/>
          <label for="radio_1" class="radio"><span>Male</span></label>
        </div>
      </div>
    </div>
    <div class="item">
      <p>Note</p>
      <textarea name="note" rows="3"></textarea>
    </div>

    <div class="btn-block">
      <button type="submit" href="/">Send</button>
    </div>
  </form>
</div>
</body>
</html>

At file “public/stylesheets/style.css”

html, body {
    min-height: 100%;
}

body, div, form, input, select, textarea, p {
    padding: 0;
    margin: 0;
    outline: none;
    font-family: Roboto, Arial, sans-serif;
    font-size: 14px;
    color: #666;
    line-height: 22px;
}

h1 {
    position: absolute;
    margin: 0;
    font-size: 36px;
    color: #fff;
    z-index: 2;
}

.testbox {
    display: flex;
    justify-content: center;
    align-items: center;
    height: inherit;
    padding: 20px;
}

form {
    width: 100%;
    padding: 20px;
    border-radius: 6px;
    background: #fff;
    box-shadow: 0 0 20px 0 #333;
}

.banner {
    position: relative;
    height: 210px;
    background-size: cover;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.banner::after {
    content: "";
    background-color: rgba(0, 0, 0, 0.4);
    position: absolute;
    width: 100%;
    height: 100%;
}

input, textarea, select {
    margin-bottom: 10px;
    border: 1px solid #ccc;
    border-radius: 3px;
}

input {
    width: calc(100% - 10px);
    padding: 5px;
}

select {
    width: 100%;
    padding: 7px 0;
    background: transparent;
}

textarea {
    width: calc(100% - 12px);
    padding: 5px;
}

.item:hover p, .item:hover i, .question:hover p, .question label:hover, input:hover::placeholder {
    color: #333;
}

.item input:hover, .item select:hover, .item textarea:hover {
    border: 1px solid transparent;
    box-shadow: 0 0 6px 0 #333;
    color: #333;
}

.item {
    position: relative;
    margin: 10px 0;
}

input[type="date"]::-webkit-inner-spin-button {
    display: none;
}

.item i, input[type="date"]::-webkit-calendar-picker-indicator {
    position: absolute;
    font-size: 20px;
    color: #a9a9a9;
}

.item i {
    right: 1%;
    top: 30px;
    z-index: 1;
}

[type="date"]::-webkit-calendar-picker-indicator {
    right: 0;
    z-index: 2;
    opacity: 0;
    cursor: pointer;
}

input[type="time"]::-webkit-inner-spin-button {
    margin: 2px 22px 0 0;
}

input[type=radio], input.other {
    display: none;
}

label.radio {
    position: relative;
    display: inline-block;
    margin: 5px 20px 10px 0;
    cursor: pointer;
}

.question span {
    margin-left: 30px;
}

label.radio:before {
    content: "";
    position: absolute;
    top: 2px;
    left: 0;
    width: 15px;
    height: 15px;
    border-radius: 50%;
    border: 2px solid #ccc;
}

#radio_5:checked ~ input.other {
    display: block;
}

input[type=radio]:checked + label.radio:before {
    border: 2px solid #444;
    background: #444;
}

label.radio:after {
    content: "";
    position: absolute;
    top: 7px;
    left: 5px;
    width: 7px;
    height: 4px;
    border: 3px solid #fff;
    border-top: none;
    border-right: none;
    transform: rotate(-45deg);
    opacity: 0;
}

input[type=radio]:checked + label:after {
    opacity: 1;
}

.btn-block {
    margin-top: 10px;
    text-align: center;
}

button {
    width: 150px;
    padding: 10px;
    border: none;
    border-radius: 5px;
    background: #444;
    font-size: 16px;
    color: #fff;
    cursor: pointer;
}

button:hover {
    background: #666;
}

Now, We can check UI will be update in browser

image



Process Server Side With API Notion

Because this is a small example. So I will write all code in “routes/index.js” for everyone easy follow

We need to make a new router for handle when Form submit

router.post("/", async function (req, res, next) {
//To be get parameter before Form submit and send data to server. We can use
const {name, email, phone, address, sex, note} = req.body;
//Just for debug
console.table({name, email, phone, address, sex, note});
//Redirect to form when before submit
res.redirect('/');
});

We can check data before submit

In web

image

In terminal be for click to “button Send”

image

Here we have done for get data from Form submit to Server, The next step we will send this data to Notion



Send data to Notion by API

First step we can install package “@notionhq/client

npm i @notionhq/client

image

Register to use the package

//Required package
const {Client} = require("@notionhq/client")
//Setup config
const notion = new Client({
    auth: process.env.NOTION_TOKEN,
})

Send data to Notion by API

await notion.pages.create({
        parent: {
            database_id: process.env.NOTION_DATABASE_ID,
        },
        properties: {
            Name: {
                title: [
                    {
                        text: {
                            content: name,
                        },
                    },
                ],
            },
            Email: {
                email: email,
            },
            PhoneNumber: {
                rich_text: [
                    {
                        text: {
                            content: phone,
                        },
                    },
                ],
            },
            Address: {
                rich_text: [
                    {
                        text: {
                            content: address,
                        },
                    },
                ],
            },
            Gender: {
                select: {
                    name: gender
                },
            },
            Note: {
                rich_text: [
                    {
                        text: {
                            content: note,
                        },
                    },
                ],
            },
        },
    });

Setup file .env

NOTION_TOKEN=secret_heBrP3242423424322iHM8UzmjnALYvJ4WoeLA
NOTION_DATABASE_ID=ccfe5824942343224aa20ec85e1c2f7e

We wrote the code

Access to link http://localhost:3000/ and fill data click button “Send”

Result

image



Git repository

https://github.com/qt91/InjectionRegistrationNotion


Print Share Comment Cite Upload Translate
APA
Thinh Nguyen | Sciencx (2024-03-29T14:22:59+00:00) » Notion receiver data Immunizations from Nodejs. Retrieved from https://www.scien.cx/2021/09/16/notion-receiver-data-immunizations-from-nodejs/.
MLA
" » Notion receiver data Immunizations from Nodejs." Thinh Nguyen | Sciencx - Thursday September 16, 2021, https://www.scien.cx/2021/09/16/notion-receiver-data-immunizations-from-nodejs/
HARVARD
Thinh Nguyen | Sciencx Thursday September 16, 2021 » Notion receiver data Immunizations from Nodejs., viewed 2024-03-29T14:22:59+00:00,<https://www.scien.cx/2021/09/16/notion-receiver-data-immunizations-from-nodejs/>
VANCOUVER
Thinh Nguyen | Sciencx - » Notion receiver data Immunizations from Nodejs. [Internet]. [Accessed 2024-03-29T14:22:59+00:00]. Available from: https://www.scien.cx/2021/09/16/notion-receiver-data-immunizations-from-nodejs/
CHICAGO
" » Notion receiver data Immunizations from Nodejs." Thinh Nguyen | Sciencx - Accessed 2024-03-29T14:22:59+00:00. https://www.scien.cx/2021/09/16/notion-receiver-data-immunizations-from-nodejs/
IEEE
" » Notion receiver data Immunizations from Nodejs." Thinh Nguyen | Sciencx [Online]. Available: https://www.scien.cx/2021/09/16/notion-receiver-data-immunizations-from-nodejs/. [Accessed: 2024-03-29T14:22:59+00:00]
rf:citation
» Notion receiver data Immunizations from Nodejs | Thinh Nguyen | Sciencx | https://www.scien.cx/2021/09/16/notion-receiver-data-immunizations-from-nodejs/ | 2024-03-29T14:22:59+00:00
https://github.com/addpipe/simple-recorderjs-demo