@bigbinary/neeto-playwright-commons 1.22.20 → 1.22.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/index.d.ts CHANGED
@@ -49,7 +49,6 @@ type ParamFilters = FilterProps[];
49
49
  type BasicTypesInterface = Record<string, number | string | boolean>;
50
50
  type ParamProps = Record<string, number | string | boolean | ParamFilters>;
51
51
  type HttpMethods = "get" | "patch" | "post" | "put" | "delete";
52
- type FileType = "csv" | "avi" | "doc" | "docx" | "flv" | "html" | "mp3" | "mp4" | "mpg" | "pdf" | "rtf" | "txt" | "webm" | "xls" | "xlsx" | "wma" | "zip" | "jpg" | "jpeg" | "png" | "gif";
53
52
  interface BreadcrumbTitleAndRoute$1 {
54
53
  title: string;
55
54
  route: string;
@@ -1457,10 +1456,6 @@ declare class HelpAndProfilePage {
1457
1456
  changelogBaseURL
1458
1457
  }: HelpAndProfilePageInitializerProps);
1459
1458
  private hoverOnBody;
1460
- /**
1461
- * @deprecated This method is deprecated. Use openHelpCenter instead.
1462
- */
1463
- openHelpCenterV2: () => Promise<void>;
1464
1459
  /**
1465
1460
  *
1466
1461
  * Opens the Help Center and expects the chat button within it to be visible.
@@ -4291,6 +4286,31 @@ declare const PROFILE_LINKS: {
4291
4286
  neetoCommunity: string;
4292
4287
  };
4293
4288
  declare const networkConditions: Record<"Slow 3G" | "Fast 3G" | "No Throttling", Protocol.Network.emulateNetworkConditionsParameters>;
4289
+ declare const FILE_FORMATS: {
4290
+ readonly csv: "csv";
4291
+ readonly avi: "avi";
4292
+ readonly doc: "doc";
4293
+ readonly docx: "docx";
4294
+ readonly flv: "flv";
4295
+ readonly html: "html";
4296
+ readonly mp3: "mp3";
4297
+ readonly mp4: "mp4";
4298
+ readonly mpg: "mpg";
4299
+ readonly pdf: "pdf";
4300
+ readonly rtf: "rtf";
4301
+ readonly txt: "txt";
4302
+ readonly webm: "webm";
4303
+ readonly xls: "xls";
4304
+ readonly xlsx: "xlsx";
4305
+ readonly wma: "wma";
4306
+ readonly zip: "zip";
4307
+ readonly jpg: "jpg";
4308
+ readonly jpeg: "jpeg";
4309
+ readonly png: "png";
4310
+ readonly ico: "ico";
4311
+ readonly svg: "svg";
4312
+ readonly gif: "gif";
4313
+ };
4294
4314
  /**
4295
4315
  *
4296
4316
  * newConversation: Text for initiating a new conversation.
@@ -6719,6 +6739,18 @@ declare const getGlobalUserProps: (page: Page) => Promise<Record<string, string>
6719
6739
  * @endexample
6720
6740
  */
6721
6741
  declare const getClipboardContent: (page: Page) => Promise<string>;
6742
+ /**
6743
+ *
6744
+ * Grants clipboard read and write permissions to the browser context. It takes the following parameters:
6745
+ *
6746
+ * context: The Playwright BrowserContext object to grant permissions to.
6747
+ *
6748
+ * @example
6749
+ *
6750
+ * await grantClipboardPermissions(context);
6751
+ * @endexample
6752
+ */
6753
+ declare const grantClipboardPermissions: (context: BrowserContext) => Promise<void>;
6722
6754
  declare const getFullUrl: (path: string) => string;
