Translate QR Scanner Interface to Spanish

Instructions

  1. Install this snippet with our free Custom JavaScript plugin. https://gravitywiz.com/gravity-forms-code-chest/

Code

Filename: gpqr-translate-qr-scanner.js

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/**
 * Gravity Perks // GP QR Code // Translate QR Scanner Interface to Spanish
 * https://gravitywiz.com/documentation/gravity-forms-qr-code/
 *
 * Instructions:
 *
 * 1. Install this snippet with our free Custom JavaScript plugin.
 *    https://gravitywiz.com/gravity-forms-code-chest/
 */
( function( $ ) {

	const translations = new Map([
		["Request Camera Permissions", "Solicitar permisos de cámara"],
		["Requesting camera permissions...", "Solicitando permisos de cámara..."],
		["No camera found", "No se encontró ninguna cámara"],
		["Stop Scanning", "Detener escaneo"],
		["Start Scanning", "Iniciar escaneo"],
		["Scan an Image File", "Escanear un archivo de imagen"],
		["Scan using camera directly", "Escanear usando la cámara directamente"],
		["Choose Image", "Elegir imagen"],
		["Choose Another", "Elegir otra"],
		["No image choosen", "Ninguna imagen seleccionada"],
		["Choose Image - No image choosen", "Elegir imagen - Ninguna imagen seleccionada"],
		["Or drop an image to scan", "O arrastra una imagen para escanear"],
		["Camera based scan", "Escaneo basado en cámara"],
		["File based scan", "Escaneo basado en archivo"],
		["Powered by ", "Desarrollado por "],
		["Report issues", "Informar de problemas"],
		["Camera access is only supported in secure context like https or localhost.", "El acceso a la cámara solo está disponible en un entorno seguro como HTTPS o localhost."]
	]);

	/**
	 * Translate text inside a node
	 */
	function translateNode( node ) {

		// Text nodes
		if ( node.nodeType === Node.TEXT_NODE ) {
			const text = node.nodeValue.trim();
			if ( translations.has( text ) ) {
				node.nodeValue = node.nodeValue.replace( text, translations.get( text ) );
			}
			return;
		}

		if ( node.nodeType !== Node.ELEMENT_NODE ) {
			return;
		}

		// Translate common attributes
		["placeholder", "aria-label", "title", "value"].forEach( attr => {
			if ( node.hasAttribute && node.hasAttribute( attr ) ) {
				const value = node.getAttribute( attr );
				if ( translations.has( value ) ) {
					node.setAttribute( attr, translations.get( value ) );
				}
			}
		});

		// Translate direct text content (buttons, spans, divs)
		if ( node.childNodes && node.childNodes.length ) {
			node.childNodes.forEach( child => translateNode( child ) );
		}
	}

	/**
	 * Run translation on existing DOM
	 */
	function translateExistingDOM() {
		translateNode( document.body );
	}

	/**
	 * Observe dynamically added elements
	 */
	function observeDOM() {
		const observer = new MutationObserver( mutations => {
			mutations.forEach( mutation => {
				mutation.addedNodes.forEach( node => translateNode( node ) );
			});
		});

		observer.observe( document.body, {
			childList: true,
			subtree: true
		});
	}

	/**
	 * Init (works for Gravity Forms + dynamic popups)
	 */
	function initTranslator() {
		translateExistingDOM();
		observeDOM();
	}

	initTranslator();

}( jQuery ));

Leave a Reply

Your email address will not be published. Required fields are marked *

  • Trouble installing this snippet? See our troubleshooting tips.
  • Need to include code? Create a gist and link to it in your comment.
  • Reporting a bug? Provide a URL where this issue can be recreated.

By commenting, I understand that I may receive emails related to Gravity Wiz and can unsubscribe at any time.