@tstdl/base 0.84.21 → 0.84.23

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.
@@ -1,5 +1,6 @@
1
- import type { ElementHandle, Frame, Page } from 'playwright';
1
+ import type { ElementHandle, Frame, FrameLocator, Page } from 'playwright';
2
2
  import type { Delay } from './element-controller.js';
3
+ import { ElementController } from './element-controller.js';
3
4
  import type { FrameController, FrameControllerOptions } from './frame-controller.js';
4
5
  import { LocatorController } from './locator-controller.js';
5
6
  import type { PageControllerOptions } from './page-controller.js';
@@ -11,16 +12,16 @@ export type DocumentControllerForwardOptions = {
11
12
  pageControllerOptions: PageControllerOptions;
12
13
  frameControllerOptions: FrameControllerOptions;
13
14
  };
14
- export declare class DocumentController extends LocatorController {
15
+ export declare class DocumentController<T extends Page | Frame = Page | Frame> extends LocatorController<T> {
15
16
  protected readonly forwardOptions: DocumentControllerForwardOptions;
16
17
  /** @deprecated should be avoided */
17
- readonly document: Page | Frame;
18
- constructor(document: Page | Frame, options: DocumentControllerOptions, forwardOptions: DocumentControllerForwardOptions);
18
+ readonly document: T;
19
+ constructor(document: T, options: DocumentControllerOptions, forwardOptions: DocumentControllerForwardOptions);
19
20
  setContent(...args: Parameters<Page['setContent']>): Promise<void>;
20
21
  navigate(...args: Parameters<Page['goto']>): Promise<void>;
21
22
  waitForLoadState(...args: Parameters<Page['waitForLoadState']>): Promise<void>;
22
23
  waitForUrl(...args: Parameters<Page['waitForURL']>): Promise<void>;
23
- waitForElement(selector: string, options?: Parameters<Page['waitForSelector']>[1]): Promise<ElementHandle>;
24
- locateInFrame(frameSelector: string): LocatorController;
24
+ waitForElement(selector: string, options?: Parameters<Page['waitForSelector']>[1]): Promise<ElementController<ElementHandle<SVGElement | HTMLElement>>>;
25
+ locateInFrame(frameSelector: string): LocatorController<FrameLocator>;
25
26
  waitForFrame(selector: string, options?: Parameters<Page['waitForSelector']>[1]): Promise<FrameController>;
26
27
  }
@@ -32,6 +32,7 @@ __export(document_controller_exports, {
32
32
  });
33
33
  module.exports = __toCommonJS(document_controller_exports);
34
34
  var import_type_guards = require("../utils/type-guards.js");
35
+ var import_element_controller = require("./element-controller.js");
35
36
  var import_locator_controller = require("./locator-controller.js");
36
37
  class DocumentController extends import_locator_controller.LocatorController {
37
38
  forwardOptions;
@@ -59,7 +60,7 @@ class DocumentController extends import_locator_controller.LocatorController {
59
60
  if ((0, import_type_guards.isNull)(element)) {
60
61
  throw new Error("Element not found.");
61
62
  }
62
- return element;
63
+ return new import_element_controller.ElementController(element, this.elementControllerOptions);
63
64
  }
64
65
  locateInFrame(frameSelector) {
65
66
  const locator = this.document.frameLocator(frameSelector);
@@ -67,7 +68,7 @@ class DocumentController extends import_locator_controller.LocatorController {
67
68
  }
68
69
  async waitForFrame(selector, options) {
69
70
  const element = await this.waitForElement(selector, options);
70
- const frame = await element.contentFrame();
71
+ const frame = await element.locatorOrHandle.contentFrame();
71
72
  if ((0, import_type_guards.isNull)(frame)) {
72
73
  throw new Error("Element is not a frame.");
73
74
  }
@@ -16,10 +16,10 @@ export type ElementControllerOptions = {
16
16
  typeDelay?: Delay;
17
17
  };
18
18
  type LocatorOptions<K extends keyof Locator, I extends keyof Parameters<Locator[K]>> = NonUndefinable<Parameters<Locator[K]>[I]>;
19
- export declare class ElementController {
20
- readonly locatorOrHandle: Locator | ElementHandle;
19
+ export declare class ElementController<T extends Locator | ElementHandle = Locator | ElementHandle> {
20
+ readonly locatorOrHandle: T;
21
21
  readonly options: ElementControllerOptions;
22
- constructor(locatorOrHandle: Locator | ElementHandle, options?: ElementControllerOptions);
22
+ constructor(locatorOrHandle: T, options?: ElementControllerOptions);
23
23
  waitFor(options?: Parameters<Locator['waitFor']>[0]): Promise<void>;
24
24
  fill(text: string, options?: Merge<LocatorOptions<'fill', 1>, ActionDelayOptions>): Promise<void>;
25
25
  type(text: string, options?: Merge<TypedOmit<LocatorOptions<'type', 1>, 'delay'>, ActionDelayOptions & TypeDelayOptions>): Promise<void>;
@@ -7,7 +7,7 @@ export type FrameControllerOptions = DocumentControllerOptions;
7
7
  export type FrameControllerForwardOptions = {
8
8
  pageControllerOptions: PageControllerOptions;
9
9
  };
10
- export declare class FrameController extends DocumentController {
10
+ export declare class FrameController extends DocumentController<Frame> {
11
11
  private readonly frameControllerForwardOptions;
12
12
  /** @deprecated should be avoided */
13
13
  readonly frame: Frame;
@@ -2,15 +2,15 @@ import type { Frame, FrameLocator, Locator, Page } from 'playwright';
2
2
  import type { NonUndefinable, SimplifyObject } from '../types.js';
3
3
  import type { ElementControllerOptions } from './element-controller.js';
4
4
  import { ElementController } from './element-controller.js';
5
- export declare class LocatorController {
5
+ export declare class LocatorController<T extends Page | Frame | Locator | FrameLocator = Page | Frame | Locator | FrameLocator> {
6
6
  protected readonly elementControllerOptions: ElementControllerOptions;
7
- readonly locatable: Page | Frame | Locator | FrameLocator;
8
- constructor(locatable: Page | Frame | Locator | FrameLocator, elementControllerOptions: ElementControllerOptions);
9
- getBySelector(selector: string, options?: SimplifyObject<Pick<NonUndefinable<Parameters<Page['locator']>[1]>, 'hasText' | 'hasNotText'>>): ElementController;
10
- getByRole(role: Parameters<Page['getByRole']>[0], options?: Parameters<Page['getByRole']>[1]): ElementController;
11
- getByLabel(text: Parameters<Page['getByLabel']>[0], options?: Parameters<Page['getByLabel']>[1]): ElementController;
12
- getByAltText(text: Parameters<Page['getByAltText']>[0], options?: Parameters<Page['getByAltText']>[1]): ElementController;
13
- getByPlaceholder(text: Parameters<Page['getByPlaceholder']>[0], options?: Parameters<Page['getByPlaceholder']>[1]): ElementController;
14
- getByText(text: Parameters<Page['getByText']>[0], options?: Parameters<Page['getByText']>[1]): ElementController;
15
- getByTitle(text: Parameters<Page['getByTitle']>[0], options?: Parameters<Page['getByTitle']>[1]): ElementController;
7
+ readonly locatable: T;
8
+ constructor(locatable: T, elementControllerOptions: ElementControllerOptions);
9
+ getBySelector(selector: string, options?: SimplifyObject<Pick<NonUndefinable<Parameters<Page['locator']>[1]>, 'hasText' | 'hasNotText'>>): ElementController<Locator>;
10
+ getByRole(role: Parameters<Page['getByRole']>[0], options?: Parameters<Page['getByRole']>[1]): ElementController<Locator>;
11
+ getByLabel(text: Parameters<Page['getByLabel']>[0], options?: Parameters<Page['getByLabel']>[1]): ElementController<Locator>;
12
+ getByAltText(text: Parameters<Page['getByAltText']>[0], options?: Parameters<Page['getByAltText']>[1]): ElementController<Locator>;
13
+ getByPlaceholder(text: Parameters<Page['getByPlaceholder']>[0], options?: Parameters<Page['getByPlaceholder']>[1]): ElementController<Locator>;
14
+ getByText(text: Parameters<Page['getByText']>[0], options?: Parameters<Page['getByText']>[1]): ElementController<Locator>;
15
+ getByTitle(text: Parameters<Page['getByTitle']>[0], options?: Parameters<Page['getByTitle']>[1]): ElementController<Locator>;
16
16
  }
@@ -10,7 +10,7 @@ import type { Abortable } from './types.js';
10
10
  export type PageControllerOptions = DocumentControllerOptions & {
11
11
  defaultFrameControllerOptions?: FrameControllerOptions;
12
12
  };
13
- export declare class PageController extends DocumentController implements AsyncDisposable {
13
+ export declare class PageController extends DocumentController<Page> implements AsyncDisposable {
14
14
  /** @deprecated should be avoided */
15
15
  readonly page: Page;
16
16
  readonly options: PageControllerOptions;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tstdl/base",
3
- "version": "0.84.21",
3
+ "version": "0.84.23",
4
4
  "author": "Patrick Hein",
5
5
  "publishConfig": {
6
6
  "access": "public"
@@ -29,7 +29,7 @@
29
29
  "@types/chroma-js": "2.4",
30
30
  "@types/koa__router": "12.0",
31
31
  "@types/luxon": "3.3",
32
- "@types/minio": "7.0",
32
+ "@types/minio": "7.1",
33
33
  "@types/mjml": "4.7",
34
34
  "@types/node": "20",
35
35
  "@types/nodemailer": "6.4",
@@ -45,7 +45,7 @@
45
45
  "typescript": "5.0"
46
46
  },
47
47
  "peerDependencies": {
48
- "@elastic/elasticsearch": "^8.7",
48
+ "@elastic/elasticsearch": "^8.8",
49
49
  "@koa/router": "^12.0",
50
50
  "@tstdl/angular": "^0.84",
51
51
  "@zxcvbn-ts/core": "^3.0",
@@ -25,9 +25,9 @@ export interface Signal<T> {
25
25
  [SIGNAL]?: unknown;
26
26
  }
27
27
  /**
28
- * Checks if the given `value` function is a reactive `Signal`.
28
+ * Checks if the given `value` is a reactive `Signal`.
29
29
  */
30
- export declare function isSignal(value: Function): value is Signal<unknown>;
30
+ export declare function isSignal(value: unknown): value is Signal<unknown>;
31
31
  /**
32
32
  * Converts `fn` into a marked signal function (where `isSignal(fn)` will be `true`).
33
33
  *
@@ -32,7 +32,7 @@ module.exports = __toCommonJS(api_exports);
32
32
  */
33
33
  const SIGNAL = Symbol("SIGNAL");
34
34
  function isSignal(value) {
35
- return value[SIGNAL] !== void 0;
35
+ return typeof value == "function" && value[SIGNAL] !== void 0;
36
36
  }
37
37
  function createSignalFromFunction(node, fn, extraApi = {}) {
38
38
  fn[SIGNAL] = node;
@@ -27,7 +27,16 @@ export type ProxyLocalizationKey<Parameters = void> = PropertyName & {
27
27
  [parametersSymbol]?: Parameters;
28
28
  };
29
29
  export type LocalizationKey<Parameters = void> = string | ProxyLocalizationKey<Parameters>;
30
- export type LocalizationData<Parameters = any> = LocalizationKey | LocalizationDataObject<Parameters> | {
30
+ export type EnumLocalizationKey<T extends Enumeration = Enumeration, Parameters = void> = Parameters extends void ? {
31
+ enum: T;
32
+ value?: EnumerationValue<T>;
33
+ parameters?: void;
34
+ } : {
35
+ enum: T;
36
+ value?: EnumerationValue<T>;
37
+ parameters: Parameters;
38
+ };
39
+ export type LocalizationData<Parameters = any, E extends Enumeration = any> = LocalizationKey | EnumLocalizationKey<E, Parameters> | LocalizationDataObject<Parameters> | {
31
40
  key: LocalizationKey;
32
41
  parameters?: void;
33
42
  };
@@ -40,6 +49,8 @@ export type ProxyLocalizationKeys<T extends LocalizationTemplate> = {
40
49
  };
41
50
  export declare function getProxyLocalizationKey<Parameters = void>(key: string): ProxyLocalizationKey<Parameters>;
42
51
  export declare function isProxyLocalizationKey(value: any): value is ProxyLocalizationKey;
52
+ export declare function isEnumLocalizationKey(key: any): key is EnumLocalizationKey;
53
+ export declare function isLocalizationDataObject(value: LocalizationData): value is LocalizationDataObject<any>;
43
54
  /** helper function to ensure type safety */
44
55
  export declare function localizationData<T>(data: LocalizationData<T>): LocalizationData<T>;
45
56
  /**
@@ -65,9 +76,9 @@ export declare class LocalizationService {
65
76
  getLanguage(languageCode: string): Language;
66
77
  setLanguage(languageOrCode: Language | string): void;
67
78
  setLocalization(localization: Localization): void;
68
- tryGetItem<Parameters>(key: LocalizationKey<Parameters> | LocalizationData<Parameters>): LocalizeItem | undefined;
79
+ tryGetItem<Parameters>(keyOrData: LocalizationKey<Parameters> | LocalizationData<Parameters>): LocalizeItem | undefined;
69
80
  hasKey<Parameters>(key: LocalizationKey<Parameters> | LocalizationData<Parameters>): boolean;
70
- localize<Parameters>(keyOrData: LocalizationKey<Parameters> | LocalizationData<Parameters>): string;
81
+ localize<Parameters = void>(keyOrData: LocalizationKey<Parameters> | LocalizationData<Parameters>): string;
71
82
  localizeEnum<T extends Enumeration>(enumeration: T, value?: EnumerationValue<T>, parameters?: unknown): string;
72
83
  localize$<Parameters>(data: LocalizationData<Parameters>): Observable<string>;
73
84
  localizeEnum$<T extends Enumeration>(enumeration: T, value?: EnumerationValue<T>, parameters?: unknown): Observable<string>;
@@ -23,6 +23,8 @@ __export(localization_service_exports, {
23
23
  enumerationLocalization: () => enumerationLocalization,
24
24
  getLocalizationKeys: () => getLocalizationKeys,
25
25
  getProxyLocalizationKey: () => getProxyLocalizationKey,
26
+ isEnumLocalizationKey: () => isEnumLocalizationKey,
27
+ isLocalizationDataObject: () => isLocalizationDataObject,
26
28
  isLocalizeItem: () => isLocalizeItem,
27
29
  isProxyLocalizationKey: () => isProxyLocalizationKey,
28
30
  localizationData: () => localizationData
@@ -62,6 +64,12 @@ function getProxyLocalizationKey(key) {
62
64
  function isProxyLocalizationKey(value) {
63
65
  return (0, import_property_name.isPropertyName)(value);
64
66
  }
67
+ function isEnumLocalizationKey(key) {
68
+ return (0, import_type_guards.isObject)(key) && (0, import_object.hasOwnProperty)(key, "enum");
69
+ }
70
+ function isLocalizationDataObject(value) {
71
+ return (0, import_type_guards.isObject)(value) && (0, import_object.hasOwnProperty)(value, "key");
72
+ }
65
73
  function localizationData(data) {
66
74
  return data;
67
75
  }
@@ -131,11 +139,15 @@ let LocalizationService = class LocalizationService2 {
131
139
  setLocalization(localization) {
132
140
  this.setLanguage(localization.language);
133
141
  }
134
- tryGetItem(key) {
142
+ tryGetItem(keyOrData) {
135
143
  if ((0, import_type_guards.isUndefined)(this.activeLanguage)) {
136
144
  return void 0;
137
145
  }
138
- const actualKey = getStringKey(key);
146
+ if (isEnumLocalizationKey(keyOrData)) {
147
+ const enumEntry = this.localizations.get(this.activeLanguage.code)?.enums.get(keyOrData.enum);
148
+ return (0, import_type_guards.isDefined)(keyOrData.value) ? enumEntry?.values[keyOrData.value] : enumEntry?.name;
149
+ }
150
+ const actualKey = getStringKey(keyOrData);
139
151
  return this.localizations.get(this.activeLanguage.code)?.keys.get(actualKey);
140
152
  }
141
153
  hasKey(key) {
@@ -144,6 +156,9 @@ let LocalizationService = class LocalizationService2 {
144
156
  }
145
157
  // eslint-disable-next-line max-statements
146
158
  localize(keyOrData) {
159
+ if (isEnumLocalizationKey(keyOrData)) {
160
+ return this.localizeEnum(keyOrData.enum, keyOrData.value, keyOrData.parameters);
161
+ }
147
162
  const key = getStringKey(keyOrData);
148
163
  const parameters = (0, import_type_guards.isString)(keyOrData) || isProxyLocalizationKey(keyOrData) ? {} : keyOrData.parameters;
149
164
  const templateOrFunction = (0, import_type_guards.isDefined)(this.activeLanguage) ? this.localizations.get(this.activeLanguage.code)?.keys.get(key) : void 0;