Apify Email Signature Generator avatar

Apify Email Signature Generator

Try for free

No credit card required

Go to Store
Apify Email Signature Generator

Apify Email Signature Generator

apify/email-signature-generator
Try for free

No credit card required

Generates a standardized email signature for Apify team members, using provided details.

Do you want to learn more about this Actor?

Get a demo

build/generateHTML.js

1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3const types_1 = require("./types");
4const sanitizeUrl = (url) => {
5    if (!/^https?:\/\//i.test(url)) {
6        return 'https://' + url;
7    }
8    return url;
9};
10const generateLinksSection = (input) => {
11    var _a;
12    const urls = [
13        { key: "Twitter", value: input.twitterUrl },
14        { key: "LinkedIn", value: input.linkedInUrl },
15        { key: "Github", value: input.githubUrl },
16        { key: "Book a meeting", value: input.hubspotUrl },
17        ...((_a = input.otherUrls) !== null && _a !== void 0 ? _a : []),
18    ];
19    const urlsHtml = urls
20        .filter((u) => u.value)
21        .map((u) => `<a href="${sanitizeUrl(u.value)}" style="color: #4990ff; text-decoration: none;">${u.key}</a>`)
22        .join(" | ");
23    return `<div style="line-height: 18px;">${urlsHtml}</div>`;
24};
25const typeToHtml = (input) => ({
26    [types_1.EmailSignatureType.Gmail]: `<div style="font-family: Verdana, sans-serif; font-size: 12px; font-weight: 400; color: #8d92af;">
27        <div style="font-weight: 600; line-height: 18px; color: #272c3d;">${input.fullName}</div>
28        <div style="line-height: 18px;">${input.position}</div>
29        <div style="display: flex; align-items: center;">
30            <a href="https://apify.com/">
31                <img src="https://apify.com/ext/logo-for-signatures.png" 
32                alt="Apify" style="margin-top: 12px; width:115px; margin-bottom: 12px;">
33            </a>
34        </div>
35        ${input.phoneNumber
36        ? `<div style="line-height: 18px;">${input.phoneNumber}</div>`
37        : ""}
38        ${generateLinksSection(input)}
39        ${input.apifyUrl
40        ? `<a href="${sanitizeUrl(input.apifyUrl)}" style="color: #4990ff; 
41        text-decoration: none;"><div style="line-height: 18px;">${input.apifyUrlLabel || 'Apify Profile'}</div></a>`
42        : ""}
43        <div style="line-height: 18px; margin-top: 12px;"><a href="https://apify.com" style="color: #4990ff; 
44            text-decoration: none; font-weight: 600;">Apify.com</a>${input.shouldDisplayHiring
45        ? ` | <a href="https://apify.com/jobs" style="color: #4990ff; 
46            text-decoration: none;">We're hiring</a>`
47        : ""}
48        </div>
49        
50        ${input.shouldDisplayG2
51        ? `<div style="display: flex; align-items: center;">
52            <a href="https://www.g2.com/products/apify/reviews">
53                <img src="https://apify.com/ext/g2badge.svg" 
54                alt="G2 badge" style="margin-top: 12px; width:90px; margin-bottom: 12px;">
55            </a>
56        </div>`
57        : ""}</div>`,
58    [types_1.EmailSignatureType.Outlook]: `<div style="font-family: Verdana, sans-serif; font-size: 12px; font-weight: 400; color: #8d92af;">
59    <div style="font-weight: 600; line-height: 18px; color: #272c3d;">${input.fullName}</div>
60    <div style="line-height: 18px;">${input.position}</div>
61    <br style="line-height: 12px;"> 
62    <a href="https://apify.com/"><img src="https://apify.com/ext/logo-for-signatures.png" 
63        alt="Apify" style="width: 115px;"></a>
64    <br style="line-height: 12px;"> 
65    ${input.phoneNumber
66        ? `<div style="line-height: 18px;">${input.phoneNumber}</div>`
67        : ""}
68    ${generateLinksSection(input)}
69    ${input.apifyUrl
70        ? `<a href="${sanitizeUrl(input.apifyUrl)}" style="color: #4990ff; 
71    text-decoration: none;"><div style="line-height: 18px;">${input.apifyUrlLabel || 'Apify Profile'}</div></a>`
72        : ""}
73    <br style="line-height: 12px;">
74    <div style="line-height: 18px;"><a href="https://apify.com" style="color: #4990ff; 
75        text-decoration: none; font-weight: 600;">Apify.com</a>${input.shouldDisplayHiring
76        ? ` | <a href="https://apify.com/jobs" style="color: #4990ff; 
77        text-decoration: none;">We're hiring</a>`
78        : ""}
79    </div>
80    <br style="line-height: 12px;">
81    ${input.shouldDisplayG2
82        ? `
83        <a href="https://www.g2.com/products/apify/reviews">
84            <img src="https://apify.com/ext/g2badge.svg" 
85            alt="G2 badge" style="width:90px;">
86        </a>`
87        : ""}
88</div>`,
89});
90exports.default = (input, type) => {
91    const result = typeToHtml(input)[type];
92    return result;
93};

build/main.js

1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3const generateHTML_1 = require("./generateHTML");
4const Apify = require("apify");
5Apify.main(async () => {
6    const input = (await Apify.getInput());
7    await Apify.setValue("OUTPUT", generateHTML_1.default(input, input.type), { 'contentType': 'text/html; charset=utf-8' });
8    console.log('Done!');
9    console.log('Your email signature can be viewed in the Key-value store under the key "OUTPUT"');
10});

build/types.js

1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3exports.EmailSignatureType = void 0;
4var EmailSignatureType;
5(function (EmailSignatureType) {
6    EmailSignatureType["Gmail"] = "Gmail";
7    EmailSignatureType["Outlook"] = "Outlook";
8})(EmailSignatureType = exports.EmailSignatureType || (exports.EmailSignatureType = {}));

src/generateHTML.ts

Download

src/main.ts

Download

src/types.ts

Download

.editorconfig

1root = true
2
3[*]
4indent_style = space
5indent_size = 4
6charset = utf-8
7trim_trailing_whitespace = true
8insert_final_newline = true
9end_of_line = lf

.eslintrc

1{
2    "extends": "@apify"
3}

.gitignore

1# This file tells Git which files shouldn't be added to source control
2
3.idea
4node_modules
5
6apify_storage

Dockerfile

1# First, specify the base Docker image. You can read more about
2# the available images at https://sdk.apify.com/docs/guides/docker-images
3# You can also use any other image from Docker Hub.
4FROM apify/actor-node:15
5
6# Second, copy just package.json and package-lock.json since it should be
7# the only file that affects "npm install" in the next step, to speed up the build
8COPY package*.json ./
9
10# Install NPM packages, skip optional and development dependencies to
11# keep the image small. Avoid logging too much and print the dependency
12# tree for debugging
13RUN npm --quiet set progress=false \
14 && npm install --only=prod --no-optional \
15 && echo "Installed NPM packages:" \
16 && (npm list || true) \
17 && echo "Node.js version:" \
18 && node --version \
19 && echo "NPM version:" \
20 && npm --version
21
22# Next, copy the remaining files and directories with the source code.
23# Since we do this after NPM install, quick build will be really fast
24# for most source file changes.
25COPY . ./
26
27# Optionally, specify how to launch the source code of your actor.
28# By default, Apify's base Docker images define the CMD instruction
29# that runs the Node.js source code using the command specified
30# in the "scripts.start" section of the package.json file.
31# In short, the instruction looks something like this:
32#
33# CMD npm start

INPUT_SCHEMA.json

1{
2    "title": "Email signature generator actor input schema",
3    "description": "Enter your details for the Apify email signature. Only enter the values that you want to have in your signature.",
4    "type": "object",
5    "schemaVersion": 1,
6    "properties": {
7        "fullName": {
8            "title": "Full Name",
9            "type": "string",
10            "description": "The full name displayed in the signature.",
11            "editor": "textfield"
12        },
13        "position": {
14            "title": "Position",
15            "type": "string",
16            "description": "Your position in Apify.",
17            "editor": "textfield"
18        },
19        "phoneNumber": {
20            "title": "Phone Number",
21            "type": "string",
22            "description": "Your phone number.",
23            "editor": "textfield"
24        },
25        "twitterUrl": {
26            "title": "Twitter URL",
27            "type": "string",
28            "description": "The URL of your Twitter.",
29            "editor": "textfield"
30        },
31        "linkedInUrl": {
32            "title": "LinkedIn URL",
33            "type": "string",
34            "description": "The URL of your LinkedIn.",
35            "editor": "textfield"
36        },
37        "githubUrl": {
38            "title": "GitHub URL",
39            "type": "string",
40            "description": "The URL of your GitHub.",
41            "editor": "textfield"
42        },
43        "hubspotUrl": {
44            "title": "Hubspot URL",
45            "type": "string",
46            "description": "The URL for Hubspot meetings.",
47            "editor": "textfield"
48        },
49        "otherUrls": {
50            "title": "Other URLs",
51            "type": "array",
52            "description": "Other URLs. The first value is the label (e.g. \"Facebook\"), the second one is the URL (e.g. \"https://facebook.com\")",
53            "editor": "keyValue",
54            "uniqueItems": false,
55            "placeholderKey": "Displayed label (e.g. \"Facebook\")",
56            "placeholderValue": "URL (e.g. \"https://facebook.com\")"
57        },
58        "apifyUrl": {
59            "title": "Apify Profile URL",
60            "type": "string",
61            "description": "The URL of your Apify profile.",
62            "editor": "textfield"
63        },
64        "apifyUrlLabel": {
65            "title": "Apify Profile URL Label",
66            "type": "string",
67            "description": "Optional label for your Apify profile URL. The default is \"Apify Profile\"",
68            "editor": "textfield"
69        },
70        "shouldDisplayHiring": {
71            "title": "Should Display Hiring Information",
72            "type": "boolean",
73            "description": "Determines whether the hiring link gets displayed.",
74            "editor": "checkbox"
75        },
76        "shouldDisplayG2": {
77            "title": "Should Display G2 banner",
78            "type": "boolean",
79            "description": "Determines whether the G2 banner gets displayed.",
80            "editor": "checkbox"
81        },
82        "type": {
83            "title": "Signature type",
84            "type": "string",
85            "description": "The signature type.",
86            "default": "Gmail",
87            "editor": "select",
88            "enum": ["Gmail", "Outlook"]
89        }
90    },
91    "required": ["fullName", "position", "shouldDisplayHiring", "type"]
92}

apify.json

1{
2	"name": "email-signature-generator",
3	"version": "0.0",
4	"buildTag": "latest",
5	"env": null,
6	"template": "project_empty"
7}

package.json

1{
2	"name": "email-signature-generator",
3	"version": "0.0.1",
4	"description": "This actor generates email signatures for Apify.",
5	"dependencies": {
6		"@types/node": "^14.17.4",
7		"apify": "^1.0.1",
8		"typescript": "^4.3.5"
9	},
10	"devDependencies": {
11		"@apify/eslint-config": "^0.1.3",
12		"eslint": "^7.0.0"
13	},
14	"scripts": {
15		"start": "npm run build && node build/main.js",
16		"lint": "./node_modules/.bin/eslint ./src --ext .js,.jsx",
17		"lint:fix": "./node_modules/.bin/eslint ./src --ext .js,.jsx --fix",
18		"test": "echo \"Error: oops, the actor has no tests yet, sad!\" && exit 1",
19		"build": "tsc -p tsconfig.json"
20	},
21	"main": "build/main.js",
22	"author": "Jiri Moravcik",
23	"license": "ISC"
24}

test.html

1<html><body>
2    <div style="font-family: Verdana, sans-serif; font-size: 12px; font-weight: 400; color: #8d92af;">
3        <div style="font-weight: 600; line-height: 18px; color: #272c3d;">Jiri Moravcik</div>
4        <div style="line-height: 18px;">Platform Engineer</div>
5        <div style="display: flex; align-items: center;">
6            <a href="https://apify.com/">
7                <img src="https://apify.com/ext/apify-logo-120px.png" 
8                alt="Apify" style="margin-top: 12px; width:115px; margin-bottom: 12px;">
9            </a>
10        </div>
11        
12        <div style="line-height: 18px;"><a href="https://linkedin.com/krystofjezek" style="color: #4990ff; 
13            text-decoration: none;">LinkedIn</a> | <a href="https://github.com/krystofjezek" style="color: #4990ff; 
14            text-decoration: none;">Github</a> | <a href="https://meetings.hubspot.com/shash-tandon" style="color: #4990ff; 
15            text-decoration: none;">Book a meeting</a>
16        </div>
17        
18        <div style="line-height: 18px; margin-top: 12px;"><a href="https://apify.com" style="color: #4990ff; 
19            text-decoration: none; font-weight: 600;">Apify.com</a>
20        </div>
21</body></html>

tsconfig.json

1{
2    "compilerOptions": {
3        "target": "es2019",
4        "module": "commonjs",
5        "moduleResolution": "node",
6        "strict": true,
7        "noImplicitAny": false,
8        "strictNullChecks": false,
9        "lib": [
10             "DOM",
11             "DOM.Iterable",
12             "ES2015",
13             "ES2016",
14             "ES2018",
15             "ES2019.Object",
16             "ES2018.AsyncIterable",
17             "ES2020.String",
18             "ES2019.Array"
19        ],
20        "rootDir": "src/",
21        "outDir": "build/"
22    },
23    "include": [
24        "src/"
25    ]
26}
Developer
Maintained by Apify

Actor Metrics

  • 3 monthly users

  • 22 stars

  • >99% runs succeeded

  • Created in Aug 2021

  • Modified 7 months ago

Categories