UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

52 lines 13.4 kB
import { gettext } from '@c8y/ngx-components'; export const HAS_ERROR = 'has-error'; export const MEASUREMENTS_PREVIEW_ITEMS_LIMIT = 5; export const SERIES_DATA_MERGED_FILE_NAME = 'seriesDataMergedFileName'; export const EXPORT_MODE_LABELS = { FULL: gettext('Full`export type`'), COMPACT: gettext('Compact`export type`') }; /** * Each export type is based on a different API: * - COMPACT - series * - FULL - measurements * All differences between export modes: * Compact: * Processes up to 5,000 records per data point, or up to the data retention limit (API limit) * Creates a single merged file containing all the data * Provides minimum and maximum values (API feature) * Preview is not available * Supports optional data aggregation (API feature) * Full: * Processes up to 1,000,000 records per data point, or up to the data retention limit (API limit) * For exports exceeding 50,000 records, data will be sent via email * Creates a compressed ZIP file containing separate data files for each selected data point * Preview is available * Does not support data aggregation */ export const EXPORT_MODE_VALUES = { full: 'FULL', compact: 'COMPACT' }; export const FILE_COMPRESSION_TYPES_VALUES = { store: 'STORE', deflate: 'DEFLATE' }; export const PRODUCT_EXPERIENCE_DATAPOINTS_EXPORT_SELECTOR = { EVENTS: { EXPORT_SELECTOR: 'exportSelector' }, COMPONENTS: { DATAPOINTS_EXPORT_SELECTOR: 'datapoints-export-selector', DATAPOINTS_EXPORT_SELECTOR_FILE_EXPORTER: 'datapoints-export-selector-file-exporter' }, ACTIONS: { OPEN_MODAL: 'openModal', DOWNLOAD_STARTED: 'downloadStarted' }, EXPORT_CONFIG: { FULL_EXPORT_TYPE: 'fullExportType', COMPACT_EXPORT_TYPE: 'compactExportType' } }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoints-export-selector.model.js","sourceRoot":"","sources":["../../../datapoints-export-selector/datapoints-export-selector.model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqB,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAIjE,MAAM,CAAC,MAAM,SAAS,GAAG,WAAW,CAAC;AACrC,MAAM,CAAC,MAAM,gCAAgC,GAAG,CAAC,CAAC;AAClD,MAAM,CAAC,MAAM,4BAA4B,GAAG,0BAA0B,CAAC;AA6MvE,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,IAAI,EAAE,OAAO,CAAC,mBAAmB,CAAW;IAC5C,OAAO,EAAE,OAAO,CAAC,sBAAsB,CAAc;CAC7C,CAAC;AAEX;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,IAAI,EAAE,MAAM;IACZ,OAAO,EAAE,SAAS;CACV,CAAC;AAEX,MAAM,CAAC,MAAM,6BAA6B,GAAG;IAC3C,KAAK,EAAE,OAAO;IACd,OAAO,EAAE,SAAS;CACV,CAAC;AAEX,MAAM,CAAC,MAAM,6CAA6C,GAAG;IAC3D,MAAM,EAAE;QACN,eAAe,EAAE,gBAAgB;KAClC;IACD,UAAU,EAAE;QACV,0BAA0B,EAAE,4BAA4B;QACxD,wCAAwC,EAAE,0CAA0C;KACrF;IACD,OAAO,EAAE;QACP,UAAU,EAAE,WAAW;QACvB,gBAAgB,EAAE,iBAAiB;KACpC;IACD,aAAa,EAAE;QACb,gBAAgB,EAAE,gBAAgB;QAClC,mBAAmB,EAAE,mBAAmB;KACzC;CACO,CAAC","sourcesContent":["import { AggregationOption, gettext } from '@c8y/ngx-components';\nimport { Measurement } from './datapoints-export-selector-modal/datapoints-export-selector-file-exporter/utils.service';\nimport { SupportedIconsSuggestions } from '@c8y/ngx-components/icon-selector/icons';\n\nexport const HAS_ERROR = 'has-error';\nexport const MEASUREMENTS_PREVIEW_ITEMS_LIMIT = 5;\nexport const SERIES_DATA_MERGED_FILE_NAME = 'seriesDataMergedFileName';\n\n/**\n * Represents counts of datapoints data categorized by their availability and delivery method.\n */\nexport interface DatapointCounts {\n  /**\n   * The number of datapoints whose data can be directly downloaded\n   * through a web browser.\n   */\n  browserDownloadableCount: number;\n  /**\n   * The number of datapoints whose data will be sent via email because its record count exceeded 50_000.\n   */\n  emailDeliverableCount: number;\n  /**\n   * The number of datapoints whose data cannot be retrieved at all,\n   * neither through direct download nor via email because its record count exceeded 1_000_000 API limit.\n   */\n  nonRetrievableCount: number;\n}\n\n/**\n * Represents a datapoints which number of records exceed a threshold where data will be precessed by a backend.\n */\nexport interface DatapointsExceedingLimit {\n  datapointDetail: DatapointDetails;\n  totalElements: number;\n}\n\nexport interface DateFetchConfig {\n  date: string;\n  shouldFetchData: boolean;\n}\n\nexport interface IDataTransformer {\n  transformToMergedFormat(data: ExportData[]): TimeSeriesColumnData;\n}\n\nexport interface FileGenerator {\n  generateMerged?: (exportData: ExportData[], mergedExportDetails: MergedExportDetails) => BlobPart;\n  getFileExtension(): string;\n  getMimeType(): string;\n  getLabel(): string;\n  getIcon(): string;\n  getType(): string;\n  getTitle(): string;\n  getZipName(): string;\n  getAcceptType(): string;\n}\n\nexport interface FileTypeMetadata {\n  extension: string;\n  icon: SupportedIconsSuggestions;\n  label: string;\n  title: string;\n  type: string;\n  zipName: string;\n}\n\n/**\n * Represents the data structure, which is used to be transformed into a file (series) or used for a preview (series and measurements).\n */\nexport interface ExportData {\n  time?: string | null;\n  source: string | number;\n  device_name: string;\n  fragment_series: string;\n  /**\n   * Represents the value of a measurement for /measurement data API.\n   */\n  value?: number | null;\n  /**\n   * Represents the min value of a measurement for /series data API.\n   */\n  value_min?: number | null;\n  /**\n   * Represents the value of a measurement for /series data API.\n   * Measurement API data does not contain max value.\n   */\n  value_max?: number | null;\n  unit?: string | null;\n}\n\nexport interface DatapointDetails {\n  deviceName?: string;\n  source: string | number;\n  valueFragmentSeries: string;\n  valueFragmentType: string;\n}\n\n/**\n * Represents the data structure, which is used to be\n * transformed into an ExportData.\n */\nexport interface DataToExport extends DatapointDetails {\n  unit: string | undefined;\n  timeValueMap: { [timestamp: string]: Measurement } | undefined;\n}\n/**\n * Represents the data to be exported along with the backend-created file.\n * Only measurements API generates a file on the backend.\n */\nexport interface DataToExportWithBackendCreatedFile {\n  source: string | number;\n  valueFragmentSeries: string;\n  valueFragmentType: string;\n  fetchedMeasurementsBlobFile: Blob;\n}\n/**\n * Base configuration for the export process.\n */\nexport interface ExportConfig {\n  aggregation?: AggregationOption;\n  datapointDetails: DatapointDetails[];\n  dateFrom: string;\n  dateTo: string;\n}\n/**\n * Represents the configuration on the basis of which the zip file is created.\n */\nexport interface FileExportConfig {\n  fileType: string;\n  zipName: string;\n}\n/**\n * Represents a required config properties used in a process of generating a measurements based export file.\n */\nexport interface MeasurementFileConfig {\n  exportConfig: ExportConfig;\n  acceptFileType: string;\n}\n/**\n * Represents a required config properties along with transformed data structures,\n * used in a process of generating a series based export file.\n */\nexport interface SeriesExportParams {\n  flattenedAndSortedExportData: ExportData[];\n  fileType: string;\n  mergedExportDetails: MergedExportDetails;\n}\n\nexport interface TimeSeriesColumnData {\n  timeSeries: Map<TimeStamp, ColumnValueMap>;\n  uniqueColumnIdentifiers: string[];\n}\n/**\n * Represents a mapping of datapoints series values.\n * The key of the map is a source, and the value is the value data from requested series.\n */\nexport type DatapointsValuesDataMap = Map<SourceId | number, string[]>;\n\nexport type SourceId = string | number;\n\nexport type FileCompressionTypes = 'STORE' | 'DEFLATE';\n\nexport type TimeSeriesData = {\n  [timestamp: string]: Measurement;\n};\n\nexport interface FileTypeConfig {\n  extension: string;\n  mimeType: string;\n  acceptType: string;\n}\n\n/**\n * Represents the details unique for a merged file.\n */\nexport type MergedExportDetails = {\n  aggregation: AggregationOption;\n  dateFrom: string;\n  dateTo: string;\n};\n\nexport type ExportedFile = {\n  fileName: string;\n  fileData: Blob;\n};\n\nexport type TimeStamp = string;\n\nexport type ReadingValue = number;\n/**\n * Represents the min and max values for a specific timestamp.\n * Both min and max values are available only when using series API.\n */\nexport type MinMaxValues = {\n  min: number;\n  max: number;\n};\n\n/**\n * Represents a merged export column header,\n * e.g. 'Temperature - 5 -> c8y_Temperature.T [ºC] (max)'\n */\ntype ColumnHeader = string;\n/**\n * Represents a mapping of column headers and their corresponding values.\n * e.g. 'Temperature - 5 -> c8y_Temperature.T [ºC] (max)': 25\n */\nexport type ColumnValueMap = {\n  [key: ColumnHeader]: ReadingValue;\n};\n\nexport const EXPORT_MODE_LABELS = {\n  FULL: gettext('Full`export type`') as 'Full',\n  COMPACT: gettext('Compact`export type`') as 'Compact'\n} as const;\n\n/**\n * Each export type is based on a different API:\n * - COMPACT - series\n * - FULL - measurements\n * All differences between export modes:\n *  Compact:\n *    Processes up to 5,000 records per data point, or up to the data retention limit (API limit)\n *    Creates a single merged file containing all the data\n *    Provides minimum and maximum values (API feature)\n *    Preview is not available\n *    Supports optional data aggregation (API feature)\n *  Full:\n *    Processes up to 1,000,000 records per data point, or up to the data retention limit (API limit)\n *    For exports exceeding 50,000 records, data will be sent via email\n *    Creates a compressed ZIP file containing separate data files for each selected data point\n *    Preview is available\n *    Does not support data aggregation\n */\nexport const EXPORT_MODE_VALUES = {\n  full: 'FULL',\n  compact: 'COMPACT'\n} as const;\n\nexport const FILE_COMPRESSION_TYPES_VALUES = {\n  store: 'STORE',\n  deflate: 'DEFLATE'\n} as const;\n\nexport const PRODUCT_EXPERIENCE_DATAPOINTS_EXPORT_SELECTOR = {\n  EVENTS: {\n    EXPORT_SELECTOR: 'exportSelector'\n  },\n  COMPONENTS: {\n    DATAPOINTS_EXPORT_SELECTOR: 'datapoints-export-selector',\n    DATAPOINTS_EXPORT_SELECTOR_FILE_EXPORTER: 'datapoints-export-selector-file-exporter'\n  },\n  ACTIONS: {\n    OPEN_MODAL: 'openModal',\n    DOWNLOAD_STARTED: 'downloadStarted'\n  },\n  EXPORT_CONFIG: {\n    FULL_EXPORT_TYPE: 'fullExportType',\n    COMPACT_EXPORT_TYPE: 'compactExportType'\n  }\n} as const;\n"]}