mirror of
https://github.com/n8n-io/n8n.git
synced 2024-11-15 09:04:07 -08:00
804 lines
24 KiB
Vue
804 lines
24 KiB
Vue
<template>
|
|
<Modal
|
|
:name="PERSONALIZATION_MODAL_KEY"
|
|
:title="$locale.baseText('personalizationModal.customizeN8n')"
|
|
:subtitle="$locale.baseText('personalizationModal.theseQuestionsHelpUs')"
|
|
:center-title="true"
|
|
:show-close="false"
|
|
:event-bus="modalBus"
|
|
:close-on-click-modal="false"
|
|
:close-on-press-escape="false"
|
|
width="460px"
|
|
data-test-id="personalization-form"
|
|
@enter="onSave"
|
|
>
|
|
<template #content>
|
|
<div :class="$style.container">
|
|
<n8n-form-inputs
|
|
v-model="formValues"
|
|
:inputs="survey"
|
|
:column-view="true"
|
|
:event-bus="formBus"
|
|
:teleported="teleported"
|
|
tag-size="small"
|
|
@submit="onSubmit"
|
|
/>
|
|
<n8n-card v-if="canRegisterForEnterpriseTrial">
|
|
<n8n-checkbox v-model="registerForEnterpriseTrial">
|
|
<i18n-t keypath="personalizationModal.registerEmailForTrial">
|
|
<template #trial>
|
|
<strong>
|
|
{{ $locale.baseText('personalizationModal.registerEmailForTrial.enterprise') }}
|
|
</strong>
|
|
</template>
|
|
</i18n-t>
|
|
<n8n-text size="small" tag="div" color="text-light">
|
|
{{ $locale.baseText('personalizationModal.registerEmailForTrial.notice') }}
|
|
</n8n-text>
|
|
</n8n-checkbox>
|
|
</n8n-card>
|
|
</div>
|
|
</template>
|
|
<template #footer>
|
|
<div>
|
|
<n8n-button
|
|
:loading="isSaving"
|
|
:label="$locale.baseText('personalizationModal.getStarted')"
|
|
float="right"
|
|
@click="onSave"
|
|
/>
|
|
</div>
|
|
</template>
|
|
</Modal>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { defineComponent } from 'vue';
|
|
import { mapStores } from 'pinia';
|
|
import {
|
|
COMPANY_SIZE_100_499,
|
|
COMPANY_SIZE_1000_OR_MORE,
|
|
COMPANY_SIZE_20_OR_LESS,
|
|
COMPANY_SIZE_20_99,
|
|
COMPANY_SIZE_500_999,
|
|
COMPANY_SIZE_KEY,
|
|
COMPANY_SIZE_PERSONAL_USE,
|
|
GOVERNMENT_INDUSTRY,
|
|
HEALTHCARE_INDUSTRY,
|
|
LEGAL_INDUSTRY,
|
|
OTHER_INDUSTRY_OPTION,
|
|
PERSONALIZATION_MODAL_KEY,
|
|
SECURITY_INDUSTRY,
|
|
EDUCATION_TYPE,
|
|
FINANCE_INSURANCE_INDUSTRY,
|
|
IT_INDUSTRY,
|
|
MARKETING_INDUSTRY,
|
|
MEDIA_INDUSTRY,
|
|
MANUFACTURING_INDUSTRY,
|
|
PHYSICAL_RETAIL_OR_SERVICES,
|
|
REAL_ESTATE_OR_CONSTRUCTION,
|
|
TELECOMS_INDUSTRY,
|
|
OTHER_AUTOMATION_GOAL,
|
|
COMPANY_TYPE_KEY,
|
|
EMAIL_KEY,
|
|
SAAS_COMPANY_TYPE,
|
|
ECOMMERCE_COMPANY_TYPE,
|
|
MSP_INDUSTRY,
|
|
DIGITAL_AGENCY_COMPANY_TYPE,
|
|
SYSTEMS_INTEGRATOR_COMPANY_TYPE,
|
|
OTHER_COMPANY_TYPE,
|
|
PERSONAL_COMPANY_TYPE,
|
|
COMPANY_INDUSTRY_EXTENDED_KEY,
|
|
OTHER_COMPANY_INDUSTRY_EXTENDED_KEY,
|
|
ONBOARDING_PROMPT_TIMEBOX,
|
|
FIRST_ONBOARDING_PROMPT_TIMEOUT,
|
|
ONBOARDING_CALL_SIGNUP_MODAL_KEY,
|
|
MARKETING_AUTOMATION_GOAL_KEY,
|
|
MARKETING_AUTOMATION_LEAD_GENERATION_GOAL,
|
|
MARKETING_AUTOMATION_CUSTOMER_COMMUNICATION,
|
|
MARKETING_AUTOMATION_ACTIONS,
|
|
MARKETING_AUTOMATION_AD_CAMPAIGN,
|
|
MARKETING_AUTOMATION_REPORTING,
|
|
MARKETING_AUTOMATION_DATA_SYNCHING,
|
|
MARKETING_AUTOMATION_OTHER,
|
|
OTHER_MARKETING_AUTOMATION_GOAL_KEY,
|
|
ROLE_KEY,
|
|
ROLE_BUSINESS_OWNER,
|
|
ROLE_CUSTOMER_SUPPORT,
|
|
ROLE_ENGINEERING,
|
|
ROLE_DATA_SCIENCE,
|
|
ROLE_DEVOPS,
|
|
ROLE_IT,
|
|
ROLE_SALES_AND_MARKETING,
|
|
ROLE_SECURITY,
|
|
ROLE_OTHER,
|
|
ROLE_OTHER_KEY,
|
|
DEVOPS_AUTOMATION_GOAL_OTHER_KEY,
|
|
DEVOPS_AUTOMATION_GOAL_KEY,
|
|
DEVOPS_AUTOMATION_OTHER,
|
|
DEVOPS_AUTOMATION_CI_CD_GOAL,
|
|
DEVOPS_AUTOMATION_CLOUD_INFRASTRUCTURE_ORCHESTRATION_GOAL,
|
|
DEVOPS_AUTOMATION_DATA_SYNCING_GOAL,
|
|
DEVOPS_INCIDENT_RESPONSE_GOAL,
|
|
DEVOPS_MONITORING_AND_ALERTING_GOAL,
|
|
DEVOPS_REPORTING_GOAL,
|
|
DEVOPS_TICKETING_SYSTEMS_INTEGRATIONS_GOAL,
|
|
AUTOMATION_BENEFICIARY_KEY,
|
|
AUTOMATION_BENEFICIARY_SELF,
|
|
AUTOMATION_BENEFICIARY_MY_TEAM,
|
|
AUTOMATION_BENEFICIARY_OTHER_TEAMS,
|
|
REPORTED_SOURCE_KEY,
|
|
REPORTED_SOURCE_GOOGLE,
|
|
REPORTED_SOURCE_TWITTER,
|
|
REPORTED_SOURCE_LINKEDIN,
|
|
REPORTED_SOURCE_YOUTUBE,
|
|
REPORTED_SOURCE_FRIEND,
|
|
REPORTED_SOURCE_PODCAST,
|
|
REPORTED_SOURCE_EVENT,
|
|
REPORTED_SOURCE_OTHER,
|
|
REPORTED_SOURCE_OTHER_KEY,
|
|
VIEWS,
|
|
} from '@/constants';
|
|
import { useToast } from '@/composables/useToast';
|
|
import Modal from '@/components/Modal.vue';
|
|
import type { IFormInputs, IPersonalizationLatestVersion, IUser } from '@/Interface';
|
|
import { getAccountAge } from '@/utils/userUtils';
|
|
import type { GenericValue } from 'n8n-workflow';
|
|
import { useUIStore } from '@/stores/ui.store';
|
|
import { useSettingsStore } from '@/stores/settings.store';
|
|
import { useRootStore } from '@/stores/n8nRoot.store';
|
|
import { useUsersStore } from '@/stores/users.store';
|
|
import { createEventBus } from 'n8n-design-system/utils';
|
|
import { usePostHog } from '@/stores/posthog.store';
|
|
import { useExternalHooks } from '@/composables/useExternalHooks';
|
|
import { useUsageStore } from '@/stores/usage.store';
|
|
import { useMessage } from '@/composables/useMessage';
|
|
|
|
const SURVEY_VERSION = 'v4';
|
|
|
|
export default defineComponent({
|
|
name: 'PersonalizationModal',
|
|
components: { Modal },
|
|
props: {
|
|
teleported: {
|
|
type: Boolean,
|
|
default: true,
|
|
},
|
|
},
|
|
setup() {
|
|
const externalHooks = useExternalHooks();
|
|
|
|
return {
|
|
externalHooks,
|
|
...useToast(),
|
|
...useMessage(),
|
|
};
|
|
},
|
|
data() {
|
|
return {
|
|
formValues: {} as Record<string, string>,
|
|
isSaving: false,
|
|
PERSONALIZATION_MODAL_KEY,
|
|
otherWorkAreaFieldVisible: false,
|
|
otherCompanyIndustryFieldVisible: false,
|
|
showAllIndustryQuestions: true,
|
|
registerForEnterpriseTrial: false,
|
|
modalBus: createEventBus(),
|
|
formBus: createEventBus(),
|
|
domainBlocklist: [] as string[],
|
|
};
|
|
},
|
|
computed: {
|
|
...mapStores(
|
|
useRootStore,
|
|
useSettingsStore,
|
|
useUIStore,
|
|
useUsersStore,
|
|
useUsageStore,
|
|
usePostHog,
|
|
),
|
|
currentUser() {
|
|
return this.usersStore.currentUser;
|
|
},
|
|
canRegisterForEnterpriseTrial() {
|
|
if (
|
|
this.settingsStore.isCloudDeployment ||
|
|
this.domainBlocklist.length === 0 ||
|
|
!this.currentUser?.email
|
|
) {
|
|
return false;
|
|
}
|
|
|
|
const isSizeEligible = [COMPANY_SIZE_500_999, COMPANY_SIZE_1000_OR_MORE].includes(
|
|
this.formValues[COMPANY_SIZE_KEY],
|
|
);
|
|
|
|
const emailParts = this.currentUser.email.split('@');
|
|
const emailDomain = emailParts[emailParts.length - 1];
|
|
const isEmailEligible = !this.domainBlocklist.find(
|
|
(blocklistedDomain) => emailDomain === blocklistedDomain,
|
|
);
|
|
|
|
return isSizeEligible && isEmailEligible;
|
|
},
|
|
survey() {
|
|
const survey: IFormInputs = [
|
|
{
|
|
name: EMAIL_KEY,
|
|
properties: {
|
|
label: this.$locale.baseText('personalizationModal.yourEmailAddress'),
|
|
type: 'text',
|
|
placeholder: this.$locale.baseText('personalizationModal.email'),
|
|
},
|
|
shouldDisplay: () =>
|
|
this.settingsStore.isDesktopDeployment && !this.usersStore.currentUser?.firstName,
|
|
},
|
|
{
|
|
name: COMPANY_TYPE_KEY,
|
|
properties: {
|
|
label: this.$locale.baseText('personalizationModal.whatBestDescribesYourCompany'),
|
|
type: 'select',
|
|
placeholder: this.$locale.baseText('personalizationModal.select'),
|
|
options: [
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.saas'),
|
|
value: SAAS_COMPANY_TYPE,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.eCommerce'),
|
|
value: ECOMMERCE_COMPANY_TYPE,
|
|
},
|
|
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.digitalAgencyOrConsultant'),
|
|
value: DIGITAL_AGENCY_COMPANY_TYPE,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.systemsIntegrator'),
|
|
value: SYSTEMS_INTEGRATOR_COMPANY_TYPE,
|
|
},
|
|
{
|
|
value: EDUCATION_TYPE,
|
|
label: this.$locale.baseText('personalizationModal.education'),
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.other'),
|
|
value: OTHER_COMPANY_TYPE,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.imNotUsingN8nForWork'),
|
|
value: PERSONAL_COMPANY_TYPE,
|
|
},
|
|
],
|
|
},
|
|
},
|
|
{
|
|
name: COMPANY_INDUSTRY_EXTENDED_KEY,
|
|
properties: {
|
|
type: 'multi-select',
|
|
label: this.$locale.baseText('personalizationModal.whichIndustriesIsYourCompanyIn'),
|
|
placeholder: this.$locale.baseText('personalizationModal.select'),
|
|
options: [
|
|
{
|
|
value: FINANCE_INSURANCE_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.financeOrInsurance'),
|
|
},
|
|
{
|
|
value: GOVERNMENT_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.government'),
|
|
},
|
|
{
|
|
value: HEALTHCARE_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.healthcare'),
|
|
},
|
|
{
|
|
value: IT_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.it'),
|
|
},
|
|
{
|
|
value: LEGAL_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.legal'),
|
|
},
|
|
{
|
|
value: MSP_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.managedServiceProvider'),
|
|
},
|
|
{
|
|
value: MARKETING_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.marketing'),
|
|
},
|
|
{
|
|
value: MEDIA_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.media'),
|
|
},
|
|
{
|
|
value: MANUFACTURING_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.manufacturing'),
|
|
},
|
|
{
|
|
value: PHYSICAL_RETAIL_OR_SERVICES,
|
|
label: this.$locale.baseText('personalizationModal.physicalRetailOrServices'),
|
|
},
|
|
{
|
|
value: REAL_ESTATE_OR_CONSTRUCTION,
|
|
label: this.$locale.baseText('personalizationModal.realEstateOrConstruction'),
|
|
},
|
|
{
|
|
value: SECURITY_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.security'),
|
|
},
|
|
{
|
|
value: TELECOMS_INDUSTRY,
|
|
label: this.$locale.baseText('personalizationModal.telecoms'),
|
|
},
|
|
{
|
|
value: OTHER_INDUSTRY_OPTION,
|
|
label: this.$locale.baseText('personalizationModal.otherPleaseSpecify'),
|
|
},
|
|
],
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
return companyType === OTHER_COMPANY_TYPE;
|
|
},
|
|
},
|
|
{
|
|
name: OTHER_COMPANY_INDUSTRY_EXTENDED_KEY,
|
|
properties: {
|
|
placeholder: this.$locale.baseText('personalizationModal.specifyYourCompanysIndustry'),
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
const companyIndustry = (values as IPersonalizationLatestVersion)[
|
|
COMPANY_INDUSTRY_EXTENDED_KEY
|
|
];
|
|
return (
|
|
companyType === OTHER_COMPANY_TYPE &&
|
|
!!companyIndustry &&
|
|
companyIndustry.includes(OTHER_INDUSTRY_OPTION)
|
|
);
|
|
},
|
|
},
|
|
{
|
|
name: ROLE_KEY,
|
|
properties: {
|
|
type: 'select',
|
|
label: this.$locale.baseText('personalizationModal.whichRoleBestDescribesYou'),
|
|
placeholder: this.$locale.baseText('personalizationModal.select'),
|
|
options: [
|
|
{
|
|
value: ROLE_BUSINESS_OWNER,
|
|
label: this.$locale.baseText('personalizationModal.businessOwner'),
|
|
},
|
|
{
|
|
value: ROLE_CUSTOMER_SUPPORT,
|
|
label: this.$locale.baseText('personalizationModal.customerSupport'),
|
|
},
|
|
{
|
|
value: ROLE_DATA_SCIENCE,
|
|
label: this.$locale.baseText('personalizationModal.dataScience'),
|
|
},
|
|
{
|
|
value: ROLE_DEVOPS,
|
|
label: this.$locale.baseText('personalizationModal.devops'),
|
|
},
|
|
{
|
|
value: ROLE_IT,
|
|
label: this.$locale.baseText('personalizationModal.it'),
|
|
},
|
|
{
|
|
value: ROLE_ENGINEERING,
|
|
label: this.$locale.baseText('personalizationModal.engineering'),
|
|
},
|
|
{
|
|
value: ROLE_SALES_AND_MARKETING,
|
|
label: this.$locale.baseText('personalizationModal.salesAndMarketing'),
|
|
},
|
|
{
|
|
value: ROLE_SECURITY,
|
|
label: this.$locale.baseText('personalizationModal.security'),
|
|
},
|
|
{
|
|
value: ROLE_OTHER,
|
|
label: this.$locale.baseText('personalizationModal.otherPleaseSpecify'),
|
|
},
|
|
],
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
return companyType !== PERSONAL_COMPANY_TYPE;
|
|
},
|
|
},
|
|
{
|
|
name: ROLE_OTHER_KEY,
|
|
properties: {
|
|
placeholder: this.$locale.baseText('personalizationModal.specifyYourRole'),
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
const role = (values as IPersonalizationLatestVersion)[ROLE_KEY];
|
|
return companyType !== PERSONAL_COMPANY_TYPE && role === ROLE_OTHER;
|
|
},
|
|
},
|
|
{
|
|
name: DEVOPS_AUTOMATION_GOAL_KEY,
|
|
properties: {
|
|
type: 'multi-select',
|
|
label: this.$locale.baseText('personalizationModal.whatAreYouLookingToAutomate'),
|
|
placeholder: this.$locale.baseText('personalizationModal.select'),
|
|
options: [
|
|
{
|
|
value: DEVOPS_AUTOMATION_CI_CD_GOAL,
|
|
label: this.$locale.baseText('personalizationModal.cicd'),
|
|
},
|
|
{
|
|
value: DEVOPS_AUTOMATION_CLOUD_INFRASTRUCTURE_ORCHESTRATION_GOAL,
|
|
label: this.$locale.baseText(
|
|
'personalizationModal.cloudInfrastructureOrchestration',
|
|
),
|
|
},
|
|
{
|
|
value: DEVOPS_AUTOMATION_DATA_SYNCING_GOAL,
|
|
label: this.$locale.baseText('personalizationModal.dataSynching'),
|
|
},
|
|
{
|
|
value: DEVOPS_INCIDENT_RESPONSE_GOAL,
|
|
label: this.$locale.baseText('personalizationModal.incidentResponse'),
|
|
},
|
|
{
|
|
value: DEVOPS_MONITORING_AND_ALERTING_GOAL,
|
|
label: this.$locale.baseText('personalizationModal.monitoringAndAlerting'),
|
|
},
|
|
{
|
|
value: DEVOPS_REPORTING_GOAL,
|
|
label: this.$locale.baseText('personalizationModal.reporting'),
|
|
},
|
|
{
|
|
value: DEVOPS_TICKETING_SYSTEMS_INTEGRATIONS_GOAL,
|
|
label: this.$locale.baseText('personalizationModal.ticketingSystemsIntegrations'),
|
|
},
|
|
{
|
|
value: OTHER_AUTOMATION_GOAL,
|
|
label: this.$locale.baseText('personalizationModal.other'),
|
|
},
|
|
],
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
const role = (values as IPersonalizationLatestVersion)[ROLE_KEY] as string;
|
|
return (
|
|
companyType !== PERSONAL_COMPANY_TYPE &&
|
|
[ROLE_DEVOPS, ROLE_ENGINEERING, ROLE_IT].includes(role)
|
|
);
|
|
},
|
|
},
|
|
{
|
|
name: DEVOPS_AUTOMATION_GOAL_OTHER_KEY,
|
|
properties: {
|
|
placeholder: this.$locale.baseText('personalizationModal.specifyYourAutomationGoal'),
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
const goals = (values as IPersonalizationLatestVersion)[DEVOPS_AUTOMATION_GOAL_KEY];
|
|
const role = (values as IPersonalizationLatestVersion)[ROLE_KEY] as string;
|
|
return (
|
|
companyType !== PERSONAL_COMPANY_TYPE &&
|
|
[ROLE_DEVOPS, ROLE_ENGINEERING, ROLE_IT].includes(role) &&
|
|
!!goals &&
|
|
goals.includes(DEVOPS_AUTOMATION_OTHER)
|
|
);
|
|
},
|
|
},
|
|
{
|
|
name: MARKETING_AUTOMATION_GOAL_KEY,
|
|
properties: {
|
|
type: 'multi-select',
|
|
label: this.$locale.baseText('personalizationModal.specifySalesMarketingGoal'),
|
|
placeholder: this.$locale.baseText('personalizationModal.select'),
|
|
options: [
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.leadGeneration'),
|
|
value: MARKETING_AUTOMATION_LEAD_GENERATION_GOAL,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.customerCommunication'),
|
|
value: MARKETING_AUTOMATION_CUSTOMER_COMMUNICATION,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.customerActions'),
|
|
value: MARKETING_AUTOMATION_ACTIONS,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.adCampaign'),
|
|
value: MARKETING_AUTOMATION_AD_CAMPAIGN,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.reporting'),
|
|
value: MARKETING_AUTOMATION_REPORTING,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.dataSynching'),
|
|
value: MARKETING_AUTOMATION_DATA_SYNCHING,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.other'),
|
|
value: MARKETING_AUTOMATION_OTHER,
|
|
},
|
|
],
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
const role = (values as IPersonalizationLatestVersion)[ROLE_KEY];
|
|
return companyType !== PERSONAL_COMPANY_TYPE && role === ROLE_SALES_AND_MARKETING;
|
|
},
|
|
},
|
|
{
|
|
name: OTHER_MARKETING_AUTOMATION_GOAL_KEY,
|
|
properties: {
|
|
placeholder: this.$locale.baseText(
|
|
'personalizationModal.specifyOtherSalesAndMarketingGoal',
|
|
),
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
const goals = (values as IPersonalizationLatestVersion)[MARKETING_AUTOMATION_GOAL_KEY];
|
|
const role = (values as IPersonalizationLatestVersion)[ROLE_KEY];
|
|
return (
|
|
companyType !== PERSONAL_COMPANY_TYPE &&
|
|
role === ROLE_SALES_AND_MARKETING &&
|
|
!!goals &&
|
|
goals.includes(MARKETING_AUTOMATION_OTHER)
|
|
);
|
|
},
|
|
},
|
|
{
|
|
name: AUTOMATION_BENEFICIARY_KEY,
|
|
properties: {
|
|
type: 'select',
|
|
label: this.$locale.baseText('personalizationModal.specifyAutomationBeneficiary'),
|
|
placeholder: this.$locale.baseText('personalizationModal.select'),
|
|
options: [
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.myself'),
|
|
value: AUTOMATION_BENEFICIARY_SELF,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.myTeam'),
|
|
value: AUTOMATION_BENEFICIARY_MY_TEAM,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.otherTeams'),
|
|
value: AUTOMATION_BENEFICIARY_OTHER_TEAMS,
|
|
},
|
|
],
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
return companyType !== PERSONAL_COMPANY_TYPE;
|
|
},
|
|
},
|
|
{
|
|
name: COMPANY_SIZE_KEY,
|
|
properties: {
|
|
type: 'select',
|
|
label: this.$locale.baseText('personalizationModal.howBigIsYourCompany'),
|
|
placeholder: this.$locale.baseText('personalizationModal.select'),
|
|
options: [
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.lessThan20People'),
|
|
value: COMPANY_SIZE_20_OR_LESS,
|
|
},
|
|
{
|
|
label: `20-99 ${this.$locale.baseText('personalizationModal.people')}`,
|
|
value: COMPANY_SIZE_20_99,
|
|
},
|
|
{
|
|
label: `100-499 ${this.$locale.baseText('personalizationModal.people')}`,
|
|
value: COMPANY_SIZE_100_499,
|
|
},
|
|
{
|
|
label: `500-999 ${this.$locale.baseText('personalizationModal.people')}`,
|
|
value: COMPANY_SIZE_500_999,
|
|
},
|
|
{
|
|
label: `1000+ ${this.$locale.baseText('personalizationModal.people')}`,
|
|
value: COMPANY_SIZE_1000_OR_MORE,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.imNotUsingN8nForWork'),
|
|
value: COMPANY_SIZE_PERSONAL_USE,
|
|
},
|
|
],
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const companyType = (values as IPersonalizationLatestVersion)[COMPANY_TYPE_KEY];
|
|
return companyType !== PERSONAL_COMPANY_TYPE;
|
|
},
|
|
},
|
|
{
|
|
name: REPORTED_SOURCE_KEY,
|
|
properties: {
|
|
type: 'select',
|
|
label: this.$locale.baseText('personalizationModal.howDidYouHearAboutN8n'),
|
|
placeholder: this.$locale.baseText('personalizationModal.select'),
|
|
options: [
|
|
{
|
|
label: 'Google',
|
|
value: REPORTED_SOURCE_GOOGLE,
|
|
},
|
|
{
|
|
label: 'Twitter',
|
|
value: REPORTED_SOURCE_TWITTER,
|
|
},
|
|
{
|
|
label: 'LinkedIn',
|
|
value: REPORTED_SOURCE_LINKEDIN,
|
|
},
|
|
{
|
|
label: 'YouTube',
|
|
value: REPORTED_SOURCE_YOUTUBE,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.friendWordOfMouth'),
|
|
value: REPORTED_SOURCE_FRIEND,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.podcast'),
|
|
value: REPORTED_SOURCE_PODCAST,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.event'),
|
|
value: REPORTED_SOURCE_EVENT,
|
|
},
|
|
{
|
|
label: this.$locale.baseText('personalizationModal.otherPleaseSpecify'),
|
|
value: REPORTED_SOURCE_OTHER,
|
|
},
|
|
],
|
|
},
|
|
},
|
|
{
|
|
name: REPORTED_SOURCE_OTHER_KEY,
|
|
properties: {
|
|
placeholder: this.$locale.baseText('personalizationModal.specifyReportedSource'),
|
|
},
|
|
shouldDisplay(values): boolean {
|
|
const reportedSource = (values as IPersonalizationLatestVersion)[REPORTED_SOURCE_KEY];
|
|
return reportedSource === REPORTED_SOURCE_OTHER;
|
|
},
|
|
},
|
|
];
|
|
|
|
return survey;
|
|
},
|
|
},
|
|
mounted() {
|
|
void this.loadDomainBlocklist();
|
|
},
|
|
methods: {
|
|
closeDialog() {
|
|
this.modalBus.emit('close');
|
|
// In case the redirect to canvas for new users didn't happen
|
|
// we try again after closing the modal
|
|
if (this.$route.name !== VIEWS.NEW_WORKFLOW) {
|
|
void this.$router.replace({ name: VIEWS.NEW_WORKFLOW });
|
|
}
|
|
},
|
|
async loadDomainBlocklist() {
|
|
try {
|
|
this.domainBlocklist = (await import('email-providers/common.json')).default;
|
|
} catch (error) {}
|
|
},
|
|
onSave() {
|
|
this.formBus.emit('submit');
|
|
},
|
|
async onSubmit(values: IPersonalizationLatestVersion): Promise<void> {
|
|
this.isSaving = true;
|
|
|
|
try {
|
|
const survey: Record<string, GenericValue> = {
|
|
...values,
|
|
version: SURVEY_VERSION,
|
|
personalization_survey_submitted_at: new Date().toISOString(),
|
|
personalization_survey_n8n_version: this.rootStore.versionCli,
|
|
};
|
|
|
|
await this.externalHooks.run(
|
|
'personalizationModal.onSubmit',
|
|
survey as IPersonalizationLatestVersion,
|
|
);
|
|
|
|
await this.usersStore.submitPersonalizationSurvey(survey as IPersonalizationLatestVersion);
|
|
|
|
this.posthogStore.setMetadata(survey, 'user');
|
|
|
|
if (Object.keys(values).length === 0) {
|
|
this.closeDialog();
|
|
}
|
|
|
|
await this.fetchOnboardingPrompt();
|
|
} catch (e) {
|
|
this.showError(e, 'Error while submitting results');
|
|
}
|
|
|
|
let licenseRequestSucceeded = false;
|
|
try {
|
|
if (this.registerForEnterpriseTrial && this.canRegisterForEnterpriseTrial) {
|
|
await this.usageStore.requestEnterpriseLicenseTrial();
|
|
licenseRequestSucceeded = true;
|
|
this.$telemetry.track('User registered for self serve trial', {
|
|
email: this.usersStore.currentUser?.email,
|
|
instance_id: this.rootStore.instanceId,
|
|
});
|
|
}
|
|
} catch (e) {
|
|
this.showError(
|
|
e,
|
|
this.$locale.baseText('personalizationModal.registerEmailForTrial.error'),
|
|
);
|
|
}
|
|
|
|
this.isSaving = false;
|
|
this.closeDialog();
|
|
|
|
if (licenseRequestSucceeded) {
|
|
await this.alert(
|
|
this.$locale.baseText('personalizationModal.registerEmailForTrial.success.message'),
|
|
{
|
|
title: this.$locale.baseText(
|
|
'personalizationModal.registerEmailForTrial.success.title',
|
|
),
|
|
confirmButtonText: this.$locale.baseText(
|
|
'personalizationModal.registerEmailForTrial.success.button',
|
|
),
|
|
},
|
|
);
|
|
}
|
|
},
|
|
async fetchOnboardingPrompt() {
|
|
if (
|
|
this.settingsStore.onboardingCallPromptEnabled &&
|
|
getAccountAge(this.usersStore.currentUser || ({} as IUser)) <= ONBOARDING_PROMPT_TIMEBOX
|
|
) {
|
|
const onboardingResponse = await this.uiStore.getNextOnboardingPrompt();
|
|
|
|
if (!onboardingResponse) {
|
|
return;
|
|
}
|
|
|
|
const promptTimeout =
|
|
onboardingResponse.toast_sequence_number === 1 ? FIRST_ONBOARDING_PROMPT_TIMEOUT : 1000;
|
|
|
|
setTimeout(async () => {
|
|
this.showToast({
|
|
type: 'info',
|
|
title: onboardingResponse.title,
|
|
message: onboardingResponse.description,
|
|
duration: 0,
|
|
customClass: 'clickable',
|
|
closeOnClick: true,
|
|
onClick: () => {
|
|
this.$telemetry.track('user clicked onboarding toast', {
|
|
seq_num: onboardingResponse.toast_sequence_number,
|
|
title: onboardingResponse.title,
|
|
description: onboardingResponse.description,
|
|
});
|
|
this.uiStore.openModal(ONBOARDING_CALL_SIGNUP_MODAL_KEY);
|
|
},
|
|
});
|
|
}, promptTimeout);
|
|
}
|
|
},
|
|
},
|
|
});
|
|
</script>
|
|
|
|
<style lang="scss" module>
|
|
.container {
|
|
> div,
|
|
section > div:not(:last-child) {
|
|
margin-bottom: var(--spacing-m);
|
|
}
|
|
}
|
|
</style>
|