trotl-modal 1.0.11 → 1.0.12
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/dist/index.css +2 -0
- package/dist/dist/index.css.map +1 -0
- package/dist/index.css +157 -2
- package/package.json +1 -1
- package/dist/index.css.map +0 -1
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
:root{--overlay:rgba(0,0,0,.35);--overlay-strong:rgba(0,0,0,.6);--bg:#fff;--header-bg:#f5f5f5;--header-color:#000;--modal-z:60000}[data-theme=light]{--overlay:rgba(0,0,0,.35);--overlay-strong:rgba(0,0,0,.6);--bg:#fff;--header-bg:#f5f5f5;--header-color:#000}[data-theme=dark]{--overlay:rgba(0,0,0,.6);--overlay-strong:rgba(0,0,0,.85);--bg:#2c2c2c;--header-bg:#3a3a3a;--header-color:#f1f1f1}.app-root{margin:0 auto;max-width:900px}button{cursor:pointer}.modal-overlay{align-items:flex-start;display:flex;inset:0;justify-content:center;opacity:0;padding:40px;pointer-events:none;position:fixed;transition:opacity .2s ease;z-index:60000}.modal-overlay.visible{opacity:1;pointer-events:auto}.modal-overlay.drawer-overlay{background:var(--overlay-strong);padding:0}.modal{background:var(--bg);border-radius:2px;box-shadow:0 10px 30px rgba(0,0,0,.3);min-width:300px;opacity:0;overflow:hidden;position:absolute;transform:translateY(-20px) scale(.85) rotate(-4deg);transition:opacity .25s ease,transform .25s ease;z-index:60001}.modal.visible{opacity:1;transform:translateY(0) scale(1) rotate(0)}.drawer{background:var(--bg);border-radius:2px;box-shadow:0 10px 30px rgba(0,0,0,.3);max-height:100%;max-width:100%;min-width:300px;opacity:0;overflow:hidden;position:absolute;transform:translate(0);transition:opacity var(--drawer-transition,.45s) ease,transform var(--drawer-transition,.45s) ease;z-index:60001}.drawer.horizontal{height:100%}.drawer.vertical{width:100%}.drawer.horizontal.side-left{transform:translateX(-100%)}.drawer.horizontal.side-right{transform:translateX(100%)}.drawer.vertical.side-top{transform:translateY(-100%)}.drawer.vertical.side-bottom{transform:translateY(100%)}.drawer.visible{opacity:1}.drawer.visible.horizontal.side-left,.drawer.visible.horizontal.side-right{transform:translateX(0)}.drawer.visible.vertical.side-bottom,.drawer.visible.vertical.side-top{transform:translateY(0)}.modal-header{align-items:center;background:var(--header-bg);color:var(--header-color);cursor:grab;display:flex;justify-content:space-between;padding:10px 12px}.modal-title{font-weight:600}.modal-close{background:transparent;border:none;font-size:18px;padding:4px 8px}.modal-body{padding:12px}@media (max-width:480px){.modal{min-width:260px}}
|
|
2
|
+
/*# sourceMappingURL=index.css.map */
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["index.css"],"names":[],"mappings":"AACA,MAEE,yBAA2B,CAC3B,+BAAiC,CACjC,SAAa,CACb,mBAAoB,CACpB,mBAAoB,CACpB,eACF,CAGA,mBACE,yBAA2B,CAC3B,+BAAiC,CACjC,SAAa,CACb,mBAAoB,CACpB,mBACF,CAEA,kBACE,wBAA0B,CAC1B,gCAAkC,CAClC,YAAa,CACb,mBAAoB,CACpB,sBACF,CAEA,UAEE,aAAA,CADA,eAEF,CAEA,OACE,cACF,CAGA,eAKE,sBAAuB,CADvB,YAAa,CAFb,OAAQ,CAIR,sBAAuB,CAGvB,SAAU,CAFV,YAAa,CAMb,mBAAoB,CAZpB,cAAe,CASf,2BAA6B,CAF7B,aAMF,CAEA,uBACE,SAAU,CACV,mBACF,CAGA,8BAEE,gCAAiC,CADjC,SAEF,CAEA,OAGE,oBAAqB,CAErB,iBAAkB,CAClB,qCAA0C,CAF1C,eAAgB,CAMhB,SAAU,CAHV,eAAgB,CANhB,iBAAkB,CAUlB,oDAAsD,CACtD,gDAAoD,CAVpD,aAWF,CAEA,eACE,SAAU,CACV,0CACF,CAGA,QAGE,oBAAqB,CAErB,iBAAkB,CAClB,qCAA0C,CAG1C,eAAgB,CADhB,cAAe,CAJf,eAAgB,CAOhB,SAAU,CAJV,eAAgB,CANhB,iBAAkB,CAWlB,sBAAyB,CACzB,kGACgD,CAZhD,aAaF,CAGA,mBAAqB,WAAc,CACnC,iBAAmB,UAAa,CAGhC,6BAAgC,2BAA8B,CAC9D,8BAAgC,0BAA6B,CAC7D,0BAAgC,2BAA8B,CAC9D,6BAAgC,0BAA6B,CAE7D,gBACE,SACF,CAEA,2EAEE,uBACF,CAEA,uEAEE,uBACF,CAEA,cAEE,kBAAmB,CAGnB,2BAA4B,CAC5B,yBAA0B,CAC1B,WAAA,CANA,YAAa,CAEb,6BAA8B,CAC9B,iBAIF,CAEA,aACE,eACF,CAEA,aAEE,sBAAuB,CADvB,WAAY,CAEZ,cAAe,CACf,eACF,CAEA,YACE,YACF,CAEA,yBACE,OACE,eACF,CACF","file":"index.css","sourcesContent":["\r\n:root {\r\n /* sensible defaults so modal isn't transparent when used standalone */\r\n --overlay: rgba(0,0,0,0.35);\r\n --overlay-strong: rgba(0,0,0,0.6);\r\n --bg: #ffffff;\r\n --header-bg: #f5f5f5;\r\n --header-color: #000;\r\n --modal-z: 60000;\r\n}\r\n\r\n/* theme overrides (use data-theme to scope) */\r\n[data-theme='light'] {\r\n --overlay: rgba(0,0,0,0.35);\r\n --overlay-strong: rgba(0,0,0,0.6);\r\n --bg: #ffffff;\r\n --header-bg: #f5f5f5;\r\n --header-color: #000;\r\n}\r\n\r\n[data-theme='dark'] {\r\n --overlay: rgba(0,0,0,0.6);\r\n --overlay-strong: rgba(0,0,0,0.85);\r\n --bg: #2c2c2c;\r\n --header-bg: #3a3a3a;\r\n --header-color: #f1f1f1;\r\n}\r\n\r\n.app-root {\r\n max-width: 900px;\r\n margin: 0 auto\r\n}\r\n\r\nbutton {\r\n cursor: pointer\r\n}\r\n\r\n/* ensure modal overlay sits above other UI (other packages use very large z-index values) */\r\n.modal-overlay {\r\n position: fixed;\r\n inset: 0;\r\n /* background: var(--overlay); */\r\n display: flex;\r\n align-items: flex-start;\r\n justify-content: center;\r\n padding: 40px;\r\n z-index: 60000; /* raised from 999 */\r\n opacity: 0;\r\n transition: opacity 0.2s ease;\r\n\r\n /* when invisible we don't want it blocking clicks */\r\n pointer-events: none;\r\n}\r\n\r\n.modal-overlay.visible {\r\n opacity: 1;\r\n pointer-events: auto;\r\n}\r\n\r\n/* drawer-specific overlay adjustments */\r\n.modal-overlay.drawer-overlay {\r\n padding: 0; /* flush to edges for drawers */\r\n background: var(--overlay-strong);\r\n}\r\n\r\n.modal {\r\n position: absolute;\r\n z-index: 60001; /* keep modal above the overlay's stacking context children */\r\n background: var(--bg);\r\n min-width: 300px;\r\n border-radius: 2px;\r\n box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);\r\n overflow: hidden;\r\n\r\n /* entry animation state */\r\n opacity: 0;\r\n transform: translateY(-20px) scale(0.85) rotate(-4deg);\r\n transition: opacity 0.25s ease, transform 0.25s ease;\r\n}\r\n\r\n.modal.visible {\r\n opacity: 1;\r\n transform: translateY(0) scale(1) rotate(0);\r\n}\r\n\r\n/* drawer uses a simple slide animation and adapts to the chosen edge */\r\n.drawer {\r\n position: absolute;\r\n z-index: 60001;\r\n background: var(--bg);\r\n min-width: 300px;\r\n border-radius: 2px;\r\n box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);\r\n overflow: hidden;\r\n max-width: 100%;\r\n max-height: 100%;\r\n\r\n opacity: 0;\r\n transform: translate(0,0);\r\n transition: opacity var(--drawer-transition, 0.45s) ease,\r\n transform var(--drawer-transition, 0.45s) ease;\r\n}\r\n\r\n/* full height when coming from left/right, full width for top/bottom */\r\n.drawer.horizontal { height: 100%; }\r\n.drawer.vertical { width: 100%; }\r\n\r\n/* offscreen start positions by 100% of its own size */\r\n.drawer.horizontal.side-left { transform: translateX(-100%); }\r\n.drawer.horizontal.side-right { transform: translateX(100%); }\r\n.drawer.vertical.side-top { transform: translateY(-100%); }\r\n.drawer.vertical.side-bottom { transform: translateY(100%); }\r\n\r\n.drawer.visible {\r\n opacity: 1;\r\n}\r\n\r\n.drawer.visible.horizontal.side-left,\r\n.drawer.visible.horizontal.side-right {\r\n transform: translateX(0);\r\n}\r\n\r\n.drawer.visible.vertical.side-top,\r\n.drawer.visible.vertical.side-bottom {\r\n transform: translateY(0);\r\n}\r\n\r\n.modal-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n padding: 10px 12px;\r\n background: var(--header-bg);\r\n color: var(--header-color);\r\n cursor: grab\r\n}\r\n\r\n.modal-title {\r\n font-weight: 600\r\n}\r\n\r\n.modal-close {\r\n border: none;\r\n background: transparent;\r\n font-size: 18px;\r\n padding: 4px 8px\r\n}\r\n\r\n.modal-body {\r\n padding: 12px\r\n}\r\n\r\n@media (max-width:480px) {\r\n .modal {\r\n min-width: 260px\r\n }\r\n}"]}
|
package/dist/index.css
CHANGED
|
@@ -1,2 +1,157 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
|
|
2
|
+
:root {
|
|
3
|
+
/* sensible defaults so modal isn't transparent when used standalone */
|
|
4
|
+
--overlay: rgba(0,0,0,0.35);
|
|
5
|
+
--overlay-strong: rgba(0,0,0,0.6);
|
|
6
|
+
--bg: #ffffff;
|
|
7
|
+
--header-bg: #f5f5f5;
|
|
8
|
+
--header-color: #000;
|
|
9
|
+
--modal-z: 60000;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
/* theme overrides (use data-theme to scope) */
|
|
13
|
+
[data-theme='light'] {
|
|
14
|
+
--overlay: rgba(0,0,0,0.35);
|
|
15
|
+
--overlay-strong: rgba(0,0,0,0.6);
|
|
16
|
+
--bg: #ffffff;
|
|
17
|
+
--header-bg: #f5f5f5;
|
|
18
|
+
--header-color: #000;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
[data-theme='dark'] {
|
|
22
|
+
--overlay: rgba(0,0,0,0.6);
|
|
23
|
+
--overlay-strong: rgba(0,0,0,0.85);
|
|
24
|
+
--bg: #2c2c2c;
|
|
25
|
+
--header-bg: #3a3a3a;
|
|
26
|
+
--header-color: #f1f1f1;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.app-root {
|
|
30
|
+
max-width: 900px;
|
|
31
|
+
margin: 0 auto
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
button {
|
|
35
|
+
cursor: pointer
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/* ensure modal overlay sits above other UI (other packages use very large z-index values) */
|
|
39
|
+
.modal-overlay {
|
|
40
|
+
position: fixed;
|
|
41
|
+
inset: 0;
|
|
42
|
+
/* background: var(--overlay); */
|
|
43
|
+
display: flex;
|
|
44
|
+
align-items: flex-start;
|
|
45
|
+
justify-content: center;
|
|
46
|
+
padding: 40px;
|
|
47
|
+
z-index: 60000; /* raised from 999 */
|
|
48
|
+
opacity: 0;
|
|
49
|
+
transition: opacity 0.2s ease;
|
|
50
|
+
|
|
51
|
+
/* when invisible we don't want it blocking clicks */
|
|
52
|
+
pointer-events: none;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.modal-overlay.visible {
|
|
56
|
+
opacity: 1;
|
|
57
|
+
pointer-events: auto;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/* drawer-specific overlay adjustments */
|
|
61
|
+
.modal-overlay.drawer-overlay {
|
|
62
|
+
padding: 0; /* flush to edges for drawers */
|
|
63
|
+
background: var(--overlay-strong);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.modal {
|
|
67
|
+
position: absolute;
|
|
68
|
+
z-index: 60001; /* keep modal above the overlay's stacking context children */
|
|
69
|
+
background: var(--bg);
|
|
70
|
+
min-width: 300px;
|
|
71
|
+
border-radius: 2px;
|
|
72
|
+
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
|
|
73
|
+
overflow: hidden;
|
|
74
|
+
|
|
75
|
+
/* entry animation state */
|
|
76
|
+
opacity: 0;
|
|
77
|
+
transform: translateY(-20px) scale(0.85) rotate(-4deg);
|
|
78
|
+
transition: opacity 0.25s ease, transform 0.25s ease;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
.modal.visible {
|
|
82
|
+
opacity: 1;
|
|
83
|
+
transform: translateY(0) scale(1) rotate(0);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
/* drawer uses a simple slide animation and adapts to the chosen edge */
|
|
87
|
+
.drawer {
|
|
88
|
+
position: absolute;
|
|
89
|
+
z-index: 60001;
|
|
90
|
+
background: var(--bg);
|
|
91
|
+
min-width: 300px;
|
|
92
|
+
border-radius: 2px;
|
|
93
|
+
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
|
|
94
|
+
overflow: hidden;
|
|
95
|
+
max-width: 100%;
|
|
96
|
+
max-height: 100%;
|
|
97
|
+
|
|
98
|
+
opacity: 0;
|
|
99
|
+
transform: translate(0,0);
|
|
100
|
+
transition: opacity var(--drawer-transition, 0.45s) ease,
|
|
101
|
+
transform var(--drawer-transition, 0.45s) ease;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
/* full height when coming from left/right, full width for top/bottom */
|
|
105
|
+
.drawer.horizontal { height: 100%; }
|
|
106
|
+
.drawer.vertical { width: 100%; }
|
|
107
|
+
|
|
108
|
+
/* offscreen start positions by 100% of its own size */
|
|
109
|
+
.drawer.horizontal.side-left { transform: translateX(-100%); }
|
|
110
|
+
.drawer.horizontal.side-right { transform: translateX(100%); }
|
|
111
|
+
.drawer.vertical.side-top { transform: translateY(-100%); }
|
|
112
|
+
.drawer.vertical.side-bottom { transform: translateY(100%); }
|
|
113
|
+
|
|
114
|
+
.drawer.visible {
|
|
115
|
+
opacity: 1;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
.drawer.visible.horizontal.side-left,
|
|
119
|
+
.drawer.visible.horizontal.side-right {
|
|
120
|
+
transform: translateX(0);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
.drawer.visible.vertical.side-top,
|
|
124
|
+
.drawer.visible.vertical.side-bottom {
|
|
125
|
+
transform: translateY(0);
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
.modal-header {
|
|
129
|
+
display: flex;
|
|
130
|
+
align-items: center;
|
|
131
|
+
justify-content: space-between;
|
|
132
|
+
padding: 10px 12px;
|
|
133
|
+
background: var(--header-bg);
|
|
134
|
+
color: var(--header-color);
|
|
135
|
+
cursor: grab
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
.modal-title {
|
|
139
|
+
font-weight: 600
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
.modal-close {
|
|
143
|
+
border: none;
|
|
144
|
+
background: transparent;
|
|
145
|
+
font-size: 18px;
|
|
146
|
+
padding: 4px 8px
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
.modal-body {
|
|
150
|
+
padding: 12px
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
@media (max-width:480px) {
|
|
154
|
+
.modal {
|
|
155
|
+
min-width: 260px
|
|
156
|
+
}
|
|
157
|
+
}
|
package/package.json
CHANGED
package/dist/index.css.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["index.css"],"names":[],"mappings":"AACA,MAEE,yBAA2B,CAC3B,+BAAiC,CACjC,SAAa,CACb,mBAAoB,CACpB,mBAAoB,CACpB,eACF,CAGA,mBACE,yBAA2B,CAC3B,+BAAiC,CACjC,SAAa,CACb,mBAAoB,CACpB,mBACF,CAEA,kBACE,wBAA0B,CAC1B,gCAAkC,CAClC,YAAa,CACb,mBAAoB,CACpB,sBACF,CAEA,UAEE,aAAA,CADA,eAEF,CAEA,OACE,cACF,CAGA,eAKE,sBAAuB,CAFvB,yBAA0B,CAC1B,YAAa,CAFb,OAAQ,CAIR,sBAAuB,CAGvB,SAAU,CAFV,YAAa,CAMb,mBAAoB,CAZpB,cAAe,CASf,2BAA6B,CAF7B,aAMF,CAEA,uBACE,SAAU,CACV,mBACF,CAGA,8BAEE,gCAAiC,CADjC,SAEF,CAEA,OAGE,oBAAqB,CAErB,iBAAkB,CAClB,qCAA0C,CAF1C,eAAgB,CAMhB,SAAU,CAHV,eAAgB,CANhB,iBAAkB,CAUlB,oDAAsD,CACtD,gDAAoD,CAVpD,aAWF,CAEA,eACE,SAAU,CACV,0CACF,CAGA,QAGE,oBAAqB,CAErB,iBAAkB,CAClB,qCAA0C,CAG1C,eAAgB,CADhB,cAAe,CAJf,eAAgB,CAOhB,SAAU,CAJV,eAAgB,CANhB,iBAAkB,CAWlB,sBAAyB,CACzB,kGACgD,CAZhD,aAaF,CAGA,mBAAqB,WAAc,CACnC,iBAAmB,UAAa,CAGhC,6BAAgC,2BAA8B,CAC9D,8BAAgC,0BAA6B,CAC7D,0BAAgC,2BAA8B,CAC9D,6BAAgC,0BAA6B,CAE7D,gBACE,SACF,CAEA,2EAEE,uBACF,CAEA,uEAEE,uBACF,CAEA,cAEE,kBAAmB,CAGnB,2BAA4B,CAC5B,yBAA0B,CAC1B,WAAA,CANA,YAAa,CAEb,6BAA8B,CAC9B,iBAIF,CAEA,aACE,eACF,CAEA,aAEE,sBAAuB,CADvB,WAAY,CAEZ,cAAe,CACf,eACF,CAEA,YACE,YACF,CAEA,yBACE,OACE,eACF,CACF","file":"index.css","sourcesContent":["\r\n:root {\r\n /* sensible defaults so modal isn't transparent when used standalone */\r\n --overlay: rgba(0,0,0,0.35);\r\n --overlay-strong: rgba(0,0,0,0.6);\r\n --bg: #ffffff;\r\n --header-bg: #f5f5f5;\r\n --header-color: #000;\r\n --modal-z: 60000;\r\n}\r\n\r\n/* theme overrides (use data-theme to scope) */\r\n[data-theme='light'] {\r\n --overlay: rgba(0,0,0,0.35);\r\n --overlay-strong: rgba(0,0,0,0.6);\r\n --bg: #ffffff;\r\n --header-bg: #f5f5f5;\r\n --header-color: #000;\r\n}\r\n\r\n[data-theme='dark'] {\r\n --overlay: rgba(0,0,0,0.6);\r\n --overlay-strong: rgba(0,0,0,0.85);\r\n --bg: #2c2c2c;\r\n --header-bg: #3a3a3a;\r\n --header-color: #f1f1f1;\r\n}\r\n\r\n.app-root {\r\n max-width: 900px;\r\n margin: 0 auto\r\n}\r\n\r\nbutton {\r\n cursor: pointer\r\n}\r\n\r\n/* ensure modal overlay sits above other UI (other packages use very large z-index values) */\r\n.modal-overlay {\r\n position: fixed;\r\n inset: 0;\r\n background: var(--overlay);\r\n display: flex;\r\n align-items: flex-start;\r\n justify-content: center;\r\n padding: 40px;\r\n z-index: 60000; /* raised from 999 */\r\n opacity: 0;\r\n transition: opacity 0.2s ease;\r\n\r\n /* when invisible we don't want it blocking clicks */\r\n pointer-events: none;\r\n}\r\n\r\n.modal-overlay.visible {\r\n opacity: 1;\r\n pointer-events: auto;\r\n}\r\n\r\n/* drawer-specific overlay adjustments */\r\n.modal-overlay.drawer-overlay {\r\n padding: 0; /* flush to edges for drawers */\r\n background: var(--overlay-strong);\r\n}\r\n\r\n.modal {\r\n position: absolute;\r\n z-index: 60001; /* keep modal above the overlay's stacking context children */\r\n background: var(--bg);\r\n min-width: 300px;\r\n border-radius: 2px;\r\n box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);\r\n overflow: hidden;\r\n\r\n /* entry animation state */\r\n opacity: 0;\r\n transform: translateY(-20px) scale(0.85) rotate(-4deg);\r\n transition: opacity 0.25s ease, transform 0.25s ease;\r\n}\r\n\r\n.modal.visible {\r\n opacity: 1;\r\n transform: translateY(0) scale(1) rotate(0);\r\n}\r\n\r\n/* drawer uses a simple slide animation and adapts to the chosen edge */\r\n.drawer {\r\n position: absolute;\r\n z-index: 60001;\r\n background: var(--bg);\r\n min-width: 300px;\r\n border-radius: 2px;\r\n box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);\r\n overflow: hidden;\r\n max-width: 100%;\r\n max-height: 100%;\r\n\r\n opacity: 0;\r\n transform: translate(0,0);\r\n transition: opacity var(--drawer-transition, 0.45s) ease,\r\n transform var(--drawer-transition, 0.45s) ease;\r\n}\r\n\r\n/* full height when coming from left/right, full width for top/bottom */\r\n.drawer.horizontal { height: 100%; }\r\n.drawer.vertical { width: 100%; }\r\n\r\n/* offscreen start positions by 100% of its own size */\r\n.drawer.horizontal.side-left { transform: translateX(-100%); }\r\n.drawer.horizontal.side-right { transform: translateX(100%); }\r\n.drawer.vertical.side-top { transform: translateY(-100%); }\r\n.drawer.vertical.side-bottom { transform: translateY(100%); }\r\n\r\n.drawer.visible {\r\n opacity: 1;\r\n}\r\n\r\n.drawer.visible.horizontal.side-left,\r\n.drawer.visible.horizontal.side-right {\r\n transform: translateX(0);\r\n}\r\n\r\n.drawer.visible.vertical.side-top,\r\n.drawer.visible.vertical.side-bottom {\r\n transform: translateY(0);\r\n}\r\n\r\n.modal-header {\r\n display: flex;\r\n align-items: center;\r\n justify-content: space-between;\r\n padding: 10px 12px;\r\n background: var(--header-bg);\r\n color: var(--header-color);\r\n cursor: grab\r\n}\r\n\r\n.modal-title {\r\n font-weight: 600\r\n}\r\n\r\n.modal-close {\r\n border: none;\r\n background: transparent;\r\n font-size: 18px;\r\n padding: 4px 8px\r\n}\r\n\r\n.modal-body {\r\n padding: 12px\r\n}\r\n\r\n@media (max-width:480px) {\r\n .modal {\r\n min-width: 260px\r\n }\r\n}"]}
|