@telia-ace/alliance-internal-client-utilities 1.0.4 → 1.0.5-next.0
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/CHANGELOG.md +6 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.js +4 -4
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
package/CHANGELOG.md
CHANGED
package/dist/index.d.ts
CHANGED
|
@@ -114,7 +114,7 @@ type VocaOption = {
|
|
|
114
114
|
};
|
|
115
115
|
declare function getVocaIcon(vocaIcons: any, name: string): VocaIcon;
|
|
116
116
|
type Unpacked<T> = T extends (infer U)[] ? U : T;
|
|
117
|
-
declare function mapToVocaOptions<T>(items: T, mapper: (item: Unpacked<T>) => VocaOption,
|
|
117
|
+
declare function mapToVocaOptions<T>(items: T, mapper: (item: Unpacked<T>) => VocaOption, placeholder?: string): VocaOption[];
|
|
118
118
|
declare function onEnter(fn: (e: KeyboardEvent) => void): (e: KeyboardEvent) => void;
|
|
119
119
|
declare function friendlyUserName(user: {
|
|
120
120
|
email: string;
|
package/dist/index.js
CHANGED
|
@@ -255,7 +255,7 @@ function getVocaIcon(vocaIcons, name) {
|
|
|
255
255
|
return icon;
|
|
256
256
|
}
|
|
257
257
|
__name(getVocaIcon, "getVocaIcon");
|
|
258
|
-
function mapToVocaOptions(items, mapper,
|
|
258
|
+
function mapToVocaOptions(items, mapper, placeholder) {
|
|
259
259
|
return items.reduce((acc, item) => {
|
|
260
260
|
acc.push({
|
|
261
261
|
disabled: false,
|
|
@@ -263,14 +263,14 @@ function mapToVocaOptions(items, mapper, label = "Choose...") {
|
|
|
263
263
|
...mapper(item)
|
|
264
264
|
});
|
|
265
265
|
return acc;
|
|
266
|
-
}, [
|
|
266
|
+
}, placeholder ? [
|
|
267
267
|
{
|
|
268
|
-
label,
|
|
268
|
+
label: placeholder,
|
|
269
269
|
value: "",
|
|
270
270
|
disabled: true,
|
|
271
271
|
selected: true
|
|
272
272
|
}
|
|
273
|
-
]);
|
|
273
|
+
] : []);
|
|
274
274
|
}
|
|
275
275
|
__name(mapToVocaOptions, "mapToVocaOptions");
|
|
276
276
|
function onEnter(fn) {
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/exceptions.ts","../src/routing.ts","../src/translations.ts","../src/texts.ts","../src/ui.ts"],"names":["FrameworkErrorCodes","UtilitiesErrorCodes","parseTemplates","message","variables","Object","entries","reduce","acc","key","value","replaceAll","allianceErrors","ALLIANCE_ERROR_NAME","AllianceError","Error","constructor","code","info","name","stack","isAllianceError","error","createQueryString","args","filteredArgs","entry","JSON","stringify","keys","length","URLSearchParams","getCurrentPath","runtimeRootUrl","getRuntimeRootUrl","href","search","window","location","replace","createCapabilityPath","app","capability","rootPath","origin","queryString","getCurrentLocationInfo","currentPath","split","filter","part","globalThis","__ALLIANCE_RUNTIME_ROOT_URL","TranslationsKey","en","Texts","getTranslations","getTranslation","translations","translation","formattedTranslation","curr","index","toString","get","MissingTranslationKey","vocaIconsToOptions","vocaIcons","selected","mapToVocaOptions","values","label","VocaButtonVariant","getVocaIcon","icon","find","items","mapper","item","push","disabled","onEnter","fn","e","friendlyUserName","user","format","email","displayName","hasDisplayName","hasEmail","classNames","classes","c","join","props","properties"],"mappings":"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","sourcesContent":["export enum FrameworkErrorCodes {\n AlreadyInitialized = 1000,\n NoAppName = 1001,\n MissingAppController = 1002,\n MissingCapabilityOnApp = 1003,\n MissingManagedObjectProvider = 1004,\n NoManifest = 1005,\n NoRootElement = 1006,\n NoView = 1007,\n CookieKeyNotDefined = 1008,\n CookieCategoryNotAllowed = 1009,\n StorageKeyNotDefined = 1010,\n StorageCategoryNotAllowed = 1011,\n LocalizationTemplateNotDefined = 1012,\n NonViewOperation = 1013,\n}\n\nexport enum UtilitiesErrorCodes {\n CurrentUserMissingProvider = 2000,\n CurrentUserGatewayNotStarted = 2001,\n CurrentUserMissingBackend = 2002,\n CurrentUserMissingInDatabase = 2003,\n}\n\ntype ErrorCodes = UtilitiesErrorCodes | FrameworkErrorCodes;\n\nfunction parseTemplates(message: string, variables: Record<string, string>) {\n return Object.entries(variables).reduce((acc, [key, value]) => {\n return acc.replaceAll(`{{${key}}}`, value);\n }, message);\n}\n\nconst allianceErrors: Record<ErrorCodes, string> = {\n // framework\n [FrameworkErrorCodes.AlreadyInitialized]: 'The runtime has already been initialized',\n [FrameworkErrorCodes.NoAppName]: 'App name is not defined on global scope',\n [FrameworkErrorCodes.MissingAppController]: \"No app controller registered for app '{{app}}'\",\n [FrameworkErrorCodes.MissingCapabilityOnApp]:\n \"No capability '{{capability}}' enabled for app '{{app}}'\",\n [FrameworkErrorCodes.MissingManagedObjectProvider]:\n \"No managed object provider registered for object '{{object}}'\",\n [FrameworkErrorCodes.NoManifest]: 'The current apps manifest is not defined on global scope',\n [FrameworkErrorCodes.NoRootElement]: 'Could not find the root element in the DOM',\n [FrameworkErrorCodes.NoView]:\n \"Could not find view with id '{{id}}' on view controller for app '{{app}}'\",\n [FrameworkErrorCodes.CookieKeyNotDefined]:\n \"Cookie key '{{key}}' not present in manifest, cookie has not been set\",\n [FrameworkErrorCodes.CookieCategoryNotAllowed]:\n \"Cookies categorized as '{{category}}' are not allowed by the user, cookie '{{key}}' has not been set\",\n [FrameworkErrorCodes.StorageKeyNotDefined]:\n \"Storage key '{{key}}' not present in manifest, item has not been stored\",\n [FrameworkErrorCodes.StorageCategoryNotAllowed]:\n \"Storage categorized as '{{category}}' is not allowed by the user, item '{{key}}' has not been stored\",\n [FrameworkErrorCodes.LocalizationTemplateNotDefined]:\n \"The translation template, referred by the key '{{key}}' is being used in app, but is not defined in the manifest.\",\n [FrameworkErrorCodes.NonViewOperation]:\n \"The capability '{{capability}}', requested by an alliance-view element, did not return a View Operation.\",\n // utilities\n [UtilitiesErrorCodes.CurrentUserMissingProvider]:\n \"No managed object provider registered for object 'currentUser'\",\n [UtilitiesErrorCodes.CurrentUserGatewayNotStarted]:\n \"Could not access the gateway when querying 'currentUser'\",\n [UtilitiesErrorCodes.CurrentUserMissingBackend]:\n \"Could not access the required backend when querying 'currentUser'\",\n [UtilitiesErrorCodes.CurrentUserMissingInDatabase]:\n 'Could not locate the authenticated user in the Alliance database',\n};\n\nconst ALLIANCE_ERROR_NAME = 'AllianceError';\n\nexport class AllianceError extends Error {\n constructor(\n public code: ErrorCodes,\n variables: Record<string, string> = {},\n ) {\n const message = parseTemplates(allianceErrors[code], variables);\n const info = `https://github.com/telia-company/ace-alliance-sdk/wiki/error-codes#${code}`;\n super(message);\n\n this.name = ALLIANCE_ERROR_NAME;\n this.stack = `[${code}] - ${message}` + '\\n' + info;\n }\n}\n\nexport function isAllianceError(error: any): error is AllianceError {\n return !!error.code && error.name === ALLIANCE_ERROR_NAME;\n}\n","import type { SerializeableObject } from './types';\n\nfunction createQueryString(args: SerializeableObject) {\n const entries = Object.entries(args);\n\n const filteredArgs = entries.reduce<SerializeableObject>((acc, entry) => {\n const [key, value] = entry;\n\n if (typeof value === 'undefined') {\n return acc;\n } else if (typeof value === 'object' && value !== null) {\n acc[key] = JSON.stringify(value);\n } else {\n acc[key] = value;\n }\n\n return acc;\n }, {});\n\n if (!Object.keys(filteredArgs).length) {\n return '';\n }\n\n return `?${new URLSearchParams(filteredArgs as Record<string, any>)}`;\n}\n\nfunction getCurrentPath() {\n const runtimeRootUrl = getRuntimeRootUrl();\n const { href, search } = window.location;\n\n return href.replace(runtimeRootUrl, '').replace(search, '');\n}\n\nexport function createCapabilityPath(\n app: string = '',\n capability: string = '',\n args: SerializeableObject = {},\n) {\n const rootPath = getRuntimeRootUrl().replace(location.origin, '');\n const queryString = createQueryString(args);\n\n if (!app) {\n return `${rootPath}${queryString}`;\n }\n\n if (!capability) {\n return `${rootPath}/${app}${queryString}`;\n }\n\n return `${rootPath}/${app}/${capability}${queryString}`;\n}\n\nexport function getCurrentLocationInfo() {\n const currentPath = getCurrentPath();\n const [app = '', capability = ''] = currentPath.split('/').filter((part) => !!part);\n\n return {\n app,\n capability,\n };\n}\n\nexport function getRuntimeRootUrl(): string {\n // @ts-ignore\n if (globalThis.__ALLIANCE_RUNTIME_ROOT_URL) {\n // @ts-ignore\n return globalThis.__ALLIANCE_RUNTIME_ROOT_URL;\n }\n return window.origin;\n}\n","export type Translations = {\n [key in TranslationsKey]: string;\n};\n\nexport enum TranslationsKey {\n AlreadyExists,\n ApiGatewayPortDescription,\n ApiServerModeDescription,\n AppConfigurationPath,\n AppCreated,\n AppEntryBuildOptionDescription,\n AppNameInquiry,\n BuildDescription,\n BuildModeOptionDescription,\n BuildWatchDescription,\n CreateAppDescription,\n CreateWorkspaceDescription,\n DevServerOpenDescription,\n DevServerPortDescription,\n DevServerLoggingDescription,\n Done,\n FetchPackageVersionError,\n ManifestEntryBuildOptionDescription,\n MissingTranslationKey,\n NoAppName,\n NoAppNameFound,\n NoAppOrWorkspaceInCurrentDirectory,\n NoWorkspaceName,\n OperationCancelled,\n ServeDescription,\n ServedStopped,\n ServerGatewayMode,\n ServerMode,\n ServerModeInquiry,\n ServerProxyMode,\n StopServerInstructions,\n TemplateFrameworkInquiry,\n TemplateLanguageInquiry,\n UnrecognizedCommand,\n WorkspaceCreated,\n WorkspaceNameInquiry,\n}\n\nexport const en: Translations = {\n [TranslationsKey.Done]: 'Done',\n [TranslationsKey.NoWorkspaceName]: 'No workspace name provided!',\n [TranslationsKey.NoAppName]: 'No app name provided!',\n [TranslationsKey.AlreadyExists]: \"File or directory '{0}' already exists!\",\n [TranslationsKey.NoAppOrWorkspaceInCurrentDirectory]:\n \"Could not find any app entry file at '{0}'!\",\n [TranslationsKey.UnrecognizedCommand]: 'Unrecognized command(s) {0}!',\n [TranslationsKey.WorkspaceCreated]: \"Workspace was created at path '{0}'!\",\n [TranslationsKey.AppCreated]: \"App was created at path '{0}'!\",\n [TranslationsKey.ServedStopped]: 'Server stopped.',\n [TranslationsKey.CreateWorkspaceDescription]:\n 'Creates an Alliance Workspace in the current directory.',\n [TranslationsKey.CreateAppDescription]:\n 'Creates an Alliance Application in the current directory or Alliance Workspace.',\n [TranslationsKey.ServeDescription]:\n 'Starts a Alliance development server using the current directory package.json.',\n [TranslationsKey.BuildDescription]: 'Builds an Alliance Application using Vite.',\n [TranslationsKey.WorkspaceNameInquiry]: 'Enter the name of your workspace',\n [TranslationsKey.ServerModeInquiry]: 'Which server mode do you want to use?',\n [TranslationsKey.AppNameInquiry]: 'Enter the name of your app',\n [TranslationsKey.MissingTranslationKey]: 'No translation key provided!',\n [TranslationsKey.OperationCancelled]: 'Operation cancelled.',\n [TranslationsKey.StopServerInstructions]: 'Press CTRL + C to stop the server.\\n',\n [TranslationsKey.TemplateLanguageInquiry]: 'Select preferred language',\n [TranslationsKey.TemplateFrameworkInquiry]: 'Select preferred framework template',\n [TranslationsKey.DevServerPortDescription]: 'The port that the dev server should use.',\n [TranslationsKey.DevServerLoggingDescription]:\n 'Whether the dev server and browser console should output more log information or not (false).',\n [TranslationsKey.ApiGatewayPortDescription]: 'The port that the api gateway should use.',\n [TranslationsKey.ApiServerModeDescription]:\n 'Which components to start. [server|server-proxy|server-gateway].',\n [TranslationsKey.DevServerOpenDescription]:\n 'Whether the dev server should automatically open in your browser or not.',\n [TranslationsKey.BuildWatchDescription]:\n 'Whether the build should start watching and rebuild when files change or not.',\n [TranslationsKey.AppEntryBuildOptionDescription]: 'The entry file for the app (./src/app).',\n [TranslationsKey.ManifestEntryBuildOptionDescription]:\n 'The entry file for the app manifest (./src/manifest).',\n [TranslationsKey.BuildModeOptionDescription]: 'Which mode to use when building the app.',\n [TranslationsKey.FetchPackageVersionError]:\n \"Failed to fetch package info from the NPM registry for package '${0}'!\",\n [TranslationsKey.NoAppNameFound]: 'Could not find app name in manifest.',\n [TranslationsKey.AppConfigurationPath]: 'The path to the app configuration file.',\n [TranslationsKey.ServerMode]: 'Server',\n [TranslationsKey.ServerProxyMode]: 'Server with proxy',\n [TranslationsKey.ServerGatewayMode]: 'Server with gateway',\n};\n","import { type Translations, TranslationsKey, en } from './translations';\n\nexport type TextArgs = (string | number)[];\n\nexport class Texts {\n protected static getTranslations = (): Translations => {\n return en;\n };\n\n protected static getTranslation = (key: TranslationsKey, ...args: TextArgs): string => {\n const translations = Texts.getTranslations();\n const translation = translations[key];\n\n if (!translation) throw new Error(`Could not find text with given key '${key}'.`);\n\n const formattedTranslation = args.reduce(\n (acc, curr, index) => acc.toString().replace(`{${index}}`, curr.toString()),\n translation,\n );\n\n return formattedTranslation.toString();\n };\n\n public static get = (\n key: TranslationsKey = TranslationsKey.MissingTranslationKey,\n ...args: TextArgs\n ) => this.getTranslation(key, ...args);\n}\n\nexport default Texts;\n","export function vocaIconsToOptions(vocaIcons: any, selected: string) {\n return mapToVocaOptions(Object.values(vocaIcons), ({ name }: any) => ({\n label: name,\n value: name,\n selected: selected === name,\n }));\n}\n\nexport type VocaIcon = { name: string; svg: string };\n\nexport enum VocaButtonVariant {\n Primary = 'primary',\n Secondary = 'secondary',\n Expressive = 'expressive',\n Destructive = 'destructive',\n Text = 'text',\n PrimaryWhite = 'primary-white',\n SecondaryWhite = 'secondary-white',\n ExpressiveWhite = 'expressive-white',\n TertiaryPurple = 'tertiary-purple',\n}\n\nexport type VocaOption = { label: string; value: string; disabled?: boolean; selected?: boolean };\n\nexport function getVocaIcon(vocaIcons: any, name: string) {\n const icon = Object.values(vocaIcons).find((icon: any) => icon.name === name);\n return icon as VocaIcon;\n}\n\nexport type Unpacked<T> = T extends (infer U)[] ? U : T;\n\nexport function mapToVocaOptions<T>(\n items: T,\n mapper: (item: Unpacked<T>) => VocaOption,\n label: string = 'Choose...',\n): VocaOption[] {\n return (items as []).reduce<VocaOption[]>(\n (acc, item) => {\n acc.push({\n disabled: false,\n selected: false,\n ...mapper(item),\n });\n\n return acc;\n },\n [\n {\n label,\n value: '',\n disabled: true,\n selected: true,\n },\n ],\n );\n}\n\nexport function onEnter(fn: (e: KeyboardEvent) => void) {\n return (e: KeyboardEvent) => {\n if (e.key === 'Enter') {\n fn(e);\n }\n };\n}\n\nexport function friendlyUserName(\n user: { email: string; displayName: string },\n format: 'single' | 'all' = 'all',\n) {\n const { email, displayName } = user;\n\n const hasDisplayName = displayName && displayName !== 'unknown';\n const hasEmail = !!email;\n\n switch (format) {\n case 'all': {\n if (hasDisplayName && hasEmail) {\n return `${displayName} (${email})`;\n } else if (hasDisplayName) {\n return displayName;\n } else if (hasEmail) {\n return email;\n }\n break;\n }\n case 'single': {\n if (hasDisplayName) {\n return displayName;\n } else if (hasEmail) {\n return email;\n }\n break;\n }\n }\n\n return '<UNKNOWN USER>';\n}\n\nexport function classNames(...classes: string[]) {\n return classes.filter((c) => !!c).join(' ');\n}\n\nexport function props(properties: object) {\n return Object.entries(properties).reduce<Record<string, string | boolean | number>>(\n (acc, [key, value]) => {\n if (typeof value !== 'object' && typeof value !== 'function') {\n acc[key] = value;\n }\n\n return acc;\n },\n {},\n );\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/exceptions.ts","../src/routing.ts","../src/translations.ts","../src/texts.ts","../src/ui.ts"],"names":["FrameworkErrorCodes","UtilitiesErrorCodes","parseTemplates","message","variables","Object","entries","reduce","acc","key","value","replaceAll","allianceErrors","ALLIANCE_ERROR_NAME","AllianceError","Error","constructor","code","info","name","stack","isAllianceError","error","createQueryString","args","filteredArgs","entry","JSON","stringify","keys","length","URLSearchParams","getCurrentPath","runtimeRootUrl","getRuntimeRootUrl","href","search","window","location","replace","createCapabilityPath","app","capability","rootPath","origin","queryString","getCurrentLocationInfo","currentPath","split","filter","part","globalThis","__ALLIANCE_RUNTIME_ROOT_URL","TranslationsKey","en","Texts","getTranslations","getTranslation","translations","translation","formattedTranslation","curr","index","toString","get","MissingTranslationKey","vocaIconsToOptions","vocaIcons","selected","mapToVocaOptions","values","label","VocaButtonVariant","getVocaIcon","icon","find","items","mapper","placeholder","item","push","disabled","onEnter","fn","e","friendlyUserName","user","format","email","displayName","hasDisplayName","hasEmail","classNames","classes","c","join","props","properties"],"mappings":"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","sourcesContent":["export enum FrameworkErrorCodes {\n AlreadyInitialized = 1000,\n NoAppName = 1001,\n MissingAppController = 1002,\n MissingCapabilityOnApp = 1003,\n MissingManagedObjectProvider = 1004,\n NoManifest = 1005,\n NoRootElement = 1006,\n NoView = 1007,\n CookieKeyNotDefined = 1008,\n CookieCategoryNotAllowed = 1009,\n StorageKeyNotDefined = 1010,\n StorageCategoryNotAllowed = 1011,\n LocalizationTemplateNotDefined = 1012,\n NonViewOperation = 1013,\n}\n\nexport enum UtilitiesErrorCodes {\n CurrentUserMissingProvider = 2000,\n CurrentUserGatewayNotStarted = 2001,\n CurrentUserMissingBackend = 2002,\n CurrentUserMissingInDatabase = 2003,\n}\n\ntype ErrorCodes = UtilitiesErrorCodes | FrameworkErrorCodes;\n\nfunction parseTemplates(message: string, variables: Record<string, string>) {\n return Object.entries(variables).reduce((acc, [key, value]) => {\n return acc.replaceAll(`{{${key}}}`, value);\n }, message);\n}\n\nconst allianceErrors: Record<ErrorCodes, string> = {\n // framework\n [FrameworkErrorCodes.AlreadyInitialized]: 'The runtime has already been initialized',\n [FrameworkErrorCodes.NoAppName]: 'App name is not defined on global scope',\n [FrameworkErrorCodes.MissingAppController]: \"No app controller registered for app '{{app}}'\",\n [FrameworkErrorCodes.MissingCapabilityOnApp]:\n \"No capability '{{capability}}' enabled for app '{{app}}'\",\n [FrameworkErrorCodes.MissingManagedObjectProvider]:\n \"No managed object provider registered for object '{{object}}'\",\n [FrameworkErrorCodes.NoManifest]: 'The current apps manifest is not defined on global scope',\n [FrameworkErrorCodes.NoRootElement]: 'Could not find the root element in the DOM',\n [FrameworkErrorCodes.NoView]:\n \"Could not find view with id '{{id}}' on view controller for app '{{app}}'\",\n [FrameworkErrorCodes.CookieKeyNotDefined]:\n \"Cookie key '{{key}}' not present in manifest, cookie has not been set\",\n [FrameworkErrorCodes.CookieCategoryNotAllowed]:\n \"Cookies categorized as '{{category}}' are not allowed by the user, cookie '{{key}}' has not been set\",\n [FrameworkErrorCodes.StorageKeyNotDefined]:\n \"Storage key '{{key}}' not present in manifest, item has not been stored\",\n [FrameworkErrorCodes.StorageCategoryNotAllowed]:\n \"Storage categorized as '{{category}}' is not allowed by the user, item '{{key}}' has not been stored\",\n [FrameworkErrorCodes.LocalizationTemplateNotDefined]:\n \"The translation template, referred by the key '{{key}}' is being used in app, but is not defined in the manifest.\",\n [FrameworkErrorCodes.NonViewOperation]:\n \"The capability '{{capability}}', requested by an alliance-view element, did not return a View Operation.\",\n // utilities\n [UtilitiesErrorCodes.CurrentUserMissingProvider]:\n \"No managed object provider registered for object 'currentUser'\",\n [UtilitiesErrorCodes.CurrentUserGatewayNotStarted]:\n \"Could not access the gateway when querying 'currentUser'\",\n [UtilitiesErrorCodes.CurrentUserMissingBackend]:\n \"Could not access the required backend when querying 'currentUser'\",\n [UtilitiesErrorCodes.CurrentUserMissingInDatabase]:\n 'Could not locate the authenticated user in the Alliance database',\n};\n\nconst ALLIANCE_ERROR_NAME = 'AllianceError';\n\nexport class AllianceError extends Error {\n constructor(\n public code: ErrorCodes,\n variables: Record<string, string> = {},\n ) {\n const message = parseTemplates(allianceErrors[code], variables);\n const info = `https://github.com/telia-company/ace-alliance-sdk/wiki/error-codes#${code}`;\n super(message);\n\n this.name = ALLIANCE_ERROR_NAME;\n this.stack = `[${code}] - ${message}` + '\\n' + info;\n }\n}\n\nexport function isAllianceError(error: any): error is AllianceError {\n return !!error.code && error.name === ALLIANCE_ERROR_NAME;\n}\n","import type { SerializeableObject } from './types';\n\nfunction createQueryString(args: SerializeableObject) {\n const entries = Object.entries(args);\n\n const filteredArgs = entries.reduce<SerializeableObject>((acc, entry) => {\n const [key, value] = entry;\n\n if (typeof value === 'undefined') {\n return acc;\n } else if (typeof value === 'object' && value !== null) {\n acc[key] = JSON.stringify(value);\n } else {\n acc[key] = value;\n }\n\n return acc;\n }, {});\n\n if (!Object.keys(filteredArgs).length) {\n return '';\n }\n\n return `?${new URLSearchParams(filteredArgs as Record<string, any>)}`;\n}\n\nfunction getCurrentPath() {\n const runtimeRootUrl = getRuntimeRootUrl();\n const { href, search } = window.location;\n\n return href.replace(runtimeRootUrl, '').replace(search, '');\n}\n\nexport function createCapabilityPath(\n app: string = '',\n capability: string = '',\n args: SerializeableObject = {},\n) {\n const rootPath = getRuntimeRootUrl().replace(location.origin, '');\n const queryString = createQueryString(args);\n\n if (!app) {\n return `${rootPath}${queryString}`;\n }\n\n if (!capability) {\n return `${rootPath}/${app}${queryString}`;\n }\n\n return `${rootPath}/${app}/${capability}${queryString}`;\n}\n\nexport function getCurrentLocationInfo() {\n const currentPath = getCurrentPath();\n const [app = '', capability = ''] = currentPath.split('/').filter((part) => !!part);\n\n return {\n app,\n capability,\n };\n}\n\nexport function getRuntimeRootUrl(): string {\n // @ts-ignore\n if (globalThis.__ALLIANCE_RUNTIME_ROOT_URL) {\n // @ts-ignore\n return globalThis.__ALLIANCE_RUNTIME_ROOT_URL;\n }\n return window.origin;\n}\n","export type Translations = {\n [key in TranslationsKey]: string;\n};\n\nexport enum TranslationsKey {\n AlreadyExists,\n ApiGatewayPortDescription,\n ApiServerModeDescription,\n AppConfigurationPath,\n AppCreated,\n AppEntryBuildOptionDescription,\n AppNameInquiry,\n BuildDescription,\n BuildModeOptionDescription,\n BuildWatchDescription,\n CreateAppDescription,\n CreateWorkspaceDescription,\n DevServerOpenDescription,\n DevServerPortDescription,\n DevServerLoggingDescription,\n Done,\n FetchPackageVersionError,\n ManifestEntryBuildOptionDescription,\n MissingTranslationKey,\n NoAppName,\n NoAppNameFound,\n NoAppOrWorkspaceInCurrentDirectory,\n NoWorkspaceName,\n OperationCancelled,\n ServeDescription,\n ServedStopped,\n ServerGatewayMode,\n ServerMode,\n ServerModeInquiry,\n ServerProxyMode,\n StopServerInstructions,\n TemplateFrameworkInquiry,\n TemplateLanguageInquiry,\n UnrecognizedCommand,\n WorkspaceCreated,\n WorkspaceNameInquiry,\n}\n\nexport const en: Translations = {\n [TranslationsKey.Done]: 'Done',\n [TranslationsKey.NoWorkspaceName]: 'No workspace name provided!',\n [TranslationsKey.NoAppName]: 'No app name provided!',\n [TranslationsKey.AlreadyExists]: \"File or directory '{0}' already exists!\",\n [TranslationsKey.NoAppOrWorkspaceInCurrentDirectory]:\n \"Could not find any app entry file at '{0}'!\",\n [TranslationsKey.UnrecognizedCommand]: 'Unrecognized command(s) {0}!',\n [TranslationsKey.WorkspaceCreated]: \"Workspace was created at path '{0}'!\",\n [TranslationsKey.AppCreated]: \"App was created at path '{0}'!\",\n [TranslationsKey.ServedStopped]: 'Server stopped.',\n [TranslationsKey.CreateWorkspaceDescription]:\n 'Creates an Alliance Workspace in the current directory.',\n [TranslationsKey.CreateAppDescription]:\n 'Creates an Alliance Application in the current directory or Alliance Workspace.',\n [TranslationsKey.ServeDescription]:\n 'Starts a Alliance development server using the current directory package.json.',\n [TranslationsKey.BuildDescription]: 'Builds an Alliance Application using Vite.',\n [TranslationsKey.WorkspaceNameInquiry]: 'Enter the name of your workspace',\n [TranslationsKey.ServerModeInquiry]: 'Which server mode do you want to use?',\n [TranslationsKey.AppNameInquiry]: 'Enter the name of your app',\n [TranslationsKey.MissingTranslationKey]: 'No translation key provided!',\n [TranslationsKey.OperationCancelled]: 'Operation cancelled.',\n [TranslationsKey.StopServerInstructions]: 'Press CTRL + C to stop the server.\\n',\n [TranslationsKey.TemplateLanguageInquiry]: 'Select preferred language',\n [TranslationsKey.TemplateFrameworkInquiry]: 'Select preferred framework template',\n [TranslationsKey.DevServerPortDescription]: 'The port that the dev server should use.',\n [TranslationsKey.DevServerLoggingDescription]:\n 'Whether the dev server and browser console should output more log information or not (false).',\n [TranslationsKey.ApiGatewayPortDescription]: 'The port that the api gateway should use.',\n [TranslationsKey.ApiServerModeDescription]:\n 'Which components to start. [server|server-proxy|server-gateway].',\n [TranslationsKey.DevServerOpenDescription]:\n 'Whether the dev server should automatically open in your browser or not.',\n [TranslationsKey.BuildWatchDescription]:\n 'Whether the build should start watching and rebuild when files change or not.',\n [TranslationsKey.AppEntryBuildOptionDescription]: 'The entry file for the app (./src/app).',\n [TranslationsKey.ManifestEntryBuildOptionDescription]:\n 'The entry file for the app manifest (./src/manifest).',\n [TranslationsKey.BuildModeOptionDescription]: 'Which mode to use when building the app.',\n [TranslationsKey.FetchPackageVersionError]:\n \"Failed to fetch package info from the NPM registry for package '${0}'!\",\n [TranslationsKey.NoAppNameFound]: 'Could not find app name in manifest.',\n [TranslationsKey.AppConfigurationPath]: 'The path to the app configuration file.',\n [TranslationsKey.ServerMode]: 'Server',\n [TranslationsKey.ServerProxyMode]: 'Server with proxy',\n [TranslationsKey.ServerGatewayMode]: 'Server with gateway',\n};\n","import { type Translations, TranslationsKey, en } from './translations';\n\nexport type TextArgs = (string | number)[];\n\nexport class Texts {\n protected static getTranslations = (): Translations => {\n return en;\n };\n\n protected static getTranslation = (key: TranslationsKey, ...args: TextArgs): string => {\n const translations = Texts.getTranslations();\n const translation = translations[key];\n\n if (!translation) throw new Error(`Could not find text with given key '${key}'.`);\n\n const formattedTranslation = args.reduce(\n (acc, curr, index) => acc.toString().replace(`{${index}}`, curr.toString()),\n translation,\n );\n\n return formattedTranslation.toString();\n };\n\n public static get = (\n key: TranslationsKey = TranslationsKey.MissingTranslationKey,\n ...args: TextArgs\n ) => this.getTranslation(key, ...args);\n}\n\nexport default Texts;\n","export function vocaIconsToOptions(vocaIcons: any, selected: string) {\n return mapToVocaOptions(Object.values(vocaIcons), ({ name }: any) => ({\n label: name,\n value: name,\n selected: selected === name,\n }));\n}\n\nexport type VocaIcon = { name: string; svg: string };\n\nexport enum VocaButtonVariant {\n Primary = 'primary',\n Secondary = 'secondary',\n Expressive = 'expressive',\n Destructive = 'destructive',\n Text = 'text',\n PrimaryWhite = 'primary-white',\n SecondaryWhite = 'secondary-white',\n ExpressiveWhite = 'expressive-white',\n TertiaryPurple = 'tertiary-purple',\n}\n\nexport type VocaOption = { label: string; value: string; disabled?: boolean; selected?: boolean };\n\nexport function getVocaIcon(vocaIcons: any, name: string) {\n const icon = Object.values(vocaIcons).find((icon: any) => icon.name === name);\n return icon as VocaIcon;\n}\n\nexport type Unpacked<T> = T extends (infer U)[] ? U : T;\n\nexport function mapToVocaOptions<T>(\n items: T,\n mapper: (item: Unpacked<T>) => VocaOption,\n placeholder?: string,\n): VocaOption[] {\n return (items as []).reduce<VocaOption[]>(\n (acc, item) => {\n acc.push({\n disabled: false,\n selected: false,\n ...mapper(item),\n });\n\n return acc;\n },\n placeholder\n ? [\n {\n label: placeholder,\n value: '',\n disabled: true,\n selected: true,\n },\n ]\n : [],\n );\n}\n\nexport function onEnter(fn: (e: KeyboardEvent) => void) {\n return (e: KeyboardEvent) => {\n if (e.key === 'Enter') {\n fn(e);\n }\n };\n}\n\nexport function friendlyUserName(\n user: { email: string; displayName: string },\n format: 'single' | 'all' = 'all',\n) {\n const { email, displayName } = user;\n\n const hasDisplayName = displayName && displayName !== 'unknown';\n const hasEmail = !!email;\n\n switch (format) {\n case 'all': {\n if (hasDisplayName && hasEmail) {\n return `${displayName} (${email})`;\n } else if (hasDisplayName) {\n return displayName;\n } else if (hasEmail) {\n return email;\n }\n break;\n }\n case 'single': {\n if (hasDisplayName) {\n return displayName;\n } else if (hasEmail) {\n return email;\n }\n break;\n }\n }\n\n return '<UNKNOWN USER>';\n}\n\nexport function classNames(...classes: string[]) {\n return classes.filter((c) => !!c).join(' ');\n}\n\nexport function props(properties: object) {\n return Object.entries(properties).reduce<Record<string, string | boolean | number>>(\n (acc, [key, value]) => {\n if (typeof value !== 'object' && typeof value !== 'function') {\n acc[key] = value;\n }\n\n return acc;\n },\n {},\n );\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@telia-ace/alliance-internal-client-utilities",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.5-next.0",
|
|
4
4
|
"description": "Utilities used internally by packages developed by team Alliance.",
|
|
5
5
|
"license": "SEE LICENSE IN LICENSE.txt",
|
|
6
6
|
"author": "Telia Company AB",
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
"dist"
|
|
15
15
|
],
|
|
16
16
|
"devDependencies": {
|
|
17
|
-
"@telia-ace/alliance-internal-node-utilities": "1.0.
|
|
17
|
+
"@telia-ace/alliance-internal-node-utilities": "1.0.5-next.0",
|
|
18
18
|
"tsup": "^7.2.0"
|
|
19
19
|
},
|
|
20
20
|
"publishConfig": {
|