-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathandroid-gslocalization.py
executable file
·58 lines (45 loc) · 2.57 KB
/
android-gslocalization.py
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
import argparse
from sys import exit
from models.android_xml_file import import_from_res_folder
from utils.utils import pwt, get_input
from cloud_managers.google_sheets_manager import GoogleSheetsManager
def parse_args():
ap = argparse.ArgumentParser()
ap.add_argument('-p', '--project_name', required=True, help='name of the android project (used in the spreadsheet name', metavar='\b')
ap.add_argument('-r', '--res_folder_path', required=True, help='path to the \'res\' directory', metavar='\b')
ap.add_argument('-a', '--auth_file_path', required=True, help='path to the Google Sheets authorization JSON file', metavar='\b')
ap.add_argument('-e', '--email', required=True, help='email used for sharing newly created worksheets', metavar='\b')
ap.add_argument('-l', '--dev_language', required=False, default='en', help='development language code (default=en)', metavar='\b')
return vars(ap.parse_args())
if __name__ == "__main__":
args = parse_args()
op_values = ['1', '2', '3']
op_type = get_input('Enter operation type [1=export, 2=import, 3=export&import]: ')
if op_type not in op_values:
pwt('INVALID OPERATION')
exit(1)
res_folder_path = args['res_folder_path']
service_account_file = args['auth_file_path']
user_email = args['email']
development_language = args['dev_language']
project_name = args['project_name']
google_sheets_manager = GoogleSheetsManager(service_account_file, user_email, project_name)
android_files = import_from_res_folder(res_folder_path, development_language)
development_language_file = next((f for f in android_files if f.target_language_code == development_language), None)
if development_language_file is None:
pwt('NO STRINGS.XML FILES FOUND IN {}'.format(res_folder_path), color='r')
exit(1)
if op_type == '1':
for l_file in android_files:
l_file.upload_to_google_sheets(gsheets_manager=google_sheets_manager)
elif op_type == '2':
for l_file in android_files:
l_file.update_from_google_sheets(gsheets_manager=google_sheets_manager,
dev_language_file=development_language_file)
l_file.update_source_xml()
elif op_type == '3':
for l_file in android_files:
l_file.upload_to_google_sheets(gsheets_manager=google_sheets_manager)
l_file.update_from_google_sheets(gsheets_manager=google_sheets_manager,
dev_language_file=development_language_file)
l_file.update_source_xml()