@duskmoon-dev/core 1.3.0 → 1.3.2
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/dist/components/cascader.css +418 -0
- package/dist/components/index.css +419 -0
- package/dist/esm/components/cascader.js +425 -0
- package/dist/index.css +749 -120
- package/dist/themes/moonlight.css +145 -60
- package/dist/themes/sunshine.css +144 -60
- package/package.json +1 -1
|
@@ -3655,6 +3655,425 @@
|
|
|
3655
3655
|
}
|
|
3656
3656
|
}
|
|
3657
3657
|
|
|
3658
|
+
/**
|
|
3659
|
+
* Cascader Component Styles
|
|
3660
|
+
* DuskMoonUI - Multi-level dropdown selection with horizontal panels
|
|
3661
|
+
*/
|
|
3662
|
+
|
|
3663
|
+
@layer components {
|
|
3664
|
+
/* Base Cascader */
|
|
3665
|
+
.cascader {
|
|
3666
|
+
position: relative;
|
|
3667
|
+
display: inline-flex;
|
|
3668
|
+
flex-direction: column;
|
|
3669
|
+
width: 100%;
|
|
3670
|
+
}
|
|
3671
|
+
|
|
3672
|
+
/* Cascader Trigger */
|
|
3673
|
+
.cascader-trigger {
|
|
3674
|
+
display: flex;
|
|
3675
|
+
align-items: center;
|
|
3676
|
+
justify-content: space-between;
|
|
3677
|
+
width: 100%;
|
|
3678
|
+
padding: 0.75rem 1rem;
|
|
3679
|
+
font-size: 1rem;
|
|
3680
|
+
line-height: 1.5rem;
|
|
3681
|
+
color: var(--color-on-surface);
|
|
3682
|
+
background-color: var(--color-surface);
|
|
3683
|
+
border: 1px solid var(--color-outline);
|
|
3684
|
+
border-radius: 0.5rem;
|
|
3685
|
+
cursor: pointer;
|
|
3686
|
+
transition: border-color 150ms ease-in-out, box-shadow 150ms ease-in-out;
|
|
3687
|
+
}
|
|
3688
|
+
|
|
3689
|
+
.cascader-trigger:hover:not(:disabled) {
|
|
3690
|
+
border-color: var(--color-on-surface-variant);
|
|
3691
|
+
}
|
|
3692
|
+
|
|
3693
|
+
.cascader-trigger:focus {
|
|
3694
|
+
outline: none;
|
|
3695
|
+
border-color: var(--color-primary);
|
|
3696
|
+
box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-primary) 10%, transparent);
|
|
3697
|
+
}
|
|
3698
|
+
|
|
3699
|
+
.cascader-trigger:disabled {
|
|
3700
|
+
cursor: not-allowed;
|
|
3701
|
+
opacity: 0.5;
|
|
3702
|
+
background-color: var(--color-surface-container);
|
|
3703
|
+
}
|
|
3704
|
+
|
|
3705
|
+
/* Value Display */
|
|
3706
|
+
.cascader-value {
|
|
3707
|
+
flex: 1;
|
|
3708
|
+
display: flex;
|
|
3709
|
+
align-items: center;
|
|
3710
|
+
gap: 0.5rem;
|
|
3711
|
+
overflow: hidden;
|
|
3712
|
+
text-overflow: ellipsis;
|
|
3713
|
+
white-space: nowrap;
|
|
3714
|
+
color: var(--color-on-surface);
|
|
3715
|
+
}
|
|
3716
|
+
|
|
3717
|
+
/* Placeholder */
|
|
3718
|
+
.cascader-placeholder {
|
|
3719
|
+
color: var(--color-on-surface-variant);
|
|
3720
|
+
}
|
|
3721
|
+
|
|
3722
|
+
/* Path Display (breadcrumb-style) */
|
|
3723
|
+
.cascader-path {
|
|
3724
|
+
display: flex;
|
|
3725
|
+
align-items: center;
|
|
3726
|
+
gap: 0.25rem;
|
|
3727
|
+
overflow: hidden;
|
|
3728
|
+
text-overflow: ellipsis;
|
|
3729
|
+
white-space: nowrap;
|
|
3730
|
+
}
|
|
3731
|
+
|
|
3732
|
+
.cascader-path-separator {
|
|
3733
|
+
color: var(--color-on-surface-variant);
|
|
3734
|
+
font-size: 0.875rem;
|
|
3735
|
+
}
|
|
3736
|
+
|
|
3737
|
+
/* Dropdown Arrow */
|
|
3738
|
+
.cascader-arrow {
|
|
3739
|
+
display: flex;
|
|
3740
|
+
align-items: center;
|
|
3741
|
+
justify-content: center;
|
|
3742
|
+
width: 1.25rem;
|
|
3743
|
+
height: 1.25rem;
|
|
3744
|
+
color: var(--color-on-surface-variant);
|
|
3745
|
+
flex-shrink: 0;
|
|
3746
|
+
transition: transform 150ms ease-in-out;
|
|
3747
|
+
}
|
|
3748
|
+
|
|
3749
|
+
.cascader-open .cascader-arrow {
|
|
3750
|
+
transform: rotate(180deg);
|
|
3751
|
+
}
|
|
3752
|
+
|
|
3753
|
+
/* Clear Button */
|
|
3754
|
+
.cascader-clear {
|
|
3755
|
+
display: flex;
|
|
3756
|
+
align-items: center;
|
|
3757
|
+
justify-content: center;
|
|
3758
|
+
width: 1.25rem;
|
|
3759
|
+
height: 1.25rem;
|
|
3760
|
+
padding: 0;
|
|
3761
|
+
color: var(--color-on-surface-variant);
|
|
3762
|
+
background-color: transparent;
|
|
3763
|
+
border: none;
|
|
3764
|
+
border-radius: 50%;
|
|
3765
|
+
cursor: pointer;
|
|
3766
|
+
flex-shrink: 0;
|
|
3767
|
+
transition: background-color 150ms ease-in-out;
|
|
3768
|
+
}
|
|
3769
|
+
|
|
3770
|
+
.cascader-clear:hover {
|
|
3771
|
+
background-color: var(--color-surface-container-high);
|
|
3772
|
+
}
|
|
3773
|
+
|
|
3774
|
+
/* Cascader Dropdown */
|
|
3775
|
+
.cascader-dropdown {
|
|
3776
|
+
position: absolute;
|
|
3777
|
+
top: 100%;
|
|
3778
|
+
left: 0;
|
|
3779
|
+
z-index: 50;
|
|
3780
|
+
display: none;
|
|
3781
|
+
margin-top: 0.25rem;
|
|
3782
|
+
background-color: var(--color-surface);
|
|
3783
|
+
border: 1px solid var(--color-outline-variant);
|
|
3784
|
+
border-radius: 0.5rem;
|
|
3785
|
+
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
|
|
3786
|
+
overflow: hidden;
|
|
3787
|
+
}
|
|
3788
|
+
|
|
3789
|
+
.cascader-open .cascader-dropdown {
|
|
3790
|
+
display: flex;
|
|
3791
|
+
}
|
|
3792
|
+
|
|
3793
|
+
/* Popover API Support */
|
|
3794
|
+
.cascader-dropdown[popover] {
|
|
3795
|
+
inset: unset;
|
|
3796
|
+
margin: 0;
|
|
3797
|
+
border: 1px solid var(--color-outline-variant);
|
|
3798
|
+
}
|
|
3799
|
+
|
|
3800
|
+
.cascader-dropdown[popover]:popover-open {
|
|
3801
|
+
display: flex;
|
|
3802
|
+
}
|
|
3803
|
+
|
|
3804
|
+
/* CSS Anchor Positioning for modern browsers */
|
|
3805
|
+
@supports (anchor-name: --anchor) {
|
|
3806
|
+
.cascader-trigger {
|
|
3807
|
+
anchor-name: --cascader-anchor;
|
|
3808
|
+
}
|
|
3809
|
+
|
|
3810
|
+
.cascader-dropdown[popover] {
|
|
3811
|
+
position-anchor: --cascader-anchor;
|
|
3812
|
+
top: anchor(bottom);
|
|
3813
|
+
left: anchor(left);
|
|
3814
|
+
margin-top: 0.25rem;
|
|
3815
|
+
position-try-fallbacks: flip-block;
|
|
3816
|
+
}
|
|
3817
|
+
}
|
|
3818
|
+
|
|
3819
|
+
/* Fallback for browsers without anchor positioning */
|
|
3820
|
+
@supports not (anchor-name: --anchor) {
|
|
3821
|
+
.cascader {
|
|
3822
|
+
position: relative;
|
|
3823
|
+
}
|
|
3824
|
+
|
|
3825
|
+
.cascader-dropdown[popover]:popover-open {
|
|
3826
|
+
position: absolute;
|
|
3827
|
+
top: 100%;
|
|
3828
|
+
left: 0;
|
|
3829
|
+
margin-top: 0.25rem;
|
|
3830
|
+
}
|
|
3831
|
+
}
|
|
3832
|
+
|
|
3833
|
+
/* Panels Container (horizontal layout) */
|
|
3834
|
+
.cascader-panels {
|
|
3835
|
+
display: flex;
|
|
3836
|
+
max-height: 16rem;
|
|
3837
|
+
}
|
|
3838
|
+
|
|
3839
|
+
/* Individual Panel */
|
|
3840
|
+
.cascader-panel {
|
|
3841
|
+
display: flex;
|
|
3842
|
+
flex-direction: column;
|
|
3843
|
+
min-width: 10rem;
|
|
3844
|
+
max-width: 14rem;
|
|
3845
|
+
overflow-y: auto;
|
|
3846
|
+
border-right: 1px solid var(--color-outline-variant);
|
|
3847
|
+
}
|
|
3848
|
+
|
|
3849
|
+
.cascader-panel:last-child {
|
|
3850
|
+
border-right: none;
|
|
3851
|
+
}
|
|
3852
|
+
|
|
3853
|
+
/* Panel Header (optional) */
|
|
3854
|
+
.cascader-panel-header {
|
|
3855
|
+
padding: 0.5rem 0.75rem;
|
|
3856
|
+
font-size: 0.75rem;
|
|
3857
|
+
font-weight: 600;
|
|
3858
|
+
color: var(--color-on-surface-variant);
|
|
3859
|
+
text-transform: uppercase;
|
|
3860
|
+
letter-spacing: 0.05em;
|
|
3861
|
+
background-color: var(--color-surface-container);
|
|
3862
|
+
border-bottom: 1px solid var(--color-outline-variant);
|
|
3863
|
+
}
|
|
3864
|
+
|
|
3865
|
+
/* Panel Options */
|
|
3866
|
+
.cascader-options {
|
|
3867
|
+
display: flex;
|
|
3868
|
+
flex-direction: column;
|
|
3869
|
+
padding: 0.25rem;
|
|
3870
|
+
flex: 1;
|
|
3871
|
+
overflow-y: auto;
|
|
3872
|
+
}
|
|
3873
|
+
|
|
3874
|
+
/* Cascader Option */
|
|
3875
|
+
.cascader-option {
|
|
3876
|
+
display: flex;
|
|
3877
|
+
align-items: center;
|
|
3878
|
+
justify-content: space-between;
|
|
3879
|
+
gap: 0.5rem;
|
|
3880
|
+
padding: 0.5rem 0.75rem;
|
|
3881
|
+
font-size: 0.875rem;
|
|
3882
|
+
color: var(--color-on-surface);
|
|
3883
|
+
background-color: transparent;
|
|
3884
|
+
border: none;
|
|
3885
|
+
border-radius: 0.375rem;
|
|
3886
|
+
cursor: pointer;
|
|
3887
|
+
text-align: left;
|
|
3888
|
+
width: 100%;
|
|
3889
|
+
transition: background-color 150ms ease-in-out;
|
|
3890
|
+
}
|
|
3891
|
+
|
|
3892
|
+
.cascader-option:hover {
|
|
3893
|
+
background-color: var(--color-surface-container);
|
|
3894
|
+
}
|
|
3895
|
+
|
|
3896
|
+
.cascader-option-active {
|
|
3897
|
+
background-color: var(--color-surface-container-high);
|
|
3898
|
+
}
|
|
3899
|
+
|
|
3900
|
+
.cascader-option-selected {
|
|
3901
|
+
background-color: var(--color-primary-container);
|
|
3902
|
+
color: var(--color-on-primary-container);
|
|
3903
|
+
}
|
|
3904
|
+
|
|
3905
|
+
.cascader-option-selected:hover {
|
|
3906
|
+
background-color: color-mix(in oklch, var(--color-primary-container), black 5%);
|
|
3907
|
+
}
|
|
3908
|
+
|
|
3909
|
+
.cascader-option-disabled {
|
|
3910
|
+
opacity: 0.5;
|
|
3911
|
+
cursor: not-allowed;
|
|
3912
|
+
}
|
|
3913
|
+
|
|
3914
|
+
.cascader-option-disabled:hover {
|
|
3915
|
+
background-color: transparent;
|
|
3916
|
+
}
|
|
3917
|
+
|
|
3918
|
+
/* Option Label */
|
|
3919
|
+
.cascader-option-label {
|
|
3920
|
+
flex: 1;
|
|
3921
|
+
overflow: hidden;
|
|
3922
|
+
text-overflow: ellipsis;
|
|
3923
|
+
white-space: nowrap;
|
|
3924
|
+
}
|
|
3925
|
+
|
|
3926
|
+
/* Option Arrow (indicates has children) */
|
|
3927
|
+
.cascader-option-arrow {
|
|
3928
|
+
display: flex;
|
|
3929
|
+
align-items: center;
|
|
3930
|
+
justify-content: center;
|
|
3931
|
+
width: 1rem;
|
|
3932
|
+
height: 1rem;
|
|
3933
|
+
color: var(--color-on-surface-variant);
|
|
3934
|
+
flex-shrink: 0;
|
|
3935
|
+
}
|
|
3936
|
+
|
|
3937
|
+
.cascader-option-selected .cascader-option-arrow {
|
|
3938
|
+
color: var(--color-on-primary-container);
|
|
3939
|
+
}
|
|
3940
|
+
|
|
3941
|
+
/* Search Input */
|
|
3942
|
+
.cascader-search {
|
|
3943
|
+
display: flex;
|
|
3944
|
+
padding: 0.5rem;
|
|
3945
|
+
border-bottom: 1px solid var(--color-outline-variant);
|
|
3946
|
+
}
|
|
3947
|
+
|
|
3948
|
+
.cascader-search-input {
|
|
3949
|
+
flex: 1;
|
|
3950
|
+
padding: 0.5rem 0.75rem;
|
|
3951
|
+
font-size: 0.875rem;
|
|
3952
|
+
color: var(--color-on-surface);
|
|
3953
|
+
background-color: var(--color-surface-container);
|
|
3954
|
+
border: none;
|
|
3955
|
+
border-radius: 0.375rem;
|
|
3956
|
+
outline: none;
|
|
3957
|
+
}
|
|
3958
|
+
|
|
3959
|
+
.cascader-search-input:focus {
|
|
3960
|
+
background-color: var(--color-surface-container-high);
|
|
3961
|
+
}
|
|
3962
|
+
|
|
3963
|
+
.cascader-search-input::placeholder {
|
|
3964
|
+
color: var(--color-on-surface-variant);
|
|
3965
|
+
}
|
|
3966
|
+
|
|
3967
|
+
/* Empty State */
|
|
3968
|
+
.cascader-empty {
|
|
3969
|
+
padding: 1.5rem;
|
|
3970
|
+
text-align: center;
|
|
3971
|
+
color: var(--color-on-surface-variant);
|
|
3972
|
+
font-size: 0.875rem;
|
|
3973
|
+
}
|
|
3974
|
+
|
|
3975
|
+
/* Size Variants */
|
|
3976
|
+
.cascader-sm .cascader-trigger {
|
|
3977
|
+
padding: 0.5rem 0.75rem;
|
|
3978
|
+
font-size: 0.875rem;
|
|
3979
|
+
border-radius: 0.375rem;
|
|
3980
|
+
}
|
|
3981
|
+
|
|
3982
|
+
.cascader-sm .cascader-panel {
|
|
3983
|
+
min-width: 8rem;
|
|
3984
|
+
max-width: 12rem;
|
|
3985
|
+
}
|
|
3986
|
+
|
|
3987
|
+
.cascader-sm .cascader-option {
|
|
3988
|
+
padding: 0.375rem 0.5rem;
|
|
3989
|
+
font-size: 0.8125rem;
|
|
3990
|
+
}
|
|
3991
|
+
|
|
3992
|
+
.cascader-lg .cascader-trigger {
|
|
3993
|
+
padding: 1rem 1.25rem;
|
|
3994
|
+
font-size: 1.125rem;
|
|
3995
|
+
border-radius: 0.625rem;
|
|
3996
|
+
}
|
|
3997
|
+
|
|
3998
|
+
.cascader-lg .cascader-panel {
|
|
3999
|
+
min-width: 12rem;
|
|
4000
|
+
max-width: 16rem;
|
|
4001
|
+
}
|
|
4002
|
+
|
|
4003
|
+
.cascader-lg .cascader-option {
|
|
4004
|
+
padding: 0.625rem 1rem;
|
|
4005
|
+
font-size: 1rem;
|
|
4006
|
+
}
|
|
4007
|
+
|
|
4008
|
+
/* Outlined Variant (Default) */
|
|
4009
|
+
.cascader-outlined .cascader-trigger {
|
|
4010
|
+
background-color: var(--color-surface);
|
|
4011
|
+
border: 1px solid var(--color-outline);
|
|
4012
|
+
}
|
|
4013
|
+
|
|
4014
|
+
/* Filled Variant */
|
|
4015
|
+
.cascader-filled .cascader-trigger {
|
|
4016
|
+
background-color: var(--color-surface-container);
|
|
4017
|
+
border: none;
|
|
4018
|
+
border-bottom: 2px solid var(--color-outline);
|
|
4019
|
+
border-radius: 0.5rem 0.5rem 0 0;
|
|
4020
|
+
}
|
|
4021
|
+
|
|
4022
|
+
.cascader-filled .cascader-trigger:focus {
|
|
4023
|
+
border-bottom-color: var(--color-primary);
|
|
4024
|
+
box-shadow: none;
|
|
4025
|
+
}
|
|
4026
|
+
|
|
4027
|
+
/* Error State */
|
|
4028
|
+
.cascader-error .cascader-trigger {
|
|
4029
|
+
border-color: var(--color-error);
|
|
4030
|
+
}
|
|
4031
|
+
|
|
4032
|
+
.cascader-error .cascader-trigger:focus {
|
|
4033
|
+
border-color: var(--color-error);
|
|
4034
|
+
box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-error) 10%, transparent);
|
|
4035
|
+
}
|
|
4036
|
+
|
|
4037
|
+
/* Disabled State */
|
|
4038
|
+
.cascader-disabled .cascader-trigger {
|
|
4039
|
+
cursor: not-allowed;
|
|
4040
|
+
opacity: 0.5;
|
|
4041
|
+
background-color: var(--color-surface-container);
|
|
4042
|
+
}
|
|
4043
|
+
|
|
4044
|
+
/* Loading State */
|
|
4045
|
+
.cascader-loading .cascader-trigger {
|
|
4046
|
+
cursor: wait;
|
|
4047
|
+
}
|
|
4048
|
+
|
|
4049
|
+
.cascader-spinner {
|
|
4050
|
+
display: inline-block;
|
|
4051
|
+
width: 1rem;
|
|
4052
|
+
height: 1rem;
|
|
4053
|
+
border: 2px solid var(--color-outline);
|
|
4054
|
+
border-top-color: var(--color-primary);
|
|
4055
|
+
border-radius: 50%;
|
|
4056
|
+
animation: cascader-spin 0.8s linear infinite;
|
|
4057
|
+
}
|
|
4058
|
+
|
|
4059
|
+
@keyframes cascader-spin {
|
|
4060
|
+
to { transform: rotate(360deg); }
|
|
4061
|
+
}
|
|
4062
|
+
|
|
4063
|
+
/* Reduce Motion */
|
|
4064
|
+
@media (prefers-reduced-motion: reduce) {
|
|
4065
|
+
.cascader-trigger,
|
|
4066
|
+
.cascader-arrow,
|
|
4067
|
+
.cascader-option,
|
|
4068
|
+
.cascader-clear {
|
|
4069
|
+
transition: none;
|
|
4070
|
+
}
|
|
4071
|
+
.cascader-spinner {
|
|
4072
|
+
animation: none;
|
|
4073
|
+
}
|
|
4074
|
+
}
|
|
4075
|
+
}
|
|
4076
|
+
|
|
3658
4077
|
/**
|
|
3659
4078
|
* Checkbox Component Styles
|
|
3660
4079
|
* DuskMoonUI - Material Design 3 inspired checkbox
|