npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@tdcerhverv/contactform

v1.23.5

Published

Contactform module for tdc.dk

Downloads

287

Readme

ContactForm

Modular Contact Forms for TDC.dk open pages.

Installation

npm install @tdcerhverv/contactform

Standard Contact Form

A baseline contact form with no out-of-the-box integrations The <StandardContactForm /> is a formik-integrated modular form which should serve as the basis for all forms on TDC.dk. It is built using Material UI and Formik.

Usage

import { StandardContactForm, FormSubmission, ISubmissionState, FeedbackDialog } from '@tdcerhverv/contactform'

Props

The props for this component are defined as follows:

export interface IStandardContactForm extends IContactFormBase {
    fieldSections: IFieldSections[]
    onSubmit: FormSubmission
}

export interface IContactFormBase {
    formId: string
    optionalLabel?: string
    submitButtonDisplay?: 'RIGHT' | 'LEFT' | 'CENTER' | 'STRETCH' | 'BETWEEN'
    buttonText?: string
    buttonTextSending?: string
    alertText?: string
    modal?: IModal
    formSubmissionState: ISubmissionState | null
    setFormSubmissionState: (formSubmissionState: ISubmissionState | null) => void
    persistState: boolean
    inlineAnnouncement?: IAlert
    preFilledMessage?: string
    environment?: Environment
}

export interface IFieldSections {
    sectionTitle?: string
    fields: InputField[]
}

Required Props:

  • formId is a string to identify the form
  • onSubmit is a function that defines how to handle form submission. FormSubmission is a type alias for (values: unknown, formikHelpers: FormikHelpers<unknown>) => Promise<boolean>
  • setFormSubmissionState is a passed down useState hook, that returns the state of the form after submission. This can be used to display any kind of feedback to the user

