Localization in Angular File Manager component
10 Jan 202524 minutes to read
The File Manager can be localized to any culture by defining its texts and messages in the corresponding culture. The default locale of the File Manager is en
(English). The following table represents the default texts and messages of the File Manager in en
culture.
KEY | Text/Message | |
---|---|---|
NewFolder | New folder | |
Upload | Upload | |
Delete | Delete | |
Rename | Rename | |
Download | Download | |
Cut | Cut | |
Copy | Copy | |
Paste | Paste | |
SortBy | Sort by | |
Refresh | Refresh | |
Item-Selection | item selected | |
Items-Selection | items selected | |
View | View | |
Details | Details | |
SelectAll | Select all | |
Open | Open | |
Tooltip-NewFolder | New folder | |
Tooltip-Upload | Upload | |
Tooltip-Delete | Delete | |
Tooltip-Rename | Rename | |
Tooltip-Download | Download | |
Tooltip-Cut | Cut | |
Tooltip-Copy | Copy | |
Tooltip-Paste | Paste | |
Tooltip-SortBy | Sort by | |
Tooltip-Refresh | Refresh | |
Tooltip-Selection | Clear selection | |
Tooltip-View | View | |
Tooltip-Details | Details | |
Tooltip-SelectAll | Select all | |
Name | Name | |
Size | Size | |
DateModified | Modified | |
DateCreated | Date created | |
Path | Path | |
Created | Created | |
Modified | Modified | |
Location | Location | |
Type | Type | |
Permission | Permission | |
Ascending | Ascending | |
Descending | Descending | |
None | None | |
View-LargeIcons | Large icons | |
View-Details | Details | |
Search | Search | |
Button-Ok | OK | |
Button-Cancel | Cancel | |
Button-Yes | Yes | |
Button-No | No | |
Button-Create | Create | |
Button-Save | Save | |
Header-NewFolder | Folder | |
Content-NewFolder | Enter your folder name | |
Header-Rename | Rename | |
Content-Rename | Enter your new name | |
Header-Rename-Confirmation | Rename Confirmation | |
Content-Rename-Confirmation | If you change a file name extension | the file might become unstable. Are you sure you want to change it? |
Header-Delete | Delete File | |
Content-Delete | Are you sure you want to delete this file? | |
Header-Multiple-Delete | Delete Multiple Files | |
Content-Multiple-Delete | Are you sure you want to delete these {0} files? | |
Header-Folder-Delete | Delete Folder | |
Content-Folder-Delete | Are you sure you want to delete this folder? | |
Header-Duplicate | File exists | |
Content-Duplicate | already exists. Are you sure you want to replace it? | |
Header-Upload | Upload Files | |
Error | Error | |
Validation-Empty | The file or folder name cannot be empty. | |
Validation-Invalid | The file or folder name {0} contains invalid characters. Please use a different name. Valid file or folder names cannot end with a dot or space, and cannot contain any of the following characters: \/:*?"<>| | |
Validation-NewFolder-Exists | A file or folder with the name {0} already exists. | |
Validation-Rename-Exists | Cannot rename {0} to {1} | destination already exists. |
Folder-Empty | This folder is empty | |
File-Upload | Drag files here to upload | |
Search-Empty | No results found | |
Search-Key | Try with different keywords | |
Filter-Empty | No results found | |
Filter-Key | Try with different filter | |
Sub-Folder-Error | The destination folder is the subfolder of the source folder | |
Same-Folder-Error | The destination folder is the same as the source folder. | |
Access-Denied | Access Denied | |
Access-Details | You don’t have permission to access this folder | |
Header-Retry | File Already Exists | |
Content-Retry | A file with this name already exists in this folder. What would you like to do? | |
Button-Keep-Both | Keep both | |
Button-Replace | Replace | |
Button-Skip | Skip | |
ApplyAll-Label | Do this for all current items | |
KB | KB | |
Access-Message | {0} is not accessible. You need permission to perform the {1} action. | |
Network-Error | NetworkError: Failed to send on XMLHTTPRequest: Failed to load | |
Server-Error | ServerError: Invalid response from |
The below example shows adding the German culture locale(de-DE
)
import { BrowserModule } from '@angular/platform-browser'
import { NgModule } from '@angular/core'
import { FileManagerModule, NavigationPaneService, ToolbarService, DetailsViewService } from '@syncfusion/ej2-angular-filemanager'
import { Component } from '@angular/core';
import { L10n } from '@syncfusion/ej2-base';
@Component({
imports: [FileManagerModule, ],
providers:[ NavigationPaneService, ToolbarService, DetailsViewService],
standalone: true,
selector: 'app-root',
styleUrls: ['./app.component.css'],
template: `<ejs-filemanager id='file-manager' [ajaxSettings]='ajaxSettings' [locale]='locale' height="375px">
</ejs-filemanager>`
})
export class AppComponent {
public ajaxSettings?: object;
public locale?: string;
public hostUrl: string = 'https://ej2-aspcore-service.azurewebsites.net/';
public ngOnInit(): void {
L10n.load({
'de': {
'filemanager': {
"NewFolder": "Neuer Ordner",
"Upload": "Hochladen",
"Delete": "Löschen",
"Rename": "Umbenennen",
"Download": "Herunterladen",
"Cut": "Schnitt",
"Copy": "Kopieren",
"Paste": "Einfügen",
"SortBy": "Sortiere nach",
"Refresh": "Aktualisierung",
"Item-Selection": "Artikel ausgewählt",
"Items-Selection": "Elemente ausgewählt",
"View": "Aussicht",
"Details": "Einzelheiten",
"SelectAll": "Wählen Sie Alle",
"Open": "Öffnen",
"Tooltip-NewFolder": "Neuer Ordner",
"Tooltip-Upload": "Hochladen",
"Tooltip-Delete": "Löschen",
"Tooltip-Rename": "Umbenennen",
"Tooltip-Download": "Herunterladen",
"Tooltip-Cut": "Schnitt",
"Tooltip-Copy": "Kopieren",
"Tooltip-Paste": "Einfügen",
"Tooltip-SortBy": "Sortiere nach",
"Tooltip-Refresh": "Aktualisierung",
"Tooltip-Selection": "Auswahl aufheben",
"Tooltip-View": "Aussicht",
"Tooltip-Details": "Einzelheiten",
"Tooltip-SelectAll": "Wählen Sie Alle",
"Name": "Name",
"Size": "Größe",
"DateModified": "Geändert",
"DateCreated": "Datum erstellt",
"Path": "Pfad",
"Modified": "Geändert",
"Created": "Erstellt",
"Location": "Ort",
"Type": "Art",
"Permission": "Genehmigung",
"Ascending": "Aufsteigend",
"Descending": "Absteigend",
"None": "Keiner",
"View-LargeIcons": "Große Icons",
"View-Details": "Einzelheiten",
"Search": "Suche",
"Button-Ok": "OK",
"Button-Cancel": "Stornieren",
"Button-Yes": "Ja",
"Button-No": "Nein",
"Button-Create": "Erstellen",
"Button-Save": "Sparen",
"Header-NewFolder": "Mappe",
"Content-NewFolder": "Geben Sie Ihren Ordnernamen ein",
"Header-Rename": "Umbenennen",
"Content-Rename": "Geben Sie Ihren neuen Namen ein",
"Header-Rename-Confirmation": "Bestätigung umbenennen",
"Content-Rename-Confirmation": "Wenn Sie eine Dateinamenerweiterung ändern, wird die Datei möglicherweise instabil. Möchten Sie sie wirklich ändern?",
"Header-Delete": "Datei löschen",
"Content-Delete": "Möchten Sie diese Datei wirklich löschen?",
"Header-Multiple-Delete": "Mehrere Dateien löschen",
"Content-Multiple-Delete": "Möchten Sie diese {0} Dateien wirklich löschen?",
"Header-Folder-Delete": "Lösche Ordner",
"Content-Folder-Delete": "Möchten Sie diesen Ordner wirklich löschen?",
"Header-Duplicate": "Datei / Ordner existiert",
"Content-Duplicate": "{0} existiert bereits. Möchten Sie umbenennen und einfügen?",
"Header-Upload": "Daten hochladen",
"Error": "Error",
"Validation-Empty": "Der Datei - oder Ordnername darf nicht leer sein.",
"Validation-Invalid": "Der Datei- oder Ordnername {0} enthält ungültige Zeichen. Bitte verwenden Sie einen anderen Namen. Gültige Datei- oder Ordnernamen dürfen nicht mit einem Punkt oder Leerzeichen enden und keines der folgenden Zeichen enthalten: \\ /: *? \" < > | ",
"Validation-NewFolder-Exists": "Eine Datei oder ein Ordner mit dem Namen {0} existiert bereits.",
"Validation-Rename-Exists": "{0} kann nicht in {1} umbenannt werden: Ziel existiert bereits.",
"Folder-Empty": "Dieser Ordner ist leer",
"File-Upload": "Dateien zum Hochladen hierher ziehen",
"Search-Empty": "Keine Ergebnisse gefunden",
"Search-Key": "Versuchen Sie es mit anderen Stichwörtern",
"Filter-Empty": "keine Ergebnisse gefunden",
"Filter-Key" : "Versuchen Sie es mit einem anderen Filter",
"Sub-Folder-Error": "Der Zielordner ist der Unterordner des Quellordners.",
"Same-Folder-Error": "Der Zielordner ist derselbe wie der Quellordner.",
"Access-Denied": "Zugriff verweigert",
"Access-Details": "Sie haben keine Berechtigung, auf diesen Ordner zuzugreifen.",
"Header-Retry": "Die Datei existiert bereits",
"Content-Retry": "In diesem Ordner ist bereits eine Datei mit diesem Namen vorhanden. Was möchten Sie tun?",
"Button-Keep-Both": "Behalte beides",
"Button-Replace": "Ersetzen",
"Button-Skip": "Überspringen",
"ApplyAll-Label": "Mache das für alle aktuellen Artikel",
"KB": "KB",
"Access-Message": "{0} ist nicht zugänglich. Sie benötigen die Berechtigung, um die Aktion {1} auszuführen.",
"Network-Error": "NetworkError: Fehler beim Senden auf XMLHTTPRequest: Fehler beim Laden",
"Server-Error": "ServerError: Ungültige Antwort von"
}
}
});
this.ajaxSettings = {
url: this.hostUrl + 'api/FileManager/FileOperations',
getImageUrl: this.hostUrl + 'api/FileManager/GetImage',
uploadUrl: this.hostUrl + 'api/FileManager/Upload',
downloadUrl: this.hostUrl + 'api/FileManager/Download'
};
this.locale = 'de';
}
}
@import 'node_modules/@syncfusion/ej2-base/styles/material.css';
@import 'node_modules/@syncfusion/ej2-inputs/styles/material.css';
@import 'node_modules/@syncfusion/ej2-popups/styles/material.css';
@import 'node_modules/@syncfusion/ej2-buttons/styles/material.css';
@import 'node_modules/@syncfusion/ej2-splitbuttons/styles/material.css';
@import 'node_modules/@syncfusion/ej2-navigations/styles/material.css';
@import 'node_modules/@syncfusion/ej2-layouts/styles/material.css';
@import 'node_modules/@syncfusion/ej2-grids/styles/material.css';
@import 'node_modules/@syncfusion/ej2-angular-base/styles/material.css';
@import 'node_modules/@syncfusion/ej2-angular-filemanager/styles/material.css';
@import 'node_modules/@syncfusion/ej2-angular-inputs/styles/material.css';
@import 'node_modules/@syncfusion/ej2-angular-popups/styles/material.css';
@import 'node_modules/@syncfusion/ej2-angular-buttons/styles/material.css';
@import 'node_modules/@syncfusion/ej2-angular-navigations/styles/material.css';
import { bootstrapApplication } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import 'zone.js';
bootstrapApplication(AppComponent).catch((err) => console.error(err));