@pitvox/partner-react 0.7.22 → 0.7.23
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/README.md +2 -1
- package/dist/index.cjs +1 -1
- package/dist/index.js +1467 -1071
- package/dist/styles.css +463 -0
- package/package.json +4 -1
package/dist/styles.css
CHANGED
|
@@ -2854,3 +2854,466 @@
|
|
|
2854
2854
|
width: 100%;
|
|
2855
2855
|
height: 100%;
|
|
2856
2856
|
}
|
|
2857
|
+
|
|
2858
|
+
/* ═══════════════════════════════════════════════════════════════════════════
|
|
2859
|
+
Promotions (giveaways)
|
|
2860
|
+
═══════════════════════════════════════════════════════════════════════════ */
|
|
2861
|
+
|
|
2862
|
+
.pvx-promo-explorer-title {
|
|
2863
|
+
font-size: 1.5rem;
|
|
2864
|
+
font-weight: 700;
|
|
2865
|
+
color: var(--pvx-text-primary);
|
|
2866
|
+
margin: 0 0 1.5rem;
|
|
2867
|
+
}
|
|
2868
|
+
|
|
2869
|
+
/* ─── Card grid ─── */
|
|
2870
|
+
|
|
2871
|
+
.pvx-promo-grid {
|
|
2872
|
+
display: grid;
|
|
2873
|
+
grid-template-columns: 1fr;
|
|
2874
|
+
gap: 1.5rem;
|
|
2875
|
+
}
|
|
2876
|
+
|
|
2877
|
+
@media (min-width: 640px) {
|
|
2878
|
+
.pvx-promo-grid { grid-template-columns: repeat(2, 1fr); }
|
|
2879
|
+
}
|
|
2880
|
+
|
|
2881
|
+
@media (min-width: 1024px) {
|
|
2882
|
+
.pvx-promo-grid { grid-template-columns: repeat(3, 1fr); }
|
|
2883
|
+
}
|
|
2884
|
+
|
|
2885
|
+
/* Count-adaptive layouts (set by PromotionCards): a lone card renders wide
|
|
2886
|
+
and centred; a pair caps at two columns. */
|
|
2887
|
+
.pvx-promo-grid--single {
|
|
2888
|
+
grid-template-columns: 1fr;
|
|
2889
|
+
max-width: 42rem;
|
|
2890
|
+
margin-inline: auto;
|
|
2891
|
+
}
|
|
2892
|
+
|
|
2893
|
+
@media (min-width: 640px) {
|
|
2894
|
+
.pvx-promo-grid--single { grid-template-columns: 1fr; }
|
|
2895
|
+
.pvx-promo-grid--pair { grid-template-columns: repeat(2, 1fr); }
|
|
2896
|
+
}
|
|
2897
|
+
|
|
2898
|
+
@media (min-width: 1024px) {
|
|
2899
|
+
.pvx-promo-grid--single { grid-template-columns: 1fr; }
|
|
2900
|
+
.pvx-promo-grid--pair { grid-template-columns: repeat(2, 1fr); }
|
|
2901
|
+
}
|
|
2902
|
+
|
|
2903
|
+
.pvx-promo-card {
|
|
2904
|
+
border-radius: var(--pvx-radius);
|
|
2905
|
+
border: 1px solid var(--pvx-border);
|
|
2906
|
+
background: var(--pvx-bg-card);
|
|
2907
|
+
overflow: hidden;
|
|
2908
|
+
cursor: pointer;
|
|
2909
|
+
transition: border-color 200ms, box-shadow 200ms;
|
|
2910
|
+
display: flex;
|
|
2911
|
+
flex-direction: column;
|
|
2912
|
+
}
|
|
2913
|
+
|
|
2914
|
+
.pvx-promo-card:hover {
|
|
2915
|
+
border-color: var(--pvx-accent);
|
|
2916
|
+
box-shadow: 0 0 0 1px var(--pvx-accent);
|
|
2917
|
+
}
|
|
2918
|
+
|
|
2919
|
+
.pvx-promo-card:focus-visible {
|
|
2920
|
+
outline: 2px solid var(--pvx-accent);
|
|
2921
|
+
outline-offset: 2px;
|
|
2922
|
+
}
|
|
2923
|
+
|
|
2924
|
+
.pvx-promo-card-poster {
|
|
2925
|
+
aspect-ratio: 16 / 9;
|
|
2926
|
+
background: #0d1117;
|
|
2927
|
+
overflow: hidden;
|
|
2928
|
+
}
|
|
2929
|
+
|
|
2930
|
+
.pvx-promo-card-poster-img {
|
|
2931
|
+
width: 100%;
|
|
2932
|
+
height: 100%;
|
|
2933
|
+
object-fit: cover;
|
|
2934
|
+
}
|
|
2935
|
+
|
|
2936
|
+
.pvx-promo-card-poster-placeholder {
|
|
2937
|
+
width: 100%;
|
|
2938
|
+
height: 100%;
|
|
2939
|
+
display: flex;
|
|
2940
|
+
align-items: center;
|
|
2941
|
+
justify-content: center;
|
|
2942
|
+
}
|
|
2943
|
+
|
|
2944
|
+
.pvx-promo-gift-icon {
|
|
2945
|
+
width: 3rem;
|
|
2946
|
+
height: 3rem;
|
|
2947
|
+
color: var(--pvx-text-dimmed);
|
|
2948
|
+
}
|
|
2949
|
+
|
|
2950
|
+
.pvx-promo-card-body {
|
|
2951
|
+
padding: 1rem;
|
|
2952
|
+
display: flex;
|
|
2953
|
+
flex-direction: column;
|
|
2954
|
+
gap: 0.5rem;
|
|
2955
|
+
flex: 1;
|
|
2956
|
+
}
|
|
2957
|
+
|
|
2958
|
+
.pvx-promo-card-badges {
|
|
2959
|
+
display: flex;
|
|
2960
|
+
align-items: center;
|
|
2961
|
+
gap: 0.375rem;
|
|
2962
|
+
flex-wrap: wrap;
|
|
2963
|
+
}
|
|
2964
|
+
|
|
2965
|
+
.pvx-promo-card-title {
|
|
2966
|
+
font-size: 1.125rem;
|
|
2967
|
+
font-weight: 600;
|
|
2968
|
+
color: var(--pvx-text-primary);
|
|
2969
|
+
margin: 0;
|
|
2970
|
+
overflow: hidden;
|
|
2971
|
+
text-overflow: ellipsis;
|
|
2972
|
+
white-space: nowrap;
|
|
2973
|
+
}
|
|
2974
|
+
|
|
2975
|
+
.pvx-promo-card-prize {
|
|
2976
|
+
font-size: 0.875rem;
|
|
2977
|
+
color: var(--pvx-text-muted);
|
|
2978
|
+
margin: 0;
|
|
2979
|
+
display: -webkit-box;
|
|
2980
|
+
-webkit-line-clamp: 2;
|
|
2981
|
+
-webkit-box-orient: vertical;
|
|
2982
|
+
overflow: hidden;
|
|
2983
|
+
}
|
|
2984
|
+
|
|
2985
|
+
.pvx-promo-card-meta {
|
|
2986
|
+
display: flex;
|
|
2987
|
+
flex-direction: column;
|
|
2988
|
+
gap: 0.25rem;
|
|
2989
|
+
margin-top: auto;
|
|
2990
|
+
font-size: 0.75rem;
|
|
2991
|
+
color: var(--pvx-text-dimmed);
|
|
2992
|
+
}
|
|
2993
|
+
|
|
2994
|
+
/* ─── Badges ─── */
|
|
2995
|
+
|
|
2996
|
+
.pvx-promo-status,
|
|
2997
|
+
.pvx-promo-type,
|
|
2998
|
+
.pvx-promo-game {
|
|
2999
|
+
display: inline-block;
|
|
3000
|
+
padding: 0.125rem 0.5rem;
|
|
3001
|
+
border-radius: 9999px;
|
|
3002
|
+
font-size: 0.6875rem;
|
|
3003
|
+
font-weight: 600;
|
|
3004
|
+
text-transform: uppercase;
|
|
3005
|
+
letter-spacing: 0.03em;
|
|
3006
|
+
}
|
|
3007
|
+
|
|
3008
|
+
.pvx-promo-status--upcoming {
|
|
3009
|
+
background: rgba(99, 102, 241, 0.2);
|
|
3010
|
+
color: #818cf8;
|
|
3011
|
+
}
|
|
3012
|
+
|
|
3013
|
+
.pvx-promo-status--open {
|
|
3014
|
+
background: rgba(34, 197, 94, 0.2);
|
|
3015
|
+
color: #4ade80;
|
|
3016
|
+
}
|
|
3017
|
+
|
|
3018
|
+
.pvx-promo-status--closed {
|
|
3019
|
+
background: rgba(245, 158, 11, 0.2);
|
|
3020
|
+
color: #fbbf24;
|
|
3021
|
+
}
|
|
3022
|
+
|
|
3023
|
+
.pvx-promo-status--winners {
|
|
3024
|
+
background: rgba(234, 179, 8, 0.25);
|
|
3025
|
+
color: #facc15;
|
|
3026
|
+
}
|
|
3027
|
+
|
|
3028
|
+
.pvx-promo-type {
|
|
3029
|
+
background: rgba(99, 102, 241, 0.2);
|
|
3030
|
+
color: #818cf8;
|
|
3031
|
+
}
|
|
3032
|
+
|
|
3033
|
+
.pvx-promo-game {
|
|
3034
|
+
background: var(--pvx-tag-bg);
|
|
3035
|
+
color: var(--pvx-tag-text);
|
|
3036
|
+
}
|
|
3037
|
+
|
|
3038
|
+
/* ─── Detail view ─── */
|
|
3039
|
+
|
|
3040
|
+
.pvx-promo-detail {
|
|
3041
|
+
display: flex;
|
|
3042
|
+
flex-direction: column;
|
|
3043
|
+
gap: 1.25rem;
|
|
3044
|
+
}
|
|
3045
|
+
|
|
3046
|
+
.pvx-promo-back {
|
|
3047
|
+
align-self: flex-start;
|
|
3048
|
+
background: none;
|
|
3049
|
+
border: none;
|
|
3050
|
+
padding: 0;
|
|
3051
|
+
font-size: 0.875rem;
|
|
3052
|
+
color: var(--pvx-text-muted);
|
|
3053
|
+
cursor: pointer;
|
|
3054
|
+
}
|
|
3055
|
+
|
|
3056
|
+
.pvx-promo-back:hover {
|
|
3057
|
+
color: var(--pvx-accent);
|
|
3058
|
+
}
|
|
3059
|
+
|
|
3060
|
+
.pvx-promo-detail-poster {
|
|
3061
|
+
border-radius: var(--pvx-radius);
|
|
3062
|
+
overflow: hidden;
|
|
3063
|
+
background: #0d1117;
|
|
3064
|
+
}
|
|
3065
|
+
|
|
3066
|
+
.pvx-promo-detail-poster img {
|
|
3067
|
+
width: 100%;
|
|
3068
|
+
max-height: 24rem;
|
|
3069
|
+
object-fit: cover;
|
|
3070
|
+
display: block;
|
|
3071
|
+
}
|
|
3072
|
+
|
|
3073
|
+
.pvx-promo-detail-header {
|
|
3074
|
+
display: flex;
|
|
3075
|
+
flex-direction: column;
|
|
3076
|
+
gap: 0.5rem;
|
|
3077
|
+
}
|
|
3078
|
+
|
|
3079
|
+
.pvx-promo-detail-title {
|
|
3080
|
+
font-size: 1.5rem;
|
|
3081
|
+
font-weight: 700;
|
|
3082
|
+
color: var(--pvx-text-primary);
|
|
3083
|
+
margin: 0;
|
|
3084
|
+
}
|
|
3085
|
+
|
|
3086
|
+
.pvx-promo-detail-prize {
|
|
3087
|
+
font-size: 1rem;
|
|
3088
|
+
color: var(--pvx-text-muted);
|
|
3089
|
+
margin: 0;
|
|
3090
|
+
}
|
|
3091
|
+
|
|
3092
|
+
.pvx-promo-detail-meta {
|
|
3093
|
+
display: flex;
|
|
3094
|
+
gap: 1rem;
|
|
3095
|
+
flex-wrap: wrap;
|
|
3096
|
+
font-size: 0.8125rem;
|
|
3097
|
+
color: var(--pvx-text-dimmed);
|
|
3098
|
+
}
|
|
3099
|
+
|
|
3100
|
+
.pvx-promo-section-title {
|
|
3101
|
+
font-size: 1rem;
|
|
3102
|
+
font-weight: 600;
|
|
3103
|
+
color: var(--pvx-text-primary);
|
|
3104
|
+
margin: 0 0 0.75rem;
|
|
3105
|
+
}
|
|
3106
|
+
|
|
3107
|
+
.pvx-promo-section-count {
|
|
3108
|
+
font-weight: 400;
|
|
3109
|
+
color: var(--pvx-text-muted);
|
|
3110
|
+
}
|
|
3111
|
+
|
|
3112
|
+
/* ─── Winners panel ─── */
|
|
3113
|
+
|
|
3114
|
+
.pvx-promo-winners {
|
|
3115
|
+
border-radius: var(--pvx-radius);
|
|
3116
|
+
border: 1px solid rgba(234, 179, 8, 0.4);
|
|
3117
|
+
background: rgba(234, 179, 8, 0.06);
|
|
3118
|
+
padding: 1rem;
|
|
3119
|
+
}
|
|
3120
|
+
|
|
3121
|
+
.pvx-promo-winners-list {
|
|
3122
|
+
display: flex;
|
|
3123
|
+
gap: 1.25rem;
|
|
3124
|
+
flex-wrap: wrap;
|
|
3125
|
+
}
|
|
3126
|
+
|
|
3127
|
+
.pvx-promo-winner {
|
|
3128
|
+
display: flex;
|
|
3129
|
+
align-items: center;
|
|
3130
|
+
gap: 0.5rem;
|
|
3131
|
+
}
|
|
3132
|
+
|
|
3133
|
+
.pvx-promo-winner-name {
|
|
3134
|
+
font-weight: 600;
|
|
3135
|
+
color: var(--pvx-text-primary);
|
|
3136
|
+
}
|
|
3137
|
+
|
|
3138
|
+
/* ─── Entry action ─── */
|
|
3139
|
+
|
|
3140
|
+
.pvx-promo-action {
|
|
3141
|
+
border-radius: var(--pvx-radius);
|
|
3142
|
+
border: 1px solid var(--pvx-border);
|
|
3143
|
+
background: var(--pvx-bg-card);
|
|
3144
|
+
padding: 1rem;
|
|
3145
|
+
}
|
|
3146
|
+
|
|
3147
|
+
.pvx-promo-action-row {
|
|
3148
|
+
display: flex;
|
|
3149
|
+
align-items: center;
|
|
3150
|
+
justify-content: space-between;
|
|
3151
|
+
gap: 1rem;
|
|
3152
|
+
flex-wrap: wrap;
|
|
3153
|
+
}
|
|
3154
|
+
|
|
3155
|
+
.pvx-promo-action-note {
|
|
3156
|
+
font-size: 0.9375rem;
|
|
3157
|
+
color: var(--pvx-text-primary);
|
|
3158
|
+
margin: 0;
|
|
3159
|
+
}
|
|
3160
|
+
|
|
3161
|
+
.pvx-promo-disclosure {
|
|
3162
|
+
font-size: 0.75rem;
|
|
3163
|
+
color: var(--pvx-text-dimmed);
|
|
3164
|
+
margin: 0.25rem 0 0;
|
|
3165
|
+
}
|
|
3166
|
+
|
|
3167
|
+
.pvx-promo-error {
|
|
3168
|
+
font-size: 0.8125rem;
|
|
3169
|
+
color: #f87171;
|
|
3170
|
+
margin: 0 0 0.25rem;
|
|
3171
|
+
}
|
|
3172
|
+
|
|
3173
|
+
.pvx-promo-enter-btn,
|
|
3174
|
+
.pvx-promo-withdraw-btn,
|
|
3175
|
+
.pvx-promo-enter-link {
|
|
3176
|
+
display: inline-block;
|
|
3177
|
+
padding: 0.5rem 1.25rem;
|
|
3178
|
+
border-radius: 0.5rem;
|
|
3179
|
+
font-size: 0.875rem;
|
|
3180
|
+
font-weight: 600;
|
|
3181
|
+
cursor: pointer;
|
|
3182
|
+
text-decoration: none;
|
|
3183
|
+
transition: background-color 150ms, opacity 150ms;
|
|
3184
|
+
border: none;
|
|
3185
|
+
}
|
|
3186
|
+
|
|
3187
|
+
.pvx-promo-enter-btn,
|
|
3188
|
+
.pvx-promo-enter-link {
|
|
3189
|
+
background: var(--pvx-accent);
|
|
3190
|
+
color: #fff;
|
|
3191
|
+
}
|
|
3192
|
+
|
|
3193
|
+
.pvx-promo-enter-btn:hover:not(:disabled),
|
|
3194
|
+
.pvx-promo-enter-link:hover {
|
|
3195
|
+
opacity: 0.9;
|
|
3196
|
+
}
|
|
3197
|
+
|
|
3198
|
+
.pvx-promo-enter-btn:disabled {
|
|
3199
|
+
opacity: 0.5;
|
|
3200
|
+
cursor: not-allowed;
|
|
3201
|
+
}
|
|
3202
|
+
|
|
3203
|
+
.pvx-promo-withdraw-btn {
|
|
3204
|
+
background: transparent;
|
|
3205
|
+
border: 1px solid var(--pvx-border);
|
|
3206
|
+
color: var(--pvx-text-muted);
|
|
3207
|
+
}
|
|
3208
|
+
|
|
3209
|
+
.pvx-promo-withdraw-btn:hover:not(:disabled) {
|
|
3210
|
+
border-color: #f87171;
|
|
3211
|
+
color: #f87171;
|
|
3212
|
+
}
|
|
3213
|
+
|
|
3214
|
+
/* ─── Description (markdown) ─── */
|
|
3215
|
+
|
|
3216
|
+
.pvx-promo-description {
|
|
3217
|
+
border-radius: var(--pvx-radius);
|
|
3218
|
+
border: 1px solid var(--pvx-border);
|
|
3219
|
+
background: var(--pvx-bg-card);
|
|
3220
|
+
padding: 1.25rem;
|
|
3221
|
+
color: var(--pvx-text-primary);
|
|
3222
|
+
font-size: 0.9375rem;
|
|
3223
|
+
line-height: 1.6;
|
|
3224
|
+
}
|
|
3225
|
+
|
|
3226
|
+
.pvx-promo-description h1,
|
|
3227
|
+
.pvx-promo-description h2,
|
|
3228
|
+
.pvx-promo-description h3 {
|
|
3229
|
+
color: var(--pvx-text-primary);
|
|
3230
|
+
margin: 1rem 0 0.5rem;
|
|
3231
|
+
}
|
|
3232
|
+
|
|
3233
|
+
.pvx-promo-description h1:first-child,
|
|
3234
|
+
.pvx-promo-description h2:first-child,
|
|
3235
|
+
.pvx-promo-description h3:first-child,
|
|
3236
|
+
.pvx-promo-description p:first-child {
|
|
3237
|
+
margin-top: 0;
|
|
3238
|
+
}
|
|
3239
|
+
|
|
3240
|
+
.pvx-promo-description p,
|
|
3241
|
+
.pvx-promo-description ul,
|
|
3242
|
+
.pvx-promo-description ol {
|
|
3243
|
+
margin: 0.5rem 0;
|
|
3244
|
+
}
|
|
3245
|
+
|
|
3246
|
+
.pvx-promo-description a {
|
|
3247
|
+
color: var(--pvx-accent);
|
|
3248
|
+
}
|
|
3249
|
+
|
|
3250
|
+
.pvx-promo-description code {
|
|
3251
|
+
background: var(--pvx-tag-bg);
|
|
3252
|
+
border-radius: 0.25rem;
|
|
3253
|
+
padding: 0.125rem 0.25rem;
|
|
3254
|
+
font-size: 0.85em;
|
|
3255
|
+
}
|
|
3256
|
+
|
|
3257
|
+
/* ─── Entrants grid ─── */
|
|
3258
|
+
|
|
3259
|
+
.pvx-promo-entrants {
|
|
3260
|
+
border-radius: var(--pvx-radius);
|
|
3261
|
+
border: 1px solid var(--pvx-border);
|
|
3262
|
+
background: var(--pvx-bg-card);
|
|
3263
|
+
padding: 1.25rem;
|
|
3264
|
+
}
|
|
3265
|
+
|
|
3266
|
+
.pvx-promo-entrants-grid {
|
|
3267
|
+
display: grid;
|
|
3268
|
+
grid-template-columns: repeat(2, 1fr);
|
|
3269
|
+
gap: 0.75rem;
|
|
3270
|
+
}
|
|
3271
|
+
|
|
3272
|
+
@media (min-width: 640px) {
|
|
3273
|
+
.pvx-promo-entrants-grid { grid-template-columns: repeat(3, 1fr); }
|
|
3274
|
+
}
|
|
3275
|
+
|
|
3276
|
+
@media (min-width: 1024px) {
|
|
3277
|
+
.pvx-promo-entrants-grid { grid-template-columns: repeat(4, 1fr); }
|
|
3278
|
+
}
|
|
3279
|
+
|
|
3280
|
+
.pvx-promo-entrant {
|
|
3281
|
+
display: flex;
|
|
3282
|
+
align-items: center;
|
|
3283
|
+
gap: 0.5rem;
|
|
3284
|
+
min-width: 0;
|
|
3285
|
+
}
|
|
3286
|
+
|
|
3287
|
+
.pvx-promo-entrant-name {
|
|
3288
|
+
font-size: 0.875rem;
|
|
3289
|
+
color: var(--pvx-text-primary);
|
|
3290
|
+
overflow: hidden;
|
|
3291
|
+
text-overflow: ellipsis;
|
|
3292
|
+
white-space: nowrap;
|
|
3293
|
+
}
|
|
3294
|
+
|
|
3295
|
+
.pvx-promo-avatar {
|
|
3296
|
+
width: 1.75rem;
|
|
3297
|
+
height: 1.75rem;
|
|
3298
|
+
border-radius: 9999px;
|
|
3299
|
+
flex-shrink: 0;
|
|
3300
|
+
object-fit: cover;
|
|
3301
|
+
}
|
|
3302
|
+
|
|
3303
|
+
.pvx-promo-avatar--lg {
|
|
3304
|
+
width: 2.5rem;
|
|
3305
|
+
height: 2.5rem;
|
|
3306
|
+
}
|
|
3307
|
+
|
|
3308
|
+
.pvx-promo-avatar--placeholder {
|
|
3309
|
+
background: var(--pvx-tag-bg);
|
|
3310
|
+
display: flex;
|
|
3311
|
+
align-items: center;
|
|
3312
|
+
justify-content: center;
|
|
3313
|
+
}
|
|
3314
|
+
|
|
3315
|
+
.pvx-promo-avatar-glyph {
|
|
3316
|
+
width: 55%;
|
|
3317
|
+
height: 55%;
|
|
3318
|
+
color: var(--pvx-text-dimmed);
|
|
3319
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pitvox/partner-react",
|
|
3
|
-
"version": "0.7.
|
|
3
|
+
"version": "0.7.23",
|
|
4
4
|
"description": "React hooks and styled components for PitVox partner websites — leaderboards, competitions, driver dashboards",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.cjs",
|
|
@@ -26,6 +26,9 @@
|
|
|
26
26
|
"react": "^18.0.0 || ^19.0.0",
|
|
27
27
|
"react-dom": "^18.0.0 || ^19.0.0"
|
|
28
28
|
},
|
|
29
|
+
"dependencies": {
|
|
30
|
+
"react-markdown": "^10.1.0"
|
|
31
|
+
},
|
|
29
32
|
"devDependencies": {
|
|
30
33
|
"@release-it/conventional-changelog": "^10.0.6",
|
|
31
34
|
"@tanstack/react-query": "^5.0.0",
|