6723
6755
  declare const globalShortcuts: (t: TFunction) => {
6724
6756
  description: string;
@@ -6735,6 +6767,21 @@ declare const globalShortcuts: (t: TFunction) => {
6735
6767
  * @endexample
6736
6768
  */
6737
6769
  declare const generatePhoneNumber: () => string;
6770
+ /**
6771
+ *
6772
+ * Initializes test data for a specific Neeto product by generating staging credentials and base URL. It takes the following parameters:
6773
+ *
6774
+ * product: The Neeto product to initialize test data.
6775
+ *
6776
+ * @example
6777
+ *
6778
+ * const { credentials, baseURL } = initializeTestData("Auth");
6779
+ * @endexample
6780
+ */
6781
+ declare const initializeTestData: (product: NeetoProducts) => {
6782
+ credentials: Credentials;
6783
+ baseURL: string;
6784
+ };
6738
6785
  interface LoginProps {
6739
6786
  page: Page;
6740
6787
  neetoPlaywrightUtilities: CustomCommands;
@@ -7257,6 +7304,8 @@ declare const simulateClickWithDelay: ({
7257
7304
  element: Locator;
7258
7305
  page: Page;
7259
7306
  }) => Promise<void>;
7307
+ type ValueOf<T> = T[keyof T];
7308
+ type FileType = ValueOf<typeof FILE_FORMATS>;
7260
7309
  interface GenerateRandomFileProps {
7261
7310
  sizeInKB: number;
7262
7311
  fileType: FileType;
@@ -7408,4 +7457,4 @@ interface Overrides {
7408
7457
  * @endexample
7409
7458
  */
7410
7459
  declare const definePlaywrightConfig: (overrides: Overrides) => _playwright_test.PlaywrightTestConfig<{}, {}>;
7411
- export { ADMIN_PANEL_SELECTORS, API_KEYS_SELECTORS, API_ROUTES, AUDIT_LOGS_TEXTS, AdminPanelPage, ApiKeysApi, ApiKeysPage, AuditLogsPage, BASE_URL, type BaseThemeStyle, type BaseThemeStyleType, CHANGELOG_WIDGET_SELECTORS, CHAT_WIDGET_SELECTORS, CHAT_WIDGET_TEXTS, COLOR, COMMON_SELECTORS, COMMON_TEXTS, COMMUNITY_TEXTS, CREDENTIALS, CUSTOM_DOMAIN_SELECTORS, CUSTOM_DOMAIN_SUFFIX, type CountryProps, CustomCommands, CustomDomainPage, type CustomFixture, DATE_PICKER_SELECTORS, DATE_TEXTS, DESCRIPTION_EDITOR_TEXTS, EMBED_SELECTORS, EMOJI_LABEL, EMPTY_STORAGE_STATE, ENGAGE_TEXTS, ENVIRONMENT, EXPANDED_FONT_SIZE, EditorPage, EmbedBase, FONT_SIZE_SELECTORS, GLOBAL_TRANSLATIONS_PATTERN, GOOGLE_ANALYTICS_SELECTORS, GOOGLE_CALENDAR_DATE_FORMAT, GOOGLE_LOGIN_SELECTORS, GOOGLE_LOGIN_TEXTS, GOOGLE_SHEETS_SELECTORS, GooglePage, HELP_CENTER_SELECTORS, HelpAndProfilePage, INTEGRATIONS_TEXTS, INTEGRATION_SELECTORS, IP_RESTRICTIONS_SELECTORS, IS_STAGING_ENV, ImageUploader, IntegrationBase, type IntroPageThemeStyle, type IntroPageThemeStyleType, KEYBOARD_SHORTCUTS_SELECTORS, LIST_MODIFIER_SELECTORS, LIST_MODIFIER_TAGS, LOGIN_SELECTORS, MEMBER_FORM_SELECTORS, MEMBER_SELECTORS, MEMBER_TEXTS, MERGE_TAGS_SELECTORS, MailerUtils, Member, MemberApis, NEETO_AUTH_BASE_URL, NEETO_EDITOR_SELECTORS, NEETO_FILTERS_SELECTORS, NEETO_IMAGE_UPLOADER_SELECTORS, NEETO_ROUTES, NEETO_TEXT_MODIFIER_SELECTORS, ONBOARDING_SELECTORS, ORGANIZATION_TEXTS, OTP_EMAIL_PATTERN, OrganizationPage, PHONE_NUMBER_FORMATS, PLURAL, PROFILE_LINKS, PROFILE_SECTION_SELECTORS, PROJECT_TRANSLATIONS_PATH, ROLES_SELECTORS, ROUTES, RoleApis, RolesPage, SELECT_COUNTRY, SIGNUP_SELECTORS, SINGULAR, SLACK_DATA_QA_SELECTORS, SLACK_DEFAULT_CHANNEL, SLACK_SELECTORS, SLACK_WEB_TEXTS, STATUS_TEXTS, STORAGE_STATE, SidebarSection, SlackPage, TABLE_SELECTORS, TAB_SELECTORS, TAGS_SELECTORS, TEXT_MODIFIER_ROLES, TEXT_MODIFIER_SELECTORS, TEXT_MODIFIER_TAGS, THANK_YOU_SELECTORS, THEMES_SELECTORS, THIRD_PARTY_ROUTES, TOASTR_MESSAGES, TWILIO_SELECTORS, TagsApi, TagsPage, TeamMembers, ThankYouPage, type ThemeCategory, USER_AGENTS, WEBHOOK_SELECTORS, WebhooksPage, ZAPIER_LIMIT_EXHAUSTED_MESSAGE, ZAPIER_SELECTORS, ZAPIER_TEST_EMAIL, ZAPIER_WEB_TEXTS, ZapierPage, baseURLGenerator, basicHTMLContent, clearCredentials, commands, cpuThrottlingUsingCDP, currencyUtils, decodeQRCodeFromFile, definePlaywrightConfig, executeWithThrottledResources, extractSubdomainFromError, filterUtils, generatePhoneNumber, generatePhoneNumberDetails, generateRandomBypassEmail, generateRandomFile, generateStagingData, getByDataQA, getClipboardContent, getFormattedPhoneNumber, getFullUrl, getGlobalUserProps, getGlobalUserState, getImagePathAndName, getListCount, globalShortcuts, headerUtils, hexToRGB, hexToRGBA, hyphenize, i18nFixture, initializeCredentials, initializeTotp, isGithubIssueOpen, joinHyphenCase, joinString, login, loginWithoutSSO, networkConditions, networkThrottlingUsingCDP, readFileSyncIfExists, removeCredentialFile, serializeFileForBrowser, shouldSkipCustomDomainSetup, shouldSkipSetupAndTeardown, simulateClickWithDelay, simulateTypingWithDelay, skipTest, squish, _default as stealthTest, tableUtils, toCamelCase, updateCredentials, writeDataToFile };
7460
+ export { ADMIN_PANEL_SELECTORS, API_KEYS_SELECTORS, API_ROUTES, AUDIT_LOGS_TEXTS, AdminPanelPage, ApiKeysApi, ApiKeysPage, AuditLogsPage, BASE_URL, type BaseThemeStyle, type BaseThemeStyleType, CHANGELOG_WIDGET_SELECTORS, CHAT_WIDGET_SELECTORS, CHAT_WIDGET_TEXTS, COLOR, COMMON_SELECTORS, COMMON_TEXTS, COMMUNITY_TEXTS, CREDENTIALS, CUSTOM_DOMAIN_SELECTORS, CUSTOM_DOMAIN_SUFFIX, type CountryProps, CustomCommands, CustomDomainPage, type CustomFixture, DATE_PICKER_SELECTORS, DATE_TEXTS, DESCRIPTION_EDITOR_TEXTS, EMBED_SELECTORS, EMOJI_LABEL, EMPTY_STORAGE_STATE, ENGAGE_TEXTS, ENVIRONMENT, EXPANDED_FONT_SIZE, EditorPage, EmbedBase, FILE_FORMATS, FONT_SIZE_SELECTORS, GLOBAL_TRANSLATIONS_PATTERN, GOOGLE_ANALYTICS_SELECTORS, GOOGLE_CALENDAR_DATE_FORMAT, GOOGLE_LOGIN_SELECTORS, GOOGLE_LOGIN_TEXTS, GOOGLE_SHEETS_SELECTORS, GooglePage, HELP_CENTER_SELECTORS, HelpAndProfilePage, INTEGRATIONS_TEXTS, INTEGRATION_SELECTORS, IP_RESTRICTIONS_SELECTORS, IS_STAGING_ENV, ImageUploader, IntegrationBase, type IntroPageThemeStyle, type IntroPageThemeStyleType, KEYBOARD_SHORTCUTS_SELECTORS, LIST_MODIFIER_SELECTORS, LIST_MODIFIER_TAGS, LOGIN_SELECTORS, MEMBER_FORM_SELECTORS, MEMBER_SELECTORS, MEMBER_TEXTS, MERGE_TAGS_SELECTORS, MailerUtils, Member, MemberApis, NEETO_AUTH_BASE_URL, NEETO_EDITOR_SELECTORS, NEETO_FILTERS_SELECTORS, NEETO_IMAGE_UPLOADER_SELECTORS, NEETO_ROUTES, NEETO_TEXT_MODIFIER_SELECTORS, ONBOARDING_SELECTORS, ORGANIZATION_TEXTS, OTP_EMAIL_PATTERN, OrganizationPage, PHONE_NUMBER_FORMATS, PLURAL, PROFILE_LINKS, PROFILE_SECTION_SELECTORS, PROJECT_TRANSLATIONS_PATH, ROLES_SELECTORS, ROUTES, RoleApis, RolesPage, SELECT_COUNTRY, SIGNUP_SELECTORS, SINGULAR, SLACK_DATA_QA_SELECTORS, SLACK_DEFAULT_CHANNEL, SLACK_SELECTORS, SLACK_WEB_TEXTS, STATUS_TEXTS, STORAGE_STATE, SidebarSection, SlackPage, TABLE_SELECTORS, TAB_SELECTORS, TAGS_SELECTORS, TEXT_MODIFIER_ROLES, TEXT_MODIFIER_SELECTORS, TEXT_MODIFIER_TAGS, THANK_YOU_SELECTORS, THEMES_SELECTORS, THIRD_PARTY_ROUTES, TOASTR_MESSAGES, TWILIO_SELECTORS, TagsApi, TagsPage, TeamMembers, ThankYouPage, type ThemeCategory, USER_AGENTS, WEBHOOK_SELECTORS, WebhooksPage, ZAPIER_LIMIT_EXHAUSTED_MESSAGE, ZAPIER_SELECTORS, ZAPIER_TEST_EMAIL, ZAPIER_WEB_TEXTS, ZapierPage, baseURLGenerator, basicHTMLContent, clearCredentials, commands, cpuThrottlingUsingCDP, currencyUtils, decodeQRCodeFromFile, definePlaywrightConfig, executeWithThrottledResources, extractSubdomainFromError, filterUtils, generatePhoneNumber, generatePhoneNumberDetails, generateRandomBypassEmail, generateRandomFile, generateStagingData, getByDataQA, getClipboardContent, getFormattedPhoneNumber, getFullUrl, getGlobalUserProps, getGlobalUserState, getImagePathAndName, getListCount, globalShortcuts, grantClipboardPermissions, headerUtils, hexToRGB, hexToRGBA, hyphenize, i18nFixture, initializeCredentials, initializeTestData, initializeTotp, isGithubIssueOpen, joinHyphenCase, joinString, login, loginWithoutSSO, networkConditions, networkThrottlingUsingCDP, readFileSyncIfExists, removeCredentialFile, serializeFileForBrowser, shouldSkipCustomDomainSetup, shouldSkipSetupAndTeardown, simulateClickWithDelay, simulateTypingWithDelay, skipTest, squish, _default as stealthTest, tableUtils, toCamelCase, updateCredentials, writeDataToFile };
package/index.js CHANGED
@@ -9,6 +9,7 @@ import { curry, not as not$1, isEmpty as isEmpty$1, pluck, mergeDeepLeft, isNotN
9
9
  import { hyphenate, isPresent, isNotPresent, isNotEmpty, humanize, keysToSnakeCase, dynamicArray, truncate, findBy, isNotEqualDeep, randomPick } from '@bigbinary/neeto-cist';
10
10
  import { execSync } from 'child_process';
11
11
  import { faker } from '@faker-js/faker';
12
+ import dayjs from 'dayjs';
12
13
  import Stream$4 from 'stream';
13
14
  import require$$0$4 from 'node:buffer';
14
15
  import require$$0$3 from 'buffer';
@@ -24,7 +25,6 @@ import zlib$5 from 'zlib';
24
25
  import require$$0$7 from 'assert';
25
26
  import require$$3$1 from 'querystring';
26
27
  import require$$4$3 from 'timers';
27
- import dayjs from 'dayjs';
28
28
  import require$$0$9 from 'tty';
29
29
  import require$$0$8 from 'os';
30
30
  import stealth$1 from 'puppeteer-extra-plugin-stealth';
@@ -3511,6 +3511,32 @@ const EMPTY_STORAGE_STATE = {
3511
3511
  storageState: { cookies: [], origins: [] },
3512
3512
  };
3513
3513
 
3514
+ const generateStagingData = (product = "invoice") => {
3515
+ const jobCompletionIndex = process.env.JOB_COMPLETION_INDEX;
3516
+ const dateTimeString = dayjs().format("DDMM-HHmm-ssSSS");
3517
+ const timestamp = jobCompletionIndex
3518
+ ? `${dateTimeString}-${jobCompletionIndex}`
3519
+ : dateTimeString;
3520
+ const firstName = "André";
3521
+ const lastName = "O'Reilly";
3522
+ const otpBypassKey = process.env.OTP_BYPASS_KEY;
3523
+ const stagingOrganization = `cpt-${product}-${timestamp}`;
3524
+ return {
3525
+ firstName,
3526
+ lastName,
3527
+ otp: 111111,
3528
+ domain: `neeto${product}.net`,
3529
+ currentUserName: IS_STAGING_ENV
3530
+ ? joinString(firstName, lastName)
3531
+ : CREDENTIALS.name,
3532
+ businessName: stagingOrganization,
3533
+ subdomainName: IS_STAGING_ENV ? stagingOrganization : "spinkart",
3534
+ email: IS_STAGING_ENV
3535
+ ? `cpt${otpBypassKey}+${product}+${timestamp}@bigbinary.com`
3536
+ : CREDENTIALS.email,
3537
+ };
3538
+ };
3539
+
3514
3540
  /* eslint-disable playwright/no-skipped-test */
3515
3541
  const execCommand = (command) => execSync(command)
3516
3542
  .toString("utf-8")
@@ -3618,11 +3644,12 @@ const getListCount = async ({ page, countSelector, }) => {
3618
3644
  };
3619
3645
  const getGlobalUserProps = async (page) => (await page.evaluate(() => window.globalProps.user));
3620
3646
  const getClipboardContent = (page) => page.evaluate(() => navigator.clipboard.readText());
3647
+ const grantClipboardPermissions = (context) => context.grantPermissions(["clipboard-read", "clipboard-write"]);
3621
3648
  const getFullUrl = (path) => shouldSkipCustomDomainSetup() ? path : `${process.env.BASE_URL}${path}`;
3622
3649
  const globalShortcuts = (t) => [
3623
3650
  {
3624
3651
  description: t("neetoMolecules.keyboardShortcuts.global.openKeyboardShortcutsPane"),
3625
- sequence: "shift+/",
3652
+ sequence: "ctrl+/",
3626
3653
  },
3627
3654
  {
3628
3655
  description: t("neetoMolecules.keyboardShortcuts.global.close"),
@@ -3638,6 +3665,11 @@ const globalShortcuts = (t) => [
3638
3665
  },
3639
3666
  ];
3640
3667
  const generatePhoneNumber = () => `${"+91"} 9${faker.string.numeric(4)} ${faker.string.numeric(5)}`;
3668
+ const initializeTestData = (product) => {
3669
+ const credentials = generateStagingData(product.toLowerCase());
3670
+ const baseURL = `https://${credentials.subdomainName}.${credentials.domain}`;
3671
+ return { credentials, baseURL };
3672
+ };
3641
3673
 
3642
3674
  const optionSelector = (option) => `neeto-editor-fixed-menu-${option}-option`;
3643
3675
  const fixedMenuSelector = (selector) => `neeto-editor-fixed-menu-${selector}`;
@@ -4203,6 +4235,8 @@ const mimeTypeMap = {
4203
4235
  jpeg: "image/jpeg",
4204
4236
  png: "image/png",
4205
4237
  gif: "image/gif",
4238
+ ico: "image/x-icon",
4239
+ svg: "image/svg+xml",
4206
4240
  };
4207
4241
  const fillRandomBytes = (byteArray) => {
4208
4242
  const CHUNK_SIZE = 65536; //Maximum allowed per call by crypto.getRandomValues.
@@ -179783,32 +179817,6 @@ const commands = {
179783
179817
  },
179784
179818
  };
179785
179819
 
179786
- const generateStagingData = (product = "invoice") => {
179787
- const jobCompletionIndex = process.env.JOB_COMPLETION_INDEX;
179788
- const dateTimeString = dayjs().format("DDMM-HHmm-ssSSS");
179789
- const timestamp = jobCompletionIndex
179790
- ? `${dateTimeString}-${jobCompletionIndex}`
179791
- : dateTimeString;
179792
- const firstName = "André";
179793
- const lastName = "O'Reilly";
179794
- const otpBypassKey = process.env.OTP_BYPASS_KEY;
179795
- const stagingOrganization = `cpt-${product}-${timestamp}`;
179796
- return {
179797
- firstName,
179798
- lastName,
179799
- otp: 111111,
179800
- domain: `neeto${product}.net`,
179801
- currentUserName: IS_STAGING_ENV
179802
- ? joinString(firstName, lastName)
179803
- : CREDENTIALS.name,
179804
- businessName: stagingOrganization,
179805
- subdomainName: IS_STAGING_ENV ? stagingOrganization : "spinkart",
179806
- email: IS_STAGING_ENV
179807
- ? `cpt${otpBypassKey}+${product}+${timestamp}@bigbinary.com`
179808
- : CREDENTIALS.email,
179809
- };
179810
- };
179811
-
179812
179820
  var src = {exports: {}};
179813
179821
 
179814
179822
  var browser$1 = {exports: {}};
@@ -189138,18 +189146,6 @@ const ORGANIZATION_TEXTS = {
189138
189146
  class HelpAndProfilePage {
189139
189147
  constructor({ page, neetoPlaywrightUtilities, chatApiBaseURL, kbDocsBaseURL, changelogBaseURL, }) {
189140
189148
  this.hoverOnBody = () => this.page.locator("body").hover();
189141
- /**
189142
- * @deprecated This method is deprecated. Use openHelpCenter instead.
189143
- */
189144
- this.openHelpCenterV2 = async () => {
189145
- await expect(async () => {
189146
- await this.hoverOnBody();
189147
- const floatingActionMenuButton = this.page.getByTestId(COMMON_SELECTORS.floatingActionMenuButton);
189148
- await floatingActionMenuButton.scrollIntoViewIfNeeded();
189149
- await floatingActionMenuButton.hover();
189150
- await expect(this.page.getByTestId(HELP_CENTER_SELECTORS.chatButton)).toBeVisible();
189151
- }).toPass({ timeout: 15000 });
189152
- };
189153
189149
  this.openHelpCenter = async () => {
189154
189150
  await expect(async () => {
189155
189151
  await this.hoverOnBody();
@@ -189205,7 +189201,7 @@ class HelpAndProfilePage {
189205
189201
  * @deprecated This method is deprecated. Use openAndVerifyHelpArticles instead.
189206
189202
  */
189207
189203
  this.openAndVerifyHelpArticlesV2 = async () => {
189208
- await test$2.step("1: Open Help Center links", this.openHelpCenterV2);
189204
+ await test$2.step("1: Open Help Center links", this.openHelpCenter);
189209
189205
  await test$2.step("2: Open and verify help articles link", async () => {
189210
189206
  const helpArticlesPromise = this.page.waitForEvent("popup");
189211
189207
  await this.page
@@ -189290,26 +189286,8 @@ class HelpAndProfilePage {
189290
189286
  * @deprecated This method is deprecated. Use openAndVerifyKeyboardShortcutsPane instead.
189291
189287
  */
189292
189288
  this.openAndVerifyKeyboardShortcutsPaneV2 = async (productShortcuts, osPlatform = "windows") => {
189293
- const globalShortcuts = [
189294
- {
189295
- description: this.t("neetoMolecules.keyboardShortcuts.global.openKeyboardShortcutsPane"),
189296
- sequence: "shift+/",
189297
- },
189298
- {
189299
- description: this.t("neetoMolecules.keyboardShortcuts.global.close"),
189300
- sequence: "esc",
189301
- },
189302
- {
189303
- description: this.t("neetoMolecules.keyboardShortcuts.global.submitForm"),
189304
- sequence: "ctrl+enter",
189305
- },
189306
- {
189307
- description: this.t("neetoMolecules.keyboardShortcuts.global.openProductSwitcher"),
189308
- sequence: "ctrl+e",
189309
- },
189310
- ];
189311
- const shortcuts = [...globalShortcuts, ...productShortcuts];
189312
- await test$2.step("1: Open Help Center", this.openHelpCenterV2);
189289
+ const shortcuts = [...globalShortcuts(this.t), ...productShortcuts];
189290
+ await test$2.step("1: Open Help Center", this.openHelpCenter);
189313
189291
  await test$2.step("2: Open and close keyboard shortcuts from UI", async () => {
189314
189292
  await this.page
189315
189293
  .getByTestId(HELP_CENTER_SELECTORS.keyboardShortcutButton)
@@ -189339,34 +189317,35 @@ class HelpAndProfilePage {
189339
189317
  });
189340
189318
  };
189341
189319
  this.openAndVerifyKeyboardShortcutsPane = async (productShortcuts, osPlatform = "windows") => {
189320
+ const keyboardShortcutsPane = this.page.getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.keyboardShortcutsPane);
189321
+ const keyItem = this.page.getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.hotKeyItem);
189322
+ const openKeyboardShortcut = osPlatform === "mac" ? "Meta+/" : "Control+/";
189342
189323
  const shortcuts = [...globalShortcuts(this.t), ...productShortcuts];
189324
+ const formattedSequences = shortcuts.map(shortcut => this.formatKeyboardShortcut(shortcut.sequence, osPlatform));
189343
189325
  await test$2.step("1: Open Help Center", this.openHelpCenter);
189344
189326
  await test$2.step("2: Open and close keyboard shortcuts from UI", async () => {
189345
189327
  await this.page
189346
189328
  .getByTestId(HELP_CENTER_SELECTORS.keyboardShortcutButton)
189347
189329
  .click();
189348
- await expect(this.page.getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.keyboardShortcutsPane)).not.toHaveCSS("width", "1px");
189330
+ await expect(keyboardShortcutsPane).not.toHaveCSS("width", "1px");
189349
189331
  await this.page
189350
189332
  .getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.closePaneButton)
189351
189333
  .click();
189352
- await expect(this.page.getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.keyboardShortcutsPane)).toHaveCSS("width", "1px");
189334
+ await expect(keyboardShortcutsPane).toHaveCSS("width", "1px");
189353
189335
  });
189354
189336
  await test$2.step("3: Open and close keyboard shortcuts through shortcut", async () => {
189355
- await this.page.keyboard.press("Shift+/");
189356
- await expect(this.page.getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.keyboardShortcutsPane)).not.toHaveCSS("width", "1px");
189337
+ await this.page.keyboard.press(openKeyboardShortcut);
189338
+ await expect(keyboardShortcutsPane).not.toHaveCSS("width", "1px");
189357
189339
  await this.page.keyboard.press("Escape");
189358
- await expect(this.page.getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.keyboardShortcutsPane)).toHaveCSS("width", "1px");
189340
+ await expect(keyboardShortcutsPane).toHaveCSS("width", "1px");
189359
189341
  });
189360
189342
  await test$2.step("4: Verify all displayed keyboard shortcuts", async () => {
189361
- await this.page.keyboard.press("Shift+/");
189362
- await expect(this.page.getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.keyboardShortcutsPane)).not.toHaveCSS("width", "1px");
189363
- await expect(this.page
189364
- .getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.hotKeyItem)
189365
- .locator("p")).toHaveText(shortcuts.map(shortcut => shortcut.description));
189366
- const formattedSequences = shortcuts.map(shortcut => this.formatKeyboardShortcut(shortcut.sequence, osPlatform));
189367
- await expect(this.page
189368
- .getByTestId(KEYBOARD_SHORTCUTS_SELECTORS.hotKeyItem)
189369
- .locator("div")).toHaveText(formattedSequences);
189343
+ await this.page.keyboard.press(openKeyboardShortcut);
189344
+ await expect(keyboardShortcutsPane).not.toHaveCSS("width", "1px");
189345
+ await Promise.all([
189346
+ expect(keyItem.locator("p")).toHaveText(shortcuts.map(shortcut => shortcut.description)),
189347
+ expect(keyItem.locator("div")).toHaveText(formattedSequences),
189348
+ ]);
189370
189349
  });
189371
189350
  };
189372
189351
  /**
@@ -189377,7 +189356,7 @@ class HelpAndProfilePage {
189377
189356
  const searchQueryPartial = productName.slice(0, 4).toLowerCase();
189378
189357
  const searchQueryFull = productName.toLowerCase();
189379
189358
  await test$2.step("1: Verify hovering over app switcher opens the app switcher drawer", () => expect(async () => {
189380
- await this.openHelpCenterV2();
189359
+ await this.openHelpCenter();
189381
189360
  await this.page.getByTestId(COMMON_SELECTORS.appSwitcherButton).hover();
189382
189361
  await expect(this.page.getByTestId(COMMON_SELECTORS.appSwitcherWrapper)).toBeVisible();
189383
189362
  }).toPass({ timeout: 45000 }));
@@ -189434,7 +189413,7 @@ class HelpAndProfilePage {
189434
189413
  this.verifyLogoutV2 = async () => {
189435
189414
  if (shouldSkipSetupAndTeardown())
189436
189415
  return;
189437
- await test$2.step("1: Open Help center and verify", this.openHelpCenterV2);
189416
+ await test$2.step("1: Open Help center and verify", this.openHelpCenter);
189438
189417
  await test$2.step("2: Click logout and verify", async () => {
189439
189418
  await this.page
189440
189419
  .getByTestId(PROFILE_SECTION_SELECTORS.logoutButton)
@@ -189495,7 +189474,7 @@ class HelpAndProfilePage {
189495
189474
  linkTestId: PROFILE_SECTION_SELECTORS.manageBillingAndSubscriptionsButton,
189496
189475
  });
189497
189476
  });
189498
- await test$2.step("3: Open Help center and verify", this.openHelpCenterV2);
189477
+ await test$2.step("3: Open Help center and verify", this.openHelpCenter);
189499
189478
  await test$2.step("4: Open My organization link and verify", async () => {
189500
189479
  await this.page
189501
189480
  .getByTestId(PROFILE_SECTION_SELECTORS.profileOrganizationSettingsButton)
@@ -193767,6 +193746,32 @@ const networkConditions = {
193767
193746
  },
193768
193747
  };
193769
193748
 
193749
+ const FILE_FORMATS = {
193750
+ csv: "csv",
193751
+ avi: "avi",
193752
+ doc: "doc",
193753
+ docx: "docx",
193754
+ flv: "flv",
193755
+ html: "html",
193756
+ mp3: "mp3",
193757
+ mp4: "mp4",
193758
+ mpg: "mpg",
193759
+ pdf: "pdf",
193760
+ rtf: "rtf",
193761
+ txt: "txt",
193762
+ webm: "webm",
193763
+ xls: "xls",
193764
+ xlsx: "xlsx",
193765
+ wma: "wma",
193766
+ zip: "zip",
193767
+ jpg: "jpg",
193768
+ jpeg: "jpeg",
193769
+ png: "png",
193770
+ ico: "ico",
193771
+ svg: "svg",
193772
+ gif: "gif",
193773
+ };
193774
+
193770
193775
  const PHONE_NUMBER_FORMATS = [
193771
193776
  { name: "Afghanistan", code: "+93", format: "70#######", flag: "🇦🇫" },
193772
193777
  { name: "Aland", code: "+358", format: "5####", flag: "🇦🇽" },
@@ -198779,5 +198784,5 @@ const definePlaywrightConfig = (overrides) => {
198779
198784
  });
198780
198785
  };
198781
198786
 
198782
- export { ADMIN_PANEL_SELECTORS, API_KEYS_SELECTORS, API_ROUTES, AUDIT_LOGS_TEXTS, AdminPanelPage, ApiKeysApi, ApiKeysPage, AuditLogsPage, BASE_URL, CHANGELOG_WIDGET_SELECTORS, CHAT_WIDGET_SELECTORS, CHAT_WIDGET_TEXTS, COLOR, COMMON_SELECTORS, COMMON_TEXTS, COMMUNITY_TEXTS, CREDENTIALS, CUSTOM_DOMAIN_SELECTORS, CUSTOM_DOMAIN_SUFFIX, CustomCommands, CustomDomainPage, DATE_PICKER_SELECTORS, DATE_TEXTS, DESCRIPTION_EDITOR_TEXTS, EMBED_SELECTORS, EMOJI_LABEL, EMPTY_STORAGE_STATE, ENGAGE_TEXTS, ENVIRONMENT, EXPANDED_FONT_SIZE, EditorPage, EmbedBase, FONT_SIZE_SELECTORS, GLOBAL_TRANSLATIONS_PATTERN, GOOGLE_ANALYTICS_SELECTORS, GOOGLE_CALENDAR_DATE_FORMAT, GOOGLE_LOGIN_SELECTORS, GOOGLE_LOGIN_TEXTS, GOOGLE_SHEETS_SELECTORS, GooglePage, HELP_CENTER_SELECTORS, HelpAndProfilePage, INTEGRATIONS_TEXTS, INTEGRATION_SELECTORS, IP_RESTRICTIONS_SELECTORS, IS_STAGING_ENV, ImageUploader, IntegrationBase, KEYBOARD_SHORTCUTS_SELECTORS, LIST_MODIFIER_SELECTORS, LIST_MODIFIER_TAGS, LOGIN_SELECTORS, MEMBER_FORM_SELECTORS, MEMBER_SELECTORS, MEMBER_TEXTS, MERGE_TAGS_SELECTORS, MailerUtils, Member, MemberApis$1 as MemberApis, NEETO_AUTH_BASE_URL, NEETO_EDITOR_SELECTORS, NEETO_FILTERS_SELECTORS, NEETO_IMAGE_UPLOADER_SELECTORS, NEETO_ROUTES, NEETO_TEXT_MODIFIER_SELECTORS, ONBOARDING_SELECTORS, ORGANIZATION_TEXTS, OTP_EMAIL_PATTERN, OrganizationPage, PHONE_NUMBER_FORMATS, PLURAL, PROFILE_LINKS, PROFILE_SECTION_SELECTORS, PROJECT_TRANSLATIONS_PATH, ROLES_SELECTORS, ROUTES, RoleApis$1 as RoleApis, RolesPage, SELECT_COUNTRY, SIGNUP_SELECTORS, SINGULAR, SLACK_DATA_QA_SELECTORS, SLACK_DEFAULT_CHANNEL, SLACK_SELECTORS, SLACK_WEB_TEXTS, STATUS_TEXTS, STORAGE_STATE, SidebarSection, SlackPage, TABLE_SELECTORS, TAB_SELECTORS, TAGS_SELECTORS, TEXT_MODIFIER_ROLES, TEXT_MODIFIER_SELECTORS, TEXT_MODIFIER_TAGS, THANK_YOU_SELECTORS, THEMES_SELECTORS, THIRD_PARTY_ROUTES, TOASTR_MESSAGES, TWILIO_SELECTORS, TagsApi$1 as TagsApi, TagsPage, TeamMembers, ThankYouPage, USER_AGENTS, WEBHOOK_SELECTORS, WebhooksPage, ZAPIER_LIMIT_EXHAUSTED_MESSAGE, ZAPIER_SELECTORS, ZAPIER_TEST_EMAIL, ZAPIER_WEB_TEXTS, ZapierPage, baseURLGenerator, basicHTMLContent, clearCredentials, commands, cpuThrottlingUsingCDP, currencyUtils, decodeQRCodeFromFile, definePlaywrightConfig, executeWithThrottledResources, extractSubdomainFromError, filterUtils, generatePhoneNumber, generatePhoneNumberDetails, generateRandomBypassEmail, generateRandomFile, generateStagingData, getByDataQA, getClipboardContent, getFormattedPhoneNumber, getFullUrl, getGlobalUserProps, getGlobalUserState, getImagePathAndName, getListCount, globalShortcuts, headerUtils, hexToRGB, hexToRGBA, hyphenize, i18nFixture, initializeCredentials, initializeTotp, isGithubIssueOpen, joinHyphenCase, joinString, login, loginWithoutSSO, networkConditions, networkThrottlingUsingCDP, readFileSyncIfExists, removeCredentialFile, serializeFileForBrowser, shouldSkipCustomDomainSetup, shouldSkipSetupAndTeardown, simulateClickWithDelay, simulateTypingWithDelay, skipTest, squish, stealth as stealthTest, tableUtils, toCamelCase, updateCredentials, writeDataToFile };
198787
+ export { ADMIN_PANEL_SELECTORS, API_KEYS_SELECTORS, API_ROUTES, AUDIT_LOGS_TEXTS, AdminPanelPage, ApiKeysApi, ApiKeysPage, AuditLogsPage, BASE_URL, CHANGELOG_WIDGET_SELECTORS, CHAT_WIDGET_SELECTORS, CHAT_WIDGET_TEXTS, COLOR, COMMON_SELECTORS, COMMON_TEXTS, COMMUNITY_TEXTS, CREDENTIALS, CUSTOM_DOMAIN_SELECTORS, CUSTOM_DOMAIN_SUFFIX, CustomCommands, CustomDomainPage, DATE_PICKER_SELECTORS, DATE_TEXTS, DESCRIPTION_EDITOR_TEXTS, EMBED_SELECTORS, EMOJI_LABEL, EMPTY_STORAGE_STATE, ENGAGE_TEXTS, ENVIRONMENT, EXPANDED_FONT_SIZE, EditorPage, EmbedBase, FILE_FORMATS, FONT_SIZE_SELECTORS, GLOBAL_TRANSLATIONS_PATTERN, GOOGLE_ANALYTICS_SELECTORS, GOOGLE_CALENDAR_DATE_FORMAT, GOOGLE_LOGIN_SELECTORS, GOOGLE_LOGIN_TEXTS, GOOGLE_SHEETS_SELECTORS, GooglePage, HELP_CENTER_SELECTORS, HelpAndProfilePage, INTEGRATIONS_TEXTS, INTEGRATION_SELECTORS, IP_RESTRICTIONS_SELECTORS, IS_STAGING_ENV, ImageUploader, IntegrationBase, KEYBOARD_SHORTCUTS_SELECTORS, LIST_MODIFIER_SELECTORS, LIST_MODIFIER_TAGS, LOGIN_SELECTORS, MEMBER_FORM_SELECTORS, MEMBER_SELECTORS, MEMBER_TEXTS, MERGE_TAGS_SELECTORS, MailerUtils, Member, MemberApis$1 as MemberApis, NEETO_AUTH_BASE_URL, NEETO_EDITOR_SELECTORS, NEETO_FILTERS_SELECTORS, NEETO_IMAGE_UPLOADER_SELECTORS, NEETO_ROUTES, NEETO_TEXT_MODIFIER_SELECTORS, ONBOARDING_SELECTORS, ORGANIZATION_TEXTS, OTP_EMAIL_PATTERN, OrganizationPage, PHONE_NUMBER_FORMATS, PLURAL, PROFILE_LINKS, PROFILE_SECTION_SELECTORS, PROJECT_TRANSLATIONS_PATH, ROLES_SELECTORS, ROUTES, RoleApis$1 as RoleApis, RolesPage, SELECT_COUNTRY, SIGNUP_SELECTORS, SINGULAR, SLACK_DATA_QA_SELECTORS, SLACK_DEFAULT_CHANNEL, SLACK_SELECTORS, SLACK_WEB_TEXTS, STATUS_TEXTS, STORAGE_STATE, SidebarSection, SlackPage, TABLE_SELECTORS, TAB_SELECTORS, TAGS_SELECTORS, TEXT_MODIFIER_ROLES, TEXT_MODIFIER_SELECTORS, TEXT_MODIFIER_TAGS, THANK_YOU_SELECTORS, THEMES_SELECTORS, THIRD_PARTY_ROUTES, TOASTR_MESSAGES, TWILIO_SELECTORS, TagsApi$1 as TagsApi, TagsPage, TeamMembers, ThankYouPage, USER_AGENTS, WEBHOOK_SELECTORS, WebhooksPage, ZAPIER_LIMIT_EXHAUSTED_MESSAGE, ZAPIER_SELECTORS, ZAPIER_TEST_EMAIL, ZAPIER_WEB_TEXTS, ZapierPage, baseURLGenerator, basicHTMLContent, clearCredentials, commands, cpuThrottlingUsingCDP, currencyUtils, decodeQRCodeFromFile, definePlaywrightConfig, executeWithThrottledResources, extractSubdomainFromError, filterUtils, generatePhoneNumber, generatePhoneNumberDetails, generateRandomBypassEmail, generateRandomFile, generateStagingData, getByDataQA, getClipboardContent, getFormattedPhoneNumber, getFullUrl, getGlobalUserProps, getGlobalUserState, getImagePathAndName, getListCount, globalShortcuts, grantClipboardPermissions, headerUtils, hexToRGB, hexToRGBA, hyphenize, i18nFixture, initializeCredentials, initializeTestData, initializeTotp, isGithubIssueOpen, joinHyphenCase, joinString, login, loginWithoutSSO, networkConditions, networkThrottlingUsingCDP, readFileSyncIfExists, removeCredentialFile, serializeFileForBrowser, shouldSkipCustomDomainSetup, shouldSkipSetupAndTeardown, simulateClickWithDelay, simulateTypingWithDelay, skipTest, squish, stealth as stealthTest, tableUtils, toCamelCase, updateCredentials, writeDataToFile };
198783
198788
  //# sourceMappingURL=index.js.map