valtech-components 2.0.359 → 2.0.360
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/esm2022/lib/components/atoms/image/image.component.mjs +352 -11
- package/esm2022/lib/components/atoms/image/types.mjs +1 -1
- package/esm2022/lib/services/lang-provider/content.mjs +26 -1
- package/fesm2022/valtech-components.mjs +375 -10
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/atoms/image/image.component.d.ts +31 -0
- package/lib/components/atoms/image/types.d.ts +2 -0
- package/package.json +1 -1
|
@@ -63,6 +63,10 @@ const globalContentData = {
|
|
|
63
63
|
copied: '¡Copiado al portapapeles!',
|
|
64
64
|
seeMore: 'ver más',
|
|
65
65
|
selected: 'seleccionados',
|
|
66
|
+
// Image preview
|
|
67
|
+
zoomIn: 'Acercar',
|
|
68
|
+
zoomOut: 'Alejar',
|
|
69
|
+
resetZoom: 'Restablecer zoom',
|
|
66
70
|
},
|
|
67
71
|
en: {
|
|
68
72
|
// Common buttons
|
|
@@ -118,14 +122,35 @@ const globalContentData = {
|
|
|
118
122
|
copied: 'Copied to clipboard!',
|
|
119
123
|
seeMore: 'see more',
|
|
120
124
|
selected: 'selected',
|
|
125
|
+
// Image preview
|
|
126
|
+
zoomIn: 'Zoom in',
|
|
127
|
+
zoomOut: 'Zoom out',
|
|
128
|
+
resetZoom: 'Reset zoom',
|
|
121
129
|
},
|
|
122
130
|
};
|
|
123
131
|
const GlobalContent = new TextContent(globalContentData);
|
|
132
|
+
// ImageComponent specific content
|
|
133
|
+
const imageComponentData = {
|
|
134
|
+
es: {
|
|
135
|
+
close: 'Cerrar',
|
|
136
|
+
zoomIn: 'Acercar',
|
|
137
|
+
zoomOut: 'Alejar',
|
|
138
|
+
resetZoom: 'Restablecer zoom',
|
|
139
|
+
},
|
|
140
|
+
en: {
|
|
141
|
+
close: 'Close',
|
|
142
|
+
zoomIn: 'Zoom in',
|
|
143
|
+
zoomOut: 'Zoom out',
|
|
144
|
+
resetZoom: 'Reset zoom',
|
|
145
|
+
},
|
|
146
|
+
};
|
|
147
|
+
const ImageComponentContent = new TextContent(imageComponentData);
|
|
124
148
|
const content = {
|
|
125
149
|
_global: GlobalContent,
|
|
126
150
|
LangSettings,
|
|
151
|
+
ImageComponent: ImageComponentContent,
|
|
127
152
|
};
|
|
128
153
|
export default content;
|
|
129
154
|
// Export named exports for user convenience
|
|
130
155
|
export { content, GlobalContent, globalContentData };
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL3NlcnZpY2VzL2xhbmctcHJvdmlkZXIvY29udGVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLFlBQVksTUFBTSw0QkFBNEIsQ0FBQztBQUN0RCxPQUFPLEVBQW9CLFdBQVcsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQU14RDs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxpQkFBaUIsR0FBcUI7SUFDMUMsRUFBRSxFQUFFO1FBQ0YsaUJBQWlCO1FBQ2pCLEVBQUUsRUFBRSxTQUFTO1FBQ2IsTUFBTSxFQUFFLFVBQVU7UUFDbEIsSUFBSSxFQUFFLFNBQVM7UUFDZixNQUFNLEVBQUUsVUFBVTtRQUNsQixJQUFJLEVBQUUsUUFBUTtRQUNkLEtBQUssRUFBRSxRQUFRO1FBQ2YsSUFBSSxFQUFFLFFBQVE7UUFDZCxJQUFJLEVBQUUsV0FBVztRQUNqQixRQUFRLEVBQUUsVUFBVTtRQUNwQixNQUFNLEVBQUUsV0FBVztRQUNuQixRQUFRLEVBQUUsV0FBVztRQUVyQixpQkFBaUI7UUFDakIsR0FBRyxFQUFFLFNBQVM7UUFDZCxNQUFNLEVBQUUsUUFBUTtRQUNoQixNQUFNLEVBQUUsUUFBUTtRQUNoQixNQUFNLEVBQUUsU0FBUztRQUNqQixJQUFJLEVBQUUsU0FBUztRQUNmLE9BQU8sRUFBRSxZQUFZO1FBRXJCLDZCQUE2QjtRQUM3QixPQUFPLEVBQUUsYUFBYTtRQUN0QixVQUFVLEVBQUUscUJBQXFCO1FBQ2pDLE1BQU0sRUFBRSwwQkFBMEI7UUFDbEMsS0FBSyxFQUFFLE9BQU87UUFDZCxPQUFPLEVBQUUsT0FBTztRQUNoQixPQUFPLEVBQUUsYUFBYTtRQUN0QixJQUFJLEVBQUUsYUFBYTtRQUNuQixRQUFRLEVBQUUsUUFBUTtRQUVsQix1QkFBdUI7UUFDdkIsVUFBVSxFQUFFLGdCQUFnQjtR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b3J0IExhbmdTZXR0aW5ncyBmcm9tICcuL2NvbXBvbmVudHMvbGFuZy1zZXR0aW5ncyc7XG5pbXBvcnQgeyBMYW5ndWFnZXNDb250ZW50LCBUZXh0Q29udGVudCB9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFByb3ZpZGVyIHtcbiAgW3g6IHN0cmluZ106IFRleHRDb250ZW50O1xufVxuXG4vKipcbiAqIEdsb2JhbCBjb250ZW50IHRoYXQgY2FuIGJlIHVzZWQgYWNyb3NzIGFsbCBjb21wb25lbnRzLlxuICogVGhlc2UgYXJlIGNvbW1vbiB0ZXh0cyBsaWtlIGJ1dHRvbnMsIGFjdGlvbnMsIHN0YXRlcywgZXRjLlxuICogU3RydWN0dXJlOiB7ZXM6IHtrZXkxOiAndmFsdWUxJywga2V5MjogJ3ZhbHVlMid9LCBlbjoge2tleTE6ICd2YWx1ZTEnLCBrZXkyOiAndmFsdWUyJ30sIGZyOiB7Li4ufX1cbiAqXG4gKiBOb3RlOiBZb3UgY2FuIGFkZCBhbnkgbGFuZ3VhZ2UgY29kZS4gVGhlIHN5c3RlbSB3aWxsIGF1dG9tYXRpY2FsbHkgZGV0ZWN0IGF2YWlsYWJsZSBsYW5ndWFnZXNcbiAqIGFuZCBwcm92aWRlIGludGVsbGlnZW50IGZhbGxiYWNrcyB3aXRoIHdhcm5pbmdzIGZvciBtaXNzaW5nIHRyYW5zbGF0aW9ucy5cbiAqL1xuY29uc3QgZ2xvYmFsQ29udGVudERhdGE6IExhbmd1YWdlc0NvbnRlbnQgPSB7XG4gIGVzOiB7XG4gICAgLy8gQ29tbW9uIGJ1dHRvbnNcbiAgICBvazogJ0FjZXB0YXInLFxuICAgIGNhbmNlbDogJ0NhbmNlbGFyJyxcbiAgICBzYXZlOiAnR3VhcmRhcicsXG4gICAgZGVsZXRlOiAnRWxpbWluYXInLFxuICAgIGVkaXQ6ICdFZGl0YXInLFxuICAgIGNsb3NlOiAnQ2VycmFyJyxcbiAgICBiYWNrOiAnVm9sdmVyJyxcbiAgICBuZXh0OiAnU2lndWllbnRlJyxcbiAgICBwcmV2aW91czogJ0FudGVyaW9yJyxcbiAgICBmaW5pc2g6ICdGaW5hbGl6YXInLFxuICAgIGNvbnRpbnVlOiAnQ29udGludWFyJyxcblxuICAgIC8vIENvbW1vbiBhY3Rpb25zXG4gICAgYWRkOiAnQWdyZWdhcicsXG4gICAgcmVtb3ZlOiAnUXVpdGFyJyxcbiAgICBzZWFyY2g6ICdCdXNjYXInLFxuICAgIGZpbHRlcjogJ0ZpbHRyYXInLFxuICAgIHNvcnQ6ICdPcmRlbmFyJyxcbiAgICByZWZyZXNoOiAnQWN0dWFsaXphcicsXG5cbiAgICAvLyBDb21tb24gc3RhdGVzIGFuZCBtZXNzYWdlc1xuICAgIGxvYWRpbmc6ICdDYXJnYW5kby4uLicsXG4gICAgcGxlYXNlV2FpdDogJ1BvciBmYXZvciBlc3BlcmUuLi4nLFxuICAgIG5vRGF0YTogJ05vIGhheSBkYXRvcyBkaXNwb25pYmxlcycsXG4gICAgZXJyb3I6ICdFcnJvcicsXG4gICAgc3VjY2VzczogJ8OJeGl0bycsXG4gICAgd2FybmluZzogJ0FkdmVydGVuY2lhJyxcbiAgICBpbmZvOiAnSW5mb3JtYWNpw7NuJyxcbiAgICBsYW5ndWFnZTogJ0lkaW9tYScsXG5cbiAgICAvLyBDb21tb24gY29uZmlybWF0aW9uc1xuICAgIGFyZVlvdVN1cmU6ICfCv0VzdMOhcyBzZWd1cm8/JyxcblxuICAgIC8vIExhbmd1YWdlIG5hbWVzICh0cmFuc2xhdGVkKSAtIGZsYXQga2V5cyBmb3IgdHlwZSBjb21wYXRpYmlsaXR5XG4gICAgbGFuZ3VhZ2VOYW1lX2VzOiAnRXNwYcOxb2wnLFxuICAgIGxhbmd1YWdlTmFtZV9lbjogJ0luZ2zDqXMnLFxuICAgIGxhbmd1YWdlTmFtZV9mcjogJ0ZyYW5jw6lzJyxcbiAgICBsYW5ndWFnZU5hbWVfZGU6ICdBbGVtw6FuJyxcbiAgICBsYW5ndWFnZU5hbWVfcHQ6ICdQb3J0dWd1w6lzJyxcbiAgICBsYW5ndWFnZU5hbWVfaXQ6ICdJdGFsaWFubycsXG4gICAgbGFuZ3VhZ2VOYW1lX3poOiAnQ2hpbm8nLFxuICAgIGxhbmd1YWdlTmFtZV9qYTogJ0phcG9uw6lzJyxcbiAgICBsYW5ndWFnZU5hbWVfa286ICdDb3JlYW5vJyxcbiAgICBsYW5ndWFnZU5hbWVfcnU6ICdSdXNvJyxcbiAgICBsYW5ndWFnZU5hbWVfYXI6ICfDgXJhYmUnLFxuICAgIGRlbGV0ZUNvbmZpcm1hdGlvbjogJ8K/RXN0w6FzIHNlZ3VybyBkZSBxdWUgZGVzZWFzIGVsaW1pbmFyIHtpdGVtTmFtZX0/JyxcbiAgICB1bnNhdmVkQ2hhbmdlczogJ1RpZW5lcyBjYW1iaW9zIHNpbiBndWFyZGFyLiDCv0Rlc2VhcyBjb250aW51YXI/JyxcblxuICAgIC8vIENvbW1vbiBwbGFjZWhvbGRlcnNcbiAgICBzZWFyY2hQbGFjZWhvbGRlcjogJ0J1c2Nhci4uLicsXG4gICAgc2VsZWN0OiAnU2VsZWNjaW9uYXIuLi4nLFxuICAgIHNlbGVjdE9wdGlvbjogJ1NlbGVjY2lvbmUgdW5hIG9wY2nDs24nLFxuICAgIHNlbGVjdExhbmd1YWdlOiAnU2VsZWNjaW9uYXIgaWRpb21hLi4uJyxcblxuICAgIC8vIFN0YXR1cyBtZXNzYWdlc1xuICAgIGNvcGllZDogJ8KhQ29waWFkbyBhbCBwb3J0YXBhcGVsZXMhJyxcbiAgICBzZWVNb3JlOiAndmVyIG3DoXMnLFxuICAgIHNlbGVjdGVkOiAnc2VsZWNjaW9uYWRvcycsXG4gIH0sXG4gIGVuOiB7XG4gICAgLy8gQ29tbW9uIGJ1dHRvbnNcbiAgICBvazogJ09LJyxcbiAgICBjYW5jZWw6ICdDYW5jZWwnLFxuICAgIHNhdmU6ICdTYXZlJyxcbiAgICBkZWxldGU6ICdEZWxldGUnLFxuICAgIGVkaXQ6ICdFZGl0JyxcbiAgICBjbG9zZTogJ0Nsb3NlJyxcbiAgICBiYWNrOiAnQmFjaycsXG4gICAgbmV4dDogJ05leHQnLFxuICAgIHByZXZpb3VzOiAnUHJldmlvdXMnLFxuICAgIGZpbmlzaDogJ0ZpbmlzaCcsXG4gICAgY29udGludWU6ICdDb250aW51ZScsXG5cbiAgICAvLyBDb21tb24gYWN0aW9uc1xuICAgIGFkZDogJ0FkZCcsXG4gICAgcmVtb3ZlOiAnUmVtb3ZlJyxcbiAgICBzZWFyY2g6ICdTZWFyY2gnLFxuICAgIGZpbHRlcjogJ0ZpbHRlcicsXG4gICAgc29ydDogJ1NvcnQnLFxuICAgIHJlZnJlc2g6ICdSZWZyZXNoJyxcblxuICAgIC8vIENvbW1vbiBzdGF0ZXMgYW5kIG1lc3NhZ2VzXG4gICAgbG9hZGluZzogJ0xvYWRpbmcuLi4nLFxuICAgIHBsZWFzZVdhaXQ6ICdQbGVhc2Ugd2FpdC4uLicsXG4gICAgbm9EYXRhOiAnTm8gZGF0YSBhdmFpbGFibGUnLFxuICAgIGVycm9yOiAnRXJyb3InLFxuICAgIHN1Y2Nlc3M6ICdTdWNjZXNzJyxcbiAgICB3YXJuaW5nOiAnV2FybmluZycsXG4gICAgaW5mbzogJ0luZm9ybWF0aW9uJyxcbiAgICBsYW5ndWFnZTogJ0xhbmd1YWdlJyxcblxuICAgIC8vIENvbW1vbiBjb25maXJtYXRpb25zXG4gICAgYXJlWW91U3VyZTogJ0FyZSB5b3Ugc3VyZT8nLFxuXG4gICAgLy8gTGFuZ3VhZ2UgbmFtZXMgKHRyYW5zbGF0ZWQpIC0gZmxhdCBrZXlzIGZvciB0eXBlIGNvbXBhdGliaWxpdHlcbiAgICBsYW5ndWFnZU5hbWVfZXM6ICdTcGFuaXNoJyxcbiAgICBsYW5ndWFnZU5hbWVfZW46ICdFbmdsaXNoJyxcbiAgICBsYW5ndWFnZU5hbWVfZnI6ICdGcmVuY2gnLFxuICAgIGxhbmd1YWdlTmFtZV9kZTogJ0dlcm1hbicsXG4gICAgbGFuZ3VhZ2VOYW1lX3B0OiAnUG9ydHVndWVzZScsXG4gICAgbGFuZ3VhZ2VOYW1lX2l0OiAnSXRhbGlhbicsXG4gICAgbGFuZ3VhZ2VOYW1lX3poOiAnQ2hpbmVzZScsXG4gICAgbGFuZ3VhZ2VOYW1lX2phOiAnSmFwYW5lc2UnLFxuICAgIGxhbmd1YWdlTmFtZV9rbzogJ0tvcmVhbicsXG4gICAgbGFuZ3VhZ2VOYW1lX3J1OiAnUnVzc2lhbicsXG4gICAgbGFuZ3VhZ2VOYW1lX2FyOiAnQXJhYmljJyxcbiAgICBkZWxldGVDb25maXJtYXRpb246ICdBcmUgeW91IHN1cmUgeW91IHdhbnQgdG8gZGVsZXRlIHtpdGVtTmFtZX0/JyxcbiAgICB1bnNhdmVkQ2hhbmdlczogJ1lvdSBoYXZlIHVuc2F2ZWQgY2hhbmdlcy4gRG8geW91IHdhbnQgdG8gY29udGludWU/JyxcblxuICAgIC8vIENvbW1vbiBwbGFjZWhvbGRlcnNcbiAgICBzZWFyY2hQbGFjZWhvbGRlcjogJ1NlYXJjaC4uLicsXG4gICAgc2VsZWN0OiAnU2VsZWN0Li4uJyxcbiAgICBzZWxlY3RPcHRpb246ICdTZWxlY3QgYW4gb3B0aW9uJyxcbiAgICBzZWxlY3RMYW5ndWFnZTogJ1NlbGVjdCBsYW5ndWFnZS4uLicsXG5cbiAgICAvLyBTdGF0dXMgbWVzc2FnZXNcbiAgICBjb3BpZWQ6ICdDb3BpZWQgdG8gY2xpcGJvYXJkIScsXG4gICAgc2VlTW9yZTogJ3NlZSBtb3JlJyxcbiAgICBzZWxlY3RlZDogJ3NlbGVjdGVkJyxcbiAgfSxcbn07XG5cbmNvbnN0IEdsb2JhbENvbnRlbnQgPSBuZXcgVGV4dENvbnRlbnQoZ2xvYmFsQ29udGVudERhdGEpO1xuXG5jb25zdCBjb250ZW50OiBQcm92aWRlciA9IHtcbiAgX2dsb2JhbDogR2xvYmFsQ29udGVudCxcbiAgTGFuZ1NldHRpbmdzLFxufTtcblxuZXhwb3J0IGRlZmF1bHQgY29udGVudDtcblxuLy8gRXhwb3J0IG5hbWVkIGV4cG9ydHMgZm9yIHVzZXIgY29udmVuaWVuY2VcbmV4cG9ydCB7IGNvbnRlbnQsIEdsb2JhbENvbnRlbnQsIGdsb2JhbENvbnRlbnREYXRhIH07XG4iXX0=
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL3NlcnZpY2VzL2xhbmctcHJvdmlkZXIvY29udGVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLFlBQVksTUFBTSw0QkFBNEIsQ0FBQztBQUN0RCxPQUFPLEVBQW9CLFdBQVcsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQU14RDs7Ozs7OztHQU9HO0FBQ0gsTUFBTSxpQkFBaUIsR0FBcUI7SUFDMUMsRUFBRSxFQUFFO1FBQ0YsaUJBQWlCO1FBQ2pCLEVBQUUsRUFBRSxTQUFTO1FBQ2IsTUFBTSxFQUFFLFVBQVU7UUFDbEIsSUFBSSxFQUFFLFNBQVM7UUFDZixNQUFNLEVBQUUsVUFBVTtRQUNsQixJQUFJLEVBQUUsUUFBUTtRQUNkLEtBQUssRUFBRSxRQUFRO1FBQ2YsSUFBSSxFQUFFLFFBQVE7UUFDZCxJQUFJLEVBQUUsV0FBVztRQUNqQixRQUFRLEVBQUUsVUFBVTtRQUNwQixNQUFNLEVBQUUsV0FBVztRQUNuQixRQUFRLEVBQUUsV0FBVztRQUVyQixpQkFBaUI7UUFDakIsR0FBRyxFQUFFLFNBQVM7UUFDZCxNQUFNLEVBQUUsUUFBUTtRQUNoQixNQUFNLEVBQUUsUUFBUTtRQUNoQixNQUFNLEVBQUUsU0FBUztRQUNqQixJQUFJLEVBQUUsU0FBUztRQUNmLE9BQU8sRUFBRSxZQUFZO1FBRXJCLDZCQUE2QjtRQUM3QixPQUFPLEVBQUUsYUFBYTtRQUN0QixVQUFVLEVBQUUscUJBQXFCO1FBQ2pDLE1BQU0sRUFBRSwwQkFBMEI7UUFDbEMsS0FBSyxFQUFFLE9BQU87UUFDZCxPQUFPLEVBQUUsT0FBTztRQUNoQixPQUFPLEVBQUUsYUFBYTtRQUN0QixJQUFJLEVBQUUsYUFBYTtRQUNuQixRQUFRLEVBQUUsUUFBUTtRQUVsQix1QkFBdUI7UUFDdkIsVUFBVSxFQUFFLGdCQUFnQjtR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LE1BQU0sa0JBQWtCLEdBQXFCO0lBQzNDLEVBQUUsRUFBRTtRQUNGLEtBQUssRUFBRSxRQUFRO1FBQ2YsTUFBTSxFQUFFLFNBQVM7UUFDakIsT0FBTyxFQUFFLFFBQVE7UUFDakIsU0FBUyxFQUFFLGtCQUFrQjtLQUM5QjtJQUNELEVBQUUsRUFBRTtRQUNGLEtBQUssRUFBRSxPQUFPO1FBQ2QsTUFBTSxFQUFFLFNBQVM7UUFDakIsT0FBTyxFQUFFLFVBQVU7UUFDbkIsU0FBUyxFQUFFLFlBQVk7S0FDeEI7Q0FDRixDQUFDO0FBRUYsTUFBTSxxQkFBcUIsR0FBRyxJQUFJLFdBQVcsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0FBRWxFLE1BQU0sT0FBTyxHQUFhO0lBQ3hCLE9BQU8sRUFBRSxhQUFhO0lBQ3RCLFlBQVk7SUFDWixjQUFjLEVBQUUscUJBQXFCO0NBQ3RDLENBQUM7QUFFRixlQUFlLE9BQU8sQ0FBQztBQUV2Qiw0Q0FBNEM7QUFDNUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBMYW5nU2V0dGluZ3MgZnJvbSAnLi9jb21wb25lbnRzL2xhbmctc2V0dGluZ3MnO1xuaW1wb3J0IHsgTGFuZ3VhZ2VzQ29udGVudCwgVGV4dENvbnRlbnQgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGludGVyZmFjZSBQcm92aWRlciB7XG4gIFt4OiBzdHJpbmddOiBUZXh0Q29udGVudDtcbn1cblxuLyoqXG4gKiBHbG9iYWwgY29udGVudCB0aGF0IGNhbiBiZSB1c2VkIGFjcm9zcyBhbGwgY29tcG9uZW50cy5cbiAqIFRoZXNlIGFyZSBjb21tb24gdGV4dHMgbGlrZSBidXR0b25zLCBhY3Rpb25zLCBzdGF0ZXMsIGV0Yy5cbiAqIFN0cnVjdHVyZToge2VzOiB7a2V5MTogJ3ZhbHVlMScsIGtleTI6ICd2YWx1ZTInfSwgZW46IHtrZXkxOiAndmFsdWUxJywga2V5MjogJ3ZhbHVlMid9LCBmcjogey4uLn19XG4gKlxuICogTm90ZTogWW91IGNhbiBhZGQgYW55IGxhbmd1YWdlIGNvZGUuIFRoZSBzeXN0ZW0gd2lsbCBhdXRvbWF0aWNhbGx5IGRldGVjdCBhdmFpbGFibGUgbGFuZ3VhZ2VzXG4gKiBhbmQgcHJvdmlkZSBpbnRlbGxpZ2VudCBmYWxsYmFja3Mgd2l0aCB3YXJuaW5ncyBmb3IgbWlzc2luZyB0cmFuc2xhdGlvbnMuXG4gKi9cbmNvbnN0IGdsb2JhbENvbnRlbnREYXRhOiBMYW5ndWFnZXNDb250ZW50ID0ge1xuICBlczoge1xuICAgIC8vIENvbW1vbiBidXR0b25zXG4gICAgb2s6ICdBY2VwdGFyJyxcbiAgICBjYW5jZWw6ICdDYW5jZWxhcicsXG4gICAgc2F2ZTogJ0d1YXJkYXInLFxuICAgIGRlbGV0ZTogJ0VsaW1pbmFyJyxcbiAgICBlZGl0OiAnRWRpdGFyJyxcbiAgICBjbG9zZTogJ0NlcnJhcicsXG4gICAgYmFjazogJ1ZvbHZlcicsXG4gICAgbmV4dDogJ1NpZ3VpZW50ZScsXG4gICAgcHJldmlvdXM6ICdBbnRlcmlvcicsXG4gICAgZmluaXNoOiAnRmluYWxpemFyJyxcbiAgICBjb250aW51ZTogJ0NvbnRpbnVhcicsXG5cbiAgICAvLyBDb21tb24gYWN0aW9uc1xuICAgIGFkZDogJ0FncmVnYXInLFxuICAgIHJlbW92ZTogJ1F1aXRhcicsXG4gICAgc2VhcmNoOiAnQnVzY2FyJyxcbiAgICBmaWx0ZXI6ICdGaWx0cmFyJyxcbiAgICBzb3J0OiAnT3JkZW5hcicsXG4gICAgcmVmcmVzaDogJ0FjdHVhbGl6YXInLFxuXG4gICAgLy8gQ29tbW9uIHN0YXRlcyBhbmQgbWVzc2FnZXNcbiAgICBsb2FkaW5nOiAnQ2FyZ2FuZG8uLi4nLFxuICAgIHBsZWFzZVdhaXQ6ICdQb3IgZmF2b3IgZXNwZXJlLi4uJyxcbiAgICBub0RhdGE6ICdObyBoYXkgZGF0b3MgZGlzcG9uaWJsZXMnLFxuICAgIGVycm9yOiAnRXJyb3InLFxuICAgIHN1Y2Nlc3M6ICfDiXhpdG8nLFxuICAgIHdhcm5pbmc6ICdBZHZlcnRlbmNpYScsXG4gICAgaW5mbzogJ0luZm9ybWFjacOzbicsXG4gICAgbGFuZ3VhZ2U6ICdJZGlvbWEnLFxuXG4gICAgLy8gQ29tbW9uIGNvbmZpcm1hdGlvbnNcbiAgICBhcmVZb3VTdXJlOiAnwr9Fc3TDoXMgc2VndXJvPycsXG5cbiAgICAvLyBMYW5ndWFnZSBuYW1lcyAodHJhbnNsYXRlZCkgLSBmbGF0IGtleXMgZm9yIHR5cGUgY29tcGF0aWJpbGl0eVxuICAgIGxhbmd1YWdlTmFtZV9lczogJ0VzcGHDsW9sJyxcbiAgICBsYW5ndWFnZU5hbWVfZW46ICdJbmdsw6lzJyxcbiAgICBsYW5ndWFnZU5hbWVfZnI6ICdGcmFuY8OpcycsXG4gICAgbGFuZ3VhZ2VOYW1lX2RlOiAnQWxlbcOhbicsXG4gICAgbGFuZ3VhZ2VOYW1lX3B0OiAnUG9ydHVndcOpcycsXG4gICAgbGFuZ3VhZ2VOYW1lX2l0OiAnSXRhbGlhbm8nLFxuICAgIGxhbmd1YWdlTmFtZV96aDogJ0NoaW5vJyxcbiAgICBsYW5ndWFnZU5hbWVfamE6ICdKYXBvbsOpcycsXG4gICAgbGFuZ3VhZ2VOYW1lX2tvOiAnQ29yZWFubycsXG4gICAgbGFuZ3VhZ2VOYW1lX3J1OiAnUnVzbycsXG4gICAgbGFuZ3VhZ2VOYW1lX2FyOiAnw4FyYWJlJyxcbiAgICBkZWxldGVDb25maXJtYXRpb246ICfCv0VzdMOhcyBzZWd1cm8gZGUgcXVlIGRlc2VhcyBlbGltaW5hciB7aXRlbU5hbWV9PycsXG4gICAgdW5zYXZlZENoYW5nZXM6ICdUaWVuZXMgY2FtYmlvcyBzaW4gZ3VhcmRhci4gwr9EZXNlYXMgY29udGludWFyPycsXG5cbiAgICAvLyBDb21tb24gcGxhY2Vob2xkZXJzXG4gICAgc2VhcmNoUGxhY2Vob2xkZXI6ICdCdXNjYXIuLi4nLFxuICAgIHNlbGVjdDogJ1NlbGVjY2lvbmFyLi4uJyxcbiAgICBzZWxlY3RPcHRpb246ICdTZWxlY2Npb25lIHVuYSBvcGNpw7NuJyxcbiAgICBzZWxlY3RMYW5ndWFnZTogJ1NlbGVjY2lvbmFyIGlkaW9tYS4uLicsXG5cbiAgICAvLyBTdGF0dXMgbWVzc2FnZXNcbiAgICBjb3BpZWQ6ICfCoUNvcGlhZG8gYWwgcG9ydGFwYXBlbGVzIScsXG4gICAgc2VlTW9yZTogJ3ZlciBtw6FzJyxcbiAgICBzZWxlY3RlZDogJ3NlbGVjY2lvbmFkb3MnLFxuXG4gICAgLy8gSW1hZ2UgcHJldmlld1xuICAgIHpvb21JbjogJ0FjZXJjYXInLFxuICAgIHpvb21PdXQ6ICdBbGVqYXInLFxuICAgIHJlc2V0Wm9vbTogJ1Jlc3RhYmxlY2VyIHpvb20nLFxuICB9LFxuICBlbjoge1xuICAgIC8vIENvbW1vbiBidXR0b25zXG4gICAgb2s6ICdPSycsXG4gICAgY2FuY2VsOiAnQ2FuY2VsJyxcbiAgICBzYXZlOiAnU2F2ZScsXG4gICAgZGVsZXRlOiAnRGVsZXRlJyxcbiAgICBlZGl0OiAnRWRpdCcsXG4gICAgY2xvc2U6ICdDbG9zZScsXG4gICAgYmFjazogJ0JhY2snLFxuICAgIG5leHQ6ICdOZXh0JyxcbiAgICBwcmV2aW91czogJ1ByZXZpb3VzJyxcbiAgICBmaW5pc2g6ICdGaW5pc2gnLFxuICAgIGNvbnRpbnVlOiAnQ29udGludWUnLFxuXG4gICAgLy8gQ29tbW9uIGFjdGlvbnNcbiAgICBhZGQ6ICdBZGQnLFxuICAgIHJlbW92ZTogJ1JlbW92ZScsXG4gICAgc2VhcmNoOiAnU2VhcmNoJyxcbiAgICBmaWx0ZXI6ICdGaWx0ZXInLFxuICAgIHNvcnQ6ICdTb3J0JyxcbiAgICByZWZyZXNoOiAnUmVmcmVzaCcsXG5cbiAgICAvLyBDb21tb24gc3RhdGVzIGFuZCBtZXNzYWdlc1xuICAgIGxvYWRpbmc6ICdMb2FkaW5nLi4uJyxcbiAgICBwbGVhc2VXYWl0OiAnUGxlYXNlIHdhaXQuLi4nLFxuICAgIG5vRGF0YTogJ05vIGRhdGEgYXZhaWxhYmxlJyxcbiAgICBlcnJvcjogJ0Vycm9yJyxcbiAgICBzdWNjZXNzOiAnU3VjY2VzcycsXG4gICAgd2FybmluZzogJ1dhcm5pbmcnLFxuICAgIGluZm86ICdJbmZvcm1hdGlvbicsXG4gICAgbGFuZ3VhZ2U6ICdMYW5ndWFnZScsXG5cbiAgICAvLyBDb21tb24gY29uZmlybWF0aW9uc1xuICAgIGFyZVlvdVN1cmU6ICdBcmUgeW91IHN1cmU/JyxcblxuICAgIC8vIExhbmd1YWdlIG5hbWVzICh0cmFuc2xhdGVkKSAtIGZsYXQga2V5cyBmb3IgdHlwZSBjb21wYXRpYmlsaXR5XG4gICAgbGFuZ3VhZ2VOYW1lX2VzOiAnU3BhbmlzaCcsXG4gICAgbGFuZ3VhZ2VOYW1lX2VuOiAnRW5nbGlzaCcsXG4gICAgbGFuZ3VhZ2VOYW1lX2ZyOiAnRnJlbmNoJyxcbiAgICBsYW5ndWFnZU5hbWVfZGU6ICdHZXJtYW4nLFxuICAgIGxhbmd1YWdlTmFtZV9wdDogJ1BvcnR1Z3Vlc2UnLFxuICAgIGxhbmd1YWdlTmFtZV9pdDogJ0l0YWxpYW4nLFxuICAgIGxhbmd1YWdlTmFtZV96aDogJ0NoaW5lc2UnLFxuICAgIGxhbmd1YWdlTmFtZV9qYTogJ0phcGFuZXNlJyxcbiAgICBsYW5ndWFnZU5hbWVfa286ICdLb3JlYW4nLFxuICAgIGxhbmd1YWdlTmFtZV9ydTogJ1J1c3NpYW4nLFxuICAgIGxhbmd1YWdlTmFtZV9hcjogJ0FyYWJpYycsXG4gICAgZGVsZXRlQ29uZmlybWF0aW9uOiAnQXJlIHlvdSBzdXJlIHlvdSB3YW50IHRvIGRlbGV0ZSB7aXRlbU5hbWV9PycsXG4gICAgdW5zYXZlZENoYW5nZXM6ICdZb3UgaGF2ZSB1bnNhdmVkIGNoYW5nZXMuIERvIHlvdSB3YW50IHRvIGNvbnRpbnVlPycsXG5cbiAgICAvLyBDb21tb24gcGxhY2Vob2xkZXJzXG4gICAgc2VhcmNoUGxhY2Vob2xkZXI6ICdTZWFyY2guLi4nLFxuICAgIHNlbGVjdDogJ1NlbGVjdC4uLicsXG4gICAgc2VsZWN0T3B0aW9uOiAnU2VsZWN0IGFuIG9wdGlvbicsXG4gICAgc2VsZWN0TGFuZ3VhZ2U6ICdTZWxlY3QgbGFuZ3VhZ2UuLi4nLFxuXG4gICAgLy8gU3RhdHVzIG1lc3NhZ2VzXG4gICAgY29waWVkOiAnQ29waWVkIHRvIGNsaXBib2FyZCEnLFxuICAgIHNlZU1vcmU6ICdzZWUgbW9yZScsXG4gICAgc2VsZWN0ZWQ6ICdzZWxlY3RlZCcsXG5cbiAgICAvLyBJbWFnZSBwcmV2aWV3XG4gICAgem9vbUluOiAnWm9vbSBpbicsXG4gICAgem9vbU91dDogJ1pvb20gb3V0JyxcbiAgICByZXNldFpvb206ICdSZXNldCB6b29tJyxcbiAgfSxcbn07XG5cbmNvbnN0IEdsb2JhbENvbnRlbnQgPSBuZXcgVGV4dENvbnRlbnQoZ2xvYmFsQ29udGVudERhdGEpO1xuXG4vLyBJbWFnZUNvbXBvbmVudCBzcGVjaWZpYyBjb250ZW50XG5jb25zdCBpbWFnZUNvbXBvbmVudERhdGE6IExhbmd1YWdlc0NvbnRlbnQgPSB7XG4gIGVzOiB7XG4gICAgY2xvc2U6ICdDZXJyYXInLFxuICAgIHpvb21JbjogJ0FjZXJjYXInLFxuICAgIHpvb21PdXQ6ICdBbGVqYXInLFxuICAgIHJlc2V0Wm9vbTogJ1Jlc3RhYmxlY2VyIHpvb20nLFxuICB9LFxuICBlbjoge1xuICAgIGNsb3NlOiAnQ2xvc2UnLFxuICAgIHpvb21JbjogJ1pvb20gaW4nLFxuICAgIHpvb21PdXQ6ICdab29tIG91dCcsXG4gICAgcmVzZXRab29tOiAnUmVzZXQgem9vbScsXG4gIH0sXG59O1xuXG5jb25zdCBJbWFnZUNvbXBvbmVudENvbnRlbnQgPSBuZXcgVGV4dENvbnRlbnQoaW1hZ2VDb21wb25lbnREYXRhKTtcblxuY29uc3QgY29udGVudDogUHJvdmlkZXIgPSB7XG4gIF9nbG9iYWw6IEdsb2JhbENvbnRlbnQsXG4gIExhbmdTZXR0aW5ncyxcbiAgSW1hZ2VDb21wb25lbnQ6IEltYWdlQ29tcG9uZW50Q29udGVudCxcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGNvbnRlbnQ7XG5cbi8vIEV4cG9ydCBuYW1lZCBleHBvcnRzIGZvciB1c2VyIGNvbnZlbmllbmNlXG5leHBvcnQgeyBjb250ZW50LCBHbG9iYWxDb250ZW50LCBnbG9iYWxDb250ZW50RGF0YSB9O1xuIl19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { EventEmitter, Component, Input, Output, Injectable, inject, InjectionToken, Inject, ChangeDetectorRef, Pipe, ChangeDetectionStrategy, ViewChild } from '@angular/core';
|
|
2
|
+
import { EventEmitter, Component, Input, Output, Injectable, inject, InjectionToken, Inject, ChangeDetectorRef, HostListener, Pipe, ChangeDetectionStrategy, ViewChild } from '@angular/core';
|
|
3
3
|
import { IonAvatar, IonCard, IonIcon, IonButton, IonSpinner, IonText, IonProgressBar, IonCardContent, IonCardHeader, IonCardTitle, IonCardSubtitle, IonCheckbox, IonButtons, IonTextarea, IonDatetime, IonDatetimeButton, IonModal, IonInput, IonSelect, IonSelectOption, IonLabel, IonRadioGroup, IonRadio, IonSearchbar, IonToolbar, IonTitle, IonMenuButton, IonFooter, IonHeader, IonList, IonListHeader, IonNote, IonItem, IonContent } from '@ionic/angular/standalone';
|
|
4
4
|
import * as i1 from '@angular/common';
|
|
5
5
|
import { CommonModule, NgStyle, AsyncPipe, NgFor, NgClass } from '@angular/common';
|
|
@@ -1796,7 +1796,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1796
1796
|
* Displays an image with various display options (bordered, shaded, dark, etc).
|
|
1797
1797
|
* Now includes a container wrapper for better flexbox support and alignment options.
|
|
1798
1798
|
*
|
|
1799
|
-
*
|
|
1799
|
+
* NEW: Optional preview mode with full-screen zoom capabilities:
|
|
1800
|
+
* - Click to open full-screen preview (when previewMode is enabled)
|
|
1801
|
+
* - Pinch-to-zoom on mobile devices
|
|
1802
|
+
* - Mouse wheel zoom on desktop
|
|
1803
|
+
* - Pan/drag to navigate zoomed images
|
|
1804
|
+
* - Zoom controls with buttons
|
|
1805
|
+
* - Keyboard shortcuts (Esc to close, +/- to zoom, 0 to reset)
|
|
1806
|
+
* - Touch-friendly interface with gesture support
|
|
1807
|
+
*
|
|
1808
|
+
* @example Basic usage:
|
|
1800
1809
|
* <val-image [props]="{
|
|
1801
1810
|
* src: 'url',
|
|
1802
1811
|
* alt: 'desc',
|
|
@@ -1807,11 +1816,41 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1807
1816
|
* caption: 'Image description'
|
|
1808
1817
|
* }"></val-image>
|
|
1809
1818
|
*
|
|
1810
|
-
* @
|
|
1819
|
+
* @example With preview mode:
|
|
1820
|
+
* <val-image [props]="{
|
|
1821
|
+
* src: 'url',
|
|
1822
|
+
* alt: 'desc',
|
|
1823
|
+
* previewMode: true,
|
|
1824
|
+
* bordered: true,
|
|
1825
|
+
* alignment: 'center'
|
|
1826
|
+
* }"></val-image>
|
|
1827
|
+
*
|
|
1828
|
+
* @input props: ImageMetadata - Configuration for the image (src, alt, size, mode, alignment, caption, previewMode, etc.)
|
|
1811
1829
|
*/
|
|
1812
1830
|
class ImageComponent {
|
|
1813
1831
|
constructor() {
|
|
1814
1832
|
this.available = true;
|
|
1833
|
+
// Preview mode properties
|
|
1834
|
+
this.isPreviewOpen = false;
|
|
1835
|
+
this.zoomLevel = 1;
|
|
1836
|
+
this.minZoom = 0.5;
|
|
1837
|
+
this.maxZoom = 5;
|
|
1838
|
+
this.panX = 0;
|
|
1839
|
+
this.panY = 0;
|
|
1840
|
+
// Touch and mouse interaction properties
|
|
1841
|
+
this.isDragging = false;
|
|
1842
|
+
this.lastPanX = 0;
|
|
1843
|
+
this.lastPanY = 0;
|
|
1844
|
+
this.startX = 0;
|
|
1845
|
+
this.startY = 0;
|
|
1846
|
+
// Touch gesture properties
|
|
1847
|
+
this.initialDistance = 0;
|
|
1848
|
+
this.initialZoom = 1;
|
|
1849
|
+
this.touches = [];
|
|
1850
|
+
// Lang service
|
|
1851
|
+
this.langService = inject(LangService);
|
|
1852
|
+
// Math for template
|
|
1853
|
+
this.Math = Math;
|
|
1815
1854
|
}
|
|
1816
1855
|
ngOnInit() {
|
|
1817
1856
|
// Set default values
|
|
@@ -1830,8 +1869,144 @@ class ImageComponent {
|
|
|
1830
1869
|
this.available = true;
|
|
1831
1870
|
}, 100);
|
|
1832
1871
|
}
|
|
1872
|
+
// Preview mode methods
|
|
1873
|
+
openPreview() {
|
|
1874
|
+
if (!this.props.previewMode)
|
|
1875
|
+
return;
|
|
1876
|
+
this.isPreviewOpen = true;
|
|
1877
|
+
this.resetZoom();
|
|
1878
|
+
document.body.style.overflow = 'hidden'; // Prevent background scrolling
|
|
1879
|
+
}
|
|
1880
|
+
closePreview() {
|
|
1881
|
+
this.isPreviewOpen = false;
|
|
1882
|
+
document.body.style.overflow = ''; // Restore scrolling
|
|
1883
|
+
}
|
|
1884
|
+
// Zoom methods
|
|
1885
|
+
zoomIn() {
|
|
1886
|
+
if (this.zoomLevel < this.maxZoom) {
|
|
1887
|
+
this.zoomLevel = Math.min(this.zoomLevel * 1.2, this.maxZoom);
|
|
1888
|
+
}
|
|
1889
|
+
}
|
|
1890
|
+
zoomOut() {
|
|
1891
|
+
if (this.zoomLevel > this.minZoom) {
|
|
1892
|
+
this.zoomLevel = Math.max(this.zoomLevel / 1.2, this.minZoom);
|
|
1893
|
+
// Reset pan if zoomed out to 1x or less
|
|
1894
|
+
if (this.zoomLevel <= 1) {
|
|
1895
|
+
this.panX = 0;
|
|
1896
|
+
this.panY = 0;
|
|
1897
|
+
}
|
|
1898
|
+
}
|
|
1899
|
+
}
|
|
1900
|
+
resetZoom() {
|
|
1901
|
+
this.zoomLevel = 1;
|
|
1902
|
+
this.panX = 0;
|
|
1903
|
+
this.panY = 0;
|
|
1904
|
+
}
|
|
1905
|
+
// Mouse events
|
|
1906
|
+
onMouseDown(event) {
|
|
1907
|
+
if (this.zoomLevel <= 1)
|
|
1908
|
+
return;
|
|
1909
|
+
this.isDragging = true;
|
|
1910
|
+
this.startX = event.clientX - this.panX;
|
|
1911
|
+
this.startY = event.clientY - this.panY;
|
|
1912
|
+
event.preventDefault();
|
|
1913
|
+
}
|
|
1914
|
+
onMouseMove(event) {
|
|
1915
|
+
if (!this.isDragging || this.zoomLevel <= 1)
|
|
1916
|
+
return;
|
|
1917
|
+
this.panX = event.clientX - this.startX;
|
|
1918
|
+
this.panY = event.clientY - this.startY;
|
|
1919
|
+
event.preventDefault();
|
|
1920
|
+
}
|
|
1921
|
+
onMouseUp(event) {
|
|
1922
|
+
this.isDragging = false;
|
|
1923
|
+
}
|
|
1924
|
+
// Touch events for mobile
|
|
1925
|
+
onTouchStart(event) {
|
|
1926
|
+
event.preventDefault();
|
|
1927
|
+
this.touches = Array.from(event.touches);
|
|
1928
|
+
if (this.touches.length === 1) {
|
|
1929
|
+
// Single touch - start dragging
|
|
1930
|
+
if (this.zoomLevel > 1) {
|
|
1931
|
+
this.isDragging = true;
|
|
1932
|
+
this.startX = this.touches[0].clientX - this.panX;
|
|
1933
|
+
this.startY = this.touches[0].clientY - this.panY;
|
|
1934
|
+
}
|
|
1935
|
+
}
|
|
1936
|
+
else if (this.touches.length === 2) {
|
|
1937
|
+
// Two touches - start pinch zoom
|
|
1938
|
+
this.isDragging = false;
|
|
1939
|
+
this.initialDistance = this.getDistance(this.touches[0], this.touches[1]);
|
|
1940
|
+
this.initialZoom = this.zoomLevel;
|
|
1941
|
+
}
|
|
1942
|
+
}
|
|
1943
|
+
onTouchMove(event) {
|
|
1944
|
+
event.preventDefault();
|
|
1945
|
+
this.touches = Array.from(event.touches);
|
|
1946
|
+
if (this.touches.length === 1 && this.isDragging && this.zoomLevel > 1) {
|
|
1947
|
+
// Single touch - drag
|
|
1948
|
+
this.panX = this.touches[0].clientX - this.startX;
|
|
1949
|
+
this.panY = this.touches[0].clientY - this.startY;
|
|
1950
|
+
}
|
|
1951
|
+
else if (this.touches.length === 2) {
|
|
1952
|
+
// Two touches - pinch zoom
|
|
1953
|
+
const currentDistance = this.getDistance(this.touches[0], this.touches[1]);
|
|
1954
|
+
const scale = currentDistance / this.initialDistance;
|
|
1955
|
+
this.zoomLevel = Math.min(Math.max(this.initialZoom * scale, this.minZoom), this.maxZoom);
|
|
1956
|
+
// Reset pan if zoomed out to 1x or less
|
|
1957
|
+
if (this.zoomLevel <= 1) {
|
|
1958
|
+
this.panX = 0;
|
|
1959
|
+
this.panY = 0;
|
|
1960
|
+
}
|
|
1961
|
+
}
|
|
1962
|
+
}
|
|
1963
|
+
onTouchEnd(event) {
|
|
1964
|
+
this.isDragging = false;
|
|
1965
|
+
this.touches = Array.from(event.touches);
|
|
1966
|
+
}
|
|
1967
|
+
// Mouse wheel zoom
|
|
1968
|
+
onWheel(event) {
|
|
1969
|
+
event.preventDefault();
|
|
1970
|
+
const delta = event.deltaY > 0 ? -1 : 1;
|
|
1971
|
+
const zoomFactor = 1 + delta * 0.1;
|
|
1972
|
+
this.zoomLevel = Math.min(Math.max(this.zoomLevel * zoomFactor, this.minZoom), this.maxZoom);
|
|
1973
|
+
// Reset pan if zoomed out to 1x or less
|
|
1974
|
+
if (this.zoomLevel <= 1) {
|
|
1975
|
+
this.panX = 0;
|
|
1976
|
+
this.panY = 0;
|
|
1977
|
+
}
|
|
1978
|
+
}
|
|
1979
|
+
// Helper methods
|
|
1980
|
+
getDistance(touch1, touch2) {
|
|
1981
|
+
const dx = touch1.clientX - touch2.clientX;
|
|
1982
|
+
const dy = touch1.clientY - touch2.clientY;
|
|
1983
|
+
return Math.sqrt(dx * dx + dy * dy);
|
|
1984
|
+
}
|
|
1985
|
+
// Keyboard shortcuts
|
|
1986
|
+
onKeyDown(event) {
|
|
1987
|
+
if (!this.isPreviewOpen)
|
|
1988
|
+
return;
|
|
1989
|
+
switch (event.key) {
|
|
1990
|
+
case 'Escape':
|
|
1991
|
+
this.closePreview();
|
|
1992
|
+
break;
|
|
1993
|
+
case '+':
|
|
1994
|
+
case '=':
|
|
1995
|
+
event.preventDefault();
|
|
1996
|
+
this.zoomIn();
|
|
1997
|
+
break;
|
|
1998
|
+
case '-':
|
|
1999
|
+
event.preventDefault();
|
|
2000
|
+
this.zoomOut();
|
|
2001
|
+
break;
|
|
2002
|
+
case '0':
|
|
2003
|
+
event.preventDefault();
|
|
2004
|
+
this.resetZoom();
|
|
2005
|
+
break;
|
|
2006
|
+
}
|
|
2007
|
+
}
|
|
1833
2008
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ImageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1834
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ImageComponent, isStandalone: true, selector: "val-image", inputs: { props: "props" }, ngImport: i0, template: `
|
|
2009
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ImageComponent, isStandalone: true, selector: "val-image", inputs: { props: "props" }, host: { listeners: { "document:keydown": "onKeyDown($event)" } }, ngImport: i0, template: `
|
|
1835
2010
|
<figure
|
|
1836
2011
|
class="val-image-container"
|
|
1837
2012
|
[class]="props.containerClass"
|
|
@@ -1848,7 +2023,11 @@ class ImageComponent {
|
|
|
1848
2023
|
@if (props.src.includes('--')) {
|
|
1849
2024
|
<img
|
|
1850
2025
|
class="val-image"
|
|
1851
|
-
[ngClass]="[
|
|
2026
|
+
[ngClass]="[
|
|
2027
|
+
props.mode,
|
|
2028
|
+
!props.width ? props.size : '',
|
|
2029
|
+
props.previewMode ? 'val-image--preview-enabled' : '',
|
|
2030
|
+
]"
|
|
1852
2031
|
[ngStyle]="{
|
|
1853
2032
|
content: 'var(' + props.src + ')',
|
|
1854
2033
|
}"
|
|
@@ -1861,11 +2040,16 @@ class ImageComponent {
|
|
|
1861
2040
|
[style.width.rem]="props.width"
|
|
1862
2041
|
[style.max-width.rem]="props.width"
|
|
1863
2042
|
[style.height.px]="props.height"
|
|
2043
|
+
(click)="props.previewMode ? openPreview() : null"
|
|
1864
2044
|
/>
|
|
1865
2045
|
} @else {
|
|
1866
2046
|
<img
|
|
1867
2047
|
class="val-image"
|
|
1868
|
-
[ngClass]="[
|
|
2048
|
+
[ngClass]="[
|
|
2049
|
+
props.mode,
|
|
2050
|
+
!props.width ? props.size : '',
|
|
2051
|
+
props.previewMode ? 'val-image--preview-enabled' : '',
|
|
2052
|
+
]"
|
|
1869
2053
|
[class.bordered]="props.bordered"
|
|
1870
2054
|
[class.shaded]="props.shaded"
|
|
1871
2055
|
[class.dark]="props.dark"
|
|
@@ -1876,6 +2060,7 @@ class ImageComponent {
|
|
|
1876
2060
|
[style.width.rem]="props.width"
|
|
1877
2061
|
[style.max-width.rem]="props.width"
|
|
1878
2062
|
[style.height.px]="props.height"
|
|
2063
|
+
(click)="props.previewMode ? openPreview() : null"
|
|
1879
2064
|
/>
|
|
1880
2065
|
}
|
|
1881
2066
|
</div>
|
|
@@ -1893,7 +2078,78 @@ class ImageComponent {
|
|
|
1893
2078
|
</figcaption>
|
|
1894
2079
|
}
|
|
1895
2080
|
</figure>
|
|
1896
|
-
|
|
2081
|
+
|
|
2082
|
+
<!-- Modal de previsualización -->
|
|
2083
|
+
@if (isPreviewOpen) {
|
|
2084
|
+
<div class="val-image-preview-modal" (click)="closePreview()">
|
|
2085
|
+
<div class="val-image-preview-container">
|
|
2086
|
+
<!-- Botón de cerrar -->
|
|
2087
|
+
<button
|
|
2088
|
+
class="val-image-preview-close"
|
|
2089
|
+
(click)="closePreview()"
|
|
2090
|
+
[attr.aria-label]="langService.getText('ImageComponent', 'close')"
|
|
2091
|
+
>
|
|
2092
|
+
<span>×</span>
|
|
2093
|
+
</button>
|
|
2094
|
+
|
|
2095
|
+
<!-- Controles de zoom -->
|
|
2096
|
+
<div class="val-image-preview-controls">
|
|
2097
|
+
<button
|
|
2098
|
+
class="val-image-preview-zoom-btn"
|
|
2099
|
+
(click)="zoomOut()"
|
|
2100
|
+
[disabled]="zoomLevel <= minZoom"
|
|
2101
|
+
[attr.aria-label]="langService.getText('ImageComponent', 'zoomOut')"
|
|
2102
|
+
>
|
|
2103
|
+
<span>−</span>
|
|
2104
|
+
</button>
|
|
2105
|
+
<span class="val-image-preview-zoom-level">{{ Math.round(zoomLevel * 100) }}%</span>
|
|
2106
|
+
<button
|
|
2107
|
+
class="val-image-preview-zoom-btn"
|
|
2108
|
+
(click)="zoomIn()"
|
|
2109
|
+
[disabled]="zoomLevel >= maxZoom"
|
|
2110
|
+
[attr.aria-label]="langService.getText('ImageComponent', 'zoomIn')"
|
|
2111
|
+
>
|
|
2112
|
+
<span>+</span>
|
|
2113
|
+
</button>
|
|
2114
|
+
<button
|
|
2115
|
+
class="val-image-preview-reset-btn"
|
|
2116
|
+
(click)="resetZoom()"
|
|
2117
|
+
[attr.aria-label]="langService.getText('ImageComponent', 'resetZoom')"
|
|
2118
|
+
>
|
|
2119
|
+
<span>⌂</span>
|
|
2120
|
+
</button>
|
|
2121
|
+
</div>
|
|
2122
|
+
|
|
2123
|
+
<!-- Imagen ampliada -->
|
|
2124
|
+
<div
|
|
2125
|
+
class="val-image-preview-viewport"
|
|
2126
|
+
(click)="$event.stopPropagation()"
|
|
2127
|
+
(touchstart)="onTouchStart($event)"
|
|
2128
|
+
(touchmove)="onTouchMove($event)"
|
|
2129
|
+
(touchend)="onTouchEnd($event)"
|
|
2130
|
+
(wheel)="onWheel($event)"
|
|
2131
|
+
(mousedown)="onMouseDown($event)"
|
|
2132
|
+
(mousemove)="onMouseMove($event)"
|
|
2133
|
+
(mouseup)="onMouseUp($event)"
|
|
2134
|
+
(mouseleave)="onMouseUp($event)"
|
|
2135
|
+
>
|
|
2136
|
+
<img
|
|
2137
|
+
#previewImage
|
|
2138
|
+
class="val-image-preview-img"
|
|
2139
|
+
[src]="props.src.includes('--') ? null : props.src"
|
|
2140
|
+
[ngStyle]="{
|
|
2141
|
+
content: props.src.includes('--') ? 'var(' + props.src + ')' : null,
|
|
2142
|
+
transform: 'scale(' + zoomLevel + ') translate(' + panX + 'px, ' + panY + 'px)',
|
|
2143
|
+
cursor: isDragging ? 'grabbing' : zoomLevel > 1 ? 'grab' : 'default',
|
|
2144
|
+
}"
|
|
2145
|
+
[alt]="props.alt"
|
|
2146
|
+
draggable="false"
|
|
2147
|
+
/>
|
|
2148
|
+
</div>
|
|
2149
|
+
</div>
|
|
2150
|
+
</div>
|
|
2151
|
+
}
|
|
2152
|
+
`, isInline: true, styles: [":root{--ion-color-primary: #7026df;--ion-color-primary-rgb: 112, 38, 223;--ion-color-primary-contrast: #ffffff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #6321c4;--ion-color-primary-tint: #7e3ce2;--ion-color-secondary: #e2ccff;--ion-color-secondary-rgb: 226, 204, 255;--ion-color-secondary-contrast: #000000;--ion-color-secondary-contrast-rgb: 0, 0, 0;--ion-color-secondary-shade: #c7b4e0;--ion-color-secondary-tint: #e5d1ff;--ion-color-texti: #354c69;--ion-color-texti-rgb: 53, 76, 105;--ion-color-texti-contrast: #ffffff;--ion-color-texti-contrast-rgb: 255, 255, 255;--ion-color-texti-shade: #2f435c;--ion-color-texti-tint: #495e78;--ion-color-darki: #090f1b;--ion-color-darki-rgb: 9, 15, 27;--ion-color-darki-contrast: #ffffff;--ion-color-darki-contrast-rgb: 255, 255, 255;--ion-color-darki-shade: #080d18;--ion-color-darki-tint: #222732;--ion-color-medium: #9e9e9e;--ion-color-medium-rgb: 158, 158, 158;--ion-color-medium-contrast: #000000;--ion-color-medium-contrast-rgb: 0, 0, 0;--ion-color-medium-shade: #8b8b8b;--ion-color-medium-tint: #a8a8a8;--swiper-pagination-color: var(--ion-color-primary);--swiper-navigation-color: var(--ion-color-primary);--swiper-pagination-bullet-inactive-color: var(--ion-color-medium)}@media (prefers-color-scheme: dark){:root{--ion-color-texti: #8fc1ff;--ion-color-texti-rgb: 143, 193, 255;--ion-color-texti-contrast: #000000;--ion-color-texti-contrast-rgb: 0, 0, 0;--ion-color-texti-shade: #7eaae0;--ion-color-texti-tint: #9ac7ff;--ion-color-darki: #ffffff;--ion-color-darki-rgb: 255, 255, 255;--ion-color-darki-contrast: #000000;--ion-color-darki-contrast-rgb: 0, 0, 0;--ion-color-darki-shade: #e0e0e0;--ion-color-darki-tint: #ffffff;--ion-color-primary: #8f49f8;--ion-color-primary-rgb: 143, 73, 248;--ion-color-primary-contrast: #ffffff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #7e40da;--ion-color-primary-tint: #9a5bf9}}.ion-color-texti{--ion-color-base: var(--ion-color-texti);--ion-color-base-rgb: var(--ion-color-texti-rgb);--ion-color-contrast: var(--ion-color-texti-contrast);--ion-color-contrast-rgb: var(--ion-color-texti-contrast-rgb);--ion-color-shade: var(--ion-color-texti-shade);--ion-color-tint: var(--ion-color-texti-tint)}.ion-color-darki{--ion-color-base: var(--ion-color-darki);--ion-color-base-rgb: var(--ion-color-darki-rgb);--ion-color-contrast: var(--ion-color-darki-contrast);--ion-color-contrast-rgb: var(--ion-color-darki-contrast-rgb);--ion-color-shade: var(--ion-color-darki-shade);--ion-color-tint: var(--ion-color-darki-tint)}.val-image-container{margin:0;padding:0;max-width:100%}.val-image-container--left{margin-right:auto;text-align:left}.val-image-container--center{margin-left:auto;margin-right:auto;text-align:center}.val-image-container--right{margin-left:auto;text-align:right}.val-image-wrapper{display:inline-block;position:relative}.val-image{width:100%;height:auto;display:block;opacity:1;max-width:100%}.val-image.center{margin:0 auto}.val-image.rounded{border-radius:.5rem}.val-image.circular{border-radius:50%;aspect-ratio:1;object-fit:cover}.val-image.box{border-radius:0}.val-image.bordered{border:.0625rem solid var(--ion-color-medium)}.val-image.shaded{box-shadow:.1875rem .625rem .5rem #1219541a}@media (prefers-color-scheme: dark){.val-image.dark{filter:invert(1)}}.val-image.limited{max-width:100%}@media (max-width: 768px){.val-image .val-image-wrapper.small{width:40%}.val-image .val-image-wrapper.medium{width:60%}.val-image .val-image-wrapper.large{width:80%}.val-image .val-image-wrapper.xlarge{width:100%}}.val-image.small{width:30%}.val-image.medium{width:50%}.val-image.large{width:70%}.val-image.xlarge{width:100%}.val-image-caption{margin-top:.5rem;color:var(--ion-color-medium-shade, #666);font-style:italic;line-height:1.4}.val-image-caption--small{font-size:.75rem}.val-image-caption--medium{font-size:.875rem}.val-image-caption--large{font-size:1rem}.val-image.visible{animation:appearance ease-in 1s forwards}@keyframes appearance{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.val-image-container{flex-shrink:0;align-self:flex-start}.flexbox-container .val-image-container--left{align-self:flex-start}.flexbox-container .val-image-container--center{align-self:center}.flexbox-container .val-image-container--right{align-self:flex-end}.val-image--preview-enabled{cursor:pointer;transition:opacity .2s ease,transform .2s ease}.val-image--preview-enabled:hover{opacity:.9;transform:scale(1.02)}.val-image-preview-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000f2;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.val-image-preview-container{position:relative;width:100%;height:100%;display:flex;flex-direction:column}.val-image-preview-close{position:absolute;top:20px;right:20px;z-index:10001;background:#ffffff1a;border:none;color:#fff;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;font-weight:700;transition:background .2s ease}.val-image-preview-close:hover{background:#fff3}.val-image-preview-close span{line-height:1}.val-image-preview-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);z-index:10001;display:flex;align-items:center;gap:10px;background:#000000b3;padding:10px 20px;border-radius:25px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.val-image-preview-zoom-btn,.val-image-preview-reset-btn{background:#ffffff1a;border:none;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;font-weight:700;transition:all .2s ease}.val-image-preview-zoom-btn:hover:not(:disabled),.val-image-preview-reset-btn:hover:not(:disabled){background:#fff3;transform:scale(1.1)}.val-image-preview-zoom-btn:disabled,.val-image-preview-reset-btn:disabled{opacity:.4;cursor:not-allowed}.val-image-preview-zoom-btn span,.val-image-preview-reset-btn span{line-height:1}.val-image-preview-zoom-level{color:#fff;font-size:14px;font-weight:600;min-width:50px;text-align:center}.val-image-preview-viewport{flex:1;overflow:hidden;display:flex;align-items:center;justify-content:center;touch-action:none}.val-image-preview-img{max-width:90vw;max-height:90vh;object-fit:contain;transition:transform .1s ease-out;transform-origin:center center;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.val-image-preview-close{top:10px;right:10px;width:40px;height:40px;font-size:20px}.val-image-preview-controls{bottom:10px;padding:8px 16px}.val-image-preview-zoom-btn,.val-image-preview-reset-btn{width:35px;height:35px;font-size:18px}.val-image-preview-zoom-level{font-size:12px;min-width:40px}.val-image-preview-img{max-width:95vw;max-height:85vh}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
|
|
1897
2153
|
}
|
|
1898
2154
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ImageComponent, decorators: [{
|
|
1899
2155
|
type: Component,
|
|
@@ -1914,7 +2170,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1914
2170
|
@if (props.src.includes('--')) {
|
|
1915
2171
|
<img
|
|
1916
2172
|
class="val-image"
|
|
1917
|
-
[ngClass]="[
|
|
2173
|
+
[ngClass]="[
|
|
2174
|
+
props.mode,
|
|
2175
|
+
!props.width ? props.size : '',
|
|
2176
|
+
props.previewMode ? 'val-image--preview-enabled' : '',
|
|
2177
|
+
]"
|
|
1918
2178
|
[ngStyle]="{
|
|
1919
2179
|
content: 'var(' + props.src + ')',
|
|
1920
2180
|
}"
|
|
@@ -1927,11 +2187,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1927
2187
|
[style.width.rem]="props.width"
|
|
1928
2188
|
[style.max-width.rem]="props.width"
|
|
1929
2189
|
[style.height.px]="props.height"
|
|
2190
|
+
(click)="props.previewMode ? openPreview() : null"
|
|
1930
2191
|
/>
|
|
1931
2192
|
} @else {
|
|
1932
2193
|
<img
|
|
1933
2194
|
class="val-image"
|
|
1934
|
-
[ngClass]="[
|
|
2195
|
+
[ngClass]="[
|
|
2196
|
+
props.mode,
|
|
2197
|
+
!props.width ? props.size : '',
|
|
2198
|
+
props.previewMode ? 'val-image--preview-enabled' : '',
|
|
2199
|
+
]"
|
|
1935
2200
|
[class.bordered]="props.bordered"
|
|
1936
2201
|
[class.shaded]="props.shaded"
|
|
1937
2202
|
[class.dark]="props.dark"
|
|
@@ -1942,6 +2207,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1942
2207
|
[style.width.rem]="props.width"
|
|
1943
2208
|
[style.max-width.rem]="props.width"
|
|
1944
2209
|
[style.height.px]="props.height"
|
|
2210
|
+
(click)="props.previewMode ? openPreview() : null"
|
|
1945
2211
|
/>
|
|
1946
2212
|
}
|
|
1947
2213
|
</div>
|
|
@@ -1959,9 +2225,83 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1959
2225
|
</figcaption>
|
|
1960
2226
|
}
|
|
1961
2227
|
</figure>
|
|
1962
|
-
|
|
2228
|
+
|
|
2229
|
+
<!-- Modal de previsualización -->
|
|
2230
|
+
@if (isPreviewOpen) {
|
|
2231
|
+
<div class="val-image-preview-modal" (click)="closePreview()">
|
|
2232
|
+
<div class="val-image-preview-container">
|
|
2233
|
+
<!-- Botón de cerrar -->
|
|
2234
|
+
<button
|
|
2235
|
+
class="val-image-preview-close"
|
|
2236
|
+
(click)="closePreview()"
|
|
2237
|
+
[attr.aria-label]="langService.getText('ImageComponent', 'close')"
|
|
2238
|
+
>
|
|
2239
|
+
<span>×</span>
|
|
2240
|
+
</button>
|
|
2241
|
+
|
|
2242
|
+
<!-- Controles de zoom -->
|
|
2243
|
+
<div class="val-image-preview-controls">
|
|
2244
|
+
<button
|
|
2245
|
+
class="val-image-preview-zoom-btn"
|
|
2246
|
+
(click)="zoomOut()"
|
|
2247
|
+
[disabled]="zoomLevel <= minZoom"
|
|
2248
|
+
[attr.aria-label]="langService.getText('ImageComponent', 'zoomOut')"
|
|
2249
|
+
>
|
|
2250
|
+
<span>−</span>
|
|
2251
|
+
</button>
|
|
2252
|
+
<span class="val-image-preview-zoom-level">{{ Math.round(zoomLevel * 100) }}%</span>
|
|
2253
|
+
<button
|
|
2254
|
+
class="val-image-preview-zoom-btn"
|
|
2255
|
+
(click)="zoomIn()"
|
|
2256
|
+
[disabled]="zoomLevel >= maxZoom"
|
|
2257
|
+
[attr.aria-label]="langService.getText('ImageComponent', 'zoomIn')"
|
|
2258
|
+
>
|
|
2259
|
+
<span>+</span>
|
|
2260
|
+
</button>
|
|
2261
|
+
<button
|
|
2262
|
+
class="val-image-preview-reset-btn"
|
|
2263
|
+
(click)="resetZoom()"
|
|
2264
|
+
[attr.aria-label]="langService.getText('ImageComponent', 'resetZoom')"
|
|
2265
|
+
>
|
|
2266
|
+
<span>⌂</span>
|
|
2267
|
+
</button>
|
|
2268
|
+
</div>
|
|
2269
|
+
|
|
2270
|
+
<!-- Imagen ampliada -->
|
|
2271
|
+
<div
|
|
2272
|
+
class="val-image-preview-viewport"
|
|
2273
|
+
(click)="$event.stopPropagation()"
|
|
2274
|
+
(touchstart)="onTouchStart($event)"
|
|
2275
|
+
(touchmove)="onTouchMove($event)"
|
|
2276
|
+
(touchend)="onTouchEnd($event)"
|
|
2277
|
+
(wheel)="onWheel($event)"
|
|
2278
|
+
(mousedown)="onMouseDown($event)"
|
|
2279
|
+
(mousemove)="onMouseMove($event)"
|
|
2280
|
+
(mouseup)="onMouseUp($event)"
|
|
2281
|
+
(mouseleave)="onMouseUp($event)"
|
|
2282
|
+
>
|
|
2283
|
+
<img
|
|
2284
|
+
#previewImage
|
|
2285
|
+
class="val-image-preview-img"
|
|
2286
|
+
[src]="props.src.includes('--') ? null : props.src"
|
|
2287
|
+
[ngStyle]="{
|
|
2288
|
+
content: props.src.includes('--') ? 'var(' + props.src + ')' : null,
|
|
2289
|
+
transform: 'scale(' + zoomLevel + ') translate(' + panX + 'px, ' + panY + 'px)',
|
|
2290
|
+
cursor: isDragging ? 'grabbing' : zoomLevel > 1 ? 'grab' : 'default',
|
|
2291
|
+
}"
|
|
2292
|
+
[alt]="props.alt"
|
|
2293
|
+
draggable="false"
|
|
2294
|
+
/>
|
|
2295
|
+
</div>
|
|
2296
|
+
</div>
|
|
2297
|
+
</div>
|
|
2298
|
+
}
|
|
2299
|
+
`, styles: [":root{--ion-color-primary: #7026df;--ion-color-primary-rgb: 112, 38, 223;--ion-color-primary-contrast: #ffffff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #6321c4;--ion-color-primary-tint: #7e3ce2;--ion-color-secondary: #e2ccff;--ion-color-secondary-rgb: 226, 204, 255;--ion-color-secondary-contrast: #000000;--ion-color-secondary-contrast-rgb: 0, 0, 0;--ion-color-secondary-shade: #c7b4e0;--ion-color-secondary-tint: #e5d1ff;--ion-color-texti: #354c69;--ion-color-texti-rgb: 53, 76, 105;--ion-color-texti-contrast: #ffffff;--ion-color-texti-contrast-rgb: 255, 255, 255;--ion-color-texti-shade: #2f435c;--ion-color-texti-tint: #495e78;--ion-color-darki: #090f1b;--ion-color-darki-rgb: 9, 15, 27;--ion-color-darki-contrast: #ffffff;--ion-color-darki-contrast-rgb: 255, 255, 255;--ion-color-darki-shade: #080d18;--ion-color-darki-tint: #222732;--ion-color-medium: #9e9e9e;--ion-color-medium-rgb: 158, 158, 158;--ion-color-medium-contrast: #000000;--ion-color-medium-contrast-rgb: 0, 0, 0;--ion-color-medium-shade: #8b8b8b;--ion-color-medium-tint: #a8a8a8;--swiper-pagination-color: var(--ion-color-primary);--swiper-navigation-color: var(--ion-color-primary);--swiper-pagination-bullet-inactive-color: var(--ion-color-medium)}@media (prefers-color-scheme: dark){:root{--ion-color-texti: #8fc1ff;--ion-color-texti-rgb: 143, 193, 255;--ion-color-texti-contrast: #000000;--ion-color-texti-contrast-rgb: 0, 0, 0;--ion-color-texti-shade: #7eaae0;--ion-color-texti-tint: #9ac7ff;--ion-color-darki: #ffffff;--ion-color-darki-rgb: 255, 255, 255;--ion-color-darki-contrast: #000000;--ion-color-darki-contrast-rgb: 0, 0, 0;--ion-color-darki-shade: #e0e0e0;--ion-color-darki-tint: #ffffff;--ion-color-primary: #8f49f8;--ion-color-primary-rgb: 143, 73, 248;--ion-color-primary-contrast: #ffffff;--ion-color-primary-contrast-rgb: 255, 255, 255;--ion-color-primary-shade: #7e40da;--ion-color-primary-tint: #9a5bf9}}.ion-color-texti{--ion-color-base: var(--ion-color-texti);--ion-color-base-rgb: var(--ion-color-texti-rgb);--ion-color-contrast: var(--ion-color-texti-contrast);--ion-color-contrast-rgb: var(--ion-color-texti-contrast-rgb);--ion-color-shade: var(--ion-color-texti-shade);--ion-color-tint: var(--ion-color-texti-tint)}.ion-color-darki{--ion-color-base: var(--ion-color-darki);--ion-color-base-rgb: var(--ion-color-darki-rgb);--ion-color-contrast: var(--ion-color-darki-contrast);--ion-color-contrast-rgb: var(--ion-color-darki-contrast-rgb);--ion-color-shade: var(--ion-color-darki-shade);--ion-color-tint: var(--ion-color-darki-tint)}.val-image-container{margin:0;padding:0;max-width:100%}.val-image-container--left{margin-right:auto;text-align:left}.val-image-container--center{margin-left:auto;margin-right:auto;text-align:center}.val-image-container--right{margin-left:auto;text-align:right}.val-image-wrapper{display:inline-block;position:relative}.val-image{width:100%;height:auto;display:block;opacity:1;max-width:100%}.val-image.center{margin:0 auto}.val-image.rounded{border-radius:.5rem}.val-image.circular{border-radius:50%;aspect-ratio:1;object-fit:cover}.val-image.box{border-radius:0}.val-image.bordered{border:.0625rem solid var(--ion-color-medium)}.val-image.shaded{box-shadow:.1875rem .625rem .5rem #1219541a}@media (prefers-color-scheme: dark){.val-image.dark{filter:invert(1)}}.val-image.limited{max-width:100%}@media (max-width: 768px){.val-image .val-image-wrapper.small{width:40%}.val-image .val-image-wrapper.medium{width:60%}.val-image .val-image-wrapper.large{width:80%}.val-image .val-image-wrapper.xlarge{width:100%}}.val-image.small{width:30%}.val-image.medium{width:50%}.val-image.large{width:70%}.val-image.xlarge{width:100%}.val-image-caption{margin-top:.5rem;color:var(--ion-color-medium-shade, #666);font-style:italic;line-height:1.4}.val-image-caption--small{font-size:.75rem}.val-image-caption--medium{font-size:.875rem}.val-image-caption--large{font-size:1rem}.val-image.visible{animation:appearance ease-in 1s forwards}@keyframes appearance{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.val-image-container{flex-shrink:0;align-self:flex-start}.flexbox-container .val-image-container--left{align-self:flex-start}.flexbox-container .val-image-container--center{align-self:center}.flexbox-container .val-image-container--right{align-self:flex-end}.val-image--preview-enabled{cursor:pointer;transition:opacity .2s ease,transform .2s ease}.val-image--preview-enabled:hover{opacity:.9;transform:scale(1.02)}.val-image-preview-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000f2;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.val-image-preview-container{position:relative;width:100%;height:100%;display:flex;flex-direction:column}.val-image-preview-close{position:absolute;top:20px;right:20px;z-index:10001;background:#ffffff1a;border:none;color:#fff;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;font-weight:700;transition:background .2s ease}.val-image-preview-close:hover{background:#fff3}.val-image-preview-close span{line-height:1}.val-image-preview-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);z-index:10001;display:flex;align-items:center;gap:10px;background:#000000b3;padding:10px 20px;border-radius:25px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.val-image-preview-zoom-btn,.val-image-preview-reset-btn{background:#ffffff1a;border:none;color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;font-weight:700;transition:all .2s ease}.val-image-preview-zoom-btn:hover:not(:disabled),.val-image-preview-reset-btn:hover:not(:disabled){background:#fff3;transform:scale(1.1)}.val-image-preview-zoom-btn:disabled,.val-image-preview-reset-btn:disabled{opacity:.4;cursor:not-allowed}.val-image-preview-zoom-btn span,.val-image-preview-reset-btn span{line-height:1}.val-image-preview-zoom-level{color:#fff;font-size:14px;font-weight:600;min-width:50px;text-align:center}.val-image-preview-viewport{flex:1;overflow:hidden;display:flex;align-items:center;justify-content:center;touch-action:none}.val-image-preview-img{max-width:90vw;max-height:90vh;object-fit:contain;transition:transform .1s ease-out;transform-origin:center center;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.val-image-preview-close{top:10px;right:10px;width:40px;height:40px;font-size:20px}.val-image-preview-controls{bottom:10px;padding:8px 16px}.val-image-preview-zoom-btn,.val-image-preview-reset-btn{width:35px;height:35px;font-size:18px}.val-image-preview-zoom-level{font-size:12px;min-width:40px}.val-image-preview-img{max-width:95vw;max-height:85vh}}\n"] }]
|
|
1963
2300
|
}], ctorParameters: () => [], propDecorators: { props: [{
|
|
1964
2301
|
type: Input
|
|
2302
|
+
}], onKeyDown: [{
|
|
2303
|
+
type: HostListener,
|
|
2304
|
+
args: ['document:keydown', ['$event']]
|
|
1965
2305
|
}] } });
|
|
1966
2306
|
|
|
1967
2307
|
/**
|
|
@@ -8257,6 +8597,10 @@ const globalContentData = {
|
|
|
8257
8597
|
copied: '¡Copiado al portapapeles!',
|
|
8258
8598
|
seeMore: 'ver más',
|
|
8259
8599
|
selected: 'seleccionados',
|
|
8600
|
+
// Image preview
|
|
8601
|
+
zoomIn: 'Acercar',
|
|
8602
|
+
zoomOut: 'Alejar',
|
|
8603
|
+
resetZoom: 'Restablecer zoom',
|
|
8260
8604
|
},
|
|
8261
8605
|
en: {
|
|
8262
8606
|
// Common buttons
|
|
@@ -8312,12 +8656,33 @@ const globalContentData = {
|
|
|
8312
8656
|
copied: 'Copied to clipboard!',
|
|
8313
8657
|
seeMore: 'see more',
|
|
8314
8658
|
selected: 'selected',
|
|
8659
|
+
// Image preview
|
|
8660
|
+
zoomIn: 'Zoom in',
|
|
8661
|
+
zoomOut: 'Zoom out',
|
|
8662
|
+
resetZoom: 'Reset zoom',
|
|
8315
8663
|
},
|
|
8316
8664
|
};
|
|
8317
8665
|
const GlobalContent = new TextContent(globalContentData);
|
|
8666
|
+
// ImageComponent specific content
|
|
8667
|
+
const imageComponentData = {
|
|
8668
|
+
es: {
|
|
8669
|
+
close: 'Cerrar',
|
|
8670
|
+
zoomIn: 'Acercar',
|
|
8671
|
+
zoomOut: 'Alejar',
|
|
8672
|
+
resetZoom: 'Restablecer zoom',
|
|
8673
|
+
},
|
|
8674
|
+
en: {
|
|
8675
|
+
close: 'Close',
|
|
8676
|
+
zoomIn: 'Zoom in',
|
|
8677
|
+
zoomOut: 'Zoom out',
|
|
8678
|
+
resetZoom: 'Reset zoom',
|
|
8679
|
+
},
|
|
8680
|
+
};
|
|
8681
|
+
const ImageComponentContent = new TextContent(imageComponentData);
|
|
8318
8682
|
const content = {
|
|
8319
8683
|
_global: GlobalContent,
|
|
8320
8684
|
LangSettings,
|
|
8685
|
+
ImageComponent: ImageComponentContent,
|
|
8321
8686
|
};
|
|
8322
8687
|
|
|
8323
8688
|
/**
|