canvasframework 0.5.16 → 0.5.18

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 (112) hide show
  1. package/dist/canvasframework.js +2 -0
  2. package/dist/canvasframework.js.LICENSE.txt +1 -0
  3. package/package.json +18 -17
  4. package/components/Accordion.js +0 -265
  5. package/components/AndroidDatePickerDialog.js +0 -406
  6. package/components/AppBar.js +0 -398
  7. package/components/AudioPlayer.js +0 -611
  8. package/components/Avatar.js +0 -202
  9. package/components/Banner.js +0 -342
  10. package/components/BottomNavigationBar.js +0 -433
  11. package/components/BottomSheet.js +0 -234
  12. package/components/Button.js +0 -360
  13. package/components/Camera.js +0 -644
  14. package/components/Card.js +0 -193
  15. package/components/Chart.js +0 -700
  16. package/components/Checkbox.js +0 -166
  17. package/components/Chip.js +0 -212
  18. package/components/CircularProgress.js +0 -327
  19. package/components/ContextMenu.js +0 -116
  20. package/components/DatePicker.js +0 -298
  21. package/components/Dialog.js +0 -337
  22. package/components/Divider.js +0 -125
  23. package/components/Drawer.js +0 -276
  24. package/components/FAB.js +0 -270
  25. package/components/FileUpload.js +0 -315
  26. package/components/FloatedCamera.js +0 -644
  27. package/components/IOSDatePickerWheel.js +0 -430
  28. package/components/ImageCarousel.js +0 -219
  29. package/components/ImageComponent.js +0 -223
  30. package/components/Input.js +0 -831
  31. package/components/InputDatalist.js +0 -723
  32. package/components/InputTags.js +0 -624
  33. package/components/List.js +0 -95
  34. package/components/ListItem.js +0 -269
  35. package/components/Modal.js +0 -364
  36. package/components/MorphingFAB.js +0 -428
  37. package/components/MultiSelectDialog.js +0 -206
  38. package/components/NumberInput.js +0 -271
  39. package/components/PasswordInput.js +0 -462
  40. package/components/ProgressBar.js +0 -88
  41. package/components/QRCodeReader.js +0 -539
  42. package/components/RadioButton.js +0 -151
  43. package/components/SearchInput.js +0 -315
  44. package/components/SegmentedControl.js +0 -357
  45. package/components/Select.js +0 -199
  46. package/components/SelectDialog.js +0 -255
  47. package/components/Slider.js +0 -113
  48. package/components/SliverAppBar.js +0 -139
  49. package/components/Snackbar.js +0 -243
  50. package/components/SpeedDialFAB.js +0 -397
  51. package/components/Stepper.js +0 -281
  52. package/components/SwipeableListItem.js +0 -327
  53. package/components/Switch.js +0 -147
  54. package/components/Table.js +0 -492
  55. package/components/Tabs.js +0 -423
  56. package/components/Text.js +0 -141
  57. package/components/TextField.js +0 -151
  58. package/components/TimePicker.js +0 -934
  59. package/components/Toast.js +0 -236
  60. package/components/TreeView.js +0 -420
  61. package/components/Video.js +0 -397
  62. package/components/View.js +0 -140
  63. package/components/VirtualList.js +0 -120
  64. package/core/CanvasFramework.js +0 -3034
  65. package/core/Component.js +0 -243
  66. package/core/ThemeManager.js +0 -358
  67. package/core/UIBuilder.js +0 -267
  68. package/core/WebGLCanvasAdapter.js +0 -782
  69. package/features/Column.js +0 -43
  70. package/features/Grid.js +0 -47
  71. package/features/LayoutComponent.js +0 -43
  72. package/features/OpenStreetMap.js +0 -310
  73. package/features/Positioned.js +0 -33
  74. package/features/PullToRefresh.js +0 -328
  75. package/features/Row.js +0 -40
  76. package/features/SignaturePad.js +0 -257
  77. package/features/Skeleton.js +0 -193
  78. package/features/Stack.js +0 -21
  79. package/index.js +0 -119
  80. package/manager/AccessibilityManager.js +0 -107
  81. package/manager/ErrorHandler.js +0 -59
  82. package/manager/FeatureFlags.js +0 -60
  83. package/manager/MemoryManager.js +0 -107
  84. package/manager/PerformanceMonitor.js +0 -84
  85. package/manager/SecurityManager.js +0 -54
  86. package/utils/AnimationEngine.js +0 -734
  87. package/utils/CryptoManager.js +0 -303
  88. package/utils/DataStore.js +0 -403
  89. package/utils/DevTools.js +0 -1618
  90. package/utils/DevToolsConsole.js +0 -201
  91. package/utils/EventBus.js +0 -407
  92. package/utils/FetchClient.js +0 -74
  93. package/utils/FirebaseAuth.js +0 -653
  94. package/utils/FirebaseCore.js +0 -246
  95. package/utils/FirebaseFirestore.js +0 -581
  96. package/utils/FirebaseFunctions.js +0 -97
  97. package/utils/FirebaseRealtimeDB.js +0 -498
  98. package/utils/FirebaseStorage.js +0 -612
  99. package/utils/FormValidator.js +0 -355
  100. package/utils/GeoLocationService.js +0 -62
  101. package/utils/I18n.js +0 -207
  102. package/utils/IndexedDBManager.js +0 -273
  103. package/utils/InspectionOverlay.js +0 -308
  104. package/utils/NotificationManager.js +0 -60
  105. package/utils/OfflineSyncManager.js +0 -342
  106. package/utils/PayPalPayment.js +0 -678
  107. package/utils/QueryBuilder.js +0 -478
  108. package/utils/SafeArea.js +0 -64
  109. package/utils/SecureStorage.js +0 -289
  110. package/utils/StateManager.js +0 -207
  111. package/utils/StripePayment.js +0 -552
  112. package/utils/WebSocketClient.js +0 -66
