Skip to content

Commit

Permalink
chore(docs): Portuguese documentation translation (react-native-webvi…
Browse files Browse the repository at this point in the history
  • Loading branch information
renesoaresse authored Jan 29, 2022
1 parent 4e987ff commit 97da548
Show file tree
Hide file tree
Showing 14 changed files with 3,022 additions and 1 deletion.
6 changes: 6 additions & 0 deletions docs/Contributing.md
Original file line number Diff line number Diff line change
Expand Up @@ -92,3 +92,9 @@ $ yarn add ../react-native-webview && react-native link react-native-webview

- We use TypeScript.
- After pulling this repo and installing all dependencies, you can run tests using the command: `yarn ci`

## Translations

This file is available at:

- [Brazilian portuguese](Contributing.portuguese.md)
99 changes: 99 additions & 0 deletions docs/Contributing.portuguese.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
# Contribuindo com o React Native WebView

Primeiramente, _obrigado_ por considerar contribuir para a Comunidade do React Native. Os pacotes mantidos pela comunidade só são possíveis por causa de pessoas incríveis como você.

Em segundo lugar, gostaríamos que a experiência de contribuição fosse a melhor possível. Embora sejamos uma pequena equipe de voluntários, ficamos felizes em receber comentários sobre suas experiências e se pudermos melhorar os documentos ou a experiência, informe-nos.

## Como testar as alterações

Após fazer um fork do repositório, cloná-lo em sua máquina e fazer suas alterações, você deverar testá-las em uma aplicação.

Existem dois métodos de teste:
1) Rodando os testes do react-native-webview
2) Testando em um projeto `react-native init`

### Rodando os testes dentro do react-native-webview

#### Para todas as plataformas:
```
$ yarn install
```

#### Para Android:
```
$ yarn start:android
```

O aplicativo de exemplo do Android será compilado, o Metro Bundler será iniciado e o aplicativo de exemplo será instalado e iniciado no emulador do Android.

#### Para iOS:
```
$ cd example/ios
$ pod install
$ cd ../..
$ yarn start:ios
```

O aplicativo de exemplo para iOS será compilado, o empacotador Metro será iniciado e o aplicativo de exemplo será instalado e iniciado no Simulador.

#### para macOS:
```
$ open example/macos/example.xcodeproj
$ yarn start:macos
```
O Metro Bundler agora estará rodando no Terminal para react-native-macos. No XCode selecione o alvo `example-macos` e execute.

#### para Windows:
```
$ yarn start:windows
$ open example/windows/WebViewWindows.sln and click run button.
```

O Metro Bundler agora estará em execução no Terminal para react-native-windows e o aplicativo de exemplo será instalado e iniciado.

### Testando em um novo projeto `react-native init`

Em um novo projeto `react-native init`, faça o seguinte:

```
$ yarn add ../react-native-webview
$ react-native link react-native-webview
```

Você pode encontrar um problema em que o mapa do módulo `jest-haste-map` diz que react-native foi adicionado duas vezes:

```
Loading dependency graph...(node:32651) UnhandledPromiseRejectionWarning: Error: jest-haste-map: Haste module naming collision:
Duplicate module name: react-native
Paths: /Users/myuser/TestApp/node_modules/react-native/package.json collides with /Users/myuser/TestApp/node_modules/react-native-webview/node_modules/react-native/package.json
```

Basta remover seguindo o caminho abaixo:

```
$ rm -rf ./node_modules/react-native-webview/node_modules/react-native
```

E, em seguida, execute novamente o comando:

```
$ react-native start --reset-cache
```

Ao fazer uma alteração, você provavelmente precisará desvincular, remover, adicionar novamente e vincular novamente o `react-native-webview`:

```
$ react-native unlink react-native-webview && yarn remove react-native-webview
$ yarn add ../react-native-webview && react-native link react-native-webview
```

## Notas

- Usamos TypeScript.
- Depois de puxar este repositório e instalar todas as dependências, você pode executar testes usando o comando: `yarn ci`

## Traduções

Esse arquivo está disponível em:

