@platforma-sdk/ui-vue 1.58.5 → 1.58.9
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/.turbo/turbo-build.log +195 -181
- package/.turbo/turbo-formatter$colon$check.log +2 -2
- package/.turbo/turbo-linter$colon$check.log +2 -2
- package/.turbo/turbo-types$colon$check.log +1 -1
- package/CHANGELOG.md +14 -0
- package/dist/AgGridVue/createAgGridColDef.js +73 -43
- package/dist/AgGridVue/createAgGridColDef.js.map +1 -1
- package/dist/AgGridVue/selection.js +55 -47
- package/dist/AgGridVue/selection.js.map +1 -1
- package/dist/AgGridVue/useAgGridOptions.js +212 -229
- package/dist/AgGridVue/useAgGridOptions.js.map +1 -1
- package/dist/_virtual/_plugin-vue_export-helper.js +5 -9
- package/dist/_virtual/_rolldown/runtime.js +15 -0
- package/dist/aggrid.js +48 -46
- package/dist/aggrid.js.map +1 -1
- package/dist/assets/block.css +1 -1
- package/dist/assets/ui.css +1 -0
- package/dist/components/BlockLayout.js +7 -0
- package/dist/components/BlockLayout.js.map +1 -0
- package/dist/components/BlockLayout.style.js +4 -0
- package/dist/components/BlockLayout.style.js.map +1 -0
- package/dist/components/BlockLayout.vue.css +1 -0
- package/dist/components/BlockLayout.vue2.js +42 -54
- package/dist/components/BlockLayout.vue2.js.map +1 -1
- package/dist/components/BlockLoader.js +5 -0
- package/dist/components/BlockLoader.js.map +1 -0
- package/dist/components/BlockLoader.vue2.js +22 -5
- package/dist/components/BlockLoader.vue2.js.map +1 -1
- package/dist/components/LoaderPage.js +10 -0
- package/dist/components/LoaderPage.js.map +1 -0
- package/dist/components/NotFound.js +5 -0
- package/dist/components/NotFound.js.map +1 -0
- package/dist/components/NotFound.vue2.js +18 -5
- package/dist/components/NotFound.vue2.js.map +1 -1
- package/dist/components/PlAdvancedFilter/FilterEditor.js +7 -0
- package/dist/components/PlAdvancedFilter/FilterEditor.js.map +1 -0
- package/dist/components/PlAdvancedFilter/FilterEditor.style.js +18 -0
- package/dist/components/PlAdvancedFilter/FilterEditor.style.js.map +1 -0
- package/dist/components/PlAdvancedFilter/FilterEditor.vue.css +1 -0
- package/dist/components/PlAdvancedFilter/FilterEditor.vue2.js +291 -322
- package/dist/components/PlAdvancedFilter/FilterEditor.vue2.js.map +1 -1
- package/dist/components/PlAdvancedFilter/OperandButton.js +7 -0
- package/dist/components/PlAdvancedFilter/OperandButton.js.map +1 -0
- package/dist/components/PlAdvancedFilter/OperandButton.style.js +8 -0
- package/dist/components/PlAdvancedFilter/OperandButton.style.js.map +1 -0
- package/dist/components/PlAdvancedFilter/OperandButton.vue.css +1 -0
- package/dist/components/PlAdvancedFilter/OperandButton.vue2.js +19 -24
- package/dist/components/PlAdvancedFilter/OperandButton.vue2.js.map +1 -1
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.js +7 -0
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.js.map +1 -0
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.style.js +12 -0
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.style.js.map +1 -0
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue.css +1 -0
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue.d.ts +1 -3
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue.d.ts.map +1 -1
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue2.js +239 -238
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue2.js.map +1 -1
- package/dist/components/PlAdvancedFilter/constants.js +115 -58
- package/dist/components/PlAdvancedFilter/constants.js.map +1 -1
- package/dist/components/PlAdvancedFilter/index.d.ts +1 -1
- package/dist/components/PlAdvancedFilter/index.d.ts.map +1 -1
- package/dist/components/PlAdvancedFilter/index.js +6 -6
- package/dist/components/PlAdvancedFilter/index.js.map +1 -1
- package/dist/components/PlAdvancedFilter/utils.js +49 -64
- package/dist/components/PlAdvancedFilter/utils.js.map +1 -1
- package/dist/components/PlAgCellFile/PlAgCellFile.js +5 -0
- package/dist/components/PlAgCellFile/PlAgCellFile.js.map +1 -0
- package/dist/components/PlAgCellFile/PlAgCellFile.vue2.js +36 -5
- package/dist/components/PlAgCellFile/PlAgCellFile.vue2.js.map +1 -1
- package/dist/components/PlAgCellProgress/PlAgCellProgress.js +5 -0
- package/dist/components/PlAgCellProgress/PlAgCellProgress.js.map +1 -0
- package/dist/components/PlAgCellProgress/PlAgCellProgress.vue2.js +13 -5
- package/dist/components/PlAgCellProgress/PlAgCellProgress.vue2.js.map +1 -1
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.js +6 -0
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.js.map +1 -0
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue2.js +12 -0
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue2.js.map +1 -0
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.js +6 -0
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.js.map +1 -0
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.style.css +1 -0
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue2.js +31 -0
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue2.js.map +1 -0
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.js +6 -0
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.js.map +1 -0
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.style.css +1 -0
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue2.js +19 -0
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue2.js.map +1 -0
- package/dist/components/PlAgColumnHeader/PlAgColumnHeader.js +5 -0
- package/dist/components/PlAgColumnHeader/PlAgColumnHeader.js.map +1 -0
- package/dist/components/PlAgColumnHeader/PlAgColumnHeader.vue2.js +68 -5
- package/dist/components/PlAgColumnHeader/PlAgColumnHeader.vue2.js.map +1 -1
- package/dist/components/PlAgColumnHeader/pl-ag-column-header.css +1 -1
- package/dist/components/PlAgCsvExporter/PlAgCsvExporter.js +5 -0
- package/dist/components/PlAgCsvExporter/PlAgCsvExporter.js.map +1 -0
- package/dist/components/PlAgCsvExporter/PlAgCsvExporter.vue2.js +26 -5
- package/dist/components/PlAgCsvExporter/PlAgCsvExporter.vue2.js.map +1 -1
- package/dist/components/PlAgCsvExporter/export-csv.js +36 -43
- package/dist/components/PlAgCsvExporter/export-csv.js.map +1 -1
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.js +7 -0
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.js.map +1 -0
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.style.js +4 -0
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.style.js.map +1 -0
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.vue.css +1 -0
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.vue2.js +68 -72
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.vue2.js.map +1 -1
- package/dist/components/PlAgDataTable/PlAgDataTableV2.js +7 -0
- package/dist/components/PlAgDataTable/PlAgDataTableV2.js.map +1 -0
- package/dist/components/PlAgDataTable/PlAgDataTableV2.style.js +7 -0
- package/dist/components/PlAgDataTable/PlAgDataTableV2.style.js.map +1 -0
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue.css +1 -0
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue2.js +307 -336
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue2.js.map +1 -1
- package/dist/components/PlAgDataTable/PlAgOverlayLoading.js +5 -0
- package/dist/components/PlAgDataTable/PlAgOverlayLoading.js.map +1 -0
- package/dist/components/PlAgDataTable/PlAgOverlayLoading.vue2.js +26 -5
- package/dist/components/PlAgDataTable/PlAgOverlayLoading.vue2.js.map +1 -1
- package/dist/components/PlAgDataTable/PlAgOverlayNoRows.js +6 -0
- package/dist/components/PlAgDataTable/PlAgOverlayNoRows.js.map +1 -0
- package/dist/components/PlAgDataTable/{PlAgOverlayNoRows.css → PlAgOverlayNoRows.style.css} +1 -1
- package/dist/components/PlAgDataTable/PlAgOverlayNoRows.vue2.js +14 -0
- package/dist/components/PlAgDataTable/PlAgOverlayNoRows.vue2.js.map +1 -0
- package/dist/components/PlAgDataTable/PlAgRowCount.js +5 -0
- package/dist/components/PlAgDataTable/PlAgRowCount.js.map +1 -0
- package/dist/components/PlAgDataTable/PlAgRowCount.vue2.js +23 -5
- package/dist/components/PlAgDataTable/PlAgRowCount.vue2.js.map +1 -1
- package/dist/components/PlAgDataTable/ag-override.js +4 -0
- package/dist/components/PlAgDataTable/ag-override.js.map +1 -0
- package/dist/components/PlAgDataTable/compositions/useFilterableColumns.js +25 -30
- package/dist/components/PlAgDataTable/compositions/useFilterableColumns.js.map +1 -1
- package/dist/components/PlAgDataTable/compositions/useGrid.js +102 -112
- package/dist/components/PlAgDataTable/compositions/useGrid.js.map +1 -1
- package/dist/components/PlAgDataTable/pl-ag-overlay-loading.css +1 -1
- package/dist/components/PlAgDataTable/pl-ag-overlay-loading.module.js +9 -0
- package/dist/components/PlAgDataTable/pl-ag-overlay-loading.module.js.map +1 -0
- package/dist/components/PlAgDataTable/sources/common.js +6 -8
- package/dist/components/PlAgDataTable/sources/common.js.map +1 -1
- package/dist/components/PlAgDataTable/sources/focus-row.js +36 -51
- package/dist/components/PlAgDataTable/sources/focus-row.js.map +1 -1
- package/dist/components/PlAgDataTable/sources/menu-items.js +10 -6
- package/dist/components/PlAgDataTable/sources/menu-items.js.map +1 -1
- package/dist/components/PlAgDataTable/sources/row-number.js +82 -94
- package/dist/components/PlAgDataTable/sources/row-number.js.map +1 -1
- package/dist/components/PlAgDataTable/sources/table-source-v2.js +178 -199
- package/dist/components/PlAgDataTable/sources/table-source-v2.js.map +1 -1
- package/dist/components/PlAgDataTable/sources/table-state-v2.js +155 -132
- package/dist/components/PlAgDataTable/sources/table-state-v2.js.map +1 -1
- package/dist/components/PlAgDataTable/sources/value-rendering.js +33 -38
- package/dist/components/PlAgDataTable/sources/value-rendering.js.map +1 -1
- package/dist/components/PlAgDataTable/types.js +54 -43
- package/dist/components/PlAgDataTable/types.js.map +1 -1
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.js +7 -0
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.js.map +1 -0
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.style.js +4 -0
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.style.js.map +1 -0
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js +89 -100
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue2.js.map +1 -1
- package/dist/components/PlAgGridColumnManager/useFilteredItems.js +46 -33
- package/dist/components/PlAgGridColumnManager/useFilteredItems.js.map +1 -1
- package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.js +5 -0
- package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.js.map +1 -0
- package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.vue.d.ts.map +1 -1
- package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.vue2.js +37 -5
- package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.vue2.js.map +1 -1
- package/dist/components/PlAgRowNumCheckbox/pl-ag-row-num-checkbox.css +1 -1
- package/dist/components/PlAgRowNumCheckbox/pl-ag-row-num-checkbox.module.js +10 -0
- package/dist/components/PlAgRowNumCheckbox/pl-ag-row-num-checkbox.module.js.map +1 -0
- package/dist/components/PlAgRowNumHeader.js +5 -0
- package/dist/components/PlAgRowNumHeader.js.map +1 -0
- package/dist/components/PlAgRowNumHeader.vue2.js +38 -5
- package/dist/components/PlAgRowNumHeader.vue2.js.map +1 -1
- package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.js +5 -0
- package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.js.map +1 -0
- package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue2.js +32 -5
- package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue2.js.map +1 -1
- package/dist/components/PlAgTextAndButtonCell/pl-ag-text-and-button-cell.css +1 -1
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.js +7 -0
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.js.map +1 -0
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.style.js +11 -0
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.style.js.map +1 -0
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue.css +1 -0
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue2.js +102 -113
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue2.js.map +1 -1
- package/dist/components/PlAnnotations/components/FilterSidebar.js +7 -0
- package/dist/components/PlAnnotations/components/FilterSidebar.js.map +1 -0
- package/dist/components/PlAnnotations/components/FilterSidebar.style.js +7 -0
- package/dist/components/PlAnnotations/components/FilterSidebar.style.js.map +1 -0
- package/dist/components/PlAnnotations/components/FilterSidebar.vue.css +1 -0
- package/dist/components/PlAnnotations/components/FilterSidebar.vue.d.ts +1 -2
- package/dist/components/PlAnnotations/components/FilterSidebar.vue.d.ts.map +1 -1
- package/dist/components/PlAnnotations/components/FilterSidebar.vue2.js +121 -131
- package/dist/components/PlAnnotations/components/FilterSidebar.vue2.js.map +1 -1
- package/dist/components/PlAnnotations/components/PlAnnotations.js +7 -0
- package/dist/components/PlAnnotations/components/PlAnnotations.js.map +1 -0
- package/dist/components/PlAnnotations/components/PlAnnotations.style.js +4 -0
- package/dist/components/PlAnnotations/components/PlAnnotations.style.js.map +1 -0
- package/dist/components/PlAnnotations/components/PlAnnotations.vue2.js +73 -65
- package/dist/components/PlAnnotations/components/PlAnnotations.vue2.js.map +1 -1
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.js +7 -0
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.js.map +1 -0
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.style.js +7 -0
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.style.js.map +1 -0
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.vue2.js +58 -52
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.vue2.js.map +1 -1
- package/dist/components/PlAnnotations/components/style.css +1 -1
- package/dist/components/PlAnnotations/components/style.module.js +8 -0
- package/dist/components/PlAnnotations/components/style.module.js.map +1 -0
- package/dist/components/PlAnnotations/utils.js +6 -8
- package/dist/components/PlAnnotations/utils.js.map +1 -1
- package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.js +5 -0
- package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.js.map +1 -0
- package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.vue2.js +57 -5
- package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.vue2.js.map +1 -1
- package/dist/components/PlAppErrorNotificationAlert/pl-app-error-notification-alert.css +1 -1
- package/dist/components/PlBtnExportArchive/Item.js +7 -0
- package/dist/components/PlBtnExportArchive/Item.js.map +1 -0
- package/dist/components/PlBtnExportArchive/Item.style.js +9 -0
- package/dist/components/PlBtnExportArchive/Item.style.js.map +1 -0
- package/dist/components/PlBtnExportArchive/Item.vue.css +1 -0
- package/dist/components/PlBtnExportArchive/Item.vue2.js +28 -42
- package/dist/components/PlBtnExportArchive/Item.vue2.js.map +1 -1
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.js +7 -0
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.js.map +1 -0
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.style.js +8 -0
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.style.js.map +1 -0
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.vue.css +1 -0
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.vue2.js +161 -159
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.vue2.js.map +1 -1
- package/dist/components/PlBtnExportArchive/Summary.js +7 -0
- package/dist/components/PlBtnExportArchive/Summary.js.map +1 -0
- package/dist/components/PlBtnExportArchive/Summary.style.js +8 -0
- package/dist/components/PlBtnExportArchive/Summary.style.js.map +1 -0
- package/dist/components/PlBtnExportArchive/Summary.vue.css +1 -0
- package/dist/components/PlBtnExportArchive/Summary.vue2.js +26 -41
- package/dist/components/PlBtnExportArchive/Summary.vue2.js.map +1 -1
- package/dist/components/PlTableFastSearch/PlTableFastSearch.js +5 -0
- package/dist/components/PlTableFastSearch/PlTableFastSearch.js.map +1 -0
- package/dist/components/PlTableFastSearch/PlTableFastSearch.vue2.js +41 -5
- package/dist/components/PlTableFastSearch/PlTableFastSearch.vue2.js.map +1 -1
- package/dist/components/PlTableFilters/PlTableFiltersV2.js +7 -0
- package/dist/components/PlTableFilters/PlTableFiltersV2.js.map +1 -0
- package/dist/components/PlTableFilters/PlTableFiltersV2.style.js +4 -0
- package/dist/components/PlTableFilters/PlTableFiltersV2.style.js.map +1 -0
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue.css +1 -0
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue.d.ts.map +1 -1
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue2.js +97 -106
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue2.js.map +1 -1
- package/dist/composition/fileContent.js +169 -200
- package/dist/composition/fileContent.js.map +1 -1
- package/dist/computedResult.js +47 -18
- package/dist/computedResult.js.map +1 -1
- package/dist/createModel.js +44 -60
- package/dist/createModel.js.map +1 -1
- package/dist/defineApp.js +87 -113
- package/dist/defineApp.js.map +1 -1
- package/dist/defineStore.js +15 -16
- package/dist/defineStore.js.map +1 -1
- package/dist/index.js +39 -98
- package/dist/index.js.map +1 -1
- package/dist/internal/UpdateSerializer.js +50 -66
- package/dist/internal/UpdateSerializer.js.map +1 -1
- package/dist/internal/createAppModel.js +54 -68
- package/dist/internal/createAppModel.js.map +1 -1
- package/dist/internal/createAppV1.js +140 -193
- package/dist/internal/createAppV1.js.map +1 -1
- package/dist/internal/createAppV2.d.ts.map +1 -1
- package/dist/internal/createAppV2.js +149 -193
- package/dist/internal/createAppV2.js.map +1 -1
- package/dist/internal/createAppV3.d.ts.map +1 -1
- package/dist/internal/createAppV3.js +157 -202
- package/dist/internal/createAppV3.js.map +1 -1
- package/dist/internal/test-helpers/utils.d.ts.map +1 -1
- package/dist/lib/util/helpers/dist/error.js +1 -0
- package/dist/lib/util/helpers/dist/functions.js +8 -9
- package/dist/lib/util/helpers/dist/functions.js.map +1 -1
- package/dist/lib/util/helpers/dist/hash.js +5 -0
- package/dist/lib/util/helpers/dist/hash.js.map +1 -0
- package/dist/lib/util/helpers/dist/index.js +9 -0
- package/dist/lib/util/helpers/dist/objects.js +75 -42
- package/dist/lib/util/helpers/dist/objects.js.map +1 -1
- package/dist/lib/util/helpers/dist/prettyBytes.js +60 -26
- package/dist/lib/util/helpers/dist/prettyBytes.js.map +1 -1
- package/dist/lib/util/helpers/dist/random.js +6 -8
- package/dist/lib/util/helpers/dist/random.js.map +1 -1
- package/dist/lib/util/helpers/dist/strings.js +11 -14
- package/dist/lib/util/helpers/dist/strings.js.map +1 -1
- package/dist/lib/util/helpers/dist/uniqId.js +7 -0
- package/dist/lib/util/helpers/dist/uniqId.js.map +1 -0
- package/dist/lib/util/helpers/dist/utils.js +34 -50
- package/dist/lib/util/helpers/dist/utils.js.map +1 -1
- package/dist/lib.js +38 -0
- package/dist/objectHash.js +13 -10
- package/dist/objectHash.js.map +1 -1
- package/dist/plugins/Monetization/EndOfPeriod.js +7 -0
- package/dist/plugins/Monetization/EndOfPeriod.js.map +1 -0
- package/dist/plugins/Monetization/EndOfPeriod.style.js +4 -0
- package/dist/plugins/Monetization/EndOfPeriod.style.js.map +1 -0
- package/dist/plugins/Monetization/EndOfPeriod.vue.css +1 -0
- package/dist/plugins/Monetization/EndOfPeriod.vue2.js +15 -23
- package/dist/plugins/Monetization/EndOfPeriod.vue2.js.map +1 -1
- package/dist/plugins/Monetization/LimitCard.js +7 -0
- package/dist/plugins/Monetization/LimitCard.js.map +1 -0
- package/dist/plugins/Monetization/LimitCard.style.js +18 -0
- package/dist/plugins/Monetization/LimitCard.style.js.map +1 -0
- package/dist/plugins/Monetization/LimitCard.vue.css +1 -0
- package/dist/plugins/Monetization/LimitCard.vue2.js +47 -84
- package/dist/plugins/Monetization/LimitCard.vue2.js.map +1 -1
- package/dist/plugins/Monetization/MonetizationSidebar.js +5 -0
- package/dist/plugins/Monetization/MonetizationSidebar.js.map +1 -0
- package/dist/plugins/Monetization/MonetizationSidebar.vue2.js +106 -5
- package/dist/plugins/Monetization/MonetizationSidebar.vue2.js.map +1 -1
- package/dist/plugins/Monetization/RunStatus.js +7 -0
- package/dist/plugins/Monetization/RunStatus.js.map +1 -0
- package/dist/plugins/Monetization/RunStatus.style.js +13 -0
- package/dist/plugins/Monetization/RunStatus.style.js.map +1 -0
- package/dist/plugins/Monetization/RunStatus.vue.css +1 -0
- package/dist/plugins/Monetization/RunStatus.vue2.js +21 -40
- package/dist/plugins/Monetization/RunStatus.vue2.js.map +1 -1
- package/dist/plugins/Monetization/UserCabinetCard.js +7 -0
- package/dist/plugins/Monetization/UserCabinetCard.js.map +1 -0
- package/dist/plugins/Monetization/UserCabinetCard.style.js +12 -0
- package/dist/plugins/Monetization/UserCabinetCard.style.js.map +1 -0
- package/dist/plugins/Monetization/UserCabinetCard.vue.css +1 -0
- package/dist/plugins/Monetization/UserCabinetCard.vue2.js +50 -70
- package/dist/plugins/Monetization/UserCabinetCard.vue2.js.map +1 -1
- package/dist/plugins/Monetization/useButtonTarget.js +15 -16
- package/dist/plugins/Monetization/useButtonTarget.js.map +1 -1
- package/dist/plugins/Monetization/useInfo.js +36 -71
- package/dist/plugins/Monetization/useInfo.js.map +1 -1
- package/dist/plugins/Monetization/validation.js +34 -42
- package/dist/plugins/Monetization/validation.js.map +1 -1
- package/dist/urls.d.ts.map +1 -1
- package/dist/urls.js +4 -5
- package/dist/urls.js.map +1 -1
- package/dist/usePlugin.js +32 -12
- package/dist/usePlugin.js.map +1 -1
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +29 -54
- package/dist/utils.js.map +1 -1
- package/package.json +8 -8
- package/src/components/PlAdvancedFilter/index.ts +1 -1
- package/src/components/PlAnnotations/components/FilterSidebar.vue +11 -6
- package/src/components/PlTableFilters/PlTableFiltersV2.vue +2 -1
- package/dist/_virtual/_plugin-vue_export-helper.js.map +0 -1
- package/dist/components/BlockLayout.css +0 -1
- package/dist/components/BlockLayout.vue.js +0 -10
- package/dist/components/BlockLayout.vue.js.map +0 -1
- package/dist/components/BlockLayout.vue3.js +0 -8
- package/dist/components/BlockLayout.vue3.js.map +0 -1
- package/dist/components/BlockLoader.vue.js +0 -26
- package/dist/components/BlockLoader.vue.js.map +0 -1
- package/dist/components/LoaderPage.vue.js +0 -15
- package/dist/components/LoaderPage.vue.js.map +0 -1
- package/dist/components/NotFound.vue.js +0 -26
- package/dist/components/NotFound.vue.js.map +0 -1
- package/dist/components/PlAdvancedFilter/FilterEditor.css +0 -1
- package/dist/components/PlAdvancedFilter/FilterEditor.vue.js +0 -10
- package/dist/components/PlAdvancedFilter/FilterEditor.vue.js.map +0 -1
- package/dist/components/PlAdvancedFilter/FilterEditor.vue3.js +0 -32
- package/dist/components/PlAdvancedFilter/FilterEditor.vue3.js.map +0 -1
- package/dist/components/PlAdvancedFilter/OperandButton.css +0 -1
- package/dist/components/PlAdvancedFilter/OperandButton.vue.js +0 -10
- package/dist/components/PlAdvancedFilter/OperandButton.vue.js.map +0 -1
- package/dist/components/PlAdvancedFilter/OperandButton.vue3.js +0 -12
- package/dist/components/PlAdvancedFilter/OperandButton.vue3.js.map +0 -1
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.css +0 -1
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue.js +0 -10
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue.js.map +0 -1
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue3.js +0 -20
- package/dist/components/PlAdvancedFilter/PlAdvancedFilter.vue3.js.map +0 -1
- package/dist/components/PlAgCellFile/PlAgCellFile.vue.js +0 -32
- package/dist/components/PlAgCellFile/PlAgCellFile.vue.js.map +0 -1
- package/dist/components/PlAgCellProgress/PlAgCellProgress.vue.js +0 -16
- package/dist/components/PlAgCellProgress/PlAgCellProgress.vue.js.map +0 -1
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue.js +0 -22
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue.js.map +0 -1
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue3.js +0 -6
- package/dist/components/PlAgCellStatusTag/PlAgCellStatusTag.vue3.js.map +0 -1
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.css +0 -1
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue.js +0 -32
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue.js.map +0 -1
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue3.js +0 -6
- package/dist/components/PlAgChartHistogramCell/PlAgChartHistogramCell.vue3.js.map +0 -1
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.css +0 -1
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue.js +0 -24
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue.js.map +0 -1
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue3.js +0 -6
- package/dist/components/PlAgChartStackedBarCell/PlAgChartStackedBarCell.vue3.js.map +0 -1
- package/dist/components/PlAgColumnHeader/PlAgColumnHeader.vue.js +0 -97
- package/dist/components/PlAgColumnHeader/PlAgColumnHeader.vue.js.map +0 -1
- package/dist/components/PlAgCsvExporter/PlAgCsvExporter.vue.js +0 -33
- package/dist/components/PlAgCsvExporter/PlAgCsvExporter.vue.js.map +0 -1
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.css +0 -1
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.vue.js +0 -10
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.vue.js.map +0 -1
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.vue3.js +0 -8
- package/dist/components/PlAgDataTable/PlAgDataTableSheets.vue3.js.map +0 -1
- package/dist/components/PlAgDataTable/PlAgDataTableV2.css +0 -1
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue.js +0 -10
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue.js.map +0 -1
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue3.js +0 -10
- package/dist/components/PlAgDataTable/PlAgDataTableV2.vue3.js.map +0 -1
- package/dist/components/PlAgDataTable/PlAgOverlayLoading.vue.js +0 -48
- package/dist/components/PlAgDataTable/PlAgOverlayLoading.vue.js.map +0 -1
- package/dist/components/PlAgDataTable/PlAgOverlayNoRows.vue.js +0 -22
- package/dist/components/PlAgDataTable/PlAgOverlayNoRows.vue.js.map +0 -1
- package/dist/components/PlAgDataTable/PlAgOverlayNoRows.vue3.js +0 -6
- package/dist/components/PlAgDataTable/PlAgOverlayNoRows.vue3.js.map +0 -1
- package/dist/components/PlAgDataTable/PlAgRowCount.vue.js +0 -26
- package/dist/components/PlAgDataTable/PlAgRowCount.vue.js.map +0 -1
- package/dist/components/PlAgDataTable/ag-override.css.js +0 -31
- package/dist/components/PlAgDataTable/ag-override.css.js.map +0 -1
- package/dist/components/PlAgDataTable/pl-ag-overlay-loading.module.scss.js +0 -14
- package/dist/components/PlAgDataTable/pl-ag-overlay-loading.module.scss.js.map +0 -1
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue.js +0 -10
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue.js.map +0 -1
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue3.js +0 -8
- package/dist/components/PlAgGridColumnManager/PlAgGridColumnManager.vue3.js.map +0 -1
- package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.vue.js +0 -48
- package/dist/components/PlAgRowNumCheckbox/PlAgRowNumCheckbox.vue.js.map +0 -1
- package/dist/components/PlAgRowNumCheckbox/pl-ag-row-num-checkbox.module.scss.js +0 -15
- package/dist/components/PlAgRowNumCheckbox/pl-ag-row-num-checkbox.module.scss.js.map +0 -1
- package/dist/components/PlAgRowNumHeader.vue.js +0 -39
- package/dist/components/PlAgRowNumHeader.vue.js.map +0 -1
- package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue.js +0 -45
- package/dist/components/PlAgTextAndButtonCell/PlAgTextAndButtonCell.vue.js.map +0 -1
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.css +0 -1
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue.js +0 -10
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue.js.map +0 -1
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue3.js +0 -18
- package/dist/components/PlAnnotations/components/AnnotationsSidebar.vue3.js.map +0 -1
- package/dist/components/PlAnnotations/components/FilterSidebar.css +0 -1
- package/dist/components/PlAnnotations/components/FilterSidebar.vue.js +0 -10
- package/dist/components/PlAnnotations/components/FilterSidebar.vue.js.map +0 -1
- package/dist/components/PlAnnotations/components/FilterSidebar.vue3.js +0 -10
- package/dist/components/PlAnnotations/components/FilterSidebar.vue3.js.map +0 -1
- package/dist/components/PlAnnotations/components/PlAnnotations.vue.js +0 -10
- package/dist/components/PlAnnotations/components/PlAnnotations.vue.js.map +0 -1
- package/dist/components/PlAnnotations/components/PlAnnotations.vue3.js +0 -8
- package/dist/components/PlAnnotations/components/PlAnnotations.vue3.js.map +0 -1
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.vue.js +0 -10
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.vue.js.map +0 -1
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.vue3.js +0 -10
- package/dist/components/PlAnnotations/components/PlAnnotationsModal.vue3.js.map +0 -1
- package/dist/components/PlAnnotations/components/style.module.css.js +0 -12
- package/dist/components/PlAnnotations/components/style.module.css.js.map +0 -1
- package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.vue.js +0 -79
- package/dist/components/PlAppErrorNotificationAlert/PlAppErrorNotificationAlert.vue.js.map +0 -1
- package/dist/components/PlBtnExportArchive/Item.css +0 -1
- package/dist/components/PlBtnExportArchive/Item.vue.js +0 -10
- package/dist/components/PlBtnExportArchive/Item.vue.js.map +0 -1
- package/dist/components/PlBtnExportArchive/Item.vue3.js +0 -14
- package/dist/components/PlBtnExportArchive/Item.vue3.js.map +0 -1
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.css +0 -1
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.vue.js +0 -10
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.vue.js.map +0 -1
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.vue3.js +0 -12
- package/dist/components/PlBtnExportArchive/PlBtnExportArchive.vue3.js.map +0 -1
- package/dist/components/PlBtnExportArchive/Summary.css +0 -1
- package/dist/components/PlBtnExportArchive/Summary.vue.js +0 -10
- package/dist/components/PlBtnExportArchive/Summary.vue.js.map +0 -1
- package/dist/components/PlBtnExportArchive/Summary.vue3.js +0 -12
- package/dist/components/PlBtnExportArchive/Summary.vue3.js.map +0 -1
- package/dist/components/PlTableFastSearch/PlTableFastSearch.vue.js +0 -54
- package/dist/components/PlTableFastSearch/PlTableFastSearch.vue.js.map +0 -1
- package/dist/components/PlTableFilters/PlTableFiltersV2.css +0 -1
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue.js +0 -10
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue.js.map +0 -1
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue3.js +0 -8
- package/dist/components/PlTableFilters/PlTableFiltersV2.vue3.js.map +0 -1
- package/dist/plugins/Monetization/EndOfPeriod.css +0 -1
- package/dist/plugins/Monetization/EndOfPeriod.vue.js +0 -10
- package/dist/plugins/Monetization/EndOfPeriod.vue.js.map +0 -1
- package/dist/plugins/Monetization/EndOfPeriod.vue3.js +0 -8
- package/dist/plugins/Monetization/EndOfPeriod.vue3.js.map +0 -1
- package/dist/plugins/Monetization/LimitCard.css +0 -1
- package/dist/plugins/Monetization/LimitCard.vue.js +0 -10
- package/dist/plugins/Monetization/LimitCard.vue.js.map +0 -1
- package/dist/plugins/Monetization/LimitCard.vue3.js +0 -32
- package/dist/plugins/Monetization/LimitCard.vue3.js.map +0 -1
- package/dist/plugins/Monetization/MonetizationSidebar.vue.js +0 -138
- package/dist/plugins/Monetization/MonetizationSidebar.vue.js.map +0 -1
- package/dist/plugins/Monetization/RunStatus.css +0 -1
- package/dist/plugins/Monetization/RunStatus.vue.js +0 -10
- package/dist/plugins/Monetization/RunStatus.vue.js.map +0 -1
- package/dist/plugins/Monetization/RunStatus.vue3.js +0 -20
- package/dist/plugins/Monetization/RunStatus.vue3.js.map +0 -1
- package/dist/plugins/Monetization/UserCabinetCard.css +0 -1
- package/dist/plugins/Monetization/UserCabinetCard.vue.js +0 -10
- package/dist/plugins/Monetization/UserCabinetCard.vue.js.map +0 -1
- package/dist/plugins/Monetization/UserCabinetCard.vue3.js +0 -20
- package/dist/plugins/Monetization/UserCabinetCard.vue3.js.map +0 -1
- /package/dist/components/PlAgCellStatusTag/{PlAgCellStatusTag.css → PlAgCellStatusTag.style.css} +0 -0
- /package/dist/components/PlAgGridColumnManager/{PlAgGridColumnManager.css → PlAgGridColumnManager.vue.css} +0 -0
- /package/dist/components/PlAnnotations/components/{PlAnnotations.css → PlAnnotations.vue.css} +0 -0
- /package/dist/components/PlAnnotations/components/{PlAnnotationsModal.css → PlAnnotationsModal.vue.css} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EndOfPeriod.vue_vue_type_style_index_0_lang.module.js","names":[],"sources":["../../../src/plugins/Monetization/EndOfPeriod.vue"],"sourcesContent":["<script setup lang=\"ts\">\ndefineProps<{\n endOfPeriod: string | null;\n}>();\n\nconst formateStringDate = (date: string | null) => {\n if (!date) return \"N/A\";\n const dateObj = new Date(date);\n const day = dateObj.getDate().toString().padStart(2, \"0\");\n const month = (dateObj.getMonth() + 1).toString().padStart(2, \"0\"); // Month is 0-indexed\n const year = dateObj.getFullYear();\n return `${day}.${month}.${year}`;\n};\n</script>\n\n<template>\n <div :class=\"$style.container\">\n <span>End of period</span>\n <span>{{ formateStringDate(endOfPeriod) }}</span>\n </div>\n</template>\n\n<style module>\n.container {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n gap: 8px;\n background-color: #f7f8fa;\n border-radius: 6px;\n min-height: 40px;\n padding: 0 12px 0 12px;\n color: var(--txt-01);\n font-size: 14px;\n font-weight: 500;\n border: 1px solid var(--border-color-div-grey);\n span:first-child {\n overflow: hidden;\n font-weight: 600;\n }\n}\n</style>\n"],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
._container_1ki68_2{min-height:40px;color:var(--txt-01);border:1px solid var(--border-color-div-grey);background-color:#f7f8fa;border-radius:6px;flex-direction:row;justify-content:space-between;align-items:center;gap:8px;padding:0 12px;font-size:14px;font-weight:500;display:flex}._container_1ki68_2 span:first-child{font-weight:600;overflow:hidden}
|
|
@@ -1,24 +1,16 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
return (e, t) => (p(), d("div", {
|
|
14
|
-
class: c(e.$style.container)
|
|
15
|
-
}, [
|
|
16
|
-
t[0] || (t[0] = n("span", null, "End of period", -1)),
|
|
17
|
-
n("span", null, f(r(o.endOfPeriod)), 1)
|
|
18
|
-
], 2));
|
|
19
|
-
}
|
|
1
|
+
import { createElementBlock as e, createElementVNode as t, defineComponent as n, normalizeClass as r, openBlock as i, toDisplayString as a } from "vue";
|
|
2
|
+
var o = /* @__PURE__ */ n({
|
|
3
|
+
__name: "EndOfPeriod",
|
|
4
|
+
props: { endOfPeriod: {} },
|
|
5
|
+
setup(n) {
|
|
6
|
+
let o = (e) => {
|
|
7
|
+
if (!e) return "N/A";
|
|
8
|
+
let t = new Date(e);
|
|
9
|
+
return `${t.getDate().toString().padStart(2, "0")}.${(t.getMonth() + 1).toString().padStart(2, "0")}.${t.getFullYear()}`;
|
|
10
|
+
};
|
|
11
|
+
return (s, c) => (i(), e("div", { class: r(s.$style.container) }, [c[0] ||= t("span", null, "End of period", -1), t("span", null, a(o(n.endOfPeriod)), 1)], 2));
|
|
12
|
+
}
|
|
20
13
|
});
|
|
21
|
-
export {
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
//# sourceMappingURL=EndOfPeriod.vue2.js.map
|
|
14
|
+
export { o as default };
|
|
15
|
+
|
|
16
|
+
//# sourceMappingURL=EndOfPeriod.vue2.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EndOfPeriod.
|
|
1
|
+
{"version":3,"file":"EndOfPeriod.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/plugins/Monetization/EndOfPeriod.vue"],"sourcesContent":["<script setup lang=\"ts\">\ndefineProps<{\n endOfPeriod: string | null;\n}>();\n\nconst formateStringDate = (date: string | null) => {\n if (!date) return \"N/A\";\n const dateObj = new Date(date);\n const day = dateObj.getDate().toString().padStart(2, \"0\");\n const month = (dateObj.getMonth() + 1).toString().padStart(2, \"0\"); // Month is 0-indexed\n const year = dateObj.getFullYear();\n return `${day}.${month}.${year}`;\n};\n</script>\n\n<template>\n <div :class=\"$style.container\">\n <span>End of period</span>\n <span>{{ formateStringDate(endOfPeriod) }}</span>\n </div>\n</template>\n\n<style module>\n.container {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n gap: 8px;\n background-color: #f7f8fa;\n border-radius: 6px;\n min-height: 40px;\n padding: 0 12px 0 12px;\n color: var(--txt-01);\n font-size: 14px;\n font-weight: 500;\n border: 1px solid var(--border-color-div-grey);\n span:first-child {\n overflow: hidden;\n font-weight: 600;\n }\n}\n</style>\n"],"mappings":";;;;;EAKA,IAAM,KAAqB,MAAwB;AACjD,OAAI,CAAC,EAAM,QAAO;GAClB,IAAM,IAAU,IAAI,KAAK,EAAK;AAI9B,UAAO,GAHK,EAAQ,SAAS,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAG3C,IAFC,EAAQ,UAAU,GAAG,GAAG,UAAU,CAAC,SAAS,GAAG,IAAI,CAE3C,GADV,EAAQ,aAAa;;yBAMlC,EAGM,OAAA,EAHA,OAAK,EAAEA,EAAAA,OAAO,UAAS,EAAA,EAAA,CAAA,AAAA,EAAA,OAC3B,EAA0B,QAAA,MAApB,iBAAa,GAAA,EACnB,EAAiD,QAAA,MAAA,EAAxC,EAAkB,EAAA,YAAW,CAAA,EAAA,EAAA,CAAA,EAAA,EAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import e from "../../_virtual/_plugin-vue_export-helper.js";
|
|
2
|
+
import t from "./LimitCard.vue2.js";
|
|
3
|
+
import n from "./LimitCard.style.js";
|
|
4
|
+
var r = /* @__PURE__ */ e(t, [["__cssModules", { $style: n }]]);
|
|
5
|
+
export { r as default };
|
|
6
|
+
|
|
7
|
+
//# sourceMappingURL=LimitCard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LimitCard.js","names":[],"sources":["../../../src/plugins/Monetization/LimitCard.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed } from \"vue\";\n\nconst props = defineProps<{\n type: \"unique_launches\" | \"volume_limit\";\n label: string;\n used: number;\n toSpend: number;\n available: number | null; // If available is null it means Unlimited\n unit?: string;\n}>();\n\nconst total = computed(() => {\n if (props.available === null) return null;\n return props.available + props.toSpend + props.used;\n});\n\nconst exceeded = computed(() => {\n if (props.available === null) return false;\n return props.available < 0;\n});\n\nconst availableNow = computed(() => {\n if (props.available === null) return null;\n return props.available + props.toSpend;\n});\n\nconst clampPercentage = (n: number) => Math.max(0, Math.min(100, n));\n\nconst toSpendPercentage = computed(() => {\n if (total.value === null) return 0;\n if (total.value === 0) return 0;\n if (exceeded.value) return 0;\n return clampPercentage((props.toSpend / total.value) * 100);\n});\n\nconst usedPercentage = computed(() => {\n if (total.value === null) return 0;\n if (total.value === 0) return 0;\n return clampPercentage((props.used / total.value) * 100);\n});\n\nconst availablePercentage = computed(() => {\n if (props.available === null) return 100;\n if (total.value === null) return 100;\n if (total.value === 0) return 100;\n if (exceeded.value) return 0;\n return clampPercentage((props.available / total.value) * 100);\n});\n\nconst computedLabel = computed(() => {\n if (props.type === \"unique_launches\") return \"Runs Limits\";\n if (props.type === \"volume_limit\") return \"Volume Limits\";\n return props.label;\n});\n\nconst toGB = (v: number) => {\n return (v / 1024 / 1024 / 1024).toFixed(2) + \" GB\";\n};\n\nconst formatUnit = (v: number) => {\n if (props.type === \"volume_limit\") return toGB(v);\n return v;\n};\n\nconst showBar = (n: number) => {\n return Number(n.toFixed(2)) > 0;\n};\n</script>\n\n<template>\n <div :class=\"$style.container\">\n <span :class=\"$style.label\">{{ computedLabel }}</span>\n <div :class=\"$style.content\">\n <div :class=\"$style.contentAvailable\">\n <div>\n Available:\n <div style=\"flex: 1\" />\n <span v-if=\"availableNow !== null\"\n ><strong>{{ formatUnit(availableNow) }}</strong> /\n {{ formatUnit(available! + toSpend + used) }}</span\n >\n <span v-else>Unlimited</span>\n </div>\n <div :class=\"[$style.afterRun, { [$style.exceeded]: exceeded }]\">\n <span v-if=\"exceeded\">Too many files selected</span>\n <span style=\"flex: 1\" />\n <span>After run:</span>\n <span v-if=\"available !== null\"\n >{{ formatUnit(available) }} / {{ formatUnit(available + toSpend + used) }}</span\n >\n </div>\n <div :class=\"[$style.progressBar, { [$style.exceeded]: exceeded }]\">\n <span\n v-if=\"showBar(availablePercentage)\"\n :class=\"$style.progressBarAvailable\"\n :style=\"{ width: `${availablePercentage.toFixed(2)}%` }\"\n />\n <span\n v-if=\"showBar(toSpendPercentage)\"\n :class=\"$style.progressBarToSpend\"\n :style=\"{ width: `${toSpendPercentage.toFixed(2)}%` }\"\n />\n <span\n v-if=\"showBar(usedPercentage)\"\n :class=\"$style.progressBarUsed\"\n :style=\"{ width: `${usedPercentage.toFixed(2)}%` }\"\n />\n </div>\n </div>\n <div :class=\"$style.legends\">\n <div :class=\"$style.toSpendLegend\">\n <span />\n To spend: {{ formatUnit(toSpend) }}\n </div>\n <div :class=\"$style.usedLegend\">\n <span />\n Used: {{ formatUnit(used) }}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<style module>\n.container {\n display: flex;\n flex-direction: column;\n background-color: var(--bg-base-light);\n border-radius: 6px;\n padding: 10px 12px 16px 12px;\n color: var(--txt-01);\n font-size: 14px;\n font-weight: 500;\n line-height: 20px;\n border: 1px solid var(--border-color-div-grey);\n}\n\n.label {\n display: block;\n min-height: 36px;\n margin-bottom: 8px;\n color: var(--txt-01);\n font-size: 14px;\n font-weight: 600;\n line-height: 20px; /* 142.857% */\n}\n\n.content {\n display: flex;\n flex-direction: column;\n gap: 16px;\n}\n\n.contentAvailable {\n display: flex;\n flex-direction: column;\n gap: 6px;\n > div {\n display: flex;\n align-items: flex-start;\n }\n > div:first-child {\n gap: 8px;\n strong {\n font-size: 28px;\n font-weight: 500;\n line-height: 36px; /* 128.571% */\n letter-spacing: -0.56px;\n }\n }\n}\n\n.afterRun {\n display: flex;\n align-items: center;\n justify-content: flex-end;\n gap: 4px;\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n color: var(--txt-03);\n &.exceeded {\n color: var(--txt-error);\n }\n}\n\n.progressBar {\n width: 100%;\n height: 12px;\n background-color: #e0e0e0;\n display: flex;\n align-items: center;\n border: 1px solid var(--border-color-default);\n > span {\n display: block;\n height: 100%;\n outline: 1px solid var(--border-color-default);\n }\n &.exceeded {\n opacity: 0.2;\n }\n}\n\n.progressBarAvailable {\n background: linear-gradient(270deg, #a1e59c 0%, #d0f5b0 98.81%);\n}\n\n.progressBarUsed {\n background-color: #ffcecc;\n}\n\n.progressBarToSpend {\n background-color: #faf5aa;\n}\n\n.legends {\n display: flex;\n justify-content: space-between;\n gap: 8px;\n\n span {\n display: block;\n border-radius: 1px;\n border: 1px solid var(--border-color-default);\n width: 12px;\n height: 12px;\n }\n}\n\n.usedLegend {\n display: flex;\n align-items: center;\n gap: 8px;\n span {\n background: #ffcecc;\n }\n}\n\n.toSpendLegend {\n display: flex;\n align-items: center;\n gap: 8px;\n span {\n background: #faf5aa;\n }\n}\n</style>\n"],"mappings":""}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import './LimitCard.vue.css';var e = {
|
|
2
|
+
container: "_container_7c2y8_2",
|
|
3
|
+
label: "_label_7c2y8_15",
|
|
4
|
+
content: "_content_7c2y8_25",
|
|
5
|
+
contentAvailable: "_contentAvailable_7c2y8_31",
|
|
6
|
+
afterRun: "_afterRun_7c2y8_50",
|
|
7
|
+
exceeded: "_exceeded_7c2y8_60",
|
|
8
|
+
progressBar: "_progressBar_7c2y8_65",
|
|
9
|
+
progressBarAvailable: "_progressBarAvailable_7c2y8_82",
|
|
10
|
+
progressBarUsed: "_progressBarUsed_7c2y8_86",
|
|
11
|
+
progressBarToSpend: "_progressBarToSpend_7c2y8_90",
|
|
12
|
+
legends: "_legends_7c2y8_94",
|
|
13
|
+
usedLegend: "_usedLegend_7c2y8_108",
|
|
14
|
+
toSpendLegend: "_toSpendLegend_7c2y8_117"
|
|
15
|
+
};
|
|
16
|
+
export { e as default };
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=LimitCard.style.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LimitCard.vue_vue_type_style_index_0_lang.module.js","names":[],"sources":["../../../src/plugins/Monetization/LimitCard.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed } from \"vue\";\n\nconst props = defineProps<{\n type: \"unique_launches\" | \"volume_limit\";\n label: string;\n used: number;\n toSpend: number;\n available: number | null; // If available is null it means Unlimited\n unit?: string;\n}>();\n\nconst total = computed(() => {\n if (props.available === null) return null;\n return props.available + props.toSpend + props.used;\n});\n\nconst exceeded = computed(() => {\n if (props.available === null) return false;\n return props.available < 0;\n});\n\nconst availableNow = computed(() => {\n if (props.available === null) return null;\n return props.available + props.toSpend;\n});\n\nconst clampPercentage = (n: number) => Math.max(0, Math.min(100, n));\n\nconst toSpendPercentage = computed(() => {\n if (total.value === null) return 0;\n if (total.value === 0) return 0;\n if (exceeded.value) return 0;\n return clampPercentage((props.toSpend / total.value) * 100);\n});\n\nconst usedPercentage = computed(() => {\n if (total.value === null) return 0;\n if (total.value === 0) return 0;\n return clampPercentage((props.used / total.value) * 100);\n});\n\nconst availablePercentage = computed(() => {\n if (props.available === null) return 100;\n if (total.value === null) return 100;\n if (total.value === 0) return 100;\n if (exceeded.value) return 0;\n return clampPercentage((props.available / total.value) * 100);\n});\n\nconst computedLabel = computed(() => {\n if (props.type === \"unique_launches\") return \"Runs Limits\";\n if (props.type === \"volume_limit\") return \"Volume Limits\";\n return props.label;\n});\n\nconst toGB = (v: number) => {\n return (v / 1024 / 1024 / 1024).toFixed(2) + \" GB\";\n};\n\nconst formatUnit = (v: number) => {\n if (props.type === \"volume_limit\") return toGB(v);\n return v;\n};\n\nconst showBar = (n: number) => {\n return Number(n.toFixed(2)) > 0;\n};\n</script>\n\n<template>\n <div :class=\"$style.container\">\n <span :class=\"$style.label\">{{ computedLabel }}</span>\n <div :class=\"$style.content\">\n <div :class=\"$style.contentAvailable\">\n <div>\n Available:\n <div style=\"flex: 1\" />\n <span v-if=\"availableNow !== null\"\n ><strong>{{ formatUnit(availableNow) }}</strong> /\n {{ formatUnit(available! + toSpend + used) }}</span\n >\n <span v-else>Unlimited</span>\n </div>\n <div :class=\"[$style.afterRun, { [$style.exceeded]: exceeded }]\">\n <span v-if=\"exceeded\">Too many files selected</span>\n <span style=\"flex: 1\" />\n <span>After run:</span>\n <span v-if=\"available !== null\"\n >{{ formatUnit(available) }} / {{ formatUnit(available + toSpend + used) }}</span\n >\n </div>\n <div :class=\"[$style.progressBar, { [$style.exceeded]: exceeded }]\">\n <span\n v-if=\"showBar(availablePercentage)\"\n :class=\"$style.progressBarAvailable\"\n :style=\"{ width: `${availablePercentage.toFixed(2)}%` }\"\n />\n <span\n v-if=\"showBar(toSpendPercentage)\"\n :class=\"$style.progressBarToSpend\"\n :style=\"{ width: `${toSpendPercentage.toFixed(2)}%` }\"\n />\n <span\n v-if=\"showBar(usedPercentage)\"\n :class=\"$style.progressBarUsed\"\n :style=\"{ width: `${usedPercentage.toFixed(2)}%` }\"\n />\n </div>\n </div>\n <div :class=\"$style.legends\">\n <div :class=\"$style.toSpendLegend\">\n <span />\n To spend: {{ formatUnit(toSpend) }}\n </div>\n <div :class=\"$style.usedLegend\">\n <span />\n Used: {{ formatUnit(used) }}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<style module>\n.container {\n display: flex;\n flex-direction: column;\n background-color: var(--bg-base-light);\n border-radius: 6px;\n padding: 10px 12px 16px 12px;\n color: var(--txt-01);\n font-size: 14px;\n font-weight: 500;\n line-height: 20px;\n border: 1px solid var(--border-color-div-grey);\n}\n\n.label {\n display: block;\n min-height: 36px;\n margin-bottom: 8px;\n color: var(--txt-01);\n font-size: 14px;\n font-weight: 600;\n line-height: 20px; /* 142.857% */\n}\n\n.content {\n display: flex;\n flex-direction: column;\n gap: 16px;\n}\n\n.contentAvailable {\n display: flex;\n flex-direction: column;\n gap: 6px;\n > div {\n display: flex;\n align-items: flex-start;\n }\n > div:first-child {\n gap: 8px;\n strong {\n font-size: 28px;\n font-weight: 500;\n line-height: 36px; /* 128.571% */\n letter-spacing: -0.56px;\n }\n }\n}\n\n.afterRun {\n display: flex;\n align-items: center;\n justify-content: flex-end;\n gap: 4px;\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n color: var(--txt-03);\n &.exceeded {\n color: var(--txt-error);\n }\n}\n\n.progressBar {\n width: 100%;\n height: 12px;\n background-color: #e0e0e0;\n display: flex;\n align-items: center;\n border: 1px solid var(--border-color-default);\n > span {\n display: block;\n height: 100%;\n outline: 1px solid var(--border-color-default);\n }\n &.exceeded {\n opacity: 0.2;\n }\n}\n\n.progressBarAvailable {\n background: linear-gradient(270deg, #a1e59c 0%, #d0f5b0 98.81%);\n}\n\n.progressBarUsed {\n background-color: #ffcecc;\n}\n\n.progressBarToSpend {\n background-color: #faf5aa;\n}\n\n.legends {\n display: flex;\n justify-content: space-between;\n gap: 8px;\n\n span {\n display: block;\n border-radius: 1px;\n border: 1px solid var(--border-color-default);\n width: 12px;\n height: 12px;\n }\n}\n\n.usedLegend {\n display: flex;\n align-items: center;\n gap: 8px;\n span {\n background: #ffcecc;\n }\n}\n\n.toSpendLegend {\n display: flex;\n align-items: center;\n gap: 8px;\n span {\n background: #faf5aa;\n }\n}\n</style>\n"],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
._container_7c2y8_2{background-color:var(--bg-base-light);color:var(--txt-01);border:1px solid var(--border-color-div-grey);border-radius:6px;flex-direction:column;padding:10px 12px 16px;font-size:14px;font-weight:500;line-height:20px;display:flex}._label_7c2y8_15{min-height:36px;color:var(--txt-01);margin-bottom:8px;font-size:14px;font-weight:600;line-height:20px;display:block}._content_7c2y8_25{flex-direction:column;gap:16px;display:flex}._contentAvailable_7c2y8_31{flex-direction:column;gap:6px;display:flex}._contentAvailable_7c2y8_31>div{align-items:flex-start;display:flex}._contentAvailable_7c2y8_31>div:first-child{gap:8px}._contentAvailable_7c2y8_31>div:first-child strong{letter-spacing:-.56px;font-size:28px;font-weight:500;line-height:36px}._afterRun_7c2y8_50{color:var(--txt-03);justify-content:flex-end;align-items:center;gap:4px;font-size:12px;font-style:normal;font-weight:500;line-height:16px;display:flex}._afterRun_7c2y8_50._exceeded_7c2y8_60{color:var(--txt-error)}._progressBar_7c2y8_65{border:1px solid var(--border-color-default);background-color:#e0e0e0;align-items:center;width:100%;height:12px;display:flex}._progressBar_7c2y8_65>span{outline:1px solid var(--border-color-default);height:100%;display:block}._progressBar_7c2y8_65._exceeded_7c2y8_60{opacity:.2}._progressBarAvailable_7c2y8_82{background:linear-gradient(270deg,#a1e59c 0%,#d0f5b0 98.81%)}._progressBarUsed_7c2y8_86{background-color:#ffcecc}._progressBarToSpend_7c2y8_90{background-color:#faf5aa}._legends_7c2y8_94{justify-content:space-between;gap:8px;display:flex}._legends_7c2y8_94 span{border:1px solid var(--border-color-default);border-radius:1px;width:12px;height:12px;display:block}._usedLegend_7c2y8_108{align-items:center;gap:8px;display:flex}._usedLegend_7c2y8_108 span{background:#ffcecc}._toSpendLegend_7c2y8_117{align-items:center;gap:8px;display:flex}._toSpendLegend_7c2y8_117 span{background:#faf5aa}
|
|
@@ -1,85 +1,48 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
b(k.value) ? (i(), r("span", {
|
|
46
|
-
key: 0,
|
|
47
|
-
class: a(e.$style.progressBarAvailable),
|
|
48
|
-
style: $({ width: `${k.value.toFixed(2)}%` })
|
|
49
|
-
}, null, 6)) : m("", !0),
|
|
50
|
-
b(g.value) ? (i(), r("span", {
|
|
51
|
-
key: 1,
|
|
52
|
-
class: a(e.$style.progressBarToSpend),
|
|
53
|
-
style: $({ width: `${g.value.toFixed(2)}%` })
|
|
54
|
-
}, null, 6)) : m("", !0),
|
|
55
|
-
b(S.value) ? (i(), r("span", {
|
|
56
|
-
key: 2,
|
|
57
|
-
class: a(e.$style.progressBarUsed),
|
|
58
|
-
style: $({ width: `${S.value.toFixed(2)}%` })
|
|
59
|
-
}, null, 6)) : m("", !0)
|
|
60
|
-
], 2)
|
|
61
|
-
], 2),
|
|
62
|
-
n("div", {
|
|
63
|
-
class: a(e.$style.legends)
|
|
64
|
-
}, [
|
|
65
|
-
n("div", {
|
|
66
|
-
class: a(e.$style.toSpendLegend)
|
|
67
|
-
}, [
|
|
68
|
-
t[4] || (t[4] = n("span", null, null, -1)),
|
|
69
|
-
f(" To spend: " + d(v(s.toSpend)), 1)
|
|
70
|
-
], 2),
|
|
71
|
-
n("div", {
|
|
72
|
-
class: a(e.$style.usedLegend)
|
|
73
|
-
}, [
|
|
74
|
-
t[5] || (t[5] = n("span", null, null, -1)),
|
|
75
|
-
f(" Used: " + d(v(s.used)), 1)
|
|
76
|
-
], 2)
|
|
77
|
-
], 2)
|
|
78
|
-
], 2)
|
|
79
|
-
], 2));
|
|
80
|
-
}
|
|
1
|
+
import { computed as e, createCommentVNode as t, createElementBlock as n, createElementVNode as r, createTextVNode as i, defineComponent as a, normalizeClass as o, normalizeStyle as s, openBlock as c, toDisplayString as l } from "vue";
|
|
2
|
+
var u = { key: 0 }, d = { key: 1 }, f = { key: 0 }, p = { key: 1 }, m = /* @__PURE__ */ a({
|
|
3
|
+
__name: "LimitCard",
|
|
4
|
+
props: {
|
|
5
|
+
type: {},
|
|
6
|
+
label: {},
|
|
7
|
+
used: {},
|
|
8
|
+
toSpend: {},
|
|
9
|
+
available: {},
|
|
10
|
+
unit: {}
|
|
11
|
+
},
|
|
12
|
+
setup(a) {
|
|
13
|
+
let m = a, h = e(() => m.available === null ? null : m.available + m.toSpend + m.used), g = e(() => m.available === null ? !1 : m.available < 0), _ = e(() => m.available === null ? null : m.available + m.toSpend), v = (e) => Math.max(0, Math.min(100, e)), y = e(() => h.value === null || h.value === 0 || g.value ? 0 : v(m.toSpend / h.value * 100)), b = e(() => h.value === null || h.value === 0 ? 0 : v(m.used / h.value * 100)), x = e(() => m.available === null || h.value === null || h.value === 0 ? 100 : g.value ? 0 : v(m.available / h.value * 100)), S = e(() => m.type === "unique_launches" ? "Runs Limits" : m.type === "volume_limit" ? "Volume Limits" : m.label), C = (e) => (e / 1024 / 1024 / 1024).toFixed(2) + " GB", w = (e) => m.type === "volume_limit" ? C(e) : e, T = (e) => Number(e.toFixed(2)) > 0;
|
|
14
|
+
return (e, m) => (c(), n("div", { class: o(e.$style.container) }, [r("span", { class: o(e.$style.label) }, l(S.value), 3), r("div", { class: o(e.$style.content) }, [r("div", { class: o(e.$style.contentAvailable) }, [
|
|
15
|
+
r("div", null, [
|
|
16
|
+
m[0] ||= i(" Available: ", -1),
|
|
17
|
+
m[1] ||= r("div", { style: { flex: "1" } }, null, -1),
|
|
18
|
+
_.value === null ? (c(), n("span", d, "Unlimited")) : (c(), n("span", u, [r("strong", null, l(w(_.value)), 1), i(" / " + l(w(a.available + a.toSpend + a.used)), 1)]))
|
|
19
|
+
]),
|
|
20
|
+
r("div", { class: o([e.$style.afterRun, { [e.$style.exceeded]: g.value }]) }, [
|
|
21
|
+
g.value ? (c(), n("span", f, "Too many files selected")) : t("", !0),
|
|
22
|
+
m[2] ||= r("span", { style: { flex: "1" } }, null, -1),
|
|
23
|
+
m[3] ||= r("span", null, "After run:", -1),
|
|
24
|
+
a.available === null ? t("", !0) : (c(), n("span", p, l(w(a.available)) + " / " + l(w(a.available + a.toSpend + a.used)), 1))
|
|
25
|
+
], 2),
|
|
26
|
+
r("div", { class: o([e.$style.progressBar, { [e.$style.exceeded]: g.value }]) }, [
|
|
27
|
+
T(x.value) ? (c(), n("span", {
|
|
28
|
+
key: 0,
|
|
29
|
+
class: o(e.$style.progressBarAvailable),
|
|
30
|
+
style: s({ width: `${x.value.toFixed(2)}%` })
|
|
31
|
+
}, null, 6)) : t("", !0),
|
|
32
|
+
T(y.value) ? (c(), n("span", {
|
|
33
|
+
key: 1,
|
|
34
|
+
class: o(e.$style.progressBarToSpend),
|
|
35
|
+
style: s({ width: `${y.value.toFixed(2)}%` })
|
|
36
|
+
}, null, 6)) : t("", !0),
|
|
37
|
+
T(b.value) ? (c(), n("span", {
|
|
38
|
+
key: 2,
|
|
39
|
+
class: o(e.$style.progressBarUsed),
|
|
40
|
+
style: s({ width: `${b.value.toFixed(2)}%` })
|
|
41
|
+
}, null, 6)) : t("", !0)
|
|
42
|
+
], 2)
|
|
43
|
+
], 2), r("div", { class: o(e.$style.legends) }, [r("div", { class: o(e.$style.toSpendLegend) }, [m[4] ||= r("span", null, null, -1), i(" To spend: " + l(w(a.toSpend)), 1)], 2), r("div", { class: o(e.$style.usedLegend) }, [m[5] ||= r("span", null, null, -1), i(" Used: " + l(w(a.used)), 1)], 2)], 2)], 2)], 2));
|
|
44
|
+
}
|
|
81
45
|
});
|
|
82
|
-
export {
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
//# sourceMappingURL=LimitCard.vue2.js.map
|
|
46
|
+
export { m as default };
|
|
47
|
+
|
|
48
|
+
//# sourceMappingURL=LimitCard.vue2.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"LimitCard.
|
|
1
|
+
{"version":3,"file":"LimitCard.vue_vue_type_script_setup_true_lang.js","names":["$style"],"sources":["../../../src/plugins/Monetization/LimitCard.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed } from \"vue\";\n\nconst props = defineProps<{\n type: \"unique_launches\" | \"volume_limit\";\n label: string;\n used: number;\n toSpend: number;\n available: number | null; // If available is null it means Unlimited\n unit?: string;\n}>();\n\nconst total = computed(() => {\n if (props.available === null) return null;\n return props.available + props.toSpend + props.used;\n});\n\nconst exceeded = computed(() => {\n if (props.available === null) return false;\n return props.available < 0;\n});\n\nconst availableNow = computed(() => {\n if (props.available === null) return null;\n return props.available + props.toSpend;\n});\n\nconst clampPercentage = (n: number) => Math.max(0, Math.min(100, n));\n\nconst toSpendPercentage = computed(() => {\n if (total.value === null) return 0;\n if (total.value === 0) return 0;\n if (exceeded.value) return 0;\n return clampPercentage((props.toSpend / total.value) * 100);\n});\n\nconst usedPercentage = computed(() => {\n if (total.value === null) return 0;\n if (total.value === 0) return 0;\n return clampPercentage((props.used / total.value) * 100);\n});\n\nconst availablePercentage = computed(() => {\n if (props.available === null) return 100;\n if (total.value === null) return 100;\n if (total.value === 0) return 100;\n if (exceeded.value) return 0;\n return clampPercentage((props.available / total.value) * 100);\n});\n\nconst computedLabel = computed(() => {\n if (props.type === \"unique_launches\") return \"Runs Limits\";\n if (props.type === \"volume_limit\") return \"Volume Limits\";\n return props.label;\n});\n\nconst toGB = (v: number) => {\n return (v / 1024 / 1024 / 1024).toFixed(2) + \" GB\";\n};\n\nconst formatUnit = (v: number) => {\n if (props.type === \"volume_limit\") return toGB(v);\n return v;\n};\n\nconst showBar = (n: number) => {\n return Number(n.toFixed(2)) > 0;\n};\n</script>\n\n<template>\n <div :class=\"$style.container\">\n <span :class=\"$style.label\">{{ computedLabel }}</span>\n <div :class=\"$style.content\">\n <div :class=\"$style.contentAvailable\">\n <div>\n Available:\n <div style=\"flex: 1\" />\n <span v-if=\"availableNow !== null\"\n ><strong>{{ formatUnit(availableNow) }}</strong> /\n {{ formatUnit(available! + toSpend + used) }}</span\n >\n <span v-else>Unlimited</span>\n </div>\n <div :class=\"[$style.afterRun, { [$style.exceeded]: exceeded }]\">\n <span v-if=\"exceeded\">Too many files selected</span>\n <span style=\"flex: 1\" />\n <span>After run:</span>\n <span v-if=\"available !== null\"\n >{{ formatUnit(available) }} / {{ formatUnit(available + toSpend + used) }}</span\n >\n </div>\n <div :class=\"[$style.progressBar, { [$style.exceeded]: exceeded }]\">\n <span\n v-if=\"showBar(availablePercentage)\"\n :class=\"$style.progressBarAvailable\"\n :style=\"{ width: `${availablePercentage.toFixed(2)}%` }\"\n />\n <span\n v-if=\"showBar(toSpendPercentage)\"\n :class=\"$style.progressBarToSpend\"\n :style=\"{ width: `${toSpendPercentage.toFixed(2)}%` }\"\n />\n <span\n v-if=\"showBar(usedPercentage)\"\n :class=\"$style.progressBarUsed\"\n :style=\"{ width: `${usedPercentage.toFixed(2)}%` }\"\n />\n </div>\n </div>\n <div :class=\"$style.legends\">\n <div :class=\"$style.toSpendLegend\">\n <span />\n To spend: {{ formatUnit(toSpend) }}\n </div>\n <div :class=\"$style.usedLegend\">\n <span />\n Used: {{ formatUnit(used) }}\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<style module>\n.container {\n display: flex;\n flex-direction: column;\n background-color: var(--bg-base-light);\n border-radius: 6px;\n padding: 10px 12px 16px 12px;\n color: var(--txt-01);\n font-size: 14px;\n font-weight: 500;\n line-height: 20px;\n border: 1px solid var(--border-color-div-grey);\n}\n\n.label {\n display: block;\n min-height: 36px;\n margin-bottom: 8px;\n color: var(--txt-01);\n font-size: 14px;\n font-weight: 600;\n line-height: 20px; /* 142.857% */\n}\n\n.content {\n display: flex;\n flex-direction: column;\n gap: 16px;\n}\n\n.contentAvailable {\n display: flex;\n flex-direction: column;\n gap: 6px;\n > div {\n display: flex;\n align-items: flex-start;\n }\n > div:first-child {\n gap: 8px;\n strong {\n font-size: 28px;\n font-weight: 500;\n line-height: 36px; /* 128.571% */\n letter-spacing: -0.56px;\n }\n }\n}\n\n.afterRun {\n display: flex;\n align-items: center;\n justify-content: flex-end;\n gap: 4px;\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n color: var(--txt-03);\n &.exceeded {\n color: var(--txt-error);\n }\n}\n\n.progressBar {\n width: 100%;\n height: 12px;\n background-color: #e0e0e0;\n display: flex;\n align-items: center;\n border: 1px solid var(--border-color-default);\n > span {\n display: block;\n height: 100%;\n outline: 1px solid var(--border-color-default);\n }\n &.exceeded {\n opacity: 0.2;\n }\n}\n\n.progressBarAvailable {\n background: linear-gradient(270deg, #a1e59c 0%, #d0f5b0 98.81%);\n}\n\n.progressBarUsed {\n background-color: #ffcecc;\n}\n\n.progressBarToSpend {\n background-color: #faf5aa;\n}\n\n.legends {\n display: flex;\n justify-content: space-between;\n gap: 8px;\n\n span {\n display: block;\n border-radius: 1px;\n border: 1px solid var(--border-color-default);\n width: 12px;\n height: 12px;\n }\n}\n\n.usedLegend {\n display: flex;\n align-items: center;\n gap: 8px;\n span {\n background: #ffcecc;\n }\n}\n\n.toSpendLegend {\n display: flex;\n align-items: center;\n gap: 8px;\n span {\n background: #faf5aa;\n }\n}\n</style>\n"],"mappings":";;;;;;;;;;;;EAGA,IAAM,IAAQ,GASR,IAAQ,QACR,EAAM,cAAc,OAAa,OAC9B,EAAM,YAAY,EAAM,UAAU,EAAM,KAC/C,EAEI,IAAW,QACX,EAAM,cAAc,OAAa,KAC9B,EAAM,YAAY,EACzB,EAEI,IAAe,QACf,EAAM,cAAc,OAAa,OAC9B,EAAM,YAAY,EAAM,QAC/B,EAEI,KAAmB,MAAc,KAAK,IAAI,GAAG,KAAK,IAAI,KAAK,EAAE,CAAC,EAE9D,IAAoB,QACpB,EAAM,UAAU,QAChB,EAAM,UAAU,KAChB,EAAS,QAAc,IACpB,EAAiB,EAAM,UAAU,EAAM,QAAS,IAAI,CAC3D,EAEI,IAAiB,QACjB,EAAM,UAAU,QAChB,EAAM,UAAU,IAAU,IACvB,EAAiB,EAAM,OAAO,EAAM,QAAS,IAAI,CACxD,EAEI,IAAsB,QACtB,EAAM,cAAc,QACpB,EAAM,UAAU,QAChB,EAAM,UAAU,IAAU,MAC1B,EAAS,QAAc,IACpB,EAAiB,EAAM,YAAY,EAAM,QAAS,IAAI,CAC7D,EAEI,IAAgB,QAChB,EAAM,SAAS,oBAA0B,gBACzC,EAAM,SAAS,iBAAuB,kBACnC,EAAM,MACb,EAEI,KAAQ,OACJ,IAAI,OAAO,OAAO,MAAM,QAAQ,EAAE,GAAG,OAGzC,KAAc,MACd,EAAM,SAAS,iBAAuB,EAAK,EAAE,GAC1C,GAGH,KAAW,MACR,OAAO,EAAE,QAAQ,EAAE,CAAC,GAAG;yBAK9B,EAkDM,OAAA,EAlDA,OAAK,EAAEA,EAAAA,OAAO,UAAS,EAAA,EAAA,CAC3B,EAAsD,QAAA,EAA/C,OAAK,EAAEA,EAAAA,OAAO,MAAK,EAAA,EAAA,EAAK,EAAA,MAAa,EAAA,EAAA,EAC5C,EA+CM,OAAA,EA/CA,OAAK,EAAEA,EAAAA,OAAO,QAAO,EAAA,EAAA,CACzB,EAmCM,OAAA,EAnCA,OAAK,EAAEA,EAAAA,OAAO,iBAAgB,EAAA,EAAA;GAClC,EAQM,OAAA,MAAA;eARD,gBAEH,GAAA;aAAA,EAAuB,OAAA,EAAlB,OAAA,EAAA,MAAA,KAAe,EAAA,EAAA,MAAA,GAAA;IACR,EAAA,UAAY,QAEmB,GAAA,EAE3C,EAA6B,QAAA,GAAhB,YAAS,KAJE,GAAA,EAAxB,EAGC,QAAA,GAAA,CAFE,EAA+C,UAAA,MAAA,EAApC,EAAW,EAAA,MAAY,CAAA,EAAA,EAAA,EAAA,EAAa,QAChD,EAAG,EAAW,EAAA,YAAa,EAAA,UAAU,EAAA,KAAI,CAAA,EAAA,EAAA,CAAA,CAAA;;GAI7C,EAOM,OAAA,EAPA,OAAK,EAAA,CAAGA,EAAAA,OAAO,UAAQ,GAAKA,EAAAA,OAAO,WAAW,EAAA,OAAQ,CAAA,CAAA,EAAA,EAAA;IAC9C,EAAA,SAAA,GAAA,EAAZ,EAAoD,QAAA,GAA9B,0BAAuB,IAAA,EAAA,IAAA,GAAA;aAC7C,EAAwB,QAAA,EAAlB,OAAA,EAAA,MAAA,KAAe,EAAA,EAAA,MAAA,GAAA;aACrB,EAAuB,QAAA,MAAjB,cAAU,GAAA;IACJ,EAAA,cAAS,OACoD,EAAA,IAAA,GAAA,IADpD,GAAA,EAArB,EAEC,QAAA,GAAA,EADK,EAAW,EAAA,UAAS,CAAA,GAAI,QAAG,EAAG,EAAW,EAAA,YAAY,EAAA,UAAU,EAAA,KAAI,CAAA,EAAA,EAAA;;GAG3E,EAgBM,OAAA,EAhBA,OAAK,EAAA,CAAGA,EAAAA,OAAO,aAAW,GAAKA,EAAAA,OAAO,WAAW,EAAA,OAAQ,CAAA,CAAA,EAAA,EAAA;IAErD,EAAQ,EAAA,MAAmB,IAAA,GAAA,EADnC,EAIE,QAAA;;KAFC,OAAK,EAAEA,EAAAA,OAAO,qBAAoB;KAClC,OAAK,EAAA,EAAA,OAAA,GAAc,EAAA,MAAoB,QAAO,EAAA,CAAA,IAAA,CAAA;;IAGzC,EAAQ,EAAA,MAAiB,IAAA,GAAA,EADjC,EAIE,QAAA;;KAFC,OAAK,EAAEA,EAAAA,OAAO,mBAAkB;KAChC,OAAK,EAAA,EAAA,OAAA,GAAc,EAAA,MAAkB,QAAO,EAAA,CAAA,IAAA,CAAA;;IAGvC,EAAQ,EAAA,MAAc,IAAA,GAAA,EAD9B,EAIE,QAAA;;KAFC,OAAK,EAAEA,EAAAA,OAAO,gBAAe;KAC7B,OAAK,EAAA,EAAA,OAAA,GAAc,EAAA,MAAe,QAAO,EAAA,CAAA,IAAA,CAAA;;;SAIhD,EASM,OAAA,EATA,OAAK,EAAEA,EAAAA,OAAO,QAAO,EAAA,EAAA,CACzB,EAGM,OAAA,EAHA,OAAK,EAAEA,EAAAA,OAAO,cAAa,EAAA,EAAA,CAAA,AAAA,EAAA,OAC/B,EAAQ,QAAA,MAAA,MAAA,GAAA,EAAA,EAAA,gBACE,EAAG,EAAW,EAAA,QAAO,CAAA,EAAA,EAAA,CAAA,EAAA,EAAA,EAEjC,EAGM,OAAA,EAHA,OAAK,EAAEA,EAAAA,OAAO,WAAU,EAAA,EAAA,CAAA,AAAA,EAAA,OAC5B,EAAQ,QAAA,MAAA,MAAA,GAAA,EAAA,EAAA,YACF,EAAG,EAAW,EAAA,KAAI,CAAA,EAAA,EAAA,CAAA,EAAA,EAAA,CAAA,EAAA,EAAA,CAAA,EAAA,EAAA,CAAA,EAAA,EAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MonetizationSidebar.js","names":[],"sources":["../../../src/plugins/Monetization/MonetizationSidebar.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ref, computed } from \"vue\";\nimport {\n PlSlideModal,\n PlBtnGhost,\n PlDropdown,\n PlAlert,\n PlIcon24,\n PlBtnSecondary,\n} from \"@milaboratories/uikit\";\nimport { useButtonTarget } from \"./useButtonTarget\";\nimport { useInfo } from \"./useInfo\";\nimport UserCabinetCard from \"./UserCabinetCard.vue\";\nimport RunStatus from \"./RunStatus.vue\";\nimport LimitCard from \"./LimitCard.vue\";\nimport EndOfPeriod from \"./EndOfPeriod.vue\";\n\nconst isOpen = ref(false);\n\nconst {\n result,\n error,\n hasMonetization,\n canRun,\n status,\n customerEmail,\n endOfBillingPeriod,\n limits,\n refresh,\n isLoading,\n} = useInfo();\n\nconst teleportTarget = useButtonTarget(hasMonetization);\n\nconst productName = computed(() => result.value?.productName);\n\nconst userCabinetUrl = computed(() => {\n if (!result.value) return undefined;\n\n const u = new URL(`https://scientist.platforma.bio/product/${result.value.productKey}`);\n\n if (customerEmail.value) {\n u.searchParams.set(\"email\", customerEmail.value);\n }\n\n return u.toString();\n});\n\nconst options = computed(() => {\n if (!result.value) return [];\n\n return [\n {\n label: result.value.productName,\n value: result.value.productName,\n },\n ];\n});\n\nconst statusText = computed(() => {\n switch (status.value) {\n case \"active\":\n return \"\";\n case \"limits_exceeded\":\n return \"Usage limits exceeded for the current billing period.\";\n case \"payment_required\":\n return \"Payment required to continue using the service.\";\n case \"select-tariff\":\n return \"Select a subscription plan in the Scientist Cabinet.\";\n case \"inactive\":\n return \"Not found billing period.\";\n default:\n return \"\";\n }\n});\n\nconst btnIcon = computed(() => {\n if (canRun.value) return \"monetization-on\";\n return \"monetization-off\";\n});\n</script>\n\n<template>\n <PlSlideModal v-if=\"hasMonetization\" v-model=\"isOpen\">\n <template #title>\n <div class=\"flex items-center gap-2\">\n <span>Subscription</span>\n </div>\n </template>\n <PlDropdown label=\"Product\" readonly :model-value=\"productName\" :options=\"options\" />\n <RunStatus :can-run=\"canRun\" :is-loading=\"isLoading\" :status-text=\"statusText\">\n <PlBtnSecondary\n title=\"Refresh status\"\n round\n size=\"small\"\n style=\"margin-left: auto\"\n icon=\"loading\"\n :loading=\"isLoading\"\n @click=\"refresh\"\n />\n </RunStatus>\n <PlAlert v-if=\"error\" type=\"error\">\n {{ error }}\n </PlAlert>\n <UserCabinetCard\n v-if=\"userCabinetUrl\"\n :email=\"customerEmail\"\n :user-cabinet-url=\"userCabinetUrl\"\n />\n <EndOfPeriod v-if=\"endOfBillingPeriod\" :end-of-period=\"endOfBillingPeriod\" />\n <template v-if=\"limits\">\n <LimitCard\n v-for=\"limit in limits\"\n :key=\"limit.type\"\n :type=\"limit.type\"\n :label=\"limit.type\"\n :used=\"limit.used\"\n :to-spend=\"limit.toSpend\"\n :available=\"limit.available\"\n />\n </template>\n </PlSlideModal>\n <!-- Teleport to the title slot -->\n <Teleport v-if=\"hasMonetization && teleportTarget\" :to=\"teleportTarget\">\n <PlBtnGhost @click.stop=\"isOpen = true\">\n Subscription\n <template #append>\n <PlIcon24 :name=\"btnIcon\" />\n </template>\n </PlBtnGhost>\n </Teleport>\n</template>\n"],"mappings":""}
|
|
@@ -1,5 +1,106 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import { useButtonTarget as e } from "./useButtonTarget.js";
|
|
2
|
+
import { useInfo as t } from "./useInfo.js";
|
|
3
|
+
import n from "./UserCabinetCard.js";
|
|
4
|
+
import r from "./RunStatus.js";
|
|
5
|
+
import i from "./LimitCard.js";
|
|
6
|
+
import a from "./EndOfPeriod.js";
|
|
7
|
+
import { Fragment as o, Teleport as s, computed as c, createBlock as l, createCommentVNode as u, createElementBlock as d, createElementVNode as f, createTextVNode as p, createVNode as m, defineComponent as h, openBlock as g, ref as _, renderList as v, toDisplayString as y, unref as b, withCtx as x, withModifiers as S } from "vue";
|
|
8
|
+
import { PlAlert as C, PlBtnGhost as w, PlBtnSecondary as T, PlDropdown as E, PlIcon24 as D, PlSlideModal as O } from "@milaboratories/uikit";
|
|
9
|
+
var k = /* @__PURE__ */ h({
|
|
10
|
+
__name: "MonetizationSidebar",
|
|
11
|
+
setup(h) {
|
|
12
|
+
let k = _(!1), { result: A, error: j, hasMonetization: M, canRun: N, status: P, customerEmail: F, endOfBillingPeriod: I, limits: L, refresh: R, isLoading: z } = t(), B = e(M), V = c(() => A.value?.productName), H = c(() => {
|
|
13
|
+
if (!A.value) return;
|
|
14
|
+
let e = new URL(`https://scientist.platforma.bio/product/${A.value.productKey}`);
|
|
15
|
+
return F.value && e.searchParams.set("email", F.value), e.toString();
|
|
16
|
+
}), U = c(() => A.value ? [{
|
|
17
|
+
label: A.value.productName,
|
|
18
|
+
value: A.value.productName
|
|
19
|
+
}] : []), W = c(() => {
|
|
20
|
+
switch (P.value) {
|
|
21
|
+
case "active": return "";
|
|
22
|
+
case "limits_exceeded": return "Usage limits exceeded for the current billing period.";
|
|
23
|
+
case "payment_required": return "Payment required to continue using the service.";
|
|
24
|
+
case "select-tariff": return "Select a subscription plan in the Scientist Cabinet.";
|
|
25
|
+
case "inactive": return "Not found billing period.";
|
|
26
|
+
default: return "";
|
|
27
|
+
}
|
|
28
|
+
}), G = c(() => N.value ? "monetization-on" : "monetization-off");
|
|
29
|
+
return (e, t) => (g(), d(o, null, [b(M) ? (g(), l(b(O), {
|
|
30
|
+
key: 0,
|
|
31
|
+
modelValue: k.value,
|
|
32
|
+
"onUpdate:modelValue": t[0] ||= (e) => k.value = e
|
|
33
|
+
}, {
|
|
34
|
+
title: x(() => [...t[2] ||= [f("div", { class: "flex items-center gap-2" }, [f("span", null, "Subscription")], -1)]]),
|
|
35
|
+
default: x(() => [
|
|
36
|
+
m(b(E), {
|
|
37
|
+
label: "Product",
|
|
38
|
+
readonly: "",
|
|
39
|
+
"model-value": V.value,
|
|
40
|
+
options: U.value
|
|
41
|
+
}, null, 8, ["model-value", "options"]),
|
|
42
|
+
m(r, {
|
|
43
|
+
"can-run": b(N),
|
|
44
|
+
"is-loading": b(z),
|
|
45
|
+
"status-text": W.value
|
|
46
|
+
}, {
|
|
47
|
+
default: x(() => [m(b(T), {
|
|
48
|
+
title: "Refresh status",
|
|
49
|
+
round: "",
|
|
50
|
+
size: "small",
|
|
51
|
+
style: { "margin-left": "auto" },
|
|
52
|
+
icon: "loading",
|
|
53
|
+
loading: b(z),
|
|
54
|
+
onClick: b(R)
|
|
55
|
+
}, null, 8, ["loading", "onClick"])]),
|
|
56
|
+
_: 1
|
|
57
|
+
}, 8, [
|
|
58
|
+
"can-run",
|
|
59
|
+
"is-loading",
|
|
60
|
+
"status-text"
|
|
61
|
+
]),
|
|
62
|
+
b(j) ? (g(), l(b(C), {
|
|
63
|
+
key: 0,
|
|
64
|
+
type: "error"
|
|
65
|
+
}, {
|
|
66
|
+
default: x(() => [p(y(b(j)), 1)]),
|
|
67
|
+
_: 1
|
|
68
|
+
})) : u("", !0),
|
|
69
|
+
H.value ? (g(), l(n, {
|
|
70
|
+
key: 1,
|
|
71
|
+
email: b(F),
|
|
72
|
+
"user-cabinet-url": H.value
|
|
73
|
+
}, null, 8, ["email", "user-cabinet-url"])) : u("", !0),
|
|
74
|
+
b(I) ? (g(), l(a, {
|
|
75
|
+
key: 2,
|
|
76
|
+
"end-of-period": b(I)
|
|
77
|
+
}, null, 8, ["end-of-period"])) : u("", !0),
|
|
78
|
+
b(L) ? (g(!0), d(o, { key: 3 }, v(b(L), (e) => (g(), l(i, {
|
|
79
|
+
key: e.type,
|
|
80
|
+
type: e.type,
|
|
81
|
+
label: e.type,
|
|
82
|
+
used: e.used,
|
|
83
|
+
"to-spend": e.toSpend,
|
|
84
|
+
available: e.available
|
|
85
|
+
}, null, 8, [
|
|
86
|
+
"type",
|
|
87
|
+
"label",
|
|
88
|
+
"used",
|
|
89
|
+
"to-spend",
|
|
90
|
+
"available"
|
|
91
|
+
]))), 128)) : u("", !0)
|
|
92
|
+
]),
|
|
93
|
+
_: 1
|
|
94
|
+
}, 8, ["modelValue"])) : u("", !0), b(M) && b(B) ? (g(), l(s, {
|
|
95
|
+
key: 1,
|
|
96
|
+
to: b(B)
|
|
97
|
+
}, [m(b(w), { onClick: t[1] ||= S((e) => k.value = !0, ["stop"]) }, {
|
|
98
|
+
append: x(() => [m(b(D), { name: G.value }, null, 8, ["name"])]),
|
|
99
|
+
default: x(() => [t[3] ||= p(" Subscription ", -1)]),
|
|
100
|
+
_: 1
|
|
101
|
+
})], 8, ["to"])) : u("", !0)], 64));
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
export { k as default };
|
|
105
|
+
|
|
106
|
+
//# sourceMappingURL=MonetizationSidebar.vue2.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MonetizationSidebar.
|
|
1
|
+
{"version":3,"file":"MonetizationSidebar.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/plugins/Monetization/MonetizationSidebar.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ref, computed } from \"vue\";\nimport {\n PlSlideModal,\n PlBtnGhost,\n PlDropdown,\n PlAlert,\n PlIcon24,\n PlBtnSecondary,\n} from \"@milaboratories/uikit\";\nimport { useButtonTarget } from \"./useButtonTarget\";\nimport { useInfo } from \"./useInfo\";\nimport UserCabinetCard from \"./UserCabinetCard.vue\";\nimport RunStatus from \"./RunStatus.vue\";\nimport LimitCard from \"./LimitCard.vue\";\nimport EndOfPeriod from \"./EndOfPeriod.vue\";\n\nconst isOpen = ref(false);\n\nconst {\n result,\n error,\n hasMonetization,\n canRun,\n status,\n customerEmail,\n endOfBillingPeriod,\n limits,\n refresh,\n isLoading,\n} = useInfo();\n\nconst teleportTarget = useButtonTarget(hasMonetization);\n\nconst productName = computed(() => result.value?.productName);\n\nconst userCabinetUrl = computed(() => {\n if (!result.value) return undefined;\n\n const u = new URL(`https://scientist.platforma.bio/product/${result.value.productKey}`);\n\n if (customerEmail.value) {\n u.searchParams.set(\"email\", customerEmail.value);\n }\n\n return u.toString();\n});\n\nconst options = computed(() => {\n if (!result.value) return [];\n\n return [\n {\n label: result.value.productName,\n value: result.value.productName,\n },\n ];\n});\n\nconst statusText = computed(() => {\n switch (status.value) {\n case \"active\":\n return \"\";\n case \"limits_exceeded\":\n return \"Usage limits exceeded for the current billing period.\";\n case \"payment_required\":\n return \"Payment required to continue using the service.\";\n case \"select-tariff\":\n return \"Select a subscription plan in the Scientist Cabinet.\";\n case \"inactive\":\n return \"Not found billing period.\";\n default:\n return \"\";\n }\n});\n\nconst btnIcon = computed(() => {\n if (canRun.value) return \"monetization-on\";\n return \"monetization-off\";\n});\n</script>\n\n<template>\n <PlSlideModal v-if=\"hasMonetization\" v-model=\"isOpen\">\n <template #title>\n <div class=\"flex items-center gap-2\">\n <span>Subscription</span>\n </div>\n </template>\n <PlDropdown label=\"Product\" readonly :model-value=\"productName\" :options=\"options\" />\n <RunStatus :can-run=\"canRun\" :is-loading=\"isLoading\" :status-text=\"statusText\">\n <PlBtnSecondary\n title=\"Refresh status\"\n round\n size=\"small\"\n style=\"margin-left: auto\"\n icon=\"loading\"\n :loading=\"isLoading\"\n @click=\"refresh\"\n />\n </RunStatus>\n <PlAlert v-if=\"error\" type=\"error\">\n {{ error }}\n </PlAlert>\n <UserCabinetCard\n v-if=\"userCabinetUrl\"\n :email=\"customerEmail\"\n :user-cabinet-url=\"userCabinetUrl\"\n />\n <EndOfPeriod v-if=\"endOfBillingPeriod\" :end-of-period=\"endOfBillingPeriod\" />\n <template v-if=\"limits\">\n <LimitCard\n v-for=\"limit in limits\"\n :key=\"limit.type\"\n :type=\"limit.type\"\n :label=\"limit.type\"\n :used=\"limit.used\"\n :to-spend=\"limit.toSpend\"\n :available=\"limit.available\"\n />\n </template>\n </PlSlideModal>\n <!-- Teleport to the title slot -->\n <Teleport v-if=\"hasMonetization && teleportTarget\" :to=\"teleportTarget\">\n <PlBtnGhost @click.stop=\"isOpen = true\">\n Subscription\n <template #append>\n <PlIcon24 :name=\"btnIcon\" />\n </template>\n </PlBtnGhost>\n </Teleport>\n</template>\n"],"mappings":";;;;;;;;;;;EAiBA,IAAM,IAAS,EAAI,GAAM,EAEnB,EACJ,WACA,UACA,oBACA,WACA,WACA,kBACA,uBACA,WACA,YACA,iBACE,GAAS,EAEP,IAAiB,EAAgB,EAAgB,EAEjD,IAAc,QAAe,EAAO,OAAO,YAAY,EAEvD,IAAiB,QAAe;AACpC,OAAI,CAAC,EAAO,MAAO;GAEnB,IAAM,IAAI,IAAI,IAAI,2CAA2C,EAAO,MAAM,aAAa;AAMvF,UAJI,EAAc,SAChB,EAAE,aAAa,IAAI,SAAS,EAAc,MAAM,EAG3C,EAAE,UAAU;IACnB,EAEI,IAAU,QACT,EAAO,QAEL,CACL;GACE,OAAO,EAAO,MAAM;GACpB,OAAO,EAAO,MAAM;GACrB,CACF,GAPyB,EAAE,CAQ5B,EAEI,IAAa,QAAe;AAChC,WAAQ,EAAO,OAAf;IACE,KAAK,SACH,QAAO;IACT,KAAK,kBACH,QAAO;IACT,KAAK,mBACH,QAAO;IACT,KAAK,gBACH,QAAO;IACT,KAAK,WACH,QAAO;IACT,QACE,QAAO;;IAEX,EAEI,IAAU,QACV,EAAO,QAAc,oBAClB,mBACP;qCAIoB,EAAA,EAAe,IAAA,GAAA,EAAnC,EAsCe,EAAA,EAAA,EAAA;;eAtC+B,EAAA;4CAAM,QAAA;;GACvC,OAAK,QAGR,CAAA,GAAA,AAAA,EAAA,OAAA,CAFN,EAEM,OAAA,EAFD,OAAM,2BAAyB,EAAA,CAClC,EAAyB,QAAA,MAAnB,eAAY,CAAA,EAAA,GAAA,CAAA,CAAA,CAAA;oBAG+D;IAArF,EAAqF,EAAA,EAAA,EAAA;KAAzE,OAAM;KAAU,UAAA;KAAU,eAAa,EAAA;KAAc,SAAS,EAAA;;IAC1E,EAUY,GAAA;KAVA,WAAS,EAAA,EAAM;KAAG,cAAY,EAAA,EAAS;KAAG,eAAa,EAAA;;sBAS/D,CARF,EAQE,EAAA,EAAA,EAAA;MAPA,OAAM;MACN,OAAA;MACA,MAAK;MACL,OAAA,EAAA,eAAA,QAAyB;MACzB,MAAK;MACJ,SAAS,EAAA,EAAS;MAClB,SAAO,EAAA,EAAO;;;;;;;;IAGJ,EAAA,EAAK,IAAA,GAAA,EAApB,EAEU,EAAA,EAAA,EAAA;;KAFY,MAAK;;sBACd,CAAA,EAAA,EAAR,EAAA,EAAK,CAAA,EAAA,EAAA,CAAA,CAAA;;;IAGF,EAAA,SAAA,GAAA,EADR,EAIE,GAAA;;KAFC,OAAO,EAAA,EAAa;KACpB,oBAAkB,EAAA;;IAEF,EAAA,EAAkB,IAAA,GAAA,EAArC,EAA6E,GAAA;;KAArC,iBAAe,EAAA,EAAkB;;IACzD,EAAA,EAAM,IAAA,EAAA,GAAA,EACpB,EAQE,GAAA,EAAA,KAAA,GAAA,EAAA,EAPgB,EAAA,EAAM,GAAf,YADT,EAQE,GAAA;KANC,KAAK,EAAM;KACX,MAAM,EAAM;KACZ,OAAO,EAAM;KACb,MAAM,EAAM;KACZ,YAAU,EAAM;KAChB,WAAW,EAAM;;;;;;;;;;sCAKR,EAAA,EAAe,IAAI,EAAA,EAAc,IAAA,GAAA,EAAjD,EAOW,GAAA;;GAPyC,IAAI,EAAA,EAAc;MACpE,EAKa,EAAA,EAAA,EAAA,EALA,SAAK,AAAA,EAAA,OAAA,GAAA,MAAO,EAAA,QAAM,IAAA,CAAA,OAAA,CAAA,EAAA,EAAA;GAElB,QAAM,QACa,CAA5B,EAA4B,EAAA,EAAA,EAAA,EAAjB,MAAM,EAAA,OAAO,EAAA,MAAA,GAAA,CAAA,OAAA,CAAA,CAAA,CAAA;oBAD1B,CAAA,AAAA,EAAA,OAAA,EAFsC,kBAEtC,GAAA,CAAA,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import e from "../../_virtual/_plugin-vue_export-helper.js";
|
|
2
|
+
import t from "./RunStatus.vue2.js";
|
|
3
|
+
import n from "./RunStatus.style.js";
|
|
4
|
+
var r = /* @__PURE__ */ e(t, [["__cssModules", { $style: n }]]);
|
|
5
|
+
export { r as default };
|
|
6
|
+
|
|
7
|
+
//# sourceMappingURL=RunStatus.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RunStatus.js","names":[],"sources":["../../../src/plugins/Monetization/RunStatus.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed } from \"vue\";\n\nconst props = defineProps<{\n canRun: boolean | undefined;\n statusText: string | undefined;\n isLoading?: boolean;\n}>();\n\nconst badgeText = computed(() => {\n if (props.isLoading) {\n return \"Updating...\";\n }\n\n if (props.canRun) {\n return \"Ready to run\";\n }\n\n return \"Cannot run\";\n});\n</script>\n\n<template>\n <div>\n <div :class=\"[{ [$style['can-run']]: canRun, [$style.loading]: isLoading }, $style.container]\">\n <div :class=\"$style.badge\">\n <i :class=\"$style.blob\">\n <span>\n <span :class=\"$style.dot\" />\n </span>\n </i>\n <span>{{ badgeText }}</span>\n </div>\n <slot />\n </div>\n <div v-if=\"statusText\" :class=\"$style.statusText\">{{ statusText }}</div>\n </div>\n</template>\n\n<style module>\n.container {\n display: flex;\n align-items: center;\n gap: 8px;\n --blob-color: #ff5c5c;\n --badge-background: rgba(255, 92, 92, 0.12);\n\n &.can-run {\n --blob-color: #49cc49;\n --badge-background: rgba(99, 224, 36, 0.12);\n }\n\n &.loading {\n --blob-color: #ffad0a;\n --badge-background: rgba(255, 173, 10, 0.12);\n }\n}\n\n.statusText {\n margin-top: 6px;\n color: var(--txt-error);\n font-size: 14px;\n font-weight: 500;\n line-height: 20px;\n}\n\n.badge {\n display: flex;\n gap: 6px;\n height: 40px;\n padding: 6px 16px 6px 8px;\n align-items: center;\n border-radius: 6px;\n border: 1px solid var(--badge-background);\n background: var(--badge-background);\n}\n\n.blob {\n width: 24px;\n height: 24px;\n display: flex;\n place-items: center;\n place-content: center;\n\n > span {\n display: flex;\n width: 16px;\n height: 16px;\n border-radius: 50%;\n place-content: center;\n place-items: center;\n background-color: rgb(from var(--blob-color) r g b / 0.24);\n }\n\n .dot {\n border-radius: 50%;\n height: 8px;\n width: 8px;\n transform: scale(1);\n\n background: var(--blob-color);\n box-shadow: 0 0 0 0 var(--blob-color);\n animation: pulse-glob 1s infinite;\n }\n}\n</style>\n"],"mappings":""}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import './RunStatus.vue.css';var e = {
|
|
2
|
+
container: "_container_13j78_2",
|
|
3
|
+
"can-run": "_can-run_13j78_9",
|
|
4
|
+
loading: "_loading_13j78_14",
|
|
5
|
+
statusText: "_statusText_13j78_20",
|
|
6
|
+
badge: "_badge_13j78_28",
|
|
7
|
+
blob: "_blob_13j78_39",
|
|
8
|
+
"pulse-glob": "_pulse-glob_13j78_1",
|
|
9
|
+
dot: "_dot_13j78_56"
|
|
10
|
+
};
|
|
11
|
+
export { e as default };
|
|
12
|
+
|
|
13
|
+
//# sourceMappingURL=RunStatus.style.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RunStatus.vue_vue_type_style_index_0_lang.module.js","names":[],"sources":["../../../src/plugins/Monetization/RunStatus.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed } from \"vue\";\n\nconst props = defineProps<{\n canRun: boolean | undefined;\n statusText: string | undefined;\n isLoading?: boolean;\n}>();\n\nconst badgeText = computed(() => {\n if (props.isLoading) {\n return \"Updating...\";\n }\n\n if (props.canRun) {\n return \"Ready to run\";\n }\n\n return \"Cannot run\";\n});\n</script>\n\n<template>\n <div>\n <div :class=\"[{ [$style['can-run']]: canRun, [$style.loading]: isLoading }, $style.container]\">\n <div :class=\"$style.badge\">\n <i :class=\"$style.blob\">\n <span>\n <span :class=\"$style.dot\" />\n </span>\n </i>\n <span>{{ badgeText }}</span>\n </div>\n <slot />\n </div>\n <div v-if=\"statusText\" :class=\"$style.statusText\">{{ statusText }}</div>\n </div>\n</template>\n\n<style module>\n.container {\n display: flex;\n align-items: center;\n gap: 8px;\n --blob-color: #ff5c5c;\n --badge-background: rgba(255, 92, 92, 0.12);\n\n &.can-run {\n --blob-color: #49cc49;\n --badge-background: rgba(99, 224, 36, 0.12);\n }\n\n &.loading {\n --blob-color: #ffad0a;\n --badge-background: rgba(255, 173, 10, 0.12);\n }\n}\n\n.statusText {\n margin-top: 6px;\n color: var(--txt-error);\n font-size: 14px;\n font-weight: 500;\n line-height: 20px;\n}\n\n.badge {\n display: flex;\n gap: 6px;\n height: 40px;\n padding: 6px 16px 6px 8px;\n align-items: center;\n border-radius: 6px;\n border: 1px solid var(--badge-background);\n background: var(--badge-background);\n}\n\n.blob {\n width: 24px;\n height: 24px;\n display: flex;\n place-items: center;\n place-content: center;\n\n > span {\n display: flex;\n width: 16px;\n height: 16px;\n border-radius: 50%;\n place-content: center;\n place-items: center;\n background-color: rgb(from var(--blob-color) r g b / 0.24);\n }\n\n .dot {\n border-radius: 50%;\n height: 8px;\n width: 8px;\n transform: scale(1);\n\n background: var(--blob-color);\n box-shadow: 0 0 0 0 var(--blob-color);\n animation: pulse-glob 1s infinite;\n }\n}\n</style>\n"],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
._container_13j78_2{--blob-color:#ff5c5c;--badge-background:#ff5c5c1f;align-items:center;gap:8px;display:flex}._container_13j78_2._can-run_13j78_9{--blob-color:#49cc49;--badge-background:#63e0241f}._container_13j78_2._loading_13j78_14{--blob-color:#ffad0a;--badge-background:#ffad0a1f}._statusText_13j78_20{color:var(--txt-error);margin-top:6px;font-size:14px;font-weight:500;line-height:20px}._badge_13j78_28{border:1px solid var(--badge-background);background:var(--badge-background);border-radius:6px;align-items:center;gap:6px;height:40px;padding:6px 16px 6px 8px;display:flex}._blob_13j78_39{place-content:center;place-items:center;width:24px;height:24px;display:flex}._blob_13j78_39>span{background-color:rgb(from var(--blob-color) r g b / .24);border-radius:50%;place-content:center;place-items:center;width:16px;height:16px;display:flex}._blob_13j78_39 ._dot_13j78_56{background:var(--blob-color);width:8px;height:8px;box-shadow:0 0 0 0 var(--blob-color);border-radius:50%;animation:1s infinite _pulse-glob_13j78_1;transform:scale(1)}
|
|
@@ -1,41 +1,22 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
class: a(e.$style.blob)
|
|
20
|
-
}, [
|
|
21
|
-
n("span", null, [
|
|
22
|
-
n("span", {
|
|
23
|
-
class: a(e.$style.dot)
|
|
24
|
-
}, null, 2)
|
|
25
|
-
])
|
|
26
|
-
], 2),
|
|
27
|
-
n("span", null, u(r.value), 1)
|
|
28
|
-
], 2),
|
|
29
|
-
y(e.$slots, "default")
|
|
30
|
-
], 2),
|
|
31
|
-
t.statusText ? (o(), l("div", {
|
|
32
|
-
key: 0,
|
|
33
|
-
class: a(e.$style.statusText)
|
|
34
|
-
}, u(t.statusText), 3)) : c("", !0)
|
|
35
|
-
]));
|
|
36
|
-
}
|
|
1
|
+
import { computed as e, createCommentVNode as t, createElementBlock as n, createElementVNode as r, defineComponent as i, normalizeClass as a, openBlock as o, renderSlot as s, toDisplayString as c } from "vue";
|
|
2
|
+
var l = /* @__PURE__ */ i({
|
|
3
|
+
__name: "RunStatus",
|
|
4
|
+
props: {
|
|
5
|
+
canRun: { type: Boolean },
|
|
6
|
+
statusText: {},
|
|
7
|
+
isLoading: { type: Boolean }
|
|
8
|
+
},
|
|
9
|
+
setup(i) {
|
|
10
|
+
let l = i, u = e(() => l.isLoading ? "Updating..." : l.canRun ? "Ready to run" : "Cannot run");
|
|
11
|
+
return (e, l) => (o(), n("div", null, [r("div", { class: a([{
|
|
12
|
+
[e.$style["can-run"]]: i.canRun,
|
|
13
|
+
[e.$style.loading]: i.isLoading
|
|
14
|
+
}, e.$style.container]) }, [r("div", { class: a(e.$style.badge) }, [r("i", { class: a(e.$style.blob) }, [r("span", null, [r("span", { class: a(e.$style.dot) }, null, 2)])], 2), r("span", null, c(u.value), 1)], 2), s(e.$slots, "default")], 2), i.statusText ? (o(), n("div", {
|
|
15
|
+
key: 0,
|
|
16
|
+
class: a(e.$style.statusText)
|
|
17
|
+
}, c(i.statusText), 3)) : t("", !0)]));
|
|
18
|
+
}
|
|
37
19
|
});
|
|
38
|
-
export {
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
//# sourceMappingURL=RunStatus.vue2.js.map
|
|
20
|
+
export { l as default };
|
|
21
|
+
|
|
22
|
+
//# sourceMappingURL=RunStatus.vue2.js.map
|