@@ -1,315 +0,0 @@
1
- import Component from '../core/Component.js';
2
-
3
- /**
4
- * Zone de téléchargement de fichiers avec drag & drop
5
- * @class
6
- * @extends Component
7
- * @property {string} label - Texte affiché
8
- * @property {string} sublabel - Sous-texte
9
- * @property {string} accept - Types de fichiers acceptés
10
- * @property {boolean} multiple - Accepter plusieurs fichiers
11
- * @property {number} maxSize - Taille max en bytes
12
- * @property {Array} files - Fichiers sélectionnés
13
- * @property {boolean} isDragOver - État de survol
14
- * @property {string} borderColor - Couleur de bordure
15
- * @property {string} bgColor - Couleur de fond
16
- * @property {string} iconColor - Couleur de l'icône
17
- * @property {Function} onFilesSelected - Callback
18
- * @property {Function} onError - Callback d'erreur
19
- */
20
- class FileUpload extends Component {
21
- /**
22
- * Crée une instance de FileUpload
23
- * @param {CanvasFramework} framework - Framework parent
24
- * @param {Object} [options={}] - Options de configuration
25
- * @param {string} [options.label='Drag & drop files here'] - Label
26
- * @param {string} [options.sublabel='or click to browse'] - Sublabel
27
- * @param {string} [options.accept='*'] - Types acceptés
28
- * @param {boolean} [options.multiple=true] - Multiple fichiers
29
- * @param {number} [options.maxSize=10485760] - Taille max (10MB)
30
- * @param {Function} [options.onFilesSelected] - Callback
31
- * @param {Function} [options.onError] - Callback erreur
32
- */
33
- constructor(framework, options = {}) {
34
- super(framework, options);
35
-
36
- this.label = options.label || 'Drag & drop files here';
37
- this.sublabel = options.sublabel || 'or click to browse';
38
- this.accept = options.accept || '*';
39
- this.multiple = options.multiple !== false;
40
- this.maxSize = options.maxSize || 10485760; // 10MB
41
- this.files = [];
42
- this.isDragOver = false;
43
-
44
- const platform = framework.platform;
45
-
46
- // Styles selon la plateforme
47
- if (platform === 'material') {
48
- this.borderColor = '#6200EE';
49
- this.bgColor = 'rgba(98, 0, 238, 0.05)';
50
- this.iconColor = '#6200EE';
51
- this.borderRadius = 4;
52
- this.borderWidth = 2;
53
- } else {
54
- this.borderColor = '#007AFF';
55
- this.bgColor = 'rgba(0, 122, 255, 0.05)';
56
- this.iconColor = '#007AFF';
57
- this.borderRadius = 12;
58
- this.borderWidth = 2;
59
- }
60
-
61
- this.onFilesSelected = options.onFilesSelected || null;
62
- this.onError = options.onError || null;
63
-
64
- // Créer un input file caché
65
- this.createFileInput();
66
- }
67
-
68
- /**
69
- * Crée l'input file HTML caché
70
- * @private
71
- */
72
- createFileInput() {
73
- this.fileInput = document.createElement('input');
74
- this.fileInput.type = 'file';
75
- this.fileInput.accept = this.accept;
76
- this.fileInput.multiple = this.multiple;
77
- this.fileInput.style.display = 'none';
78
- document.body.appendChild(this.fileInput);
79
-
80
- this.fileInput.addEventListener('change', (e) => {
81
- this.handleFiles(Array.from(e.target.files));
82
- });
83
- }
84
-
85
- /**
86
- * Gère les fichiers sélectionnés
87
- * @param {Array} fileList - Liste des fichiers
88
- * @private
89
- */
90
- handleFiles(fileList) {
91
- const validFiles = [];
92
-
93
- for (let file of fileList) {
94
- // Vérifier la taille
95
- if (file.size > this.maxSize) {
96
- if (this.onError) {
97
- this.onError({
98
- type: 'size',
99
- message: `${file.name} exceeds max size of ${this.formatBytes(this.maxSize)}`,
100
- file: file
101
- });
102
- }
103
- continue;
104
- }
105
-
106
- // Vérifier le type si spécifié
107
- if (this.accept !== '*') {
108
- const acceptedTypes = this.accept.split(',').map(t => t.trim());
109
- const fileType = file.type;
110
- const fileExt = '.' + file.name.split('.').pop();
111
-
112
- const isAccepted = acceptedTypes.some(type => {
113
- if (type.startsWith('.')) {
114
- return fileExt === type;
115
- } else if (type.endsWith('/*')) {
116
- return fileType.startsWith(type.replace('/*', ''));
117
- } else {
118
- return fileType === type;
119
- }
120
- });
121
-
122
- if (!isAccepted) {
123
- if (this.onError) {
124
- this.onError({
125
- type: 'type',
126
- message: `${file.name} is not an accepted file type`,
127
- file: file
128
- });
129
- }
130
- continue;
131
- }
132
- }
133
-
134
- validFiles.push(file);
135
- }
136
-
137
- if (validFiles.length > 0) {
138
- this.files = validFiles;
139
- if (this.onFilesSelected) {
140
- this.onFilesSelected(validFiles);
141
- }
142
- }
143
-
144
- // Reset input
145
- this.fileInput.value = '';
146
- }
147
-
148
- /**
149
- * Formate les bytes en format lisible
150
- * @param {number} bytes - Nombre de bytes
151
- * @returns {string} Taille formatée
152
- * @private
153
- */
154
- formatBytes(bytes) {
155
- if (bytes === 0) return '0 Bytes';
156
- const k = 1024;
157
- const sizes = ['Bytes', 'KB', 'MB', 'GB'];
158
- const i = Math.floor(Math.log(bytes) / Math.log(k));
159
- return Math.round(bytes / Math.pow(k, i) * 100) / 100 + ' ' + sizes[i];
160
- }
161
-
162
- /**
163
- * Dessine le composant
164
- * @param {CanvasRenderingContext2D} ctx - Contexte de dessin
165
- */
166
- draw(ctx) {
167
- ctx.save();
168
-
169
- // Fond
170
- ctx.fillStyle = this.isDragOver || this.pressed ?
171
- this.lightenColor(this.bgColor) : this.bgColor;
172
- ctx.beginPath();
173
- this.roundRect(ctx, this.x, this.y, this.width, this.height, this.borderRadius);
174
- ctx.fill();
175
-
176
- // Bordure en pointillés
177
- ctx.strokeStyle = this.borderColor;
178
- ctx.lineWidth = this.borderWidth;
179
- ctx.setLineDash([8, 8]);
180
- ctx.beginPath();
181
- this.roundRect(ctx, this.x, this.y, this.width, this.height, this.borderRadius);
182
- ctx.stroke();
183
- ctx.setLineDash([]);
184
-
185
- // Icône de fichier (simple)
186
- const iconSize = 40;
187
- const iconX = this.x + this.width / 2 - iconSize / 2;
188
- const iconY = this.y + this.height / 2 - 40;
189
-
190
- ctx.strokeStyle = this.iconColor;
191
- ctx.lineWidth = 3;
192
-
193
- // Document
194
- ctx.beginPath();
195
- ctx.moveTo(iconX, iconY);
196
- ctx.lineTo(iconX + iconSize * 0.7, iconY);
197
- ctx.lineTo(iconX + iconSize, iconY + iconSize * 0.3);
198
- ctx.lineTo(iconX + iconSize, iconY + iconSize);
199
- ctx.lineTo(iconX, iconY + iconSize);
200
- ctx.closePath();
201
- ctx.stroke();
202
-
203
- // Coin plié
204
- ctx.beginPath();
205
- ctx.moveTo(iconX + iconSize * 0.7, iconY);
206
- ctx.lineTo(iconX + iconSize * 0.7, iconY + iconSize * 0.3);
207
- ctx.lineTo(iconX + iconSize, iconY + iconSize * 0.3);
208
- ctx.stroke();
209
-
210
- // Flèche montante
211
- const arrowX = iconX + iconSize / 2;
212
- const arrowY = iconY + iconSize * 0.5;
213
- const arrowSize = 12;
214
-
215
- ctx.beginPath();
216
- ctx.moveTo(arrowX, arrowY - arrowSize);
217
- ctx.lineTo(arrowX, arrowY + arrowSize);
218
- ctx.stroke();
219
-
220
- ctx.beginPath();
221
- ctx.moveTo(arrowX - arrowSize / 2, arrowY - arrowSize / 2);
222
- ctx.lineTo(arrowX, arrowY - arrowSize);
223
- ctx.lineTo(arrowX + arrowSize / 2, arrowY - arrowSize / 2);
224
- ctx.stroke();
225
-
226
- // Texte
227
- ctx.fillStyle = '#000000';
228
- ctx.font = '16px -apple-system, BlinkMacSystemFont, Roboto, sans-serif';
229
- ctx.textAlign = 'center';
230
- ctx.textBaseline = 'middle';
231
- ctx.fillText(this.label, this.x + this.width / 2, this.y + this.height / 2 + 30);
232
-
233
- ctx.fillStyle = '#666666';
234
- ctx.font = '14px -apple-system, BlinkMacSystemFont, Roboto, sans-serif';
235
- ctx.fillText(this.sublabel, this.x + this.width / 2, this.y + this.height / 2 + 52);
236
-
237
- // Afficher les fichiers sélectionnés
238
- if (this.files.length > 0) {
239
- ctx.fillStyle = this.borderColor;
240
- ctx.font = '12px -apple-system, BlinkMacSystemFont, Roboto, sans-serif';
241
- const fileText = this.files.length === 1 ?
242
- this.files[0].name :
243
- `${this.files.length} files selected`;
244
- ctx.fillText(fileText, this.x + this.width / 2, this.y + this.height - 20);
245
- }
246
-
247
- ctx.restore();
248
- }
249
-
250
- /**
251
- * Dessine un rectangle avec coins arrondis
252
- * @param {CanvasRenderingContext2D} ctx - Contexte de dessin
253
- * @param {number} x - Position X
254
- * @param {number} y - Position Y
255
- * @param {number} width - Largeur
256
- * @param {number} height - Hauteur
257
- * @param {number} radius - Rayon des coins
258
- * @private
259
- */
260
- roundRect(ctx, x, y, width, height, radius) {
261
- ctx.moveTo(x + radius, y);
262
- ctx.lineTo(x + width - radius, y);
263
- ctx.quadraticCurveTo(x + width, y, x + width, y + radius);
264
- ctx.lineTo(x + width, y + height - radius);
265
- ctx.quadraticCurveTo(x + width, y + height, x + width - radius, y + height);
266
- ctx.lineTo(x + radius, y + height);
267
- ctx.quadraticCurveTo(x, y + height, x, y + height - radius);
268
- ctx.lineTo(x, y + radius);
269
- ctx.quadraticCurveTo(x, y, x + radius, y);
270
- }
271
-
272
- /**
273
- * Éclaircit une couleur
274
- * @param {string} color - Couleur
275
- * @returns {string} Couleur éclaircie
276
- * @private
277
- */
278
- lightenColor(color) {
279
- if (color.startsWith('rgba')) {
280
- return color.replace(/[\d.]+\)$/g, '0.15)');
281
- }
282
- return color;
283
- }
284
-
285
- /**
286
- * Vérifie si un point est dans les limites
287
- * @param {number} x - Coordonnée X
288
- * @param {number} y - Coordonnée Y
289
- * @returns {boolean} True si le point est dans le composant
290
- */
291
- isPointInside(x, y) {
292
- return x >= this.x &&
293
- x <= this.x + this.width &&
294
- y >= this.y &&
295
- y <= this.y + this.height;
296
- }
297
-
298
- /**
299
- * Override du onClick pour ouvrir le file picker
300
- */
301
- onClick() {
302
- this.fileInput.click();
303
- }
304
-
305
- /**
306
- * Nettoie le composant
307
- */
308
- destroy() {
309
- if (this.fileInput && this.fileInput.parentNode) {
310
- this.fileInput.parentNode.removeChild(this.fileInput);
311
- }
312
- }
313
- }
314
-
315
- export default FileUpload;