- [Inglês](Contributing.md)
5 changes: 5 additions & 0 deletions docs/Custom-Android.md
Original file line number Diff line number Diff line change
Expand Up @@ -215,3 +215,8 @@ export default class CustomWebView extends Component {
}
}
```
## Translations

This file is available at:

- [Brazilian portuguese](Custom-Android.portuguese.md)
223 changes: 223 additions & 0 deletions docs/Custom-Android.portuguese.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,223 @@
Embora a visualização da Web integrada tenha muitos recursos, não é possível lidar com todos os casos de uso no React Native. Você pode, no entanto, estender a visualização da web com código nativo sem bifurcar o React Native ou duplicar todo o código de visualização da web existente.

Antes de fazer isso, você deve estar familiarizado com os conceitos de [componentes de interface do usuário nativos](https://reactnative.dev/docs/native-components-android). Você também deve se familiarizar com o [código nativo para visualizações da web](https://github.com/react-native-webview/react-native-webview/blob/master/android/src/main/java/com/reactnativecommunity/webview/RNCWebViewManager.java), pois você terá que usar isso como referência ao implementar novos recursos, embora não seja necessária uma compreensão profunda.

## Código Nativo

Para começar, você precisará criar uma subclasse de `RNCWebViewManager`, `RNCWebView` e `RNCWebViewClient`. Em seu gerenciador de visualizações, você precisará substituir:

- `createReactWebViewInstance`
- `getName`
- `addEventEmitters`

```java
@ReactModule(name = CustomWebViewManager.REACT_CLASS)
public class CustomWebViewManager extends RNCWebViewManager {
/* Este nome deve corresponder ao que estamos nos referindo em JS */
protected static final String REACT_CLASS = "RCTCustomWebView";

protected static class CustomWebViewClient extends RNCWebViewClient { }

protected static class CustomWebView extends RNCWebView {
public CustomWebView(ThemedReactContext reactContext) {
super(reactContext);
}
}

@Override
protected RNCWebView createRNCWebViewInstance(ThemedReactContext reactContext) {
return new CustomWebView(reactContext);
}

@Override
public String getName() {
return REACT_CLASS;
}

@Override
protected void addEventEmitters(ThemedReactContext reactContext, WebView view) {
view.setWebViewClient(new CustomWebViewClient());
}
}
```

Você precisará seguir as etapas usuais para [registrar o módulo](native-modules-android.md#register-the-module).

### Adicionando novas propriedades

Para adicionar uma nova propriedade, você precisará adicioná-la a `CustomWebView` e depois expô-la em `CustomWebViewManager`.

```java
public class CustomWebViewManager extends RNCWebViewManager {
...

protected static class CustomWebView extends RNCWebView {
public CustomWebView(ThemedReactContext reactContext) {
super(reactContext);
}

protected @Nullable String mFinalUrl;

public void setFinalUrl(String url) {
mFinalUrl = url;
}

public String getFinalUrl() {
return mFinalUrl;
}
}

...

@ReactProp(name = "finalUrl")
public void setFinalUrl(WebView view, String url) {
((CustomWebView) view).setFinalUrl(url);
}
}
```

### Adicionando novos eventos

Para eventos, primeiro você precisará criar uma subclasse de evento.

```java
// NavigationCompletedEvent.java
public class NavigationCompletedEvent extends Event<NavigationCompletedEvent> {
private WritableMap mParams;

public NavigationCompletedEvent(int viewTag, WritableMap params) {
super(viewTag);
this.mParams = params;
}

@Override
public String getEventName() {
return "navigationCompleted";
}

@Override
public void dispatch(RCTEventEmitter rctEventEmitter) {
init(getViewTag());
rctEventEmitter.receiveEvent(getViewTag(), getEventName(), mParams);
}
}
```

Você pode acionar o evento em seu cliente de visualização da web. Você pode conectar manipuladores existentes se seus eventos forem baseados neles.

Você deve consultar [RNCWebViewManager.java](https://github.com/react-native-webview/react-native-webview/blob/master/android/src/main/java/com/reactnativecommunity/webview/RNCWebViewManager.java) na base de código react-native-webview para ver quais manipuladores estão disponíveis e como eles são implementados. Você pode estender quaisquer métodos aqui para fornecer funcionalidade extra.

```java
public class NavigationCompletedEvent extends Event<NavigationCompletedEvent> {
private WritableMap mParams;

public NavigationCompletedEvent(int viewTag, WritableMap params) {
super(viewTag);
this.mParams = params;
}

@Override
public String getEventName() {
return "navigationCompleted";
}

@Override
public void dispatch(RCTEventEmitter rctEventEmitter) {
init(getViewTag());
rctEventEmitter.receiveEvent(getViewTag(), getEventName(), mParams);
}
}

