Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(22)

Side by Side Diff: ios/web_view/internal/translate/cwv_translation_controller.mm

Issue 2839093002: Implemented new Translate API for purely Objective-C clients. (Closed)
Patch Set: addressed final comments Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #import "ios/web_view/public/cwv_translation_controller.h"
michaeldo 2017/05/01 18:25:37 nit: You can replace this import with _internal.h
jzw1 2017/05/08 03:36:27 Done.
6
7 #include <string>
8
9 #include "base/memory/ptr_util.h"
10 #include "base/strings/string16.h"
11 #include "components/translate/core/browser/translate_manager.h"
12 #include "components/translate/core/browser/translate_ui_delegate.h"
13 #import "ios/web_view/internal/translate/cwv_language_detection_result_internal. h"
14 #import "ios/web_view/internal/translate/cwv_translation_controller_internal.h"
15 #import "ios/web_view/internal/translate/cwv_translation_language_internal.h"
16 #import "ios/web_view/internal/translate/web_view_translate_client.h"
17
18 #if !defined(__has_feature) || !__has_feature(objc_arc)
19 #error "This file requires ARC support."
20 #endif
21
22 NSErrorDomain const CWVTranslationErrorDomain = @"com.cwv.translation.errors";
michaeldo 2017/05/01 18:25:37 It looks like Chrome uses Error domains of the sty
jzw1 2017/05/08 03:36:28 Sounds good.
23
24 const NSInteger CWVTranslationErrorNetwork =
25 translate::TranslateErrors::NETWORK;
26 const NSInteger CWVTranslationErrorInitializationError =
27 translate::TranslateErrors::INITIALIZATION_ERROR;
28 const NSInteger CWVTranslationErrorUnknownLanguage =
29 translate::TranslateErrors::UNKNOWN_LANGUAGE;
30 const NSInteger CWVTranslationErrorUnsupportedLanguage =
31 translate::TranslateErrors::UNSUPPORTED_LANGUAGE;
32 const NSInteger CWVTranslationErrorIdenticalLanguages =
33 translate::TranslateErrors::IDENTICAL_LANGUAGES;
34 const NSInteger CWVTranslationErrorTranslationError =
35 translate::TranslateErrors::TRANSLATION_ERROR;
36 const NSInteger CWVTranslationErrorTranslationTimeout =
37 translate::TranslateErrors::TRANSLATION_TIMEOUT;
38 const NSInteger CWVTranslationErrorUnexpectedScriptError =
39 translate::TranslateErrors::UNEXPECTED_SCRIPT_ERROR;
40 const NSInteger CWVTranslationErrorBadOrigin =
41 translate::TranslateErrors::BAD_ORIGIN;
42 const NSInteger CWVTranslationErrorScriptLoadError =
43 translate::TranslateErrors::SCRIPT_LOAD_ERROR;
44
45 @interface CWVTranslationController ()
46
47 // Convenience method to generate all supported languages from
48 // |translateUIDelegate|.
49 - (NSArray<CWVTranslationLanguage*>*)supportedLanguages;
50
51 // Convenience method to get a language at |index| from |translateUIDelegate|.
52 - (CWVTranslationLanguage*)languageAtIndex:(size_t)index;
53
54 @end
55
56 @implementation CWVTranslationController {
57 ios_web_view::WebViewTranslateClient* _translateClient;
58 std::unique_ptr<translate::TranslateUIDelegate> _translateUIDelegate;
59 }
60
61 @synthesize delegate = _delegate;
62 @synthesize webState = _webState;
63
64 #pragma mark - Internal Methods
65
66 - (void)setWebState:(web::WebState*)webState {
67 _webState = webState;
68
69 ios_web_view::WebViewTranslateClient::CreateForWebState(_webState);
70 _translateClient =
71 ios_web_view::WebViewTranslateClient::FromWebState(_webState);
72 _translateClient->set_translation_controller(self);
michaeldo 2017/05/01 18:25:37 Do we need to do any cleanup here if webState was
jzw1 2017/05/08 03:36:28 the webstate can be set again via CWVWebView#reset
michaeldo 2017/05/08 15:15:48 If the previous webState is still alive somewhere,
73 }
74
75 - (void)updateTranslateStep:(translate::TranslateStep)step
76 sourceLanguage:(const std::string&)sourceLanguage
77 targetLanguage:(const std::string&)targetLanguage
78 errorType:(translate::TranslateErrors::Type)errorType
79 triggeredFromMenu:(bool)triggeredFromMenu {
80 translate::TranslateManager* manager = _translateClient->translate_manager();
81 _translateUIDelegate = base::MakeUnique<translate::TranslateUIDelegate>(
82 manager->GetWeakPtr(), sourceLanguage, targetLanguage);
83
84 CWVTranslationLanguage* source =
85 [self languageAtIndex:_translateUIDelegate->GetOriginalLanguageIndex()];
86 CWVTranslationLanguage* target =
87 [self languageAtIndex:_translateUIDelegate->GetTargetLanguageIndex()];
88
89 NSError* error;
90 if (errorType != translate::TranslateErrors::NONE) {
91 error = [NSError errorWithDomain:CWVTranslationErrorDomain
92 code:errorType
93 userInfo:nil];
94 }
95
96 switch (step) {
97 case translate::TRANSLATE_STEP_BEFORE_TRANSLATE: {
98 CWVLanguageDetectionResult* languageDetectionResult =
99 [[CWVLanguageDetectionResult alloc]
100 initWithPageLanguage:source
101 suggestedTargetLanguage:target
102 supportedLanguages:[self supportedLanguages]];
103 if ([_delegate respondsToSelector:@selector
104 (translationController:didFinishLanguageDetectionWithResult
105 :error:)]) {
106 [_delegate translationController:self
107 didFinishLanguageDetectionWithResult:languageDetectionResult
108 error:error];
109 }
110 break;
111 }
112 case translate::TRANSLATE_STEP_TRANSLATING:
113 if ([_delegate respondsToSelector:@selector
114 (translationController:didStartTranslationFromLanguage
115 :toLanguage:)]) {
116 [_delegate translationController:self
117 didStartTranslationFromLanguage:source
118 toLanguage:target];
119 }
120 break;
121 case translate::TRANSLATE_STEP_AFTER_TRANSLATE:
122 if ([_delegate respondsToSelector:@selector
123 (translationController:didFinishTranslationFromLanguage
124 :toLanguage:error:)]) {
125 [_delegate translationController:self
126 didFinishTranslationFromLanguage:source
127 toLanguage:target
128 error:error];
129 }
130 break;
131 case translate::TRANSLATE_STEP_NEVER_TRANSLATE:
132 break;
133 case translate::TRANSLATE_STEP_TRANSLATE_ERROR:
134 break;
135 }
136 }
137
138 #pragma mark - Public Methodse
michaeldo 2017/05/01 18:25:37 s/Methodse/Methods
jzw1 2017/05/08 03:36:27 Done.
139
140 - (void)translatePageFromLanguage:(CWVTranslationLanguage*)sourceLanguage
141 toLanguage:(CWVTranslationLanguage*)targetLanguage {
142 _translateUIDelegate->Translate();
michaeldo 2017/05/01 18:25:37 It looks like these parameters are dropped. This w
jzw1 2017/05/08 03:36:28 Actually I just haven't used these yet. I'll add a
michaeldo 2017/05/08 15:15:48 Sounds good. Thank you.
143 }
144
145 - (void)revertTranslation {
146 _translateUIDelegate->RevertTranslation();
147 }
148
149 #pragma mark - Private Methods
150
151 - (NSArray<CWVTranslationLanguage*>*)supportedLanguages {
152 NSMutableArray* supportedLanguages = [NSMutableArray array];
153 for (size_t i = 0; i < _translateUIDelegate->GetNumberOfLanguages(); i++) {
154 CWVTranslationLanguage* language = [self languageAtIndex:i];
155 [supportedLanguages addObject:language];
156 }
157
158 return [supportedLanguages copy];
159 }
160
161 - (CWVTranslationLanguage*)languageAtIndex:(size_t)index {
162 std::string languageCode = _translateUIDelegate->GetLanguageCodeAt(index);
163 base::string16 languageName = _translateUIDelegate->GetLanguageNameAt(index);
164 return [[CWVTranslationLanguage alloc] initWithLanguageCode:languageCode
165 languageName:languageName];
166 }
167
168 @end
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698