]> git.ipfire.org Git - thirdparty/bootstrap.git/commitdiff
Customize browse text of the custom file input with HTML (#27651)
authorMartijn Cuppens <martijn.cuppens@gmail.com>
Tue, 13 Nov 2018 06:30:17 +0000 (07:30 +0100)
committerXhmikosR <xhmikosr@gmail.com>
Tue, 13 Nov 2018 06:30:17 +0000 (08:30 +0200)
scss/_custom-forms.scss
site/docs/4.1/components/forms.md

index 9088662fda86b048fde978a97d19b03d2a258e35..e999daf0ca8b2c30790a67a0f2fd7f1b66020596 100644 (file)
       content: $value;
     }
   }
+
+  ~ .custom-file-label[data-browse]::after {
+    content: attr(data-browse);
+  }
 }
 
 .custom-file-label {
index 64ec2cea2f25a49b322b5eadc15034e6eb52d921..29f7fc10bc59d1dea29977398aeae4810fe87e73 100644 (file)
@@ -1287,7 +1287,7 @@ The file input is the most gnarly of the bunch and requires additional JavaScrip
 
 We hide the default file `<input>` via `opacity` and instead style the `<label>`. The button is generated and positioned with `::after`. Lastly, we declare a `width` and `height` on the `<input>` for proper spacing for surrounding content.
 
-#### Translating or customizing the strings
+#### Translating or customizing the strings with SCSS
 
 The [`:lang()` pseudo-class](https://developer.mozilla.org/en-US/docs/Web/CSS/:lang) is used to allow for translation of the "Browse" text into other languages. Override or add entries to the `$custom-file-text` Sass variable with the relevant [language tag](https://en.wikipedia.org/wiki/IETF_language_tag) and localized strings. The English strings can be customized the same way. For example, here's how one might add a Spanish translation (Spanish's language code is `es`):
 
@@ -1309,3 +1309,15 @@ Here's `lang(es)` in action on the custom file input for a Spanish translation:
 {% include example.html content=example %}
 
 You'll need to set the language of your document (or subtree thereof) correctly in order for the correct text to be shown. This can be done using [the `lang` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang) on the `<html>` element or the [`Content-Language` HTTP header](https://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.12), among other methods.
+
+#### Translating or customizing the strings with HTML
+
+Bootstrap also provides a way to translate the "Browse" text in HTML with the `data-browse` attribute which can be added to the custom input label (example in Dutch):
+
+{% capture example %}
+<div class="custom-file">
+  <input type="file" class="custom-file-input" id="customFileLangHTML">
+  <label class="custom-file-label" for="customFileLangHTML" data-browse="Bestand kiezen">Voeg je document toe</label>
+</div>
+{% endcapture %}
+{% include example.html content=example %}