@apia/api 2.0.9 → 2.0.10

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.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiaApi.js","sources":["../src/apiaApi.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-invalid-void-type */\r\nimport axios, { AxiosResponse } from 'axios';\r\nimport merge from 'lodash-es/merge';\r\nimport QueryString from 'qs';\r\nimport { session } from '@apia/session';\r\nimport {\r\n arrayOrArray,\r\n parseXmlAsync,\r\n EventEmitter,\r\n TModify,\r\n TApiaAction,\r\n TApiaSystemMessageObj,\r\n debugDispatcher,\r\n TNotificationMessage,\r\n} from '@apia/util';\r\nimport {\r\n dispatchNotifications,\r\n getNotificationMessageObj,\r\n notify,\r\n} from '@apia/notifications';\r\nimport { handle } from './ApiaApiHandler';\r\nimport {\r\n IApiaApiRequestConfig,\r\n TApiaApiConfigurator,\r\n TApiaApiResult,\r\n TColors,\r\n} from './types';\r\n\r\ndebugDispatcher.on(\r\n 'parseXml',\r\n async ([text]) => {\r\n const result = await parseXmlAsync<unknown>(text as string);\r\n console.info(result);\r\n },\r\n 'Acepta un parámetro de tipo string y realiza un parseo como si fuera xml, convirtiéndolo a objeto javascript.',\r\n);\r\n\r\nconst defaultConfig: IApiaApiRequestConfig<unknown> = {\r\n debug: false,\r\n colors: {\r\n exception: 'red',\r\n alert: 'yellow',\r\n message: 'lightgreen',\r\n },\r\n handleLoad: false,\r\n};\r\n\r\nconst STORED_CONFIG = 'ApiaApiConfig';\r\n\r\nlet forcedConfig: Partial<IApiaApiRequestConfig<unknown>> = {};\r\nconst storedConfig = localStorage.getItem(STORED_CONFIG);\r\nif (storedConfig)\r\n forcedConfig = JSON.parse(storedConfig) as Partial<\r\n IApiaApiRequestConfig<unknown>\r\n >;\r\n\r\nexport function getApiaApiConfigurator(): TApiaApiConfigurator {\r\n return {\r\n reset() {\r\n forcedConfig = {};\r\n localStorage.removeItem(STORED_CONFIG);\r\n },\r\n config(newConfig) {\r\n if (\r\n newConfig.notificationsCategory ||\r\n newConfig.axiosConfig ||\r\n newConfig.modalConfiguration ||\r\n newConfig.handleLoad ||\r\n newConfig.queryData ||\r\n newConfig.stringifyOptions ||\r\n newConfig.validateResponse\r\n )\r\n throw new Error('Operación ilegal');\r\n\r\n const toStoreConfig = merge(forcedConfig, newConfig);\r\n localStorage.setItem(STORED_CONFIG, JSON.stringify(toStoreConfig));\r\n forcedConfig = toStoreConfig;\r\n console.log('Se guardó la configuración correctamente', {\r\n config: toStoreConfig,\r\n });\r\n },\r\n shout() {\r\n console.log({ config: getConfig({}) });\r\n },\r\n theme(theme) {\r\n if (theme.toLowerCase() === 'dark') {\r\n getApiaApiConfigurator().config({\r\n colors: {\r\n exception: 'red',\r\n alert: 'yellow',\r\n message: 'lightgreen',\r\n },\r\n });\r\n } else if (theme.toLowerCase() === 'light') {\r\n getApiaApiConfigurator().config({\r\n colors: {\r\n exception: 'red',\r\n alert: '#e0e006',\r\n message: 'darkgreen',\r\n },\r\n });\r\n } else {\r\n console.log(`Tema ${theme} desconocido, prueba 'light' o 'dark'.`);\r\n return;\r\n }\r\n\r\n console.log(`Tema ${theme} establecido correctamente.`);\r\n },\r\n };\r\n}\r\n\r\nfunction getConfig<LoadType>(\r\n outerBehaveConfig?: IApiaApiRequestConfig<LoadType>,\r\n) {\r\n return merge({}, defaultConfig, outerBehaveConfig, forcedConfig);\r\n}\r\n\r\nfunction makeUrl(\r\n url: string,\r\n queryData: IApiaApiRequestConfig<unknown>['queryData'],\r\n stringifyOptions: IApiaApiRequestConfig<unknown>['stringifyOptions'],\r\n) {\r\n let finalUrl = url;\r\n const questionMarkIndex = finalUrl.indexOf('?');\r\n\r\n if (questionMarkIndex === -1) finalUrl += '?';\r\n else if (questionMarkIndex !== finalUrl.length - 1 && !finalUrl.endsWith('&'))\r\n finalUrl += '&';\r\n let parsedUrl = `${finalUrl}${\r\n queryData ? QueryString.stringify(queryData, stringifyOptions) : ''\r\n }`;\r\n if (parsedUrl.endsWith('&') || parsedUrl.endsWith('?')) {\r\n parsedUrl = parsedUrl.slice(0, parsedUrl.length - 1);\r\n }\r\n return parsedUrl;\r\n}\r\n\r\nconst getURLActionName = (url: string): string => {\r\n const actionIdx = url.match(/action=(\\w+)/)?.[1];\r\n return actionIdx ?? 'noAction';\r\n};\r\n\r\nclass ApiaActionsClass extends EventEmitter<{\r\n action: TModify<TApiaAction, { param: string[] }>;\r\n}> {}\r\n\r\nexport const ApiaActions = new ApiaActionsClass();\r\n\r\nfunction getColor(\r\n color: keyof TColors,\r\n colors: TColors = defaultConfig.colors ?? {\r\n exception: 'red',\r\n alert: 'yellow',\r\n message: 'green',\r\n },\r\n) {\r\n return colors[color] as string;\r\n}\r\n\r\nconst handleWrongResponse = (error: Error) => {\r\n let errorMessage: string;\r\n if (typeof error !== 'string') {\r\n if (error.message) errorMessage = error.message;\r\n else errorMessage = error.toString();\r\n } else errorMessage = error;\r\n\r\n notify({\r\n type: 'danger',\r\n message: error.message.replaceAll('AxiosError', 'Error'),\r\n });\r\n console.log('%c ', 'font-size:10vh');\r\n console.log('%cError in ApiaApi', 'color:red;font-size:2em;font-weight:bold');\r\n console.log(`red/${errorMessage}`, { error });\r\n console.log('%c ', 'font-size:10vh');\r\n};\r\n\r\nexport function isJsonResponse(response: AxiosResponse<unknown>) {\r\n return (response.headers['content-type'] as string).match('application/json');\r\n}\r\nexport function isXmlResponse(response: AxiosResponse<unknown>) {\r\n return (response.headers['content-type'] as string).match(\r\n /(?:application|text)?\\/xml/,\r\n );\r\n}\r\nexport function isHtmlResponse(response: AxiosResponse<unknown>) {\r\n return (response.headers['content-type'] as string).match(\r\n /(?:application|text)?\\/html/,\r\n );\r\n}\r\n\r\nfunction handleActions(actions: TApiaSystemMessageObj['actions']) {\r\n if (actions) {\r\n if (getConfig().debug)\r\n console.log(\r\n '%cHandled actions: ',\r\n `color: ${getConfig().colors?.message ?? 'green'}`,\r\n { actions },\r\n );\r\n const actionsArray = arrayOrArray(actions.action);\r\n actionsArray.forEach((action) => {\r\n ApiaActions.emit('action', {\r\n ...action,\r\n param: arrayOrArray(action.param),\r\n });\r\n });\r\n }\r\n}\r\nfunction handleOnClose({\r\n exceptions,\r\n onClose,\r\n sysExceptions,\r\n sysMessages,\r\n}: TModify<TNotificationMessage, { onClose: string }>) {\r\n try {\r\n import(\r\n /* webpackChunkName: \"api-[request]\" */ `/api/onClose/${onClose}.ts`\r\n ).then(\r\n (func: { default: () => void }) => {\r\n if (exceptions || sysExceptions || sysMessages) {\r\n const notificationsObject = getNotificationMessageObj({\r\n exceptions,\r\n onClose,\r\n sysExceptions,\r\n sysMessages,\r\n });\r\n if (notificationsObject)\r\n notificationsObject.forEach((notification) => {\r\n notify({\r\n ...notification,\r\n onClose: func.default,\r\n });\r\n });\r\n else func.default();\r\n } else func.default();\r\n },\r\n (e) => {\r\n notify({\r\n message: `onClose action not found: ${String(e)}`,\r\n type: 'danger',\r\n });\r\n },\r\n );\r\n } catch (e) {\r\n parseMessages({ exceptions, sysExceptions, sysMessages });\r\n console.error('Error while handling onClose');\r\n console.error(e);\r\n }\r\n}\r\n\r\nexport function parseMessages(response: Record<string, unknown>) {\r\n if (!response) return;\r\n const { exceptions, sysMessages, sysExceptions } = response;\r\n if (exceptions || sysExceptions || sysMessages) {\r\n try {\r\n dispatchNotifications({\r\n exceptions,\r\n sysExceptions,\r\n sysMessages,\r\n } as TNotificationMessage);\r\n } catch (e: unknown) {\r\n handleWrongResponse(new Error(e as string));\r\n }\r\n }\r\n}\r\n\r\nexport const parseSuccessfulResponse = async <\r\n LoadType extends Record<string, unknown>,\r\n>(\r\n response: AxiosResponse<string>,\r\n currentUrl: string,\r\n outerBehaveConfig: IApiaApiRequestConfig<LoadType> = defaultConfig,\r\n) => {\r\n const behaveConfig = getConfig(outerBehaveConfig);\r\n\r\n let parsedObj: TApiaSystemMessageObj<LoadType> | void | undefined = undefined;\r\n if (isJsonResponse(response)) {\r\n if (typeof response.data === 'string')\r\n parsedObj = JSON.parse(\r\n response.data.trim(),\r\n ) as TApiaSystemMessageObj<LoadType> | void;\r\n else if (typeof response.data === 'object' && response.data)\r\n parsedObj = response.data;\r\n } else if (isXmlResponse(response)) {\r\n parsedObj = await parseXmlAsync<LoadType>(response.data).catch(\r\n (e: unknown) => {\r\n handleWrongResponse(new Error(e as string));\r\n },\r\n );\r\n } else if (isHtmlResponse(response)) {\r\n console.error(\r\n 'El contenido devuelto es Html, no se esperaba esa respuesta',\r\n );\r\n return null;\r\n }\r\n\r\n if (behaveConfig.validateResponse) {\r\n const validateResult = await behaveConfig.validateResponse({\r\n ...response,\r\n data: parsedObj?.load ?? parsedObj,\r\n });\r\n if (typeof validateResult === 'string')\r\n throw new Error(`Validation error: ${validateResult}`);\r\n else if (!validateResult) {\r\n throw new Error('Error');\r\n }\r\n }\r\n\r\n if (parsedObj) {\r\n const {\r\n actions,\r\n onClose,\r\n exceptions,\r\n sysExceptions,\r\n sysMessages,\r\n load,\r\n ...rest\r\n } = parsedObj; // Session handling\r\n if (rest.code === '-1' && exceptions) {\r\n session.invalidate();\r\n return null;\r\n }\r\n\r\n if (exceptions && behaveConfig.debug) {\r\n console.log(\r\n `%cparseSuccessfulResponse`,\r\n `color: ${getColor('exception', behaveConfig.colors)}`,\r\n {\r\n exceptions,\r\n },\r\n );\r\n }\r\n if (sysExceptions && behaveConfig.debug) {\r\n console.log(\r\n `%cparseSuccessfulResponse`,\r\n `color: ${getColor('exception', behaveConfig.colors)}`,\r\n {\r\n sysExceptions,\r\n },\r\n );\r\n }\r\n if (sysMessages && behaveConfig.debug) {\r\n console.log(\r\n `%cparseSuccessfulResponse`,\r\n `color: ${getColor('alert', behaveConfig.colors)}`,\r\n {\r\n sysMessages,\r\n },\r\n );\r\n }\r\n\r\n handleActions(actions);\r\n\r\n if (behaveConfig.handleLoad && onClose)\r\n handleOnClose({\r\n exceptions,\r\n onClose,\r\n sysExceptions,\r\n sysMessages,\r\n });\r\n else parseMessages({ exceptions, sysExceptions, sysMessages });\r\n\r\n if (load) {\r\n if (behaveConfig.handleLoad) {\r\n console.log(\r\n `%chandleLoad`,\r\n `color: ${getColor('message', behaveConfig.colors)}`,\r\n {\r\n load,\r\n },\r\n );\r\n if (\r\n !handle(load, currentUrl, {\r\n methodsPath: outerBehaveConfig.methodsPath,\r\n modalConfiguration: {\r\n ...behaveConfig.modalConfiguration,\r\n onClose: () => {\r\n if (onClose)\r\n handleOnClose({\r\n exceptions,\r\n onClose,\r\n sysExceptions,\r\n sysMessages,\r\n });\r\n if (behaveConfig.modalConfiguration?.onClose)\r\n behaveConfig.modalConfiguration?.onClose();\r\n },\r\n },\r\n })\r\n ) {\r\n console.log(\r\n `%cunhandledLoad -> There is no handler defined`,\r\n `color: ${getColor('exception', behaveConfig.colors)}`,\r\n {\r\n load,\r\n },\r\n );\r\n }\r\n }\r\n return { ...load, sysMessages, exceptions, sysExceptions };\r\n }\r\n return { ...(rest as LoadType), sysMessages, exceptions, sysExceptions };\r\n }\r\n\r\n return null;\r\n};\r\n\r\nexport type TApiaApiAxiosResponse<LoadType> = AxiosResponse<LoadType | null> & {\r\n hasError: boolean;\r\n hasMessages: boolean;\r\n};\r\n\r\nasync function handleResponse<LoadType extends Record<string, unknown>>(\r\n result: AxiosResponse<string> | void,\r\n currentUrl: string,\r\n outerBehaveConfig: IApiaApiRequestConfig<LoadType> = defaultConfig,\r\n): Promise<TApiaApiAxiosResponse<LoadType> | null> {\r\n const behaveConfig = getConfig(outerBehaveConfig);\r\n try {\r\n if (!result || result.data === undefined) {\r\n if (behaveConfig.debug)\r\n console.log(\r\n `%cApiaApi wrong response`,\r\n `color: ${getColor('alert', behaveConfig.colors)}`,\r\n );\r\n } else {\r\n const parsedResponse = await parseSuccessfulResponse<LoadType>(\r\n result,\r\n currentUrl,\r\n behaveConfig,\r\n );\r\n\r\n const action = getURLActionName(currentUrl);\r\n if (behaveConfig.debug)\r\n console.log(\r\n `%c <- ApiaApi.${result.config.method ?? ''} ${action} `,\r\n `color: ${getColor('message', behaveConfig.colors)}`,\r\n {\r\n data: parsedResponse,\r\n },\r\n );\r\n\r\n return {\r\n ...result,\r\n data: parsedResponse,\r\n hasError:\r\n !!parsedResponse?.exceptions || !!parsedResponse?.sysExceptions,\r\n hasMessages: !!parsedResponse?.sysMessages,\r\n };\r\n }\r\n } catch (e: unknown) {\r\n handleWrongResponse(new Error(e as string));\r\n return null;\r\n }\r\n\r\n return null;\r\n}\r\n\r\n/**\r\n* IMPORTANT!! The ApiaApi is programmed under the slogan that\r\n * **should never throw an exception**. **Errors** coming from\r\n * connectivity or exceptions on the server **will be handled\r\n * automatically** by ApiaApi, using the notification system\r\n * of the application. It is possible to determine in what context they should\r\n * be thrown those exceptions (global, main, modal) using the\r\n * alertsCategory configuration properties **(see errorsHandling.md)**.\r\n *\r\n * @param url String, the url you want to call\r\n * @param config interface IApiaApiRequestConfig<DataType>;\r\n *\r\n * @throws Nothing\r\n *\r\n * @example\r\n *\r\n * ApiaApi.post<ResponseType>('url...', {\r\n axiosConfig?: AxiosRequestConfig;\r\n\r\n // Configuración de postData\r\n postData? unknown;\r\n postDataTreatement?: 'stringify' | undefined;\r\n\r\n // Configuración de queryString\r\n queryData?: string | Record<string, unknown>;\r\n stringifyOptions?: QueryString.IStringifyOptions;\r\n\r\n // Response validator,\r\n // If it returns true, everything continues correctly\r\n // If it returns false, the ApiaApi throws a standard error.\r\n // If it returns string, ApiaApi throws the error returned in the string.\r\n validateResponse?: (\r\n response: AxiosResponse<DataType | null>,\r\n ) => boolean | string;\r\n\r\n // Configuración de alertas\r\n alertsImportance?: TAlertImportance;\r\n\r\n // Configuración de ApiaApiHandler, falta documentar\r\n handleLoad?: boolean;\r\n eventsHandler?: IEventsHandler;\r\n\r\n // other configuration\r\n colors?: TColors;\r\n debug?: boolean;\r\n }\r\n * @returns The type of the return value depends on the type passed when calling the function. If there was an error it returns null.\r\n */\r\nasync function post<\r\n LoadType extends Record<string, unknown> = Record<string, unknown>,\r\n DataType = unknown,\r\n>(\r\n url:\r\n | string\r\n | TModify<\r\n IApiaApiRequestConfig<LoadType>,\r\n { postData?: DataType; postDataTreatement?: 'stringify' }\r\n >,\r\n config?: TModify<\r\n IApiaApiRequestConfig<LoadType>,\r\n {\r\n postData?: DataType;\r\n postDataTreatement?: 'stringify';\r\n }\r\n >,\r\n): TApiaApiResult<LoadType>;\r\nasync function post<\r\n LoadType extends Record<string, unknown> = Record<string, unknown>,\r\n DataType = unknown,\r\n>(\r\n config: TModify<\r\n IApiaApiRequestConfig<LoadType>,\r\n {\r\n postData?: DataType;\r\n postDataTreatement?: 'stringify';\r\n }\r\n >,\r\n): TApiaApiResult<LoadType>;\r\nasync function post<\r\n LoadType extends Record<string, unknown> = Record<string, unknown>,\r\n DataType = unknown,\r\n T = unknown,\r\n>(\r\n par1:\r\n | string\r\n | TModify<\r\n IApiaApiRequestConfig<LoadType>,\r\n { postData?: DataType; postDataTreatement?: 'stringify' }\r\n >,\r\n par2?: TModify<\r\n IApiaApiRequestConfig<LoadType>,\r\n { postData?: DataType; postDataTreatement?: 'stringify' }\r\n >,\r\n): TApiaApiResult<LoadType> {\r\n const actualUrl = typeof par1 !== 'string' ? makeApiaUrl() : par1;\r\n\r\n const configParameter = (\r\n typeof par1 === 'string' ? par2 ?? defaultConfig : par1\r\n ) as TModify<\r\n IApiaApiRequestConfig<LoadType>,\r\n { postData?: DataType; postDataTreatement?: 'stringify' }\r\n >;\r\n\r\n const behaveConfig = {\r\n ...getConfig(configParameter),\r\n postData:\r\n configParameter.postDataTreatement === 'stringify'\r\n ? QueryString.stringify(\r\n configParameter.postData,\r\n configParameter.stringifyOptions,\r\n )\r\n : configParameter.postData,\r\n };\r\n\r\n const parsedUrl = makeUrl(\r\n actualUrl,\r\n behaveConfig.queryData,\r\n behaveConfig.stringifyOptions,\r\n );\r\n\r\n if (behaveConfig.debug) {\r\n const queryString = actualUrl.split('&');\r\n const action = getURLActionName(actualUrl);\r\n\r\n console.log(\r\n `%cApiaApi.post ${action}`,\r\n `color: ${getColor('message', behaveConfig.colors)}`,\r\n {\r\n url: parsedUrl,\r\n queryDataInURL: [...queryString],\r\n queryData: behaveConfig.queryData,\r\n formData: behaveConfig.postData,\r\n stringifyOptiopns: behaveConfig.stringifyOptions,\r\n },\r\n );\r\n }\r\n\r\n const response = await axios\r\n .post<\r\n T,\r\n AxiosResponse<string>,\r\n DataType | string\r\n >(parsedUrl, behaveConfig.postData, behaveConfig.axiosConfig)\r\n .catch((e: unknown) => {\r\n handleWrongResponse(new Error(e as string));\r\n });\r\n\r\n if (response) {\r\n const result = handleResponse<LoadType>(response, actualUrl, behaveConfig);\r\n return result;\r\n }\r\n return null;\r\n}\r\n\r\n/**\r\n * IMPORTANTE!! El ApiaApi está programado bajo la consigna de que\r\n * **no debe tirar núnca una excepción**. **Los errores** provenientes\r\n * de la conectividad o de excepciones en el servidor **serán manejados\r\n * automáticamente** por el ApiaApi utilizando el sistema de notificaciones\r\n * de la aplicación. Es posible determinar en qué contexto deben\r\n * ser lanzadas esas excepciones (global, main, modal) utilizando las\r\n * propiedades de configuración alertsCategory **(ver errorsHandling.md)**.\r\n *\r\n * @param url String, el url al que se desea llamar\r\n * @param config interface IApiaApiRequestConfig<DataType>;\r\n *\r\n * @throws Nothing\r\n *\r\n * @example\r\n *\r\n * ApiaApi.get<TipoDeRespuesta>('url...', {\r\n axiosConfig?: AxiosRequestConfig;\r\n\r\n // Configuración de queryString\r\n queryData?: string | Record<string, unknown>;\r\n stringifyOptions?: QueryString.IStringifyOptions;\r\n\r\n // Validador de respuesta,\r\n // Si devuelve true, todo sigue correctamente\r\n // Si devuelve false, el ApiaApi tira un error estándar.\r\n // Si devuelve string, el ApiaApi tira el error devuelto en el string.\r\n validateResponse?: (\r\n response: AxiosResponse<DataType | null>,\r\n ) => boolean | string;\r\n\r\n // Configuración de alertas\r\n alertsImportance?: TAlertImportance;\r\n\r\n // Configuración de ApiaApiHandler, falta documentar\r\n handleLoad?: boolean;\r\n eventsHandler?: IEventsHandler;\r\n\r\n // Otra configuración\r\n colors?: TColors;\r\n debug?: boolean;\r\n }\r\n * @returns El tipo del valor devuelto depende del tipo pasado al llamar a la función. Si hubo un error devuelve null\r\n */\r\nasync function get<\r\n LoadType extends Record<string, unknown> = Record<string, unknown>,\r\n>(\r\n url: string | IApiaApiRequestConfig<LoadType>,\r\n config?: IApiaApiRequestConfig<LoadType>,\r\n): TApiaApiResult<LoadType>;\r\nasync function get<\r\n LoadType extends Record<string, unknown> = Record<string, unknown>,\r\n>(config: IApiaApiRequestConfig<LoadType>): TApiaApiResult<LoadType>;\r\nasync function get<\r\n LoadType extends Record<string, unknown> = Record<string, unknown>,\r\n T = unknown,\r\n D = unknown,\r\n>(\r\n par1: string | IApiaApiRequestConfig<LoadType>,\r\n par2?: IApiaApiRequestConfig<LoadType>,\r\n): TApiaApiResult<LoadType> {\r\n const actualUrl = typeof par1 !== 'string' ? makeApiaUrl() : par1;\r\n\r\n const behaveConfig = getConfig<LoadType>(\r\n typeof par1 === 'string' ? par2 ?? defaultConfig : par1,\r\n );\r\n\r\n const parsedUrl = makeUrl(\r\n actualUrl,\r\n behaveConfig.queryData,\r\n behaveConfig.stringifyOptions,\r\n );\r\n\r\n if (behaveConfig.debug)\r\n console.log(\r\n `%cApiaApi.get`,\r\n `color: ${getColor('message', behaveConfig.colors)}`,\r\n {\r\n url: parsedUrl,\r\n },\r\n );\r\n const response = await axios\r\n .get<T, AxiosResponse<string>, D>(parsedUrl, behaveConfig.axiosConfig)\r\n .catch((e: unknown) => {\r\n handleWrongResponse(new Error(e as string));\r\n });\r\n if (response) {\r\n const result = await handleResponse<LoadType>(\r\n response,\r\n actualUrl,\r\n behaveConfig,\r\n );\r\n return result;\r\n }\r\n return null;\r\n}\r\n\r\nconst ApiaApi = {\r\n get,\r\n getConfig,\r\n post,\r\n};\r\n/**\r\n * Creates an url based on the general requirements of Apia.\r\n * If the ajaxUrl property is not passed, it will use the\r\n * window.URL_REQUEST_AJAX. Its use is very simple, just pass the objects you\r\n * want to appear in the query string.\r\n *\r\n * @example makeApiaUrl({\r\n * ajaxUrl: 'the.endpoint.you.want',\r\n * queryString: 'an=existent&query=string',\r\n * action: 'theAction',\r\n * anotherProp: 15\r\n * })\r\n *\r\n * @returns the well formed url, in the example, the response url is:\r\n * /context/the.endpoint.you.want?an=existent&query=string&anotherProp=15&tabId=...&tokenId=...&action=theAction\r\n */\r\nexport function makeApiaUrl(props?: {\r\n action?: string;\r\n ajaxUrl?: string;\r\n queryString?: string;\r\n stringifyOptions?: QueryString.IStringifyOptions;\r\n tabId?: string | number;\r\n preventAsXmlParameter?: boolean;\r\n avoidTabId?: boolean;\r\n [key: string]: unknown;\r\n}) {\r\n let actualQueryData: Record<string, unknown> | unknown = {};\r\n\r\n if (props) {\r\n const {\r\n ajaxUrl,\r\n queryString,\r\n stringifyOptions,\r\n shouldAvoidTabId,\r\n preventAsXmlParameter,\r\n avoidTabId,\r\n tabId: outerTabId,\r\n ...rest\r\n } = props;\r\n actualQueryData = { ...rest };\r\n }\r\n\r\n const queryString = QueryString.stringify(\r\n actualQueryData,\r\n props?.stringifyOptions ?? {\r\n arrayFormat: 'repeat',\r\n encodeValuesOnly: false,\r\n },\r\n );\r\n\r\n let actualAjaxUrl = props?.ajaxUrl ?? window.URL_REQUEST_AJAX;\r\n if (actualAjaxUrl.indexOf('?') === actualAjaxUrl.length - 1) {\r\n actualAjaxUrl = actualAjaxUrl.slice(0, actualAjaxUrl.length - 1);\r\n }\r\n if (!actualAjaxUrl.startsWith('/')) {\r\n actualAjaxUrl = `/${actualAjaxUrl}`;\r\n }\r\n\r\n const match = window.TAB_ID_REQUEST.match(/tokenId=(\\w+)/);\r\n const currentTokenId = (match ?? [])[1];\r\n\r\n let tabId = (\r\n props?.tabId\r\n ? `&tabId=${props.tabId}&tokenId=${currentTokenId}`\r\n : window.TAB_ID_REQUEST\r\n ).slice(1);\r\n if (props?.avoidTabId) {\r\n tabId = '';\r\n }\r\n\r\n let { CONTEXT } = window;\r\n if (CONTEXT?.endsWith('/')) {\r\n CONTEXT += CONTEXT.slice(0, CONTEXT.length - 1);\r\n }\r\n\r\n let timestamp = `timestamp=${Date.now()}&`;\r\n if (\r\n (props?.queryString && props.queryString.includes('timestamp=')) ||\r\n queryString?.includes('timestamp=')\r\n ) {\r\n timestamp = '';\r\n }\r\n\r\n const contextWord = CONTEXT.replaceAll('/', '');\r\n actualAjaxUrl = actualAjaxUrl.match(\r\n new RegExp(`^(?:(?:/?${contextWord})?/)?(.+)$`),\r\n )?.[1] as string;\r\n\r\n return `${\r\n contextWord ? '/' : ''\r\n }${contextWord}/${actualAjaxUrl}?${timestamp}${\r\n !props?.preventAsXmlParameter ? 'asXml=true&' : ''\r\n }${props?.queryString ? `${props.queryString}&` : ''}${\r\n queryString ? `${queryString}&` : ''\r\n }${tabId}`;\r\n}\r\n\r\ndeclare global {\r\n interface Window {\r\n TAB_ID_REQUEST: string;\r\n CONTEXT: string;\r\n URL_REQUEST_AJAX: string;\r\n }\r\n}\r\n\r\nexport default ApiaApi;\r\n"],"names":["queryString"],"mappings":"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"}
@@ -0,0 +1,129 @@
1
+ import { jsx } from '@apia/theme/jsx-runtime';
2
+ import { arrayOrArray } from '@apia/util';
3
+ import uniqueId from 'lodash-es/uniqueId';
4
+ import QueryString from 'qs';
5
+ import React__default from 'react';
6
+ import { Box } from '@apia/theme';
7
+ import { useFormContext, validationsStore, hasSucceedFormValidation } from '@apia/validations';
8
+ import { SimpleButton } from '@apia/components';
9
+ import { getFunction } from '../ApiaApiHandler.js';
10
+ import ApiaApi from '../apiaApi.js';
11
+
12
+ const parseButtons = (buttons) => {
13
+ return buttons.map((currentButton) => ({
14
+ ...currentButton,
15
+ buttonKey: uniqueId(),
16
+ type: ["submitAjax", "submit"].includes(currentButton.type) ? "submit" : "button"
17
+ }));
18
+ };
19
+ const NonMemoizedApiaApiButtonsContainer = (props) => {
20
+ const buttonElements = React__default.useMemo(
21
+ () => arrayOrArray(props.definition?.form.buttons?.button ?? []),
22
+ [props.definition?.form.buttons?.button]
23
+ );
24
+ const buttons = React__default.useMemo(
25
+ () => parseButtons(buttonElements),
26
+ [buttonElements]
27
+ );
28
+ const modalConfiguration = React__default.useMemo(
29
+ () => props.configuration?.modalConfiguration,
30
+ [props.configuration?.modalConfiguration]
31
+ );
32
+ const methodsPath = React__default.useMemo(
33
+ () => props.configuration?.methodsPath,
34
+ [props.configuration?.methodsPath]
35
+ );
36
+ const { name: apiaApiForm } = useFormContext();
37
+ const renderButton = React__default.useCallback(
38
+ (currentButton) => {
39
+ const key = currentButton.buttonKey;
40
+ const className = `handler__${currentButton.type ?? ""}`;
41
+ const onClick = () => {
42
+ void async function submitForm() {
43
+ const validationResult = await validationsStore.validateForm(apiaApiForm);
44
+ if (!hasSucceedFormValidation(validationResult)) {
45
+ return;
46
+ }
47
+ const { submitValues } = validationResult;
48
+ function runButtonMethod() {
49
+ void (async () => {
50
+ if (currentButton.onclick) {
51
+ const actions = currentButton.onclick.split(";");
52
+ for await (const action of actions) {
53
+ const method = await getFunction(action, {
54
+ ...props
55
+ });
56
+ if (method) {
57
+ method({
58
+ currentUrl: props.definition?.form.action ?? "noUrl"
59
+ });
60
+ } else {
61
+ throw new Error(
62
+ `The requested action is not defined: "${props.definition?.form.action ?? ""}"`
63
+ );
64
+ }
65
+ }
66
+ }
67
+ })();
68
+ }
69
+ if (props?.definition && currentButton.type === "submit") {
70
+ const formData = new FormData();
71
+ Object.entries(submitValues).forEach(([name, value]) => {
72
+ formData.append(name, value ?? "");
73
+ });
74
+ const hasContext = props?.definition.form.action.match(
75
+ new RegExp(`^${window.CONTEXT}/`)
76
+ );
77
+ const url = `${hasContext ? "" : window.CONTEXT}${!props?.definition.form.action.startsWith("/") ? "/" : ""}${props?.definition.form.action}`;
78
+ props.setState((current) => ({
79
+ ...current,
80
+ isLoading: true
81
+ }));
82
+ void ApiaApi.post(url, {
83
+ postData: props.state.isMultipart ? formData : QueryString.stringify(
84
+ [...formData.entries(), ["isAjax", true]].reduce((accumulated, [name, value]) => {
85
+ const retValue = { ...accumulated };
86
+ retValue[name.toString()] = value.toString();
87
+ return retValue;
88
+ }, {})
89
+ ),
90
+ handleLoad: true,
91
+ notificationsCategory: "apiaApiHandler",
92
+ modalConfiguration,
93
+ methodsPath
94
+ }).finally(() => {
95
+ runButtonMethod();
96
+ if (props?.definition?.form.closeOnSubmit) {
97
+ props.close();
98
+ }
99
+ });
100
+ } else {
101
+ runButtonMethod();
102
+ }
103
+ }();
104
+ };
105
+ return /* @__PURE__ */ jsx(
106
+ SimpleButton,
107
+ {
108
+ className,
109
+ disabled: props.state.disabled,
110
+ id: currentButton.id || currentButton.text,
111
+ isLoading: props.state.isLoading,
112
+ title: currentButton.text,
113
+ type: currentButton.type,
114
+ onClick,
115
+ children: currentButton.text
116
+ },
117
+ key
118
+ );
119
+ },
120
+ [apiaApiForm, methodsPath, modalConfiguration, props]
121
+ );
122
+ return /* @__PURE__ */ jsx(Box, { className: "handler__form__buttons", children: buttons.map((currentButton) => renderButton(currentButton)) });
123
+ };
124
+ const ApiaApiButtonsContainer = React__default.memo(
125
+ NonMemoizedApiaApiButtonsContainer
126
+ );
127
+
128
+ export { ApiaApiButtonsContainer };
129
+ //# sourceMappingURL=ApiaApiButtonsContainer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApiaApiButtonsContainer.js","sources":["../../src/buttons/ApiaApiButtonsContainer.tsx"],"sourcesContent":["import { arrayOrArray, TApiaFormButton, TApiaLoad } from '@apia/util';\r\nimport uniqueId from 'lodash-es/uniqueId';\r\nimport QueryString from 'qs';\r\nimport React from 'react';\r\nimport { Box } from '@apia/theme';\r\nimport {\r\n hasSucceedFormValidation,\r\n useFormContext,\r\n validationsStore,\r\n} from '@apia/validations';\r\nimport { ISimpleButton, SimpleButton } from '@apia/components';\r\nimport { getFunction, TApiaApiMethodHandler } from '../ApiaApiHandler';\r\nimport ApiaApi from '../apiaApi';\r\n\r\ntype TApiaApiButtonsContainer = TApiaApiMethodHandler & {\r\n definition?: TApiaLoad | undefined;\r\n};\r\n\r\ntype TApiaApiButton = Omit<TApiaFormButton, 'type'> &\r\n Pick<ISimpleButton, 'type'> & {\r\n buttonKey: string;\r\n };\r\n\r\nconst parseButtons = (buttons: TApiaFormButton[]): TApiaApiButton[] => {\r\n return buttons.map((currentButton) => ({\r\n ...currentButton,\r\n buttonKey: uniqueId(),\r\n type: ['submitAjax', 'submit'].includes(currentButton.type)\r\n ? 'submit'\r\n : 'button',\r\n }));\r\n};\r\n\r\nconst NonMemoizedApiaApiButtonsContainer = (\r\n props: TApiaApiButtonsContainer,\r\n) => {\r\n const buttonElements = React.useMemo(\r\n () => arrayOrArray(props.definition?.form.buttons?.button ?? []),\r\n [props.definition?.form.buttons?.button],\r\n );\r\n const buttons = React.useMemo(\r\n () => parseButtons(buttonElements),\r\n [buttonElements],\r\n );\r\n const modalConfiguration = React.useMemo(\r\n () => props.configuration?.modalConfiguration,\r\n [props.configuration?.modalConfiguration],\r\n );\r\n const methodsPath = React.useMemo(\r\n () => props.configuration?.methodsPath,\r\n [props.configuration?.methodsPath],\r\n );\r\n const { name: apiaApiForm } = useFormContext();\r\n\r\n const renderButton = React.useCallback(\r\n (currentButton: TApiaApiButton) => {\r\n const key = currentButton.buttonKey;\r\n const className = `handler__${currentButton.type ?? ''}`;\r\n const onClick = () => {\r\n void (async function submitForm() {\r\n const validationResult =\r\n await validationsStore.validateForm(apiaApiForm);\r\n if (!hasSucceedFormValidation(validationResult)) {\r\n return;\r\n }\r\n const { submitValues } = validationResult;\r\n\r\n function runButtonMethod() {\r\n void (async () => {\r\n if (currentButton.onclick) {\r\n const actions = currentButton.onclick.split(';');\r\n // eslint-disable-next-line no-restricted-syntax\r\n for await (const action of actions) {\r\n const method = await getFunction(action, {\r\n ...props,\r\n });\r\n\r\n if (method) {\r\n method({\r\n currentUrl: props.definition?.form.action ?? 'noUrl',\r\n });\r\n } else {\r\n throw new Error(\r\n `The requested action is not defined: \"${\r\n props.definition?.form.action ?? ''\r\n }\"`,\r\n );\r\n }\r\n }\r\n }\r\n })();\r\n }\r\n\r\n if (props?.definition && currentButton.type === 'submit') {\r\n const formData = new FormData();\r\n Object.entries(submitValues).forEach(([name, value]) => {\r\n formData.append(name, (value as string | Blob) ?? '');\r\n });\r\n\r\n const hasContext = props?.definition.form.action.match(\r\n new RegExp(`^${window.CONTEXT}/`),\r\n );\r\n const url = `${hasContext ? '' : window.CONTEXT}${\r\n !props?.definition.form.action.startsWith('/') ? '/' : ''\r\n }${props?.definition.form.action}`;\r\n\r\n props.setState((current) => ({\r\n ...current,\r\n isLoading: true,\r\n }));\r\n\r\n void ApiaApi.post(url, {\r\n postData: props.state.isMultipart\r\n ? formData\r\n : QueryString.stringify(\r\n [...formData.entries(), ['isAjax', true]].reduce<\r\n Record<string, string>\r\n >((accumulated, [name, value]) => {\r\n const retValue = { ...accumulated };\r\n retValue[name.toString()] = value.toString();\r\n return retValue;\r\n }, {}),\r\n ),\r\n handleLoad: true,\r\n notificationsCategory: 'apiaApiHandler',\r\n modalConfiguration,\r\n methodsPath,\r\n }).finally(() => {\r\n runButtonMethod();\r\n if (props?.definition?.form.closeOnSubmit) {\r\n props.close();\r\n }\r\n });\r\n } else {\r\n runButtonMethod();\r\n }\r\n })();\r\n };\r\n return (\r\n <SimpleButton\r\n className={className}\r\n disabled={props.state.disabled}\r\n id={currentButton.id || currentButton.text}\r\n isLoading={props.state.isLoading}\r\n key={key}\r\n title={currentButton.text}\r\n type={currentButton.type}\r\n onClick={onClick}\r\n >\r\n {currentButton.text}\r\n </SimpleButton>\r\n );\r\n },\r\n [apiaApiForm, methodsPath, modalConfiguration, props],\r\n );\r\n\r\n return (\r\n <Box className=\"handler__form__buttons\">\r\n {buttons.map((currentButton) => renderButton(currentButton))}\r\n </Box>\r\n );\r\n};\r\n\r\nexport const ApiaApiButtonsContainer = React.memo(\r\n NonMemoizedApiaApiButtonsContainer,\r\n);\r\n"],"names":["React"],"mappings":"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"}
@@ -0,0 +1,39 @@
1
+ import { jsx } from '@apia/theme/jsx-runtime';
2
+ import { classToValidate, Checkbox } from '@apia/validations';
3
+ import React__default from 'react';
4
+
5
+ const ApiaApiCheckbox = (props) => {
6
+ const element = React__default.useMemo(() => props.element, [props.element]);
7
+ const className = React__default.useMemo(
8
+ () => element.class ? `handler__checkbox ${element.class}` : "handler__checkbox",
9
+ [element.class]
10
+ );
11
+ const validationRules = React__default.useMemo(
12
+ () => ({
13
+ required: element.mandatory,
14
+ ...classToValidate(element.class)
15
+ }),
16
+ [element.class, element.mandatory]
17
+ );
18
+ const submitValueParser = React__default.useCallback(
19
+ (value) => value === "on" || value === true,
20
+ []
21
+ );
22
+ return /* @__PURE__ */ jsx(
23
+ Checkbox,
24
+ {
25
+ className,
26
+ name: element.id || element.name,
27
+ label: element.text,
28
+ title: element.title || element.text,
29
+ initialValue: String(element.selected) === "true",
30
+ disabled: element.readonly || element.disabled,
31
+ validationRules,
32
+ onChange: element.onChange,
33
+ submitValueParser
34
+ }
35
+ );
36
+ };
37
+
38
+ export { ApiaApiCheckbox };
39
+ //# sourceMappingURL=ApiaApiCheckbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApiaApiCheckbox.js","sources":["../../src/fields/ApiaApiCheckbox.tsx"],"sourcesContent":["import { classToValidate, Checkbox } from '@apia/validations';\r\nimport React from 'react';\r\nimport { TApiaApiField } from '../ApiaApiHandler';\r\n\r\nexport const ApiaApiCheckbox = (props: TApiaApiField) => {\r\n const element = React.useMemo(() => props.element, [props.element]);\r\n const className = React.useMemo(\r\n () =>\r\n element.class\r\n ? `handler__checkbox ${element.class}`\r\n : 'handler__checkbox',\r\n [element.class],\r\n );\r\n const validationRules = React.useMemo(\r\n () => ({\r\n required: element.mandatory,\r\n ...classToValidate(element.class),\r\n }),\r\n [element.class, element.mandatory],\r\n );\r\n const submitValueParser = React.useCallback(\r\n (value: boolean | string) => value === 'on' || value === true,\r\n [],\r\n );\r\n return (\r\n <Checkbox\r\n className={className}\r\n name={element.id || element.name}\r\n label={element.text}\r\n title={element.title || element.text}\r\n initialValue={String(element.selected) === 'true'}\r\n disabled={element.readonly || element.disabled}\r\n validationRules={validationRules}\r\n onChange={element.onChange}\r\n submitValueParser={submitValueParser}\r\n />\r\n );\r\n};\r\n"],"names":["React"],"mappings":";;;;AAIa,MAAA,eAAA,GAAkB,CAAC,KAAyB,KAAA;AACvD,EAAM,MAAA,OAAA,GAAUA,eAAM,OAAQ,CAAA,MAAM,MAAM,OAAS,EAAA,CAAC,KAAM,CAAA,OAAO,CAAC,CAAA,CAAA;AAClE,EAAA,MAAM,YAAYA,cAAM,CAAA,OAAA;AAAA,IACtB,MACE,OAAQ,CAAA,KAAA,GACJ,CAAqB,kBAAA,EAAA,OAAA,CAAQ,KAAK,CAClC,CAAA,GAAA,mBAAA;AAAA,IACN,CAAC,QAAQ,KAAK,CAAA;AAAA,GAChB,CAAA;AACA,EAAA,MAAM,kBAAkBA,cAAM,CAAA,OAAA;AAAA,IAC5B,OAAO;AAAA,MACL,UAAU,OAAQ,CAAA,SAAA;AAAA,MAClB,GAAG,eAAgB,CAAA,OAAA,CAAQ,KAAK,CAAA;AAAA,KAClC,CAAA;AAAA,IACA,CAAC,OAAA,CAAQ,KAAO,EAAA,OAAA,CAAQ,SAAS,CAAA;AAAA,GACnC,CAAA;AACA,EAAA,MAAM,oBAAoBA,cAAM,CAAA,WAAA;AAAA,IAC9B,CAAC,KAAA,KAA4B,KAAU,KAAA,IAAA,IAAQ,KAAU,KAAA,IAAA;AAAA,IACzD,EAAC;AAAA,GACH,CAAA;AACA,EACE,uBAAA,GAAA;AAAA,IAAC,QAAA;AAAA,IAAA;AAAA,MACC,SAAA;AAAA,MACA,IAAA,EAAM,OAAQ,CAAA,EAAA,IAAM,OAAQ,CAAA,IAAA;AAAA,MAC5B,OAAO,OAAQ,CAAA,IAAA;AAAA,MACf,KAAA,EAAO,OAAQ,CAAA,KAAA,IAAS,OAAQ,CAAA,IAAA;AAAA,MAChC,YAAc,EAAA,MAAA,CAAO,OAAQ,CAAA,QAAQ,CAAM,KAAA,MAAA;AAAA,MAC3C,QAAA,EAAU,OAAQ,CAAA,QAAA,IAAY,OAAQ,CAAA,QAAA;AAAA,MACtC,eAAA;AAAA,MACA,UAAU,OAAQ,CAAA,QAAA;AAAA,MAClB,iBAAA;AAAA,KAAA;AAAA,GACF,CAAA;AAEJ;;;;"}
@@ -0,0 +1,213 @@
1
+ import { jsx, jsxs } from '@apia/theme/jsx-runtime';
2
+ import { Box, getVariant } from '@apia/theme';
3
+ import { arrayOrArray } from '@apia/util';
4
+ import uniqueId from 'lodash-es/uniqueId';
5
+ import React__default from 'react';
6
+ import { getFunction } from '../ApiaApiHandler.js';
7
+ import { ApiaApiCheckbox } from './ApiaApiCheckbox.js';
8
+ import { ApiaApiFileInput } from './ApiaApiFileInput.js';
9
+ import { ApiaApiInput } from './ApiaApiInput.js';
10
+ import { ApiaApiRadio } from './ApiaApiRadio.js';
11
+ import { ApiaApiSelect } from './ApiaApiSelect.js';
12
+ import { ApiaApiTextArea } from './ApiaApiTextArea.js';
13
+
14
+ const parseApiaApiSections = (elements) => {
15
+ const removeEndingSpacers = (sectionElements) => {
16
+ if (sectionElements.length > 1) {
17
+ for (let i = sectionElements.length - 1; i >= 0; i--) {
18
+ if (sectionElements[i].type === "empty") {
19
+ sectionElements.pop();
20
+ } else {
21
+ return sectionElements;
22
+ }
23
+ }
24
+ }
25
+ return sectionElements;
26
+ };
27
+ const sectionIndexes = [];
28
+ if (elements[0]?.type !== "2columnTitle") {
29
+ sectionIndexes.push(-1);
30
+ }
31
+ elements.forEach((element, index) => {
32
+ if (element.type === "2columnTitle") {
33
+ sectionIndexes.push(index);
34
+ }
35
+ });
36
+ const sections = [];
37
+ sectionIndexes.forEach((sectionIndex, arrayIndex) => {
38
+ const start = sectionIndex + 1 < elements.length ? sectionIndex + 1 : elements.length - 1;
39
+ const end = arrayIndex + 1 < sectionIndexes.length ? sectionIndexes[arrayIndex + 1] : void 0;
40
+ sections.push({
41
+ sectionId: `ApiaApiSection_${arrayIndex}`,
42
+ sectionHeader: sectionIndex !== -1 ? {
43
+ ...elements[sectionIndex],
44
+ sectionElementId: `sectionHeader_${arrayIndex}`
45
+ } : void 0,
46
+ sectionElements: removeEndingSpacers(elements.slice(start, end)).map(
47
+ (currentElement) => ({
48
+ ...currentElement,
49
+ sectionElementId: `sectionElement_${currentElement.id || currentElement.name || uniqueId()}`
50
+ })
51
+ )
52
+ });
53
+ });
54
+ return sections;
55
+ };
56
+ const NonMemoizedApiaApiFieldsContainer = (props) => {
57
+ const elements = React__default.useMemo(
58
+ () => arrayOrArray(props?.definition?.form.elements?.element ?? []),
59
+ [props?.definition?.form.elements?.element]
60
+ );
61
+ const sections = React__default.useMemo(
62
+ () => parseApiaApiSections(elements),
63
+ [elements]
64
+ );
65
+ const renderSectionContent = React__default.useCallback(
66
+ (sectionId, sectionElements) => {
67
+ const isVisible = sectionElements.findIndex((element) => element.type !== "hidden") !== -1;
68
+ return /* @__PURE__ */ jsx(
69
+ Box,
70
+ {
71
+ className: isVisible ? "handler__form__elements__section__content" : `handler__form__elements__section__content handler__hidden`,
72
+ children: sectionElements.map((current) => {
73
+ const element = {
74
+ ...current,
75
+ onChange() {
76
+ getFunction(current.onChange, props).then((onChangeMethod) => {
77
+ if (onChangeMethod) {
78
+ onChangeMethod();
79
+ }
80
+ }).catch(console.error);
81
+ }
82
+ };
83
+ switch (element.type) {
84
+ case "table": {
85
+ const data = JSON.parse(element.text);
86
+ return /* @__PURE__ */ jsx(
87
+ Box,
88
+ {
89
+ ...getVariant("layout.common.tables.information"),
90
+ children: /* @__PURE__ */ jsxs("table", { sx: { width: "100%" }, children: [
91
+ /* @__PURE__ */ jsx("thead", { children: /* @__PURE__ */ jsx("tr", { children: data.columns.map((column) => {
92
+ return /* @__PURE__ */ jsx("th", { children: column }, column);
93
+ }) }) }),
94
+ /* @__PURE__ */ jsx("tbody", { children: data.rows.map((row) => {
95
+ return /* @__PURE__ */ jsx("tr", { children: row.cells.map((cell, i) => {
96
+ return /* @__PURE__ */ jsx("td", { children: cell }, `${cell}_${data.columns[i]}`);
97
+ }) }, row.cells.join("-"));
98
+ }) })
99
+ ] })
100
+ },
101
+ element.sectionElementId
102
+ );
103
+ }
104
+ case "2columnSubTitle":
105
+ return /* @__PURE__ */ jsx(
106
+ Box,
107
+ {
108
+ className: element.class,
109
+ as: "h6",
110
+ children: element.value || element.text
111
+ },
112
+ element.sectionElementId
113
+ );
114
+ case "2column":
115
+ return /* @__PURE__ */ jsx(
116
+ Box,
117
+ {
118
+ dangerouslySetInnerHTML: {
119
+ __html: element.value || element.text
120
+ },
121
+ className: element.class
122
+ },
123
+ element.sectionElementId
124
+ );
125
+ case "checkbox":
126
+ return /* @__PURE__ */ jsx(
127
+ ApiaApiCheckbox,
128
+ {
129
+ ...props,
130
+ element
131
+ },
132
+ element.sectionElementId
133
+ );
134
+ case "file":
135
+ return /* @__PURE__ */ jsx(
136
+ ApiaApiFileInput,
137
+ {
138
+ ...props,
139
+ element
140
+ },
141
+ element.sectionElementId
142
+ );
143
+ case "hidden":
144
+ case "password":
145
+ case "text":
146
+ return /* @__PURE__ */ jsx(
147
+ ApiaApiInput,
148
+ {
149
+ ...props,
150
+ element
151
+ },
152
+ element.sectionElementId
153
+ );
154
+ case "select":
155
+ return /* @__PURE__ */ jsx(
156
+ ApiaApiSelect,
157
+ {
158
+ ...props,
159
+ element
160
+ },
161
+ element.sectionElementId
162
+ );
163
+ case "radio":
164
+ return /* @__PURE__ */ jsx(
165
+ ApiaApiRadio,
166
+ {
167
+ ...props,
168
+ element
169
+ },
170
+ element.sectionElementId
171
+ );
172
+ case "textarea":
173
+ return /* @__PURE__ */ jsx(
174
+ ApiaApiTextArea,
175
+ {
176
+ ...props,
177
+ element
178
+ },
179
+ element.sectionElementId
180
+ );
181
+ case "empty":
182
+ return /* @__PURE__ */ jsx(Box, { className: "spacer" }, element.sectionElementId);
183
+ default:
184
+ console.warn(
185
+ `Unhandled element type: ${element.type}`,
186
+ element
187
+ );
188
+ return null;
189
+ }
190
+ })
191
+ },
192
+ sectionId
193
+ );
194
+ },
195
+ [props]
196
+ );
197
+ return /* @__PURE__ */ jsx(Box, { className: "handler__form__elements", children: sections.map((section) => {
198
+ if (section.sectionHeader) {
199
+ return renderSectionContent(
200
+ section.sectionId,
201
+ section.sectionElements
202
+ );
203
+ }
204
+ return renderSectionContent(section.sectionId, section.sectionElements);
205
+ }) });
206
+ };
207
+ const ApiaApiFieldsContainer = React__default.memo(
208
+ NonMemoizedApiaApiFieldsContainer
209
+ );
210
+ ApiaApiFieldsContainer.displayName = "ApiaApiFieldsContainer";
211
+
212
+ export { ApiaApiFieldsContainer };
213
+ //# sourceMappingURL=ApiaApiFieldsContainer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApiaApiFieldsContainer.js","sources":["../../src/fields/ApiaApiFieldsContainer.tsx"],"sourcesContent":["import { getVariant } from '@apia/theme';\r\nimport { arrayOrArray, TApiaFormElement, TApiaLoad } from '@apia/util';\r\nimport uniqueId from 'lodash-es/uniqueId';\r\nimport React from 'react';\r\nimport { Box } from '@apia/theme';\r\nimport { getFunction, TApiaApiMethodHandler } from '../ApiaApiHandler';\r\nimport { TModalTable } from '../types';\r\nimport { ApiaApiCheckbox } from './ApiaApiCheckbox';\r\nimport { ApiaApiFileInput } from './ApiaApiFileInput';\r\nimport { ApiaApiInput } from './ApiaApiInput';\r\nimport { ApiaApiRadio } from './ApiaApiRadio';\r\nimport { ApiaApiSelect } from './ApiaApiSelect';\r\nimport { ApiaApiTextArea } from './ApiaApiTextArea';\r\n\r\ntype TApiaApiFieldsContainer = TApiaApiMethodHandler & {\r\n definition?: TApiaLoad | undefined;\r\n};\r\n\r\ntype TApiaApiSectionElement = TApiaFormElement & {\r\n sectionElementId: string;\r\n};\r\n\r\ntype TApiaApiSection = {\r\n sectionId: string;\r\n sectionHeader?: TApiaApiSectionElement;\r\n sectionElements: TApiaApiSectionElement[];\r\n};\r\n\r\nconst parseApiaApiSections = (elements: TApiaFormElement[]) => {\r\n const removeEndingSpacers = (\r\n sectionElements: TApiaFormElement[],\r\n ): TApiaFormElement[] => {\r\n if (sectionElements.length > 1) {\r\n for (let i = sectionElements.length - 1; i >= 0; i--) {\r\n if (sectionElements[i].type === 'empty') {\r\n sectionElements.pop();\r\n } else {\r\n return sectionElements;\r\n }\r\n }\r\n }\r\n return sectionElements;\r\n };\r\n const sectionIndexes: number[] = [];\r\n if (elements[0]?.type !== '2columnTitle') {\r\n sectionIndexes.push(-1);\r\n }\r\n elements.forEach((element, index) => {\r\n if (element.type === '2columnTitle') {\r\n sectionIndexes.push(index);\r\n }\r\n });\r\n const sections: TApiaApiSection[] = [];\r\n sectionIndexes.forEach((sectionIndex, arrayIndex) => {\r\n const start =\r\n sectionIndex + 1 < elements.length\r\n ? sectionIndex + 1\r\n : elements.length - 1;\r\n const end =\r\n arrayIndex + 1 < sectionIndexes.length\r\n ? sectionIndexes[arrayIndex + 1]\r\n : undefined;\r\n sections.push({\r\n sectionId: `ApiaApiSection_${arrayIndex}`,\r\n sectionHeader:\r\n sectionIndex !== -1\r\n ? {\r\n ...elements[sectionIndex],\r\n sectionElementId: `sectionHeader_${arrayIndex}`,\r\n }\r\n : undefined,\r\n sectionElements: removeEndingSpacers(elements.slice(start, end)).map(\r\n (currentElement) => ({\r\n ...currentElement,\r\n sectionElementId: `sectionElement_${\r\n currentElement.id || currentElement.name || uniqueId()\r\n }`,\r\n }),\r\n ),\r\n });\r\n });\r\n return sections;\r\n};\r\n\r\nconst NonMemoizedApiaApiFieldsContainer = (props: TApiaApiFieldsContainer) => {\r\n const elements = React.useMemo(\r\n () => arrayOrArray(props?.definition?.form.elements?.element ?? []),\r\n [props?.definition?.form.elements?.element],\r\n );\r\n\r\n const sections = React.useMemo(\r\n () => parseApiaApiSections(elements),\r\n [elements],\r\n );\r\n\r\n const renderSectionContent = React.useCallback(\r\n (sectionId: string, sectionElements: TApiaApiSectionElement[]) => {\r\n const isVisible =\r\n sectionElements.findIndex((element) => element.type !== 'hidden') !==\r\n -1;\r\n return (\r\n <Box\r\n className={\r\n isVisible\r\n ? 'handler__form__elements__section__content'\r\n : `handler__form__elements__section__content handler__hidden`\r\n }\r\n key={sectionId}\r\n >\r\n {sectionElements.map((current) => {\r\n const element = {\r\n ...current,\r\n onChange() {\r\n getFunction(current.onChange, props)\r\n .then((onChangeMethod) => {\r\n if (onChangeMethod) {\r\n onChangeMethod();\r\n }\r\n })\r\n .catch(console.error);\r\n },\r\n };\r\n switch (element.type) {\r\n case 'table': {\r\n const data = JSON.parse(element.text) as TModalTable;\r\n return (\r\n <Box\r\n key={element.sectionElementId}\r\n {...getVariant('layout.common.tables.information')}\r\n >\r\n <table sx={{ width: '100%' }}>\r\n <thead>\r\n <tr>\r\n {data.columns.map((column) => {\r\n return <th key={column}>{column}</th>;\r\n })}\r\n </tr>\r\n </thead>\r\n <tbody>\r\n {data.rows.map((row) => {\r\n return (\r\n <tr key={row.cells.join('-')}>\r\n {row.cells.map((cell, i) => {\r\n return (\r\n <td key={`${cell}_${data.columns[i]}`}>\r\n {cell}\r\n </td>\r\n );\r\n })}\r\n </tr>\r\n );\r\n })}\r\n </tbody>\r\n </table>\r\n </Box>\r\n );\r\n }\r\n case '2columnSubTitle':\r\n return (\r\n <Box\r\n key={element.sectionElementId}\r\n className={element.class}\r\n as=\"h6\"\r\n >\r\n {element.value || element.text}\r\n </Box>\r\n );\r\n case '2column':\r\n return (\r\n <Box\r\n key={element.sectionElementId}\r\n dangerouslySetInnerHTML={{\r\n __html: element.value || element.text,\r\n }}\r\n className={element.class}\r\n />\r\n );\r\n case 'checkbox':\r\n return (\r\n <ApiaApiCheckbox\r\n key={element.sectionElementId}\r\n {...props}\r\n element={element}\r\n />\r\n );\r\n case 'file':\r\n return (\r\n <ApiaApiFileInput\r\n key={element.sectionElementId}\r\n {...props}\r\n element={element}\r\n />\r\n );\r\n case 'hidden':\r\n case 'password':\r\n case 'text':\r\n return (\r\n <ApiaApiInput\r\n key={element.sectionElementId}\r\n {...props}\r\n element={element}\r\n />\r\n );\r\n case 'select':\r\n return (\r\n <ApiaApiSelect\r\n key={element.sectionElementId}\r\n {...props}\r\n element={element}\r\n />\r\n );\r\n case 'radio':\r\n return (\r\n <ApiaApiRadio\r\n key={element.sectionElementId}\r\n {...props}\r\n element={element}\r\n />\r\n );\r\n case 'textarea':\r\n return (\r\n <ApiaApiTextArea\r\n key={element.sectionElementId}\r\n {...props}\r\n element={element}\r\n />\r\n );\r\n case 'empty':\r\n return (\r\n <Box key={element.sectionElementId} className=\"spacer\" />\r\n );\r\n default:\r\n console.warn(\r\n `Unhandled element type: ${element.type}`,\r\n element,\r\n );\r\n return null;\r\n }\r\n })}\r\n </Box>\r\n );\r\n },\r\n [props],\r\n );\r\n return (\r\n <Box className=\"handler__form__elements\">\r\n {sections.map((section) => {\r\n if (section.sectionHeader) {\r\n return renderSectionContent(\r\n section.sectionId,\r\n section.sectionElements,\r\n );\r\n }\r\n return renderSectionContent(section.sectionId, section.sectionElements);\r\n })}\r\n </Box>\r\n );\r\n};\r\n\r\nexport const ApiaApiFieldsContainer = React.memo(\r\n NonMemoizedApiaApiFieldsContainer,\r\n);\r\n\r\nApiaApiFieldsContainer.displayName = 'ApiaApiFieldsContainer';\r\n"],"names":["React"],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ import { jsx } from '@apia/theme/jsx-runtime';
2
+ import { classToValidate, FileInput } from '@apia/validations';
3
+ import React__default from 'react';
4
+
5
+ const ApiaApiFileInput = (props) => {
6
+ const element = React__default.useMemo(() => props.element, [props.element]);
7
+ const className = React__default.useMemo(
8
+ () => element.class ? `handler__file ${element.class}` : "handler__file",
9
+ [element.class]
10
+ );
11
+ const validationRules = React__default.useMemo(
12
+ () => ({
13
+ required: element.mandatory,
14
+ ...classToValidate(element.class)
15
+ }),
16
+ [element.class, element.mandatory]
17
+ );
18
+ return /* @__PURE__ */ jsx(
19
+ FileInput,
20
+ {
21
+ className,
22
+ name: element.id || element.name,
23
+ label: element.text,
24
+ title: element.title || element.text,
25
+ readOnly: element.readonly,
26
+ disabled: element.disabled,
27
+ validationRules
28
+ }
29
+ );
30
+ };
31
+ ApiaApiFileInput.displayName = "ApiaApiFileInput";
32
+
33
+ export { ApiaApiFileInput };
34
+ //# sourceMappingURL=ApiaApiFileInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApiaApiFileInput.js","sources":["../../src/fields/ApiaApiFileInput.tsx"],"sourcesContent":["import { classToValidate, FileInput } from '@apia/validations';\r\nimport React from 'react';\r\nimport { TApiaApiField } from '../ApiaApiHandler';\r\n\r\nexport const ApiaApiFileInput = (props: TApiaApiField) => {\r\n const element = React.useMemo(() => props.element, [props.element]);\r\n const className = React.useMemo(\r\n () => (element.class ? `handler__file ${element.class}` : 'handler__file'),\r\n [element.class],\r\n );\r\n const validationRules = React.useMemo(\r\n () => ({\r\n required: element.mandatory,\r\n ...classToValidate(element.class),\r\n }),\r\n [element.class, element.mandatory],\r\n );\r\n\r\n return (\r\n <FileInput\r\n className={className}\r\n name={element.id || element.name}\r\n label={element.text}\r\n title={element.title || element.text}\r\n readOnly={element.readonly}\r\n disabled={element.disabled}\r\n validationRules={validationRules}\r\n />\r\n );\r\n};\r\n\r\nApiaApiFileInput.displayName = 'ApiaApiFileInput';\r\n"],"names":["React"],"mappings":";;;;AAIa,MAAA,gBAAA,GAAmB,CAAC,KAAyB,KAAA;AACxD,EAAM,MAAA,OAAA,GAAUA,eAAM,OAAQ,CAAA,MAAM,MAAM,OAAS,EAAA,CAAC,KAAM,CAAA,OAAO,CAAC,CAAA,CAAA;AAClE,EAAA,MAAM,YAAYA,cAAM,CAAA,OAAA;AAAA,IACtB,MAAO,OAAQ,CAAA,KAAA,GAAQ,CAAiB,cAAA,EAAA,OAAA,CAAQ,KAAK,CAAK,CAAA,GAAA,eAAA;AAAA,IAC1D,CAAC,QAAQ,KAAK,CAAA;AAAA,GAChB,CAAA;AACA,EAAA,MAAM,kBAAkBA,cAAM,CAAA,OAAA;AAAA,IAC5B,OAAO;AAAA,MACL,UAAU,OAAQ,CAAA,SAAA;AAAA,MAClB,GAAG,eAAgB,CAAA,OAAA,CAAQ,KAAK,CAAA;AAAA,KAClC,CAAA;AAAA,IACA,CAAC,OAAA,CAAQ,KAAO,EAAA,OAAA,CAAQ,SAAS,CAAA;AAAA,GACnC,CAAA;AAEA,EACE,uBAAA,GAAA;AAAA,IAAC,SAAA;AAAA,IAAA;AAAA,MACC,SAAA;AAAA,MACA,IAAA,EAAM,OAAQ,CAAA,EAAA,IAAM,OAAQ,CAAA,IAAA;AAAA,MAC5B,OAAO,OAAQ,CAAA,IAAA;AAAA,MACf,KAAA,EAAO,OAAQ,CAAA,KAAA,IAAS,OAAQ,CAAA,IAAA;AAAA,MAChC,UAAU,OAAQ,CAAA,QAAA;AAAA,MAClB,UAAU,OAAQ,CAAA,QAAA;AAAA,MAClB,eAAA;AAAA,KAAA;AAAA,GACF,CAAA;AAEJ,EAAA;AAEA,gBAAA,CAAiB,WAAc,GAAA,kBAAA;;;;"}
@@ -0,0 +1,20 @@
1
+ import React__default from 'react';
2
+ import { TApiaApiField } from '../ApiaApiHandler.js';
3
+
4
+ declare global {
5
+ interface Window {
6
+ SALT: string;
7
+ IV: string;
8
+ PASSPHRASE: string;
9
+ KEY_SIZE: number;
10
+ ITERATION_COUNT: string;
11
+ }
12
+ }
13
+ /**
14
+ * Permite cargar en forma asíncrona un modal que se encuentre dentro del
15
+ * directorio /api/modals
16
+ * */
17
+ declare const getModal: (path: string) => React__default.LazyExoticComponent<React__default.ComponentType<TApiaApiField>>;
18
+
19
+ export { getModal };
20
+ //# sourceMappingURL=ApiaApiInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApiaApiInput.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}