// CustomWebViewManager.java
protected static class CustomWebViewClient extends RNCWebViewClient {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
boolean shouldOverride = super.shouldOverrideUrlLoading(view, url);
String finalUrl = ((CustomWebView) view).getFinalUrl();

if (!shouldOverride && url != null && finalUrl != null && new String(url).equals(finalUrl)) {
final WritableMap params = Arguments.createMap();
dispatchEvent(view, new NavigationCompletedEvent(view.getId(), params));
}

return shouldOverride;
}
}
```

Finalmente, você precisará expor os eventos em `CustomWebViewManager` através de `getExportedCustomDirectEventTypeConstants`. Observe que atualmente, a implementação padrão retorna `null`, mas isso pode mudar no futuro.

```java
public class CustomWebViewManager extends RNCWebViewManager {
...

@Override
public @Nullable
Map getExportedCustomDirectEventTypeConstants() {
Map<String, Object> export = super.getExportedCustomDirectEventTypeConstants();
if (export == null) {
export = MapBuilder.newHashMap();
}
export.put("navigationCompleted", MapBuilder.of("registrationName", "onNavigationCompleted"));
return export;
}
}
```

## Interface JavaScript

Para usar sua visualização da Web personalizada, você pode criar uma classe para ela. Sua classe deve retornar um componente `WebView` com o prop `nativeConfig.component` definido para seu componente nativo (veja abaixo).

Para obter seu componente nativo, você deve usar `requireNativeComponent`: o mesmo que para componentes personalizados regulares.

```javascript
import React, { Component } from 'react';
import { requireNativeComponent } from 'react-native';
import { WebView } from 'react-native-webview';

export default class CustomWebView extends Component {
render() {
return (
<WebView {...this.props} nativeConfig={{ component: RCTCustomWebView }} />
);
}
}

const RCTCustomWebView = requireNativeComponent('RCTCustomWebView');
```

Se você quiser adicionar props customizadas ao seu componente nativo, você pode usar `nativeConfig.props` na visualização da web.

Para eventos, o manipulador de eventos deve sempre ser definido para uma função. Isso significa que não é seguro usar o manipulador de eventos diretamente de `this.props`, pois o usuário pode não ter fornecido um. A abordagem padrão é criar um manipulador de eventos em sua classe e, em seguida, invocar o manipulador de eventos fornecido em `this.props` se ele existir.

Se você não tiver certeza de como algo deve ser implementado do lado do JS, consulte [WebView.android.tsx](https://github.com/react-native-webview/react-native-webview/blob/master/src/WebView.android.tsx) na fonte React Native WebView.

```javascript
export default class CustomWebView extends Component {
_onNavigationCompleted = (event) => {
const { onNavigationCompleted } = this.props;
onNavigationCompleted && onNavigationCompleted(event);
};

render() {
return (
<WebView
{...this.props}
nativeConfig={{
component: RCTCustomWebView,
props: {
finalUrl: this.props.finalUrl,
onNavigationCompleted: this._onNavigationCompleted,
},
}}
/>
);
}
}
```

## Traduções

Esse arquivo está disponível em:

- [Inglês](Custom-Android.md)
5 changes: 5 additions & 0 deletions docs/Custom-iOS.md
Original file line number Diff line number Diff line change
Expand Up @@ -229,3 +229,8 @@ export default class CustomWebView extends Component {
}
}
```
## Translations

This file is available at:

- [Brazilian portuguese](Custom-iOS.portuguese.md)
Loading

0 comments on commit 97da548

Please sign in to comment.