Optional Props:

  • fieldSections is a two dimensional array which takes sections as objects. The sections include an array of fields and an optional section title (sectionTitle). Sections provide a visual distinction between groups of fields (there is 24px spacing between fields, while sections are seperated with a divider component. If you do not want multiple sections in your form, simply add 1 section which includes all inputfields.
  • submitButtonDisplay allows you yo change the flexbox properties and alignment of the "send" button
  • buttonText allows you to change the text in the form's submission button. Default value is "Send"
  • buttonTextSending allows you the change the text in the form's submission button while the form is submitting. Default value is "Sender Besked"
  • alertText allows you to change the text of the alert that is displayed when a field is not filled correctly. Default value is "Der er felter, som ikke er udfyldt korrekt"
  • modal This prop task two required props. One is the close dialog handle function, and the other is the inner text for cancel button. This this props is provided, the form is now able to control the open/close state of a dialog.
  • inlineAnnouncement This prop allows to have an inline Announcement at the top of the form in case any additonal information should be displayed to the user. The prop takes an object of type IAlert which can be seen below. The description can take markdown or a string.
  • preFilledMessage When this is added the string will be added as initial value for the MESSAGE field.
interface IAlert {
    title: string
    description: {
        description: string
    }
    severity: 'error' | 'warning' | 'success' | 'info'
}

Optional Field Props:

  • fieldWidth An optional prop that can be used to define the width of a field. if given no value, fields will default to 100% width except for number fields. The prop takes a string or an int

FormSubmission

import { StandardContactForm, FormSubmission, ISubmissionState, FeedbackDialog } from '@tdcerhverv/contactform'

const [formSubmissionState, setFormSubmissionState] = useState<ISubmissionState | null>(null)

//simple submission handler to display form values in an alert
const handleSubmission: FormSubmission = (values, _formikHelpers) => {
    alert(JSON.stringify(values, null, '\t'))
}

;<StandardContactForm formId="myForm" onSubmit={handleSubmission} setFormSubmissionState={setFormSubmissionState} />
{
    formSubmissionState && <FeedbackDialog {...formSubmissionState} />
}

Validation

The <StandardContactForm /> uses a combination of Formik and Yup to provide a standard validation schema to all forms.

Individual fields have the following validation rules and error messages:

| Field Name | Validation Rule | Error Message | | ---------- | -------------------- | --------------------------------------- | | EMAIL | yup.string.email() | Angiv venligst en gyldig E-mail adresse | | MESSAGE | yup.string.min(10) | Beskeden skal bestå af mindst 10 tegn. |

Any fields which are not specified here are given the yup.mixed() validation rule, with the default error of Der sket en fejl. This validation should not be seen by users, but acts as a safety net for unforseen errors.

All fields can be given the required prop, which will append the yup.required() rule to that field's validation schema. Any empty fields that are required will block formik.onSubmit from being called, and display the error message 'Obligatorisk felt' as assistive text to the field.

Salesforce Form

The <SalesforceForm /> is the primary form used on TDC.dk. This form is built upon the <StandardContactForm />, and provides off-the-shelf validation and integration with our Salesforce Integration Middleware for LEAD and CASE forms.

Props

The salesforceForm has the following props:

export interface ISalesforceForm extends IContactFormProps {
    formType: FormType
    environment: Environment
    formData: ICaseForm | ILeadForm
    fields: [
        {
            salesforcemapping?: string
        } & InputField,
    ]
}
  • formType prop can be CASE or LEAD, defines if this is a Case form or a Lead form.
  • environment prop can be PROD or DEV, sets up to send the cases to the Salesforce production or development endpoints.
  • formData prop defines all the data needed by Salesforce in addition to the fields and user-supplied values. Find the details in Salesforce Definitions section below.
  • fields prop refers to input fields. Example: text, cvr, address etc.
  • salesforcemapping is an optional prop, but is required for the following types of fields:
    • CHECKBOX
    • CHECKBOXGROUP
    • RADIO
    • TEXT
  • Salesforce also requires a sourceUrl, though this is provided on submission as window.location.host + window.location.pathname.
interface IBaseSalesforceFormData {
    Recordtypeid?: string
    Origin: string //Origin is called LeadSource on LeadForm
}
export interface ICaseForm extends IBaseSalesforceFormData {
    Type__c: string
    Sub_Type__c: string
    Subject: string
}
export interface ILeadForm extends IBaseSalesforceFormData {
    Lead_Type__c: string
    DemandBase_Information__c?: string
}

Salesforce Definitions

CASE:

| field-name | field-rules | Salesforce Requirements | Business Requirements | | ------------------------ | ------------------- | :---------------------: | :-------------------: | | Subject | Text(255) | Optional | ✔ | | Description | Text Area(32000) | Optional | ✔(when given) | | Recordtypeid | Id(similar to text) | Optional | ✔ | | Type__c | Picklist | ✔ | ✔ | | Sub_Type__c | Picklist | Optional | ✔ | | SuppliedName | Text(255) | Optional | ✔(when given) | | SuppliedPhone | Phone | Optional | ✔(when given) | | SuppliedEmail | Email | Optional | ✔(when given) | | CVR_number__c | Text(255) | Optional | ✔ | | Web_Account_Name__c | Text(50) | Optional | ✔(when CVR is given) | | Web_Account_Address__c | Text Area(255) | Optional | ✔(when CVR is given) | | Web_Account_Number__c | Text(15) | Optional | ✔(when CVR is given) | | Web_Invoice_Number__c | Text(15) | Optional | ✔(when CVR is given) | | Origin | Picklist | Optional | ✔ | | Web_P_Number__c | Text(255) | Optional | Optional |

ONE+ CONFIGURATOR LEAD:

| field-name | field-rules | Salesforce Requirements | Business Requirements | | ------------------------ | --------------------- | :---------------------: | :-------------------: | | LeadSource | Picklist | ✔ | ✔ | | Company | Text(255) | ✔ | ✔(when CVR is given) | | Lead_Type__c | Picklist | ✔ | ✔ | | FirstName | Text(40) | ✔ | ✔(when given) | | LastName | Text(80) | ✔ | ✔(when given) | | Web_Email__c | Email | Optional | ✔(when given) | | Email | Email | Optional | ✔(when given) | | Web_CVR__c | Long Text(255) | ✔ | ✔(when CVR is given) | | Phone | Phone | Optional | ✔(when given) | | Description | Text Area(32000) | Optional | ✔(when given) | | Recordtypeid | Id(similar to text) | Optional | ✔ | | Product_of_Interest__c | Multi Picklist | Optional | ✔(when given) | | Source_URL__c | Text(1000) | Optional | ✔ | | Product_Information__c | Long Text Area(32000) | Optional | Optional |

VERTIC LEAD:

| field-name | field-rules | Salesforce Requirements | Business Requirements | | --------------------------- | --------------------- | :---------------------: | :-------------------: | | LeadSource | Picklist | ✔ | ✔ | | Company | Text(255) | ✔ | ✔(when CVR is given) | | Lead_Type__c | Picklist | ✔ | ✔ | | FirstName | Text(40) | ✔ | ✔(when given) | | LastName | Text(80) | ✔ | ✔(when given) | | Web_Email__c | Email | Optional | ✔(when given) | | Email | Email | Optional | ✔(when given) | | Web_CVR__c | Long Text(255) | ✔ | ✔(when CVR is given) | | Phone | Phone | Optional | ✔(when given) | | Description | Text Area(32000) | Optional | ✔(when given) | | Recordtypeid | Id(similar to text) | Optional | ✔ | | Product_of_Interest__c | Multi Picklist | Optional | ✔(when given) | | Source_URL__c | Text(1000) | Optional | ✔ | | DemandBase_Information__c | Long Text Area(32000) | Optional | Optional |

Salesforce Picklist values

CASE:

Type__c:      Billing | Inquiry
Sub_Type__c:  Inquiry | Standard Inquiry
Origin:       Web - Open Pages

Vertic LEAD:

Lead_Type__c: Digital Demand Engine
LeadSource:   Web - Open Pages
Product_of_Interest__c: One+| Mobil| Internet

One+ Configurator LEAD:

Lead_Type__c: One+ Configurator
LeadSource:   Web - Open Pages
Product_of_Interest__c: One+
Product_Information__c: Its a generic field that can take any string. Max length 32000 characters.
This field contains the user choices from the One+ configurator.

FeedbackDialog

The <FeedbackDialog /> is the standalone component that can be use in conjunction with the StandardContantForm or the SaleforceForm. It take props of ISubmissionState.

Salesforce mappings

Known salesforce fields that are mapped by using the salesforcemapping parameter | field-name | field-rules | Salesforce Requirements | Business Requirements | | --------------------------- | --------------------- | :---------------------: | :-------------------: | | Web_Address__c | Text Area(255) | Optional | ✔(when the field is given) |