@salesforcedevs/docs-components 0.0.6 → 0.0.7-edit

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.
Files changed (135) hide show
  1. package/lwc.config.json +25 -2
  2. package/package.json +17 -6
  3. package/src/modules/README.md +41 -0
  4. package/src/modules/doc/amfModelParser/amfModelParser.ts +674 -0
  5. package/src/modules/doc/amfReference/amfReference.css +25 -0
  6. package/src/modules/doc/amfReference/amfReference.html +60 -0
  7. package/src/modules/doc/amfReference/amfReference.ts +1494 -0
  8. package/src/modules/doc/amfReference/constants.ts +76 -0
  9. package/src/modules/doc/amfReference/types.ts +125 -0
  10. package/src/modules/doc/amfTopic/amfTopic.css +21 -0
  11. package/src/modules/doc/amfTopic/amfTopic.html +3 -0
  12. package/src/modules/doc/amfTopic/amfTopic.ts +111 -0
  13. package/src/modules/doc/amfTopic/types.ts +56 -0
  14. package/src/modules/doc/amfTopic/utils.ts +136 -0
  15. package/src/modules/doc/breadcrumbItem/breadcrumbItem.css +51 -0
  16. package/src/modules/doc/breadcrumbItem/breadcrumbItem.html +5 -0
  17. package/src/modules/doc/breadcrumbItem/breadcrumbItem.ts +71 -0
  18. package/src/modules/doc/breadcrumbs/breadcrumbs.css +27 -0
  19. package/src/modules/doc/breadcrumbs/breadcrumbs.html +58 -0
  20. package/src/modules/doc/breadcrumbs/breadcrumbs.ts +183 -0
  21. package/src/modules/doc/chat/README.md +179 -0
  22. package/src/modules/doc/chat/chat.css +821 -0
  23. package/src/modules/doc/chat/chat.html +241 -0
  24. package/src/modules/doc/chat/chat.ts +586 -0
  25. package/src/modules/doc/componentPlayground/componentPlayground.css +22 -0
  26. package/src/modules/doc/componentPlayground/componentPlayground.html +20 -0
  27. package/src/modules/doc/componentPlayground/componentPlayground.ts +29 -0
  28. package/src/modules/doc/content/content.css +249 -87
  29. package/src/modules/doc/content/content.html +3 -2
  30. package/src/modules/doc/content/content.ts +272 -152
  31. package/src/modules/doc/contentCallout/contentCallout.css +25 -26
  32. package/src/modules/doc/contentCallout/contentCallout.html +13 -4
  33. package/src/modules/doc/contentCallout/contentCallout.ts +21 -10
  34. package/src/modules/doc/contentLayout/contentLayout.css +1 -0
  35. package/src/modules/doc/contentLayout/contentLayout.html +68 -0
  36. package/src/modules/doc/contentLayout/contentLayout.ts +531 -0
  37. package/src/modules/doc/contentMedia/contentMedia.css +49 -0
  38. package/src/modules/doc/contentMedia/contentMedia.html +23 -0
  39. package/src/modules/doc/contentMedia/contentMedia.ts +34 -0
  40. package/src/modules/doc/doDont/doDont.css +47 -0
  41. package/src/modules/doc/doDont/doDont.html +27 -0
  42. package/src/modules/doc/doDont/doDont.ts +17 -0
  43. package/src/modules/doc/editFile/editFile.css +512 -0
  44. package/src/modules/doc/editFile/editFile.html +164 -0
  45. package/src/modules/doc/editFile/editFile.ts +215 -0
  46. package/src/modules/doc/header/header.css +132 -0
  47. package/src/modules/doc/header/header.html +55 -0
  48. package/src/modules/doc/header/header.ts +120 -0
  49. package/src/modules/doc/heading/heading.css +33 -0
  50. package/src/modules/doc/heading/heading.html +14 -0
  51. package/src/modules/doc/heading/heading.ts +67 -0
  52. package/src/modules/doc/headingAnchor/headingAnchor.css +33 -0
  53. package/src/modules/doc/headingAnchor/headingAnchor.html +19 -0
  54. package/src/modules/doc/headingAnchor/headingAnchor.ts +43 -0
  55. package/src/modules/doc/headingContent/headingContent.css +53 -0
  56. package/src/modules/doc/headingContent/headingContent.html +13 -0
  57. package/src/modules/doc/headingContent/headingContent.ts +30 -0
  58. package/src/modules/doc/lwcContentLayout/lwcContentLayout.css +1 -0
  59. package/src/modules/doc/lwcContentLayout/lwcContentLayout.html +68 -0
  60. package/src/modules/doc/lwcContentLayout/lwcContentLayout.ts +168 -0
  61. package/src/modules/doc/nav/nav.css +4 -2
  62. package/src/modules/doc/nav/nav.ts +1 -1
  63. package/src/modules/doc/overview/overview.css +40 -0
  64. package/src/modules/doc/overview/overview.html +34 -0
  65. package/src/modules/doc/overview/overview.ts +12 -0
  66. package/src/modules/doc/phase/phase.css +70 -0
  67. package/src/modules/doc/phase/phase.html +38 -0
  68. package/src/modules/doc/phase/phase.ts +93 -0
  69. package/src/modules/doc/specificationContent/specificationContent.css +36 -0
  70. package/src/modules/doc/specificationContent/specificationContent.html +171 -0
  71. package/src/modules/doc/specificationContent/specificationContent.ts +127 -0
  72. package/src/modules/doc/sprigSurvey/sprigSurvey.html +20 -0
  73. package/src/modules/doc/sprigSurvey/sprigSurvey.scoped.css +16 -0
  74. package/src/modules/doc/sprigSurvey/sprigSurvey.ts +16 -0
  75. package/src/modules/doc/toc/toc.html +11 -6
  76. package/src/modules/doc/toc/toc.ts +1 -1
  77. package/src/modules/doc/toolbar/toolbar.html +8 -1
  78. package/src/modules/doc/versionPicker/versionPicker.css +64 -0
  79. package/src/modules/doc/versionPicker/versionPicker.html +38 -0
  80. package/src/modules/doc/versionPicker/versionPicker.ts +65 -0
  81. package/src/modules/doc/xmlContent/types.ts +120 -0
  82. package/src/modules/doc/xmlContent/utils.ts +163 -0
  83. package/src/modules/doc/xmlContent/xmlContent.css +54 -0
  84. package/src/modules/doc/xmlContent/xmlContent.html +52 -0
  85. package/src/modules/doc/xmlContent/xmlContent.ts +792 -0
  86. package/src/modules/docHelpers/amfStyle/amfStyle.css +355 -0
  87. package/src/modules/docHelpers/contentLayoutStyle/contentLayoutStyle.css +131 -0
  88. package/src/modules/docHelpers/imgStyle/imgStyle.css +59 -0
  89. package/src/modules/docHelpers/status/status.css +22 -0
  90. package/src/modules/docUtils/searchSyncer/searchSyncer.ts +86 -0
  91. package/src/modules/docUtils/utils/__mocks__/coveo.analytics.ts +16 -0
  92. package/src/modules/docUtils/utils/coveo.analytics.d.ts +10 -0
  93. package/src/modules/docUtils/utils/utils.ts +32 -0
  94. package/src/modules/doc/container/__benchmarks__/container.benchmark.js +0 -43
  95. package/src/modules/doc/container/__mocks__/mockAvailableLanguages.js +0 -8
  96. package/src/modules/doc/container/__mocks__/mockAvailableVersions.js +0 -122
  97. package/src/modules/doc/container/__mocks__/mockContentFetchResponse.json +0 -5
  98. package/src/modules/doc/container/__mocks__/mockDocContent.js +0 -29
  99. package/src/modules/doc/container/__mocks__/mockNavigationFetchResponse.json +0 -4061
  100. package/src/modules/doc/container/__mocks__/mockPageReference.js +0 -8
  101. package/src/modules/doc/container/__mocks__/mockPdfUrl.js +0 -1
  102. package/src/modules/doc/container/__mocks__/mockSelectedLanguage.js +0 -8
  103. package/src/modules/doc/container/__mocks__/mockSelectedVersion.js +0 -8
  104. package/src/modules/doc/container/__mocks__/mockToc.js +0 -146
  105. package/src/modules/doc/container/__tests__/container.test.ts +0 -82
  106. package/src/modules/doc/container/container.css +0 -34
  107. package/src/modules/doc/container/container.html +0 -23
  108. package/src/modules/doc/container/container.stories.ts +0 -18
  109. package/src/modules/doc/container/container.ts +0 -356
  110. package/src/modules/doc/content/__tests__/content.test.ts +0 -30
  111. package/src/modules/doc/content/__tests__/mockDocContent.ts +0 -29
  112. package/src/modules/doc/content/__tests__/mockPageReference.ts +0 -8
  113. package/src/modules/doc/contentCallout/__tests__/contentCallout.test.ts +0 -80
  114. package/src/modules/doc/contentCallout/__tests__/mockProps.ts +0 -14
  115. package/src/modules/doc/contentCallout/contentCallout.stories.ts +0 -29
  116. package/src/modules/doc/nav/__tests__/mockAvailableLanguages.ts +0 -8
  117. package/src/modules/doc/nav/__tests__/mockAvailableVersions.ts +0 -122
  118. package/src/modules/doc/nav/__tests__/mockPageReference.ts +0 -8
  119. package/src/modules/doc/nav/__tests__/mockPdfUrl.ts +0 -1
  120. package/src/modules/doc/nav/__tests__/mockSelectedLanguage.ts +0 -8
  121. package/src/modules/doc/nav/__tests__/mockSelectedVersion.ts +0 -8
  122. package/src/modules/doc/nav/__tests__/mockToc.ts +0 -146
  123. package/src/modules/doc/nav/__tests__/nav.test.ts +0 -62
  124. package/src/modules/doc/search/__tests__/search.test.ts +0 -20
  125. package/src/modules/doc/search/search.html +0 -1
  126. package/src/modules/doc/search/search.ts +0 -3
  127. package/src/modules/doc/toc/__tests__/mockPageReference.ts +0 -8
  128. package/src/modules/doc/toc/__tests__/mockToc.ts +0 -146
  129. package/src/modules/doc/toc/__tests__/toc.test.ts +0 -29
  130. package/src/modules/doc/toolbar/__tests__/mockAvailableLanguages.ts +0 -8
  131. package/src/modules/doc/toolbar/__tests__/mockAvailableVersions.ts +0 -122
  132. package/src/modules/doc/toolbar/__tests__/mockPdfUrl.ts +0 -1
  133. package/src/modules/doc/toolbar/__tests__/mockSelectedLanguage.ts +0 -8
  134. package/src/modules/doc/toolbar/__tests__/mockSelectedVersion.ts +0 -8
  135. package/src/modules/doc/toolbar/__tests__/toolbar.test.ts +0 -44
