diff --git a/build/tsup.config.ts b/build/tsup.config.ts index 512866f8..fdbf1814 100644 --- a/build/tsup.config.ts +++ b/build/tsup.config.ts @@ -37,7 +37,7 @@ ${ if (!dev) { plugins.push( budgetPlugin(pkg.psv.budget), - scssBundlePlugin(), + // scssBundlePlugin(), assetsPlugin({ 'LICENSE': license(), '.npmrc': npmrc(), diff --git a/packages/compass-plugin/src/style.scss b/packages/compass-plugin/src/style.scss index a23c9836..763b04ab 100644 --- a/packages/compass-plugin/src/style.scss +++ b/packages/compass-plugin/src/style.scss @@ -1,4 +1,4 @@ -@import '../../shared/vars'; +@use '../../shared/vars'; $psv-compass-margin: 10px !default; diff --git a/packages/core/src/styles/index.scss b/packages/core/src/styles/index.scss index 81e6e3f0..b91da5a7 100644 --- a/packages/core/src/styles/index.scss +++ b/packages/core/src/styles/index.scss @@ -1,12 +1,9 @@ -@use 'sass:list'; -@use 'sass:map'; -@use 'sass:math'; -@import '../../../shared/vars'; -@import 'viewer'; -@import 'loader'; -@import 'navbar'; -@import 'zoom-range'; -@import 'notification'; -@import 'overlay'; -@import 'panel'; -@import 'tooltip'; +@use 'viewer'; +@use 'loader'; +@use 'navbar'; +@use 'zoom-range'; +@use 'notification'; +@use 'overlay'; +@use 'panel'; +@use 'tooltip'; +@forward '../../../shared/vars'; diff --git a/packages/core/src/styles/loader.scss b/packages/core/src/styles/loader.scss index 357ddb3c..2d2135f3 100644 --- a/packages/core/src/styles/loader.scss +++ b/packages/core/src/styles/loader.scss @@ -1,3 +1,5 @@ +@use '../../../shared/vars' as psv; + .psv-loader-container { display: flex; align-items: center; @@ -7,20 +9,20 @@ left: 0; width: 100%; height: 100%; - z-index: $psv-loader-zindex; + z-index: psv.$loader-zindex; } .psv-loader { - --psv-loader-border: #{$psv-loader-border}; - --psv-loader-tickness: #{$psv-loader-tickness}; + --psv-loader-border: #{psv.$loader-border}; + --psv-loader-tickness: #{psv.$loader-tickness}; position: relative; display: flex; justify-content: center; align-items: center; - color: $psv-loader-color; - width: $psv-loader-width; - height: $psv-loader-width; + color: psv.$loader-color; + width: psv.$loader-width; + height: psv.$loader-width; &-canvas { position: absolute; @@ -28,12 +30,12 @@ left: 0; width: 100%; height: 100%; - color: $psv-loader-bg-color; + color: psv.$loader-bg-color; z-index: -1; } &-text { - font: $psv-loader-font; + font: psv.$loader-font; text-align: center; } } diff --git a/packages/core/src/styles/navbar.scss b/packages/core/src/styles/navbar.scss index 96fc611e..32e7bd01 100644 --- a/packages/core/src/styles/navbar.scss +++ b/packages/core/src/styles/navbar.scss @@ -1,14 +1,17 @@ +@use 'sass:list'; +@use '../../../shared/vars' as psv; + .psv-navbar { display: flex; position: absolute; - z-index: $psv-navbar-zindex; - bottom: -$psv-navbar-height; + z-index: psv.$navbar-zindex; + bottom: -#{psv.$navbar-height}; left: 0; width: 100%; - height: $psv-navbar-height; - background: $psv-navbar-background; + height: psv.$navbar-height; + background: psv.$navbar-background; transition: bottom ease-in-out 0.1s; - font: $psv-caption-font; + font: psv.$caption-font; cursor: default; &--open { @@ -23,47 +26,47 @@ .psv-button { flex: 0 0 auto; - padding: $psv-buttons-padding; + padding: psv.$buttons-padding; position: relative; cursor: pointer; - height: $psv-buttons-height; - width: $psv-buttons-height; - background: $psv-buttons-background; - color: $psv-buttons-color; + height: psv.$buttons-height; + width: psv.$buttons-height; + background: psv.$buttons-background; + color: psv.$buttons-color; &--active { - background: $psv-buttons-active-background; + background: psv.$buttons-active-background; } &--disabled { pointer-events: none; - opacity: $psv-buttons-disabled-opacity; + opacity: psv.$buttons-disabled-opacity; } &-svg { width: 100%; transform: scale(1); - transition: transform $psv-buttons-hover-scale-delay ease; + transition: transform psv.$buttons-hover-scale-delay ease; vertical-align: initial; } } .psv-button:not(.psv-button--disabled):focus-visible { - outline: $psv-element-focus-outline; - outline-offset: -#{list.nth($psv-element-focus-outline, 1)}; + outline: psv.$element-focus-outline; + outline-offset: -#{list.nth(psv.$element-focus-outline, 1)}; } .psv-container:not(.psv--is-touch) .psv-button--hover-scale:not(.psv-button--disabled):hover .psv-button-svg { - transform: scale($psv-buttons-hover-scale); + transform: scale(psv.$buttons-hover-scale); } .psv-move-button + .psv-move-button { - margin-left: -$psv-buttons-padding; + margin-left: -#{psv.$buttons-padding}; } .psv-custom-button { width: auto; - min-width: $psv-buttons-height; + min-width: psv.$buttons-height; &--no-padding { padding: 0; @@ -73,7 +76,7 @@ .psv-caption { flex: 1 1 100%; - color: $psv-caption-text-color; + color: psv.$caption-text-color; overflow: hidden; text-align: center; cursor: unset; @@ -83,7 +86,7 @@ &-content { display: inline-block; - padding: $psv-buttons-padding; + padding: psv.$buttons-padding; white-space: nowrap; } } diff --git a/packages/core/src/styles/notification.scss b/packages/core/src/styles/notification.scss index c3adacfa..b309ed95 100644 --- a/packages/core/src/styles/notification.scss +++ b/packages/core/src/styles/notification.scss @@ -1,7 +1,9 @@ +@use '../../../shared/vars' as psv; + .psv-notification { position: absolute; - z-index: $psv-notification-zindex; - bottom: $psv-notification-position-from; + z-index: psv.$notification-zindex; + bottom: psv.$notification-position-from; display: flex; justify-content: center; box-sizing: border-box; @@ -10,19 +12,19 @@ opacity: 0; transition-property: opacity, bottom; transition-timing-function: ease-in-out; - transition-duration: $psv-notification-animate-delay; + transition-duration: psv.$notification-animate-delay; &-content { max-width: 50em; - background: $psv-notification-background; - border-radius: $psv-notification-radius; - padding: $psv-notification-padding; - font: $psv-notification-font; - color: $psv-notification-text-color; + background: psv.$notification-background; + border-radius: psv.$notification-radius; + padding: psv.$notification-padding; + font: psv.$notification-font; + color: psv.$notification-text-color; } &--visible { opacity: 100; - bottom: $psv-notification-position-to; + bottom: psv.$notification-position-to; } } diff --git a/packages/core/src/styles/overlay.scss b/packages/core/src/styles/overlay.scss index eedb1c70..968cb2a7 100644 --- a/packages/core/src/styles/overlay.scss +++ b/packages/core/src/styles/overlay.scss @@ -1,39 +1,42 @@ +@use 'sass:map'; +@use '../../../shared/vars' as psv; + .psv-overlay { display: flex; flex-direction: column; align-items: center; justify-content: center; position: absolute; - z-index: $psv-overlay-zindex; + z-index: psv.$overlay-zindex; inset: 0; - background: $psv-main-background; - opacity: $psv-overlay-opacity; + background: psv.$main-background; + opacity: psv.$overlay-opacity; cursor: default; &-image { width: 100%; text-align: center; - color: $psv-overlay-icon-color; + color: psv.$overlay-icon-color; svg { - width: map.get($psv-overlay-image-size, portrait); + width: map.get(psv.$overlay-image-size, portrait); @container psv-container (orientation: landscape) { - width: map.get($psv-overlay-image-size, landscape); + width: map.get(psv.$overlay-image-size, landscape); } } } &-title { - color: $psv-overlay-title-color; + color: psv.$overlay-title-color; margin-top: 1em; - font: $psv-overlay-title-font; + font: psv.$overlay-title-font; text-align: center; } &-text { - color: $psv-overlay-text-color; - font: $psv-overlay-text-font; + color: psv.$overlay-text-color; + font: psv.$overlay-text-font; opacity: 0.8; text-align: center; } diff --git a/packages/core/src/styles/panel.scss b/packages/core/src/styles/panel.scss index 1b76feb6..3f83770e 100644 --- a/packages/core/src/styles/panel.scss +++ b/packages/core/src/styles/panel.scss @@ -1,3 +1,7 @@ +@use 'sass:math'; +@use 'sass:list'; +@use '../../../shared/vars' as psv; + @function make-dot-shadow($color, $w, $h) { $val: 1px 0 $color; $x: 3; @@ -18,22 +22,22 @@ .psv-panel { position: absolute; - z-index: $psv-panel-zindex; + z-index: psv.$panel-zindex; right: 0; height: 100%; - width: $psv-panel-width; - max-width: calc(100% - #{$psv-panel-resizer-width}); - background: $psv-panel-background; + width: psv.$panel-width; + max-width: calc(100% - #{psv.$panel-resizer-width}); + background: psv.$panel-background; transform: translate3d(100%, 0, 0); opacity: 0; transition-property: opacity, transform; transition-timing-function: ease-in-out; - transition-duration: $psv-panel-animate-delay; + transition-duration: psv.$panel-animate-delay; cursor: default; - margin-left: $psv-panel-resizer-width; + margin-left: psv.$panel-resizer-width; .psv--has-navbar & { - height: calc(100% - #{$psv-navbar-height}); + height: calc(100% - #{psv.$navbar-height}); } &-close-button { @@ -41,20 +45,20 @@ position: absolute; top: -1px; right: 0; - width: math.div($psv-panel-close-button-size, 5) * 3; - height: math.div($psv-panel-close-button-size, 5) * 3; - padding: math.div($psv-panel-close-button-size, 5); + width: math.div(psv.$panel-close-button-size, 5) * 3; + height: math.div(psv.$panel-close-button-size, 5) * 3; + padding: math.div(psv.$panel-close-button-size, 5); background: transparent; - color: $psv-panel-close-button-color; - transition: background $psv-panel-close-button-animate-delay ease-in-out; + color: psv.$panel-close-button-color; + transition: background psv.$panel-close-button-animate-delay ease-in-out; cursor: pointer; svg { - transition: transform $psv-panel-close-button-animate-delay ease-in-out; + transition: transform psv.$panel-close-button-animate-delay ease-in-out; } &:hover { - background: $psv-panel-close-button-background; + background: psv.$panel-close-button-background; svg { transform: scale(-1); @@ -66,27 +70,27 @@ display: none; position: absolute; top: 0; - left: -$psv-panel-resizer-width; - width: $psv-panel-resizer-width; + left: -#{psv.$panel-resizer-width}; + width: psv.$panel-resizer-width; height: 100%; - background-color: $psv-panel-resizer-background; + background-color: psv.$panel-resizer-background; cursor: col-resize; - $psv-panel-resizer-grip-width: $psv-panel-resizer-width - 4px; + $panel-resizer-grip-width: psv.$panel-resizer-width - 4px; - @if $psv-panel-resizer-grip-width > 0 { + @if $panel-resizer-grip-width > 0 { &::before { content: ''; position: absolute; top: 50%; - left: ($psv-panel-resizer-width - $psv-panel-resizer-grip-width) * 0.5 - 1px; - margin-top: (-$psv-panel-resizer-grip-height * 0.5); + left: #{psv.$panel-resizer-width - $panel-resizer-grip-width * 0.5 - 1px}; + margin-top: -#{psv.$panel-resizer-grip-height * 0.5}; width: 1px; height: 1px; box-shadow: make-dot-shadow( - $psv-panel-resizer-grip-color, - $psv-panel-resizer-grip-width, - $psv-panel-resizer-grip-height + psv.$panel-resizer-grip-color, + $panel-resizer-grip-width, + psv.$panel-resizer-grip-height ); background: transparent; } @@ -97,12 +101,12 @@ width: 100%; height: 100%; box-sizing: border-box; - color: $psv-panel-text-color; - font: $psv-panel-font; + color: psv.$panel-text-color; + font: psv.$panel-font; overflow: auto; &:not(&--no-margin) { - padding: $psv-panel-padding; + padding: psv.$panel-padding; } &--no-interaction { @@ -122,7 +126,7 @@ } } - @container psv-container (max-width: #{$psv-panel-width}) { + @container psv-container (max-width: #{psv.$panel-width}) { width: 100% !important; max-width: none; @@ -141,14 +145,14 @@ flex: none; display: flex; align-items: center; - font: $psv-panel-title-font; - margin: $psv-panel-title-margin $psv-panel-title-margin * 0.5; + font: psv.$panel-title-font; + margin: psv.$panel-title-margin psv.$panel-title-margin * 0.5; /* stylelint-disable-next-line no-descending-specificity */ svg { - width: $psv-panel-title-icon-size; - height: $psv-panel-title-icon-size; - margin-right: $psv-panel-title-margin * 0.5; + width: psv.$panel-title-icon-size; + height: psv.$panel-title-icon-size; + margin-right: psv.$panel-title-margin * 0.5; } } @@ -161,8 +165,8 @@ } &-item { - min-height: $psv-panel-menu-item-height; - padding: $psv-panel-menu-item-padding; + min-height: psv.$panel-menu-item-height; + padding: psv.$panel-menu-item-padding; cursor: pointer; display: flex; align-items: center; @@ -170,15 +174,15 @@ transition: background 0.1s ease-in-out; &--active { - outline: $psv-panel-menu-item-active-outline solid currentcolor; - outline-offset: -$psv-panel-menu-item-active-outline; + outline: psv.$panel-menu-item-active-outline solid currentcolor; + outline-offset: -#{psv.$panel-menu-item-active-outline}; } &-icon { flex: none; - height: $psv-panel-menu-item-height; - width: $psv-panel-menu-item-height; - margin-right: #{list.nth($psv-panel-menu-item-padding, 1)}; + height: psv.$panel-menu-item-height; + width: psv.$panel-menu-item-height; + margin-right: #{list.nth(psv.$panel-menu-item-padding, 1)}; img { max-width: 100%; @@ -193,28 +197,28 @@ } &:focus-visible { - outline: $psv-element-focus-outline; - outline-offset: -#{list.nth($psv-element-focus-outline, 1)}; + outline: psv.$element-focus-outline; + outline-offset: -#{list.nth(psv.$element-focus-outline, 1)}; } } &--stripped &-item { &:hover { - background: $psv-panel-menu-hover-background; + background: psv.$panel-menu-hover-background; } &:nth-child(odd), &:nth-child(odd)::before { - background: $psv-panel-menu-odd-background; + background: psv.$panel-menu-odd-background; } &:nth-child(even), &:nth-child(even)::before { - background: $psv-panel-menu-even-background; + background: psv.$panel-menu-even-background; } } } .psv-container:not(.psv--is-touch) .psv-panel-menu-item:hover { - background: $psv-panel-menu-hover-background; + background: psv.$panel-menu-hover-background; } diff --git a/packages/core/src/styles/tooltip.scss b/packages/core/src/styles/tooltip.scss index 0452ea51..ba5e8b5b 100644 --- a/packages/core/src/styles/tooltip.scss +++ b/packages/core/src/styles/tooltip.scss @@ -1,104 +1,106 @@ +@use '../../../shared/vars' as psv; + .psv-tooltip { position: absolute; - z-index: $psv-tooltip-zindex; + z-index: psv.$tooltip-zindex; box-sizing: border-box; - max-width: $psv-tooltip-max-width; - background: $psv-tooltip-background; - border-radius: $psv-tooltip-radius; + max-width: psv.$tooltip-max-width; + background: psv.$tooltip-background; + border-radius: psv.$tooltip-radius; opacity: 0; transition-property: opacity, transform; transition-timing-function: ease-in-out; - transition-duration: $psv-tooltip-animate-delay; + transition-duration: psv.$tooltip-animate-delay; cursor: default; &-content { - color: $psv-tooltip-text-color; - font: $psv-tooltip-font; - text-shadow: $psv-tooltip-text-shadow; - padding: $psv-tooltip-padding; + color: psv.$tooltip-text-color; + font: psv.$tooltip-font; + text-shadow: psv.$tooltip-text-shadow; + padding: psv.$tooltip-padding; } &-arrow { position: absolute; height: 0; width: 0; - border: $psv-tooltip-arrow-size solid transparent; + border: psv.$tooltip-arrow-size solid transparent; } &--top-left, &--top-center, &--top-right { - transform: translate3d(0, $psv-tooltip-animate-offset, 0); + transform: translate3d(0, psv.$tooltip-animate-offset, 0); .psv-tooltip-arrow { - border-top-color: $psv-tooltip-background; + border-top-color: psv.$tooltip-background; } } &--bottom-left, &--bottom-center, &--bottom-right { - transform: translate3d(0, -$psv-tooltip-animate-offset, 0); + transform: translate3d(0, -#{psv.$tooltip-animate-offset}, 0); .psv-tooltip-arrow { - border-bottom-color: $psv-tooltip-background; + border-bottom-color: psv.$tooltip-background; } } &--left-top, &--center-left, &--left-bottom { - transform: translate3d($psv-tooltip-animate-offset, 0, 0); + transform: translate3d(psv.$tooltip-animate-offset, 0, 0); .psv-tooltip-arrow { - border-left-color: $psv-tooltip-background; + border-left-color: psv.$tooltip-background; } } &--right-top, &--center-right, &--right-bottom { - transform: translate3d(-$psv-tooltip-animate-offset, 0, 0); + transform: translate3d(-#{psv.$tooltip-animate-offset}, 0, 0); .psv-tooltip-arrow { - border-right-color: $psv-tooltip-background; + border-right-color: psv.$tooltip-background; } } &--left-top, &--top-left { - box-shadow: #{-$psv-tooltip-shadow-offset} #{-$psv-tooltip-shadow-offset} 0 $psv-tooltip-shadow-color; + box-shadow: -#{psv.$tooltip-shadow-offset} -#{psv.$tooltip-shadow-offset} 0 psv.$tooltip-shadow-color; } &--top-center { - box-shadow: 0 #{-$psv-tooltip-shadow-offset} 0 $psv-tooltip-shadow-color; + box-shadow: 0 -#{psv.$tooltip-shadow-offset} 0 psv.$tooltip-shadow-color; } &--right-top, &--top-right { - box-shadow: $psv-tooltip-shadow-offset #{-$psv-tooltip-shadow-offset} 0 $psv-tooltip-shadow-color; + box-shadow: psv.$tooltip-shadow-offset -#{psv.$tooltip-shadow-offset} 0 psv.$tooltip-shadow-color; } &--left-bottom, &--bottom-left { - box-shadow: #{-$psv-tooltip-shadow-offset} $psv-tooltip-shadow-offset 0 $psv-tooltip-shadow-color; + box-shadow: -#{psv.$tooltip-shadow-offset} psv.$tooltip-shadow-offset 0 psv.$tooltip-shadow-color; } &--bottom-center { - box-shadow: 0 $psv-tooltip-shadow-offset 0 $psv-tooltip-shadow-color; + box-shadow: 0 psv.$tooltip-shadow-offset 0 psv.$tooltip-shadow-color; } &--right-bottom, &--bottom-right { - box-shadow: $psv-tooltip-shadow-offset $psv-tooltip-shadow-offset 0 $psv-tooltip-shadow-color; + box-shadow: psv.$tooltip-shadow-offset psv.$tooltip-shadow-offset 0 psv.$tooltip-shadow-color; } &--center-left { - box-shadow: #{-$psv-tooltip-shadow-offset} 0 0 $psv-tooltip-shadow-color; + box-shadow: -#{psv.$tooltip-shadow-offset} 0 0 psv.$tooltip-shadow-color; } &--center-right { - box-shadow: $psv-tooltip-shadow-offset 0 0 $psv-tooltip-shadow-color; + box-shadow: psv.$tooltip-shadow-offset 0 0 psv.$tooltip-shadow-color; } &--visible { diff --git a/packages/core/src/styles/viewer.scss b/packages/core/src/styles/viewer.scss index 5d585962..8675d5dd 100644 --- a/packages/core/src/styles/viewer.scss +++ b/packages/core/src/styles/viewer.scss @@ -1,3 +1,5 @@ +@use '../../../shared/vars' as psv; + .psv-container { --psv-core-loaded: true; @@ -8,7 +10,7 @@ margin: 0; padding: 0; position: relative; - background: $psv-main-background; + background: psv.$main-background; overflow: hidden; * { @@ -20,7 +22,7 @@ position: absolute; top: 0; left: 0; - z-index: $psv-canvas-zindex; + z-index: psv.$canvas-zindex; transition: opacity linear 100ms; } diff --git a/packages/core/src/styles/zoom-range.scss b/packages/core/src/styles/zoom-range.scss index 10088b78..a0ca60bf 100644 --- a/packages/core/src/styles/zoom-range.scss +++ b/packages/core/src/styles/zoom-range.scss @@ -1,34 +1,36 @@ +@use '../../../shared/vars' as psv; + .psv-zoom-range { &.psv-button { - width: $psv-zoom-range-width; - height: $psv-zoom-range-tickness; - margin: $psv-buttons-padding 0; - padding: #{($psv-buttons-height - $psv-zoom-range-tickness) * 0.5} 0; - max-width: $psv-zoom-range-media-min-width; // trick for JS access + width: psv.$zoom-range-width; + height: psv.$zoom-range-tickness; + margin: psv.$buttons-padding 0; + padding: #{(psv.$buttons-height - psv.$zoom-range-tickness) * 0.5} 0; + max-width: psv.$zoom-range-media-min-width; // trick for JS access } &-line { position: relative; - width: $psv-zoom-range-width; - height: $psv-zoom-range-tickness; - background: $psv-buttons-color; + width: psv.$zoom-range-width; + height: psv.$zoom-range-tickness; + background: psv.$buttons-color; transition: all 0.3s ease; } &-handle { position: absolute; border-radius: 50%; - top: #{($psv-zoom-range-tickness - $psv-zoom-range-diameter) * 0.5}; - width: $psv-zoom-range-diameter; - height: $psv-zoom-range-diameter; - background: $psv-buttons-color; + top: #{(psv.$zoom-range-tickness - psv.$zoom-range-diameter) * 0.5}; + width: psv.$zoom-range-diameter; + height: psv.$zoom-range-diameter; + background: psv.$buttons-color; transform: scale(1); transition: transform 0.3s ease; } &:not(.psv-button--disabled):hover { .psv-zoom-range-line { - box-shadow: 0 0 2px $psv-buttons-color; + box-shadow: 0 0 2px psv.$buttons-color; } .psv-zoom-range-handle { diff --git a/packages/gallery-plugin/src/style.scss b/packages/gallery-plugin/src/style.scss index 0d09ec98..5734ef39 100644 --- a/packages/gallery-plugin/src/style.scss +++ b/packages/gallery-plugin/src/style.scss @@ -1,4 +1,4 @@ -@import '../../shared/vars'; +@forward '../../shared/vars'; $psv-gallery-padding: 15px !default; $psv-gallery-border: 1px solid $psv-caption-text-color !default; diff --git a/packages/map-plugin/src/style.scss b/packages/map-plugin/src/style.scss index ba22eb0d..45432e5b 100644 --- a/packages/map-plugin/src/style.scss +++ b/packages/map-plugin/src/style.scss @@ -1,5 +1,5 @@ @use 'sass:math'; -@import '../../shared/vars'; +@use '../../shared/vars'; $psv-map-margin: 10px !default; $psv-map-radius: 8px !default; diff --git a/packages/markers-plugin/src/style.scss b/packages/markers-plugin/src/style.scss index 8cf26f05..5e046f4f 100644 --- a/packages/markers-plugin/src/style.scss +++ b/packages/markers-plugin/src/style.scss @@ -1,4 +1,4 @@ -@import '../../shared/vars'; +@use '../../shared/vars'; .psv-container { --psv-markers-plugin-loaded: true; diff --git a/packages/plan-plugin/src/style.scss b/packages/plan-plugin/src/style.scss index 9c5a049e..f9b70028 100644 --- a/packages/plan-plugin/src/style.scss +++ b/packages/plan-plugin/src/style.scss @@ -1,5 +1,5 @@ @use 'sass:math'; -@import '../../shared/vars'; +@use'../../shared/vars'; $psv-plan-margin: 10px !default; $psv-plan-radius: 8px !default; diff --git a/packages/settings-plugin/src/style.scss b/packages/settings-plugin/src/style.scss index 9cc3653c..ce30fd61 100644 --- a/packages/settings-plugin/src/style.scss +++ b/packages/settings-plugin/src/style.scss @@ -1,5 +1,5 @@ @use 'sass:list'; -@import '../../shared/vars'; +@use '../../shared/vars'; $psv-settings-margin: 10px !default; $psv-settings-font: $psv-caption-font !default; diff --git a/packages/shared/_vars.scss b/packages/shared/_vars.scss index 92f9c0b9..7b4d9126 100644 --- a/packages/shared/_vars.scss +++ b/packages/shared/_vars.scss @@ -1,119 +1,119 @@ // *** MAIN *** -$psv-main-background-stops: #fff 0%, +$main-background-stops: #fff 0%, #fdfdfd 16%, #fbfbfb 33%, #f8f8f8 49%, #efefef 66%, #dfdfdf 82%, #bfbfbf 100% !default; -$psv-main-background: radial-gradient($psv-main-background-stops) !default; -$psv-element-focus-outline: 2px solid #007cff !default; +$main-background: radial-gradient($main-background-stops) !default; +$element-focus-outline: 2px solid #007cff !default; // *** LOADER *** -$psv-loader-bg-color: rgba(61, 61, 61, 0.5) !default; -$psv-loader-color: rgba(255, 255, 255, 0.7) !default; -$psv-loader-width: 150px !default; -$psv-loader-tickness: 10px !default; -$psv-loader-border: 3px !default; -$psv-loader-font: 600 16px sans-serif !default; +$loader-bg-color: rgba(61, 61, 61, 0.5) !default; +$loader-color: rgba(255, 255, 255, 0.7) !default; +$loader-width: 150px !default; +$loader-tickness: 10px !default; +$loader-border: 3px !default; +$loader-font: 600 16px sans-serif !default; // *** NAVBAR *** -$psv-navbar-height: 40px !default; -$psv-navbar-background: rgba(61, 61, 61, 0.5) !default; +$navbar-height: 40px !default; +$navbar-background: rgba(61, 61, 61, 0.5) !default; -$psv-caption-font: 16px sans-serif !default; -$psv-caption-text-color: rgba(255, 255, 255, 0.7) !default; +$caption-font: 16px sans-serif !default; +$caption-text-color: rgba(255, 255, 255, 0.7) !default; -$psv-buttons-height: 20px !default; -$psv-buttons-padding: (($psv-navbar-height - $psv-buttons-height) * 0.5) !default; -$psv-buttons-background: transparent !default; -$psv-buttons-active-background: rgba(255, 255, 255, 0.2) !default; -$psv-buttons-color: rgba(255, 255, 255, 0.7) !default; -$psv-buttons-disabled-opacity: 0.5 !default; +$buttons-height: 20px !default; +$buttons-padding: (($navbar-height - $buttons-height) * 0.5) !default; +$buttons-background: transparent !default; +$buttons-active-background: rgba(255, 255, 255, 0.2) !default; +$buttons-color: rgba(255, 255, 255, 0.7) !default; +$buttons-disabled-opacity: 0.5 !default; -$psv-buttons-hover-scale: 1.2 !default; -$psv-buttons-hover-scale-delay: 200ms !default; +$buttons-hover-scale: 1.2 !default; +$buttons-hover-scale-delay: 200ms !default; -$psv-zoom-range-width: 80px !default; -$psv-zoom-range-tickness: 1px !default; -$psv-zoom-range-diameter: 7px !default; -$psv-zoom-range-media-min-width: 600px !default; +$zoom-range-width: 80px !default; +$zoom-range-tickness: 1px !default; +$zoom-range-diameter: 7px !default; +$zoom-range-media-min-width: 600px !default; // *** TOOLTIP *** -$psv-tooltip-background: rgba(61, 61, 61, 0.8) !default; -$psv-tooltip-animate-offset: 5px !default; -$psv-tooltip-animate-delay: 100ms !default; -$psv-tooltip-radius: 4px !default; -$psv-tooltip-padding: 0.5em 1em !default; -$psv-tooltip-arrow-size: 7px !default; -$psv-tooltip-max-width: 200px !default; +$tooltip-background: rgba(61, 61, 61, 0.8) !default; +$tooltip-animate-offset: 5px !default; +$tooltip-animate-delay: 100ms !default; +$tooltip-radius: 4px !default; +$tooltip-padding: 0.5em 1em !default; +$tooltip-arrow-size: 7px !default; +$tooltip-max-width: 200px !default; -$psv-tooltip-text-color: rgb(255, 255, 255) !default; -$psv-tooltip-font: 14px sans-serif !default; -$psv-tooltip-text-shadow: 0 1px #000 !default; +$tooltip-text-color: rgb(255, 255, 255) !default; +$tooltip-font: 14px sans-serif !default; +$tooltip-text-shadow: 0 1px #000 !default; -$psv-tooltip-shadow-color: rgba(90, 90, 90, 0.7) !default; -$psv-tooltip-shadow-offset: 3px !default; // the shadow is always at the opposite side of the arrow +$tooltip-shadow-color: rgba(90, 90, 90, 0.7) !default; +$tooltip-shadow-offset: 3px !default; // the shadow is always at the opposite side of the arrow // *** PANEL *** -$psv-panel-background: rgba(10, 10, 10, 0.7) !default; -$psv-panel-text-color: rgb(220, 220, 220) !default; -$psv-panel-font: 16px sans-serif !default; -$psv-panel-width: 400px !default; -$psv-panel-padding: 1em !default; -$psv-panel-animate-delay: 100ms !default; - -$psv-panel-resizer-width: 9px !default; // must be odd -$psv-panel-resizer-background: rgba(0, 0, 0, 0.9) !default; -$psv-panel-resizer-grip-color: #fff !default; -$psv-panel-resizer-grip-height: 29px !default; // must be odd -$psv-panel-close-button-size: 32px !default; -$psv-panel-close-button-background: $psv-panel-resizer-background !default; -$psv-panel-close-button-color: #fff !default; -$psv-panel-close-button-animate-delay: 300ms !default; - -$psv-panel-title-font: 24px sans-serif !default; -$psv-panel-title-icon-size: 24px !default; -$psv-panel-title-margin: 24px !default; - -$psv-panel-menu-item-height: 1.5em !default; -$psv-panel-menu-item-padding: 0.5em 1em !default; -$psv-panel-menu-item-active-outline: 1px !default; -$psv-panel-menu-odd-background: rgba(255, 255, 255, 0.1) !default; -$psv-panel-menu-even-background: transparent !default; -$psv-panel-menu-hover-background: rgba(255, 255, 255, 0.2) !default; +$panel-background: rgba(10, 10, 10, 0.7) !default; +$panel-text-color: rgb(220, 220, 220) !default; +$panel-font: 16px sans-serif !default; +$panel-width: 400px !default; +$panel-padding: 1em !default; +$panel-animate-delay: 100ms !default; + +$panel-resizer-width: 9px !default; // must be odd +$panel-resizer-background: rgba(0, 0, 0, 0.9) !default; +$panel-resizer-grip-color: #fff !default; +$panel-resizer-grip-height: 29px !default; // must be odd +$panel-close-button-size: 32px !default; +$panel-close-button-background: $panel-resizer-background !default; +$panel-close-button-color: #fff !default; +$panel-close-button-animate-delay: 300ms !default; + +$panel-title-font: 24px sans-serif !default; +$panel-title-icon-size: 24px !default; +$panel-title-margin: 24px !default; + +$panel-menu-item-height: 1.5em !default; +$panel-menu-item-padding: 0.5em 1em !default; +$panel-menu-item-active-outline: 1px !default; +$panel-menu-odd-background: rgba(255, 255, 255, 0.1) !default; +$panel-menu-even-background: transparent !default; +$panel-menu-hover-background: rgba(255, 255, 255, 0.2) !default; // *** NOTIFICATION *** -$psv-notification-position-from: -$psv-navbar-height !default; -$psv-notification-position-to: $psv-navbar-height * 2 !default; -$psv-notification-animate-delay: 200ms !default; -$psv-notification-background: $psv-tooltip-background !default; -$psv-notification-radius: $psv-tooltip-radius !default; -$psv-notification-padding: $psv-tooltip-padding !default; -$psv-notification-font: $psv-tooltip-font !default; -$psv-notification-text-color: $psv-tooltip-text-color !default; +$notification-position-from: -$navbar-height !default; +$notification-position-to: $navbar-height * 2 !default; +$notification-animate-delay: 200ms !default; +$notification-background: $tooltip-background !default; +$notification-radius: $tooltip-radius !default; +$notification-padding: $tooltip-padding !default; +$notification-font: $tooltip-font !default; +$notification-text-color: $tooltip-text-color !default; // *** OVERLAY *** -$psv-overlay-opacity: 0.8 !default; -$psv-overlay-icon-color: rgb(48, 48, 48) !default; -$psv-overlay-title-font: 30px sans-serif !default; -$psv-overlay-title-color: black !default; -$psv-overlay-text-font: 20px sans-serif !default; -$psv-overlay-text-color: rgba(0, 0, 0, 0.8) !default; -$psv-overlay-image-size: ( +$overlay-opacity: 0.8 !default; +$overlay-icon-color: rgb(48, 48, 48) !default; +$overlay-title-font: 30px sans-serif !default; +$overlay-title-color: black !default; +$overlay-text-font: 20px sans-serif !default; +$overlay-text-color: rgba(0, 0, 0, 0.8) !default; +$overlay-image-size: ( portrait: 50%, landscape: 33%, ) !default; // *** Z-INDEXES *** -$psv-canvas-zindex: 0 !default; -$psv-hud-zindex: 10 !default; -$psv-polygon-marker-zindex: 20 !default; -$psv-marker-zindex: 30 !default; -$psv-ui-zindex: 40 !default; -$psv-tooltip-zindex: 50 !default; -$psv-loader-zindex: 80 !default; -$psv-panel-zindex: 90 !default; -$psv-navbar-zindex: 90 !default; -$psv-notification-zindex: 100 !default; -$psv-overlay-zindex: 110 !default; +$canvas-zindex: 0 !default; +$hud-zindex: 10 !default; +$polygon-marker-zindex: 20 !default; +$marker-zindex: 30 !default; +$ui-zindex: 40 !default; +$tooltip-zindex: 50 !default; +$loader-zindex: 80 !default; +$panel-zindex: 90 !default; +$navbar-zindex: 90 !default; +$notification-zindex: 100 !default; +$overlay-zindex: 110 !default; diff --git a/packages/video-plugin/src/style.scss b/packages/video-plugin/src/style.scss index e8228f97..512ca322 100644 --- a/packages/video-plugin/src/style.scss +++ b/packages/video-plugin/src/style.scss @@ -1,5 +1,5 @@ @use 'sass:map'; -@import '../../shared/vars'; +@use '../../shared/vars'; $psv-progressbar-height: 3px !default; $psv-progressbar-height-active: 5px !default; diff --git a/packages/virtual-tour-plugin/src/style.scss b/packages/virtual-tour-plugin/src/style.scss index aafed504..8550cad3 100644 --- a/packages/virtual-tour-plugin/src/style.scss +++ b/packages/virtual-tour-plugin/src/style.scss @@ -1,5 +1,5 @@ @use 'sass:list'; -@import '../../shared/vars'; +@use '../../shared/vars'; $psv-virtual-tour-link-button-color: rgba(255, 255, 255, 0.8) !default; $psv-virtual-tour-link-button-ring: rgb(97, 170, 242) !default; diff --git a/packages/visible-range-plugin/tsup.config.bundled_3xw7lo3c0vh.mjs b/packages/visible-range-plugin/tsup.config.bundled_3xw7lo3c0vh.mjs new file mode 100644 index 00000000..77b865f3 --- /dev/null +++ b/packages/visible-range-plugin/tsup.config.bundled_3xw7lo3c0vh.mjs @@ -0,0 +1,251 @@ +// ../../build/tsup.config.ts +import { sassPlugin } from "esbuild-sass-plugin"; +import { defineConfig } from "tsup"; + +// ../../build/plugins/esbuild-plugin-assets.ts +import { mkdir, writeFile } from "fs/promises"; +import path from "path"; +import prettyBytes from "pretty-bytes"; +function assetsPlugin(files) { + return { + name: "assets", + setup(build) { + if (build.initialOptions.format !== "esm") { + return; + } + build.onEnd(() => { + const outdir = build.initialOptions.outdir; + return mkdir(path.resolve(outdir), { recursive: true }).then( + () => Promise.all( + Object.entries(files).map(([filename, contentOrPromise]) => { + const outpath = outdir + "/" + filename; + return Promise.resolve(contentOrPromise).then((content) => { + console.log("ASSET", outpath, prettyBytes(content.length)); + return writeFile(outpath, content); + }); + }) + ) + ).then(() => void 0); + }); + } + }; +} + +// ../../build/plugins/esbuild-plugin-budget.ts +import chalk from "chalk"; +function budgetPlugin(budget) { + if (!budget || !budget.endsWith("kb")) { + throw new Error("Missing/invalid budget"); + } + const maxsize = 1024 * parseInt(budget, 10); + return { + name: "budget", + setup(build) { + build.onEnd((result) => { + ["index.cjs", "index.module.js"].forEach((filename) => { + const file = result.outputFiles.find((f) => f.path.endsWith(filename)); + if (file) { + if (file.contents.length > maxsize) { + const size = Math.round(file.contents.length / 1024); + throw chalk.red(`File ${filename} exceeds budget of ${budget}, current size: ${size}kb`); + } + } + }); + }); + } + }; +} + +// ../../build/plugins/esbuild-plugin-map-fix.ts +import { basename } from "path"; +function mapFixPlugin() { + return { + name: "mapFix", + setup(build) { + build.onEnd((result) => { + ["index.css.map", "index.cjs.map", "index.module.js.map"].forEach((filename) => { + const mapFile = result.outputFiles.find((f) => f.path.endsWith(filename)); + if (!mapFile) { + return; + } + console.log("MAP", `Fix ${basename(mapFile.path)}`); + const content = JSON.parse(mapFile.text); + content.sources = content.sources.map((src) => { + return src.replace("../src", "src").replace("../../shared", "../shared").replace("../../../node_modules", "../node_modules"); + }); + mapFile.contents = Buffer.from(JSON.stringify(content)); + }); + }); + } + }; +} + +// ../../build/templates/license.ts +import { readFile } from "fs/promises"; +import path2 from "path"; +var __injected_dirname__ = "/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates"; +var license = () => readFile(path2.join(__injected_dirname__, "../../LICENSE"), { encoding: "utf8" }); + +// ../../build/templates/npmrc.ts +var npmrc = () => `@photo-sphere-viewer:registry=https://registry.npmjs.org +//registry.npmjs.org/:_authToken=\${NODE_AUTH_TOKEN} +`; + +// ../../build/templates/package.ts +import _ from "lodash"; +import sortPackageJson, { sortOrder } from "sort-package-json"; +sortOrder.splice(sortOrder.indexOf("style") + 1, 0, "sass"); +var packageJson = (pkg) => { + const content = { + ...pkg, + main: "index.cjs", + module: "index.module.js", + types: "index.d.ts", + exports: { + ".": { + import: "./index.module.js", + require: "./index.cjs" + } + }, + license: "MIT", + repository: { + type: "git", + url: "git://github.com/mistic100/Photo-Sphere-Viewer.git" + }, + author: { + name: `Damien 'Mistic' Sorel`, + email: "contact@git.strangeplanet.fr", + homepage: "https://www.strangeplanet.fr" + }, + keywords: ["photosphere", "panorama", "threejs", ...pkg.keywords || []], + dependencies: _.pickBy(pkg.dependencies, (val, key) => !key.startsWith("@photo-sphere-viewer")), + peerDependencies: _.pickBy(pkg.dependencies, (val, key) => key.startsWith("@photo-sphere-viewer")) + }; + if (pkg.psv.style) { + content.style = "index.css"; + content.sass = "index.scss"; + } + if (pkg.name === "@photo-sphere-viewer/core") { + content.contributors = [ + { + name: "J\xE9r\xE9my Heleine", + email: "jeremy.heleine@gmail.com", + homepage: "https://jeremyheleine.me" + } + ]; + } + delete content.devDependencies; + delete content.psv; + delete content.scripts; + return JSON.stringify(sortPackageJson(content), null, 2); +}; + +// ../../build/templates/readme.ts +var readme = (pkg) => `# ${pkg.psv.title} + +[![NPM version](https://img.shields.io/npm/v/${pkg.name}?logo=npm)](https://www.npmjs.com/package/${pkg.name}) +[![NPM Downloads](https://img.shields.io/npm/dm/${pkg.name}?color=f86036&label=npm&logo=npm)](https://www.npmjs.com/package/${pkg.name}) +[![jsDelivr Hits](https://img.shields.io/jsdelivr/npm/hm/${pkg.name}?color=%23f86036&logo=jsdelivr)](https://www.jsdelivr.com/package/npm/${pkg.name}) + +${pkg.description} + +## Documentation + +${pkg.homepage} + +## License + +This library is available under the MIT license. +`; + +// ../../build/tsup.config.ts +function createConfig(pkg) { + const banner = `/*! + * ${pkg.psv.title} ${pkg.version} +${pkg.name === "@photo-sphere-viewer/core" ? " * @copyright 2014-2015 J\xE9r\xE9my Heleine\n" : ""} * @copyright 2015-${(/* @__PURE__ */ new Date()).getFullYear()} Damien "Mistic" Sorel + * @licence MIT (https://opensource.org/licenses/MIT) + */`; + return defineConfig((options) => { + const e2e = options.env?.E2E; + const dev = e2e || options.watch; + const plugins = [ + sassPlugin() + ]; + if (!e2e) { + plugins.push( + mapFixPlugin() + ); + } + if (!dev) { + plugins.push( + budgetPlugin(pkg.psv.budget), + // scssBundlePlugin(), + assetsPlugin({ + "LICENSE": license(), + ".npmrc": npmrc(), + "README.md": readme(pkg), + "package.json": packageJson(pkg) + }) + ); + } + return { + entryPoints: [pkg.main], + outDir: "dist", + clean: true, + format: dev ? ["esm"] : ["esm", "cjs"], + outExtension: ({ format }) => ({ + js: { cjs: ".cjs", esm: ".module.js", iife: ".js" }[format] + }), + dts: !dev, + sourcemap: true, + external: ["three"], + noExternal: [/three\/examples\/.*/], + target: "es2021", + define: { + PKG_VERSION: `'${pkg.version}'` + }, + loader: { + ".svg": "text", + ".glsl": "text" + }, + banner: { + js: banner, + css: banner + }, + esbuildPlugins: plugins + }; + }); +} + +// package.json +var package_default = { + name: "@photo-sphere-viewer/visible-range-plugin", + version: "0.0.0", + description: "Photo Sphere Viewer plugin to lock the visible angles.", + homepage: "https://photo-sphere-viewer.js.org/plugins/visible-range.html", + license: "MIT", + main: "./src/index.ts", + types: "./src/index.ts", + dependencies: { + "@photo-sphere-viewer/core": "0.0.0" + }, + scripts: { + build: "tsup", + watch: "tsup --watch", + instrument: "nyc instrument dist/index.module.js .", + lint: "tsc --noEmit && eslint . --fix", + "publish-dist": "cd dist && npm publish --tag=$NPM_TAG --access=public", + "npm-link": "cd dist && npm link" + }, + psv: { + title: "Photo Sphere Viewer / Visible Range Plugin", + budget: "20kb" + } +}; + +// tsup.config.ts +var tsup_config_default = createConfig(package_default); +export { + tsup_config_default as default +}; +//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../build/tsup.config.ts", "../../build/plugins/esbuild-plugin-assets.ts", "../../build/plugins/esbuild-plugin-budget.ts", "../../build/plugins/esbuild-plugin-map-fix.ts", "../../build/templates/license.ts", "../../build/templates/npmrc.ts", "../../build/templates/package.ts", "../../build/templates/readme.ts", "package.json", "tsup.config.ts"],
  "sourcesContent": ["const __injected_filename__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/tsup.config.ts\";const __injected_dirname__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build\";const __injected_import_meta_url__ = \"file:///home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/tsup.config.ts\";import type { Plugin } from 'esbuild';\nimport { sassPlugin } from 'esbuild-sass-plugin';\nimport { defineConfig } from 'tsup';\nimport { assetsPlugin } from './plugins/esbuild-plugin-assets';\nimport { budgetPlugin } from './plugins/esbuild-plugin-budget';\n// import { istanbulPlugin } from './plugins/esbuild-plugin-istanbul';\nimport { mapFixPlugin } from './plugins/esbuild-plugin-map-fix';\nimport { scssBundlePlugin } from './plugins/esbuild-plugin-scss-bundle';\nimport { license } from './templates/license';\nimport { npmrc } from './templates/npmrc';\nimport { packageJson } from './templates/package';\nimport { readme } from './templates/readme';\n\nexport default function createConfig(pkg: any) {\n    const banner = `/*!\n * ${pkg.psv.title} ${pkg.version}\n${\n    pkg.name === '@photo-sphere-viewer/core' ? ' * @copyright 2014-2015 J\u00E9r\u00E9my Heleine\\n' : ''\n} * @copyright 2015-${new Date().getFullYear()} Damien \"Mistic\" Sorel\n * @licence MIT (https://opensource.org/licenses/MIT)\n */`;\n\n    return defineConfig((options) => {\n        const e2e = options.env?.E2E;\n        const dev = e2e || options.watch;\n\n        const plugins: Plugin[] = [\n            sassPlugin(),\n        ];\n\n        if (!e2e) {\n            plugins.push(\n                mapFixPlugin(),\n            );\n        }\n\n        if (!dev) {\n            plugins.push(\n                budgetPlugin(pkg.psv.budget),\n                // scssBundlePlugin(),\n                assetsPlugin({\n                    'LICENSE': license(),\n                    '.npmrc': npmrc(),\n                    'README.md': readme(pkg),\n                    'package.json': packageJson(pkg),\n                }),\n            );\n        }\n\n        return {\n            entryPoints: [pkg.main],\n            outDir: 'dist',\n            clean: true,\n            format: dev ? ['esm'] : ['esm', 'cjs'],\n            outExtension: ({ format }) => ({\n                js: { cjs: '.cjs', esm: '.module.js', iife: '.js' }[format],\n            }),\n            dts: !dev,\n            sourcemap: true,\n            external: ['three'],\n            noExternal: [/three\\/examples\\/.*/],\n            target: 'es2021',\n            define: {\n                PKG_VERSION: `'${pkg.version}'`,\n            },\n            loader: {\n                '.svg': 'text',\n                '.glsl': 'text',\n            },\n            banner: {\n                js: banner,\n                css: banner,\n            },\n            esbuildPlugins: plugins,\n        };\n    });\n}\n", "const __injected_filename__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/plugins/esbuild-plugin-assets.ts\";const __injected_dirname__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/plugins\";const __injected_import_meta_url__ = \"file:///home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/plugins/esbuild-plugin-assets.ts\";import type { Plugin } from 'esbuild';\nimport { mkdir, writeFile } from 'fs/promises';\nimport path from 'path';\nimport prettyBytes from 'pretty-bytes';\n\n/**\n * Generates static files in output directory\n */\nexport function assetsPlugin(files: Record<string, string | Promise<string>>): Plugin {\n    return {\n        name: 'assets',\n        setup(build) {\n            if (build.initialOptions.format !== 'esm') {\n                return;\n            }\n\n            build.onEnd(() => {\n                const outdir = build.initialOptions.outdir;\n\n                return mkdir(path.resolve(outdir), { recursive: true })\n                    .then(() =>\n                        Promise.all(\n                            Object.entries(files).map(([filename, contentOrPromise]) => {\n                                const outpath = outdir + '/' + filename;\n                                return Promise.resolve(contentOrPromise).then((content) => {\n                                    console.log('ASSET', outpath, prettyBytes(content.length));\n                                    return writeFile(outpath, content);\n                                });\n                            }),\n                        ),\n                    )\n                    .then(() => undefined);\n            });\n        },\n    };\n}\n", "const __injected_filename__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/plugins/esbuild-plugin-budget.ts\";const __injected_dirname__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/plugins\";const __injected_import_meta_url__ = \"file:///home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/plugins/esbuild-plugin-budget.ts\";import type { Plugin } from 'esbuild';\nimport chalk from 'chalk';\n\n/**\n * Checks the final bundle size\n */\nexport function budgetPlugin(budget: string): Plugin {\n    if (!budget || !budget.endsWith('kb')) {\n        throw new Error('Missing/invalid budget');\n    }\n\n    const maxsize = 1024 * parseInt(budget, 10);\n\n    return {\n        name: 'budget',\n        setup(build) {\n            build.onEnd((result) => {\n                ['index.cjs', 'index.module.js'].forEach((filename) => {\n                    const file = result.outputFiles.find(f => f.path.endsWith(filename));\n                    if (file) {\n                        if (file.contents.length > maxsize) {\n                            const size = Math.round(file.contents.length / 1024);\n                            throw chalk.red(`File ${filename} exceeds budget of ${budget}, current size: ${size}kb`);\n                        }\n                    }\n                });\n            });\n        },\n    };\n}\n", "const __injected_filename__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/plugins/esbuild-plugin-map-fix.ts\";const __injected_dirname__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/plugins\";const __injected_import_meta_url__ = \"file:///home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/plugins/esbuild-plugin-map-fix.ts\";import type { Plugin } from 'esbuild';\nimport { basename } from 'path';\n\n/**\n * Alters the paths in maps\n */\nexport function mapFixPlugin(): Plugin {\n    return {\n        name: 'mapFix',\n        setup(build) {\n            build.onEnd((result) => {\n                ['index.css.map', 'index.cjs.map', 'index.module.js.map'].forEach((filename) => {\n                    const mapFile = result.outputFiles.find(f => f.path.endsWith(filename));\n                    if (!mapFile) {\n                        return;\n                    }\n\n                    console.log('MAP', `Fix ${basename(mapFile.path)}`);\n\n                    const content = JSON.parse(mapFile.text);\n                    content.sources = content.sources.map((src: string) => {\n                        return src\n                            .replace('../src', 'src')\n                            .replace('../../shared', '../shared')\n                            .replace('../../../node_modules', '../node_modules');\n                    });\n                    mapFile.contents = Buffer.from(JSON.stringify(content));\n                });\n            });\n        },\n    };\n}\n", "const __injected_filename__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates/license.ts\";const __injected_dirname__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates\";const __injected_import_meta_url__ = \"file:///home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates/license.ts\";import { readFile } from 'fs/promises';\nimport path from 'path';\n\nexport const license = () => readFile(path.join(__dirname, '../../LICENSE'), { encoding: 'utf8' });\n", "const __injected_filename__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates/npmrc.ts\";const __injected_dirname__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates\";const __injected_import_meta_url__ = \"file:///home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates/npmrc.ts\";export const npmrc = () =>\n    `@photo-sphere-viewer:registry=https://registry.npmjs.org\n//registry.npmjs.org/:_authToken=\\${NODE_AUTH_TOKEN}\n`;\n", "const __injected_filename__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates/package.ts\";const __injected_dirname__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates\";const __injected_import_meta_url__ = \"file:///home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates/package.ts\";import _ from 'lodash';\nimport sortPackageJson, { sortOrder } from 'sort-package-json';\n\nsortOrder.splice(sortOrder.indexOf('style') + 1, 0, 'sass');\n\nexport const packageJson = (pkg: any) => {\n    const content = {\n        ...pkg,\n        main: 'index.cjs',\n        module: 'index.module.js',\n        types: 'index.d.ts',\n        exports: {\n            '.': {\n                import: './index.module.js',\n                require: './index.cjs',\n            },\n        },\n        license: 'MIT',\n        repository: {\n            type: 'git',\n            url: 'git://github.com/mistic100/Photo-Sphere-Viewer.git',\n        },\n        author: {\n            name: `Damien 'Mistic' Sorel`,\n            email: 'contact@git.strangeplanet.fr',\n            homepage: 'https://www.strangeplanet.fr',\n        },\n        keywords: ['photosphere', 'panorama', 'threejs', ...(pkg.keywords || [])],\n        dependencies: _.pickBy(pkg.dependencies, (val, key) => !key.startsWith('@photo-sphere-viewer')),\n        peerDependencies: _.pickBy(pkg.dependencies, (val, key) => key.startsWith('@photo-sphere-viewer')),\n    };\n\n    if (pkg.psv.style) {\n        content.style = 'index.css';\n        content.sass = 'index.scss';\n    }\n\n    if (pkg.name === '@photo-sphere-viewer/core') {\n        content.contributors = [\n            {\n                name: 'J\u00E9r\u00E9my Heleine',\n                email: 'jeremy.heleine@gmail.com',\n                homepage: 'https://jeremyheleine.me',\n            },\n        ];\n    }\n\n    delete content.devDependencies;\n    delete content.psv;\n    delete content.scripts;\n\n    return JSON.stringify(sortPackageJson(content), null, 2);\n};\n", "const __injected_filename__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates/readme.ts\";const __injected_dirname__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates\";const __injected_import_meta_url__ = \"file:///home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/build/templates/readme.ts\";export const readme = (pkg: any) =>\n    `# ${pkg.psv.title}\n\n[![NPM version](https://img.shields.io/npm/v/${pkg.name}?logo=npm)](https://www.npmjs.com/package/${pkg.name})\n[![NPM Downloads](https://img.shields.io/npm/dm/${pkg.name}?color=f86036&label=npm&logo=npm)](https://www.npmjs.com/package/${pkg.name})\n[![jsDelivr Hits](https://img.shields.io/jsdelivr/npm/hm/${pkg.name}?color=%23f86036&logo=jsdelivr)](https://www.jsdelivr.com/package/npm/${pkg.name})\n\n${pkg.description}\n\n## Documentation\n\n${pkg.homepage}\n\n## License\n\nThis library is available under the MIT license.\n`;\n", "{\n  \"name\": \"@photo-sphere-viewer/visible-range-plugin\",\n  \"version\": \"0.0.0\",\n  \"description\": \"Photo Sphere Viewer plugin to lock the visible angles.\",\n  \"homepage\": \"https://photo-sphere-viewer.js.org/plugins/visible-range.html\",\n  \"license\": \"MIT\",\n  \"main\": \"./src/index.ts\",\n  \"types\": \"./src/index.ts\",\n  \"dependencies\": {\n    \"@photo-sphere-viewer/core\": \"0.0.0\"\n  },\n  \"scripts\": {\n    \"build\": \"tsup\",\n    \"watch\": \"tsup --watch\",\n    \"instrument\": \"nyc instrument dist/index.module.js .\",\n    \"lint\": \"tsc --noEmit && eslint . --fix\",\n    \"publish-dist\": \"cd dist && npm publish --tag=$NPM_TAG --access=public\",\n    \"npm-link\": \"cd dist && npm link\"\n  },\n  \"psv\": {\n    \"title\": \"Photo Sphere Viewer / Visible Range Plugin\",\n    \"budget\": \"20kb\"\n  }\n}\n", "const __injected_filename__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/packages/visible-range-plugin/tsup.config.ts\";const __injected_dirname__ = \"/home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/packages/visible-range-plugin\";const __injected_import_meta_url__ = \"file:///home/damiensorel@sglk.local/mistic/Photo-Sphere-Viewer/packages/visible-range-plugin/tsup.config.ts\";import createConfig from '../../build/tsup.config';\nimport pkg from './package.json';\n\nexport default createConfig(pkg);\n"],
  "mappings": "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",
  "names": ["path", "path"]
}