@@ -0,0 +1,47 @@
1
+ @import "dxHelpers/reset";
2
+ @import "dxHelpers/text";
3
+
4
+ .container {
5
+ display: flex;
6
+ flex-direction: column;
7
+ gap: var(--dx-g-spacing-md);
8
+ flex: 1;
9
+ }
10
+
11
+ .doc-do-dont-header {
12
+ display: flex;
13
+ align-items: center;
14
+ gap: var(--dx-g-spacing-sm);
15
+ }
16
+
17
+ .doc-do-dont-label {
18
+ font-family: var(--dx-g-font-display);
19
+ font-size: var(--dx-g-spacing-md);
20
+ font-weight: var(--dx-g-font-demi);
21
+ line-height: var(--dx-g-spacing-lg);
22
+ }
23
+
24
+ .doc-do-color {
25
+ color: var(--dx-g-green-vibrant-50);
26
+ }
27
+
28
+ .doc-dont-color {
29
+ color: var(--dx-g-red-vibrant-30);
30
+ }
31
+
32
+ .do-dont-image-container {
33
+ display: flex;
34
+ max-height: 480px;
35
+ min-height: 140px;
36
+ padding: var(--dx-g-spacing-3xl) var(--dx-g-spacing-2xl);
37
+ flex-direction: column;
38
+ justify-content: center;
39
+ align-items: center;
40
+ flex: 1;
41
+ border-radius: var(--dx-g-spacing-sm);
42
+ border: 1px solid var(--dx-g-brand-default-color-border-2);
43
+ }
44
+
45
+ .doc-do-dont-img {
46
+ object-fit: contain;
47
+ }
@@ -0,0 +1,27 @@
1
+ <template>
2
+ <div class="container">
3
+ <div class="doc-do-dont-header">
4
+ <template lwc:if={isDo}>
5
+ <dx-icon
6
+ symbol="success"
7
+ size="large"
8
+ color="green-vibrant-50"
9
+ ></dx-icon>
10
+ <div class="doc-do-dont-label doc-do-color">Do</div>
11
+ </template>
12
+ <template lwc:else>
13
+ <dx-icon
14
+ symbol="clear"
15
+ size="large"
16
+ color="red-vibrant-30"
17
+ class="doc-do-dont-icon"
18
+ ></dx-icon>
19
+ <div class="doc-do-dont-label doc-dont-color">Don't</div>
20
+ </template>
21
+ </div>
22
+ <div class="do-dont-image-container">
23
+ <img class="doc-do-dont-img" src={imgSrc} alt={caption} />
24
+ </div>
25
+ <div class="dx-text-body-4">{caption}</div>
26
+ </div>
27
+ </template>
@@ -0,0 +1,17 @@
1
+ import { LightningElement, api } from "lwc";
2
+ import { normalizeBoolean } from "dxUtils/normalizers";
3
+
4
+ export default class DoDont extends LightningElement {
5
+ @api caption: string = "";
6
+ @api imgSrc!: string;
7
+ _isDo: boolean = false;
8
+
9
+ @api
10
+ get isDo(): boolean {
11
+ return this._isDo;
12
+ }
13
+
14
+ set isDo(value) {
15
+ this._isDo = normalizeBoolean(value);
16
+ }
17
+ }
@@ -0,0 +1,512 @@
1
+ /* Host container */
2
+ :host {
3
+ font-family: "Salesforce Sans", -apple-system, BlinkMacSystemFont,
4
+ "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue",
5
+ sans-serif;
6
+ position: absolute;
7
+ top: 10px;
8
+ left: 50%;
9
+ transform: translateX(-50%);
10
+ z-index: 1000;
11
+ }
12
+
13
+ /* Edit File Trigger Button */
14
+ .edit-file-trigger {
15
+ background: linear-gradient(135deg, #0176d3 0%, #005fb2 100%);
16
+ color: white;
17
+ border: none;
18
+ border-radius: 12px;
19
+ padding: 12px 16px;
20
+ cursor: pointer;
21
+ display: flex;
22
+ align-items: center;
23
+ gap: 8px;
24
+ box-shadow: 0 4px 16px rgb(1 118 211 / 25%), 0 2px 8px rgb(1 118 211 / 15%);
25
+ transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
26
+ font-size: 14px;
27
+ font-weight: 500;
28
+ letter-spacing: 0.02em;
29
+ width: 150px;
30
+ justify-content: center;
31
+ }
32
+
33
+ .edit-file-trigger:hover:not(:disabled) {
34
+ background: linear-gradient(135deg, #005fb2 0%, #003e73 100%);
35
+ transform: translateY(-2px);
36
+ box-shadow: 0 6px 20px rgb(1 118 211 / 35%), 0 4px 12px rgb(1 118 211 / 25%);
37
+ }
38
+
39
+ .edit-file-trigger:active:not(:disabled) {
40
+ transform: translateY(0);
41
+ box-shadow: 0 2px 8px rgb(1 118 211 / 30%);
42
+ }
43
+
44
+ .edit-file-trigger:disabled {
45
+ background: #d8dde6;
46
+ color: #706e6b;
47
+ cursor: not-allowed;
48
+ transform: none;
49
+ box-shadow: 0 1px 3px rgb(0 0 0 / 12%);
50
+ }
51
+
52
+ .edit-file-icon {
53
+ width: 18px;
54
+ height: 18px;
55
+ flex-shrink: 0;
56
+ }
57
+
58
+ .edit-file-trigger-text {
59
+ font-weight: 500;
60
+ white-space: nowrap;
61
+ }
62
+
63
+ /* Overlay */
64
+ .edit-file-overlay {
65
+ position: fixed;
66
+ top: 0;
67
+ left: 0;
68
+ width: 100%;
69
+ height: 100%;
70
+ background: rgb(0 0 0 / 50%);
71
+ backdrop-filter: blur(4px);
72
+ z-index: 10000;
73
+ display: flex;
74
+ align-items: center;
75
+ justify-content: center;
76
+ opacity: 0;
77
+ visibility: hidden;
78
+ transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
79
+ padding: 20px;
80
+ box-sizing: border-box;
81
+ }
82
+
83
+ .edit-file-overlay_open {
84
+ opacity: 1;
85
+ visibility: visible;
86
+ }
87
+
88
+ /* Popover */
89
+ .edit-file-popover {
90
+ background: white;
91
+ border-radius: 16px;
92
+ box-shadow: 0 20px 60px rgb(0 0 0 / 20%), 0 8px 24px rgb(0 0 0 / 15%);
93
+ width: 100%;
94
+ max-width: 900px;
95
+ max-height: 90vh;
96
+ display: flex;
97
+ flex-direction: column;
98
+ transform: scale(0.9) translateY(20px);
99
+ transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
100
+ overflow: hidden;
101
+ }
102
+
103
+ .edit-file-popover_open {
104
+ transform: scale(1) translateY(0);
105
+ }
106
+
107
+ /* Popover Header */
108
+ .edit-file-header {
109
+ padding: 24px 24px 20px;
110
+ border-bottom: 1px solid #e5e7ea;
111
+ display: flex;
112
+ align-items: flex-start;
113
+ justify-content: space-between;
114
+ gap: 16px;
115
+ background: linear-gradient(180deg, #fafbfc 0%, #f7f9fb 100%);
116
+ position: relative;
117
+ }
118
+
119
+ .edit-file-title {
120
+ margin: 0;
121
+ font-size: 24px;
122
+ font-weight: 700;
123
+ color: #181818;
124
+ letter-spacing: -0.02em;
125
+ }
126
+
127
+ .edit-file-filename {
128
+ margin: 8px 0 0;
129
+ font-size: 14px;
130
+ color: #706e6b;
131
+ display: flex;
132
+ align-items: center;
133
+ gap: 6px;
134
+ font-weight: 500;
135
+ }
136
+
137
+ .edit-file-file-icon {
138
+ width: 16px;
139
+ height: 16px;
140
+ color: #0176d3;
141
+ }
142
+
143
+ .edit-file-close {
144
+ width: 40px;
145
+ height: 40px;
146
+ border: none;
147
+ background: transparent;
148
+ border-radius: 10px;
149
+ cursor: pointer;
150
+ display: flex;
151
+ align-items: center;
152
+ justify-content: center;
153
+ transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
154
+ color: #706e6b;
155
+ flex-shrink: 0;
156
+ }
157
+
158
+ .edit-file-close:hover {
159
+ background: #f3f3f3;
160
+ color: #181818;
161
+ transform: scale(1.05);
162
+ }
163
+
164
+ .edit-file-close-icon {
165
+ width: 20px;
166
+ height: 20px;
167
+ }
168
+
169
+ /* Popover Content */
170
+ .edit-file-content {
171
+ flex: 1;
172
+ padding: 24px;
173
+ overflow-y: auto;
174
+ min-height: 0;
175
+ }
176
+
177
+ /* Loading State */
178
+ .edit-file-loading {
179
+ display: flex;
180
+ flex-direction: column;
181
+ align-items: center;
182
+ justify-content: center;
183
+ padding: 60px 20px;
184
+ gap: 16px;
185
+ }
186
+
187
+ .edit-file-spinner {
188
+ width: 32px;
189
+ height: 32px;
190
+ border: 3px solid #e5e7ea;
191
+ border-top: 3px solid #0176d3;
192
+ border-radius: 50%;
193
+ animation: edit-file-spin 1s linear infinite;
194
+ }
195
+
196
+ .edit-file-loading-text {
197
+ margin: 0;
198
+ color: #706e6b;
199
+ font-size: 16px;
200
+ font-weight: 500;
201
+ }
202
+
203
+ /* Error State */
204
+ .edit-file-error {
205
+ display: flex;
206
+ align-items: center;
207
+ gap: 12px;
208
+ padding: 16px 20px;
209
+ background: #fef7f7;
210
+ border: 1px solid #fecaca;
211
+ border-radius: 12px;
212
+ color: #dc2626;
213
+ margin-bottom: 20px;
214
+ }
215
+
216
+ .edit-file-error-icon {
217
+ width: 20px;
218
+ height: 20px;
219
+ flex-shrink: 0;
220
+ }
221
+
222
+ .edit-file-error-text {
223
+ font-size: 14px;
224
+ font-weight: 500;
225
+ }
226
+
227
+ /* Editor */
228
+ .edit-file-editor {
229
+ width: 100%;
230
+ }
231
+
232
+ .edit-file-label {
233
+ display: block;
234
+ margin-bottom: 8px;
235
+ font-size: 14px;
236
+ font-weight: 600;
237
+ color: #181818;
238
+ }
239
+
240
+ .edit-file-textarea {
241
+ width: 100%;
242
+ min-height: 400px;
243
+ padding: 16px;
244
+ border: 2px solid #e5e7ea;
245
+ border-radius: 12px;
246
+ font-family: "SF Mono", "Monaco", "Consolas", "Liberation Mono", "Courier New", monospace;
247
+ font-size: 14px;
248
+ line-height: 1.5;
249
+ resize: vertical;
250
+ outline: none;
251
+ background: #fafbfc;
252
+ transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
253
+ box-sizing: border-box;
254
+ }
255
+
256
+ .edit-file-textarea:focus {
257
+ border-color: #0176d3;
258
+ background: white;
259
+ box-shadow: 0 0 0 3px rgb(1 118 211 / 10%);
260
+ }
261
+
262
+ .edit-file-textarea::placeholder {
263
+ color: #9ca3af;
264
+ }
265
+
266
+ /* Popover Footer */
267
+ .edit-file-footer {
268
+ padding: 20px 24px 24px;
269
+ border-top: 1px solid #e5e7ea;
270
+ display: flex;
271
+ align-items: center;
272
+ justify-content: space-between;
273
+ gap: 16px;
274
+ background: linear-gradient(180deg, #fafbfc 0%, #f7f9fb 100%);
275
+ }
276
+
277
+ /* Status Indicators */
278
+ .edit-file-status {
279
+ display: flex;
280
+ align-items: center;
281
+ gap: 8px;
282
+ font-size: 14px;
283
+ font-weight: 500;
284
+ }
285
+
286
+ .edit-file-saving {
287
+ display: flex;
288
+ align-items: center;
289
+ gap: 8px;
290
+ color: #0176d3;
291
+ }
292
+
293
+ .edit-file-mini-spinner {
294
+ width: 16px;
295
+ height: 16px;
296
+ border: 2px solid #e5e7ea;
297
+ border-top: 2px solid #0176d3;
298
+ border-radius: 50%;
299
+ animation: edit-file-spin 1s linear infinite;
300
+ }
301
+
302
+ .edit-file-unchanged {
303
+ color: #706e6b;
304
+ }
305
+
306
+ .edit-file-modified {
307
+ color: #059669;
308
+ position: relative;
309
+ }
310
+
311
+ .edit-file-modified::before {
312
+ content: "●";
313
+ margin-right: 6px;
314
+ color: #059669;
315
+ }
316
+
317
+ /* Action Buttons */
318
+ .edit-file-actions {
319
+ display: flex;
320
+ gap: 12px;
321
+ }
322
+
323
+ .edit-file-button {
324
+ padding: 12px 24px;
325
+ border-radius: 10px;
326
+ font-size: 14px;
327
+ font-weight: 600;
328
+ cursor: pointer;
329
+ transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
330
+ display: flex;
331
+ align-items: center;
332
+ gap: 8px;
333
+ border: none;
334
+ white-space: nowrap;
335
+ }
336
+
337
+ .edit-file-button_secondary {
338
+ background: #f3f3f3;
339
+ color: #181818;
340
+ border: 1px solid #e5e7ea;
341
+ }
342
+
343
+ .edit-file-button_secondary:hover:not(:disabled) {
344
+ background: #e5e7ea;
345
+ transform: translateY(-1px);
346
+ }
347
+
348
+ .edit-file-button_primary {
349
+ background: linear-gradient(135deg, #0176d3 0%, #005fb2 100%);
350
+ color: white;
351
+ }
352
+
353
+ .edit-file-button_primary:hover:not(:disabled) {
354
+ background: linear-gradient(135deg, #005fb2 0%, #003e73 100%);
355
+ transform: translateY(-1px);
356
+ box-shadow: 0 4px 12px rgb(1 118 211 / 25%);
357
+ }
358
+
359
+ .edit-file-button_disabled {
360
+ background: #d8dde6 !important;
361
+ color: #706e6b !important;
362
+ cursor: not-allowed !important;
363
+ transform: none !important;
364
+ box-shadow: none !important;
365
+ }
366
+
367
+ .edit-file-button:disabled {
368
+ background: #d8dde6;
369
+ color: #706e6b;
370
+ cursor: not-allowed;
371
+ transform: none;
372
+ box-shadow: none;
373
+ }
374
+
375
+ .edit-file-button-spinner {
376
+ width: 16px;
377
+ height: 16px;
378
+ border: 2px solid transparent;
379
+ border-top: 2px solid currentColor;
380
+ border-radius: 50%;
381
+ animation: edit-file-spin 1s linear infinite;
382
+ }
383
+
384
+ /* Animations */
385
+ @keyframes edit-file-spin {
386
+ to {
387
+ transform: rotate(360deg);
388
+ }
389
+ }
390
+
391
+ /* Responsive Design */
392
+ @media (max-width: 768px) {
393
+ .edit-file-trigger {
394
+ padding: 10px 14px;
395
+ font-size: 13px;
396
+ }
397
+
398
+ .edit-file-trigger-text {
399
+ display: none;
400
+ }
401
+
402
+ .edit-file-overlay {
403
+ padding: 16px;
404
+ }
405
+
406
+ .edit-file-popover {
407
+ max-width: 100%;
408
+ max-height: 95vh;
409
+ }
410
+
411
+ .edit-file-header {
412
+ padding: 20px 20px 16px;
413
+ }
414
+
415
+ .edit-file-title {
416
+ font-size: 20px;
417
+ }
418
+
419
+ .edit-file-content {
420
+ padding: 20px;
421
+ }
422
+
423
+ .edit-file-textarea {
424
+ min-height: 300px;
425
+ font-size: 13px;
426
+ }
427
+
428
+ .edit-file-footer {
429
+ padding: 16px 20px 20px;
430
+ flex-direction: column;
431
+ align-items: stretch;
432
+ gap: 12px;
433
+ }
434
+
435
+ .edit-file-actions {
436
+ width: 100%;
437
+ justify-content: stretch;
438
+ }
439
+
440
+ .edit-file-button {
441
+ flex: 1;
442
+ justify-content: center;
443
+ }
444
+ }
445
+
446
+ @media (max-width: 480px) {
447
+ .edit-file-trigger {
448
+ padding: 8px 12px;
449
+ }
450
+
451
+ .edit-file-overlay {
452
+ padding: 12px;
453
+ }
454
+
455
+ .edit-file-header {
456
+ padding: 16px;
457
+ }
458
+
459
+ .edit-file-title {
460
+ font-size: 18px;
461
+ }
462
+
463
+ .edit-file-content {
464
+ padding: 16px;
465
+ }
466
+
467
+ .edit-file-footer {
468
+ padding: 12px 16px 16px;
469
+ }
470
+
471
+ .edit-file-textarea {
472
+ min-height: 250px;
473
+ padding: 12px;
474
+ }
475
+ }
476
+
477
+ /* Accessibility improvements */
478
+ @media (prefers-reduced-motion: reduce) {
479
+ .edit-file-trigger,
480
+ .edit-file-overlay,
481
+ .edit-file-popover,
482
+ .edit-file-close,
483
+ .edit-file-button,
484
+ .edit-file-textarea {
485
+ transition: none;
486
+ }
487
+
488
+ .edit-file-spinner,
489
+ .edit-file-mini-spinner,
490
+ .edit-file-button-spinner {
491
+ animation: none;
492
+ }
493
+ }
494
+
495
+ /* High contrast mode support */
496
+ @media (prefers-contrast: high) {
497
+ .edit-file-trigger {
498
+ border: 2px solid;
499
+ }
500
+
501
+ .edit-file-popover {
502
+ border: 2px solid #000;
503
+ }
504
+
505
+ .edit-file-textarea {
506
+ border: 2px solid #000;
507
+ }
508
+
509
+ .edit-file-button {
510
+ border: 2px solid;
511
+ }
512
+ }