LoginViewController.m 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473
  1. //
  2. // LoginViewController.m
  3. // RedAnt ERP Mobile
  4. //
  5. // Created by Ray on 14-6-20.
  6. // Copyright (c) 2014年 United Software Applications, Inc. All rights reserved.
  7. //
  8. #import "LoginViewController.h"
  9. #import "RAUtils.h"
  10. #import "RANetwork.h"
  11. #import "AppDelegate.h"
  12. //#import "RetrievePassViewController.h"
  13. //#import "UILabel+FontAppearance.h"
  14. //#import "OLDataProvider.h"
  15. //#import "NotificationNameCenter.h"
  16. //#import "OfflineSettingViewController.h"
  17. //#import "MainViewController.h"
  18. //#import "WebViewController.h"
  19. @interface LoginViewController ()
  20. @property (strong, nonatomic) IBOutlet UIButton *requestLoginBtn;
  21. @end
  22. @implementation LoginViewController
  23. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
  24. {
  25. self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
  26. if (self) {
  27. // Custom initialization
  28. }
  29. return self;
  30. }
  31. - (void)searchAutocompleteEntriesWithSubstring:(NSString *)substring {
  32. // Put anything that starts with this substring into the autocompleteUrls array
  33. // 过滤,剩下符合输入文字的候选
  34. [self.filterlogindata removeAllObjects];
  35. for(NSString *curString in self.logindata) {
  36. NSRange substringRange = [curString rangeOfString:substring];
  37. if (substringRange.location == 0) {
  38. [self.filterlogindata addObject:curString];
  39. }
  40. }
  41. if(self.filterlogindata.count==0)
  42. {
  43. self.Loginlist.hidden=true;
  44. self.showList = false;
  45. }
  46. [self.Loginlist reloadData];
  47. }
  48. - (void)viewDidLoad
  49. {
  50. [super viewDidLoad];
  51. self.title=@"Sign in";//@"Granite Expo";
  52. self.showList = false;
  53. self.bb_close.image=[[UIImage imageNamed:@"close"] imageWithRenderingMode:UIImageRenderingModeAutomatic];
  54. [self.checkSavePassword setImage:[UIImage imageNamed:@"checkbox"] forState:UIControlStateNormal];
  55. [self.checkSavePassword setImage:[UIImage imageNamed:@"checkbox_check"] forState:UIControlStateSelected];
  56. self.filterlogindata = [NSMutableArray new];
  57. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  58. NSString * user = [AESCrypt decrypt:[defaults stringForKey:@"user"] password:@"usai"];
  59. NSString * password = [AESCrypt decrypt:[defaults stringForKey:@"password"] password:@"usai"];
  60. if(user.length>0&&password.length>0)
  61. {
  62. self.edituser.text=user;
  63. self.editpass.text=password;
  64. self.checkSavePassword.selected=true;
  65. }
  66. // NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  67. // [defaults removeObjectForKey:@"EnableOfflineMode"];
  68. // [defaults setBool:self.checkOfflineMode.selected forKey:@"EnableOfflineMode"];
  69. [self.checkSavePassword addTarget:self action:@selector(checkboxClick:) forControlEvents:UIControlEventTouchUpInside];
  70. // self.checkOfflineMode.tag=999;
  71. // self.logindata = [iSalesDB get_saveduser];
  72. self.logindata = [[defaults arrayForKey:@"login_data"] mutableCopy];
  73. if(self.logindata==nil)
  74. self.logindata = [NSMutableArray new];
  75. // UIButton* combobutton=[[UIButton alloc] initWithFrame:CGRectMake(0, 0, 24, 24)];
  76. // [combobutton setBackgroundImage:[UIImage imageNamed:@"combo_24"] forState:UIControlStateNormal];
  77. // [combobutton addTarget:self action:@selector(LoginList:) forControlEvents:UIControlEventTouchUpInside];
  78. //
  79. // self.edituser.rightView = combobutton;
  80. // self.edituser.rightViewMode=UITextFieldViewModeAlways;
  81. //
  82. self.Loginlist.layer.borderColor = [UIColor lightGrayColor].CGColor;
  83. self.Loginlist.layer.borderWidth = 1.0;
  84. // self.Loginlist.layer.cornerRadius=15;
  85. self.Loginlist.layer.masksToBounds=true;
  86. // Do any additional setup after loading the view.
  87. }
  88. - (void)LoginList:(UIButton *)sender {
  89. [self.edituser endEditing:true];
  90. self.showList= !self.showList;
  91. self.Loginlist.hidden = !self.showList;
  92. // showList;
  93. }
  94. -(void)checkboxClick:(UIButton *)btn
  95. {
  96. btn.selected = !btn.selected;
  97. {
  98. if(!btn.selected)
  99. {
  100. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  101. [defaults removeObjectForKey:@"user"];
  102. [defaults removeObjectForKey:@"password"];
  103. [defaults synchronize];
  104. // NSString* encryptu=[AESCrypt encrypt:self.edituser.text password:@"usai"];
  105. // NSString* sql=[NSString stringWithFormat:@"delete from login_info where name='%@'",encryptu];
  106. // [iSalesDB execSql:sql];
  107. // self.logindata = [iSalesDB get_saveduser];
  108. // [self.Loginlist reloadData];
  109. }
  110. }
  111. }
  112. - (IBAction)CloseClick:(id)sender {
  113. [self dismissViewControllerAnimated:true completion:nil];
  114. if(self.returnValue)
  115. self.returnValue(false);
  116. }
  117. - (IBAction)onRetrievePassword:(id)sender {
  118. // RetrievePassViewController* vc = [self.storyboard instantiateViewControllerWithIdentifier:@"RetrievePassViewController" ];
  119. // // dvc
  120. // // UINavigationController* nv = self.navigationController;
  121. //
  122. // [self.navigationController pushViewController:vc animated:true];
  123. }
  124. - (IBAction)onLoginClick:(UIButton *)sender {
  125. NSString* user = self.edituser.text;
  126. NSString* password = self.editpass.text;
  127. // NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  128. //
  129. // bool forcedownload = [defaults boolForKey:@"Forcedownload"];
  130. // if(forcedownload && self.checkOfflineMode.selected)
  131. // {
  132. // self.checkOfflineMode.selected = !self.checkOfflineMode.selected;
  133. //
  134. // [RAUtils alert_view:@"Detected incomplete sync, please finish sync first." title:@"Incomplete sync"];
  135. // return;
  136. // }
  137. if(user.length==0||password.length==0)
  138. {
  139. // UIAlertView * alert = [[UIAlertView alloc] initWithTitle: @"Error!" message:@"user or password can not be empty." delegate:nil cancelButtonTitle:NSLocalizedString(@"ok", nil) otherButtonTitles:nil, nil];
  140. // // UIAlertView *alert=[[UIAlertView alloc]initWithTitle:@"Error!" message:@"User&Password can not be empty!" delegate:nil cancelButtonTitle:NSLocalizedString(@"ok", nil) , nil];
  141. //
  142. //
  143. // //[[UILabel appearanceWhenContainedIn:UIAlertView.class, nil] setAppearanceFont:[UIFont boldSystemFontOfSize:10]];
  144. // [alert show];
  145. // [RAUtils alert_view:@"Username or Password cannot be blank." title:@"Cannot sign-in"];
  146. // [RAUtils message_alert:@"Username or Password cannot be blank." title:@"Cannot sign-in" controller:self];
  147. [RAUtils message_box:@"Sign in" message:@"Username or Password cannot be blank." completion:nil];
  148. return;
  149. }
  150. DebugLog(@"Login... user= %@ ; password= %@",user,password);
  151. self.btnLogin.enabled = false;
  152. // __block UIAlertController * waitalert = [RAUtils waiting_alert:self title:@"Sign in" completion:^{
  153. PopWaitAlert* pop =[RAUtils waiting_pop:@"Sign in" completion:nil];
  154. [RANetwork request_login:user password:password completionHandler:^(NSMutableDictionary *result) {
  155. [pop hide];
  156. // int ret=[RANetwork Authorize:user password:password];
  157. int ret=[result[@"result"] intValue];
  158. self.btnLogin.enabled = true;
  159. if(ret==RESULT_TRUE)
  160. {
  161. //
  162. // NSString* contactid=[self.content_data[indexPath.row] valueForKey:@"contact_id"] ;
  163. // AppDelegate *appDelegate = (AppDelegate*)[[UIApplication sharedApplication] delegate];
  164. // appDelegate.contact_id=contactid;
  165. // appDelegate.contact_name =[self.content_data[indexPath.row] valueForKey:@"name"];
  166. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  167. [defaults removeObjectForKey:@"user"];
  168. [defaults removeObjectForKey:@"password"];
  169. NSString* encryptu=[AESCrypt encrypt:RASingleton.sharedInstance.user password:@"usai"];
  170. NSString* encryptp=[AESCrypt encrypt:self.editpass.text password:@"usai"] ;
  171. // long index =[self.logindata indexOfObject:appDelegate.user];
  172. if(![self.logindata containsObject:RASingleton.sharedInstance.user])
  173. {
  174. [self.logindata addObject:RASingleton.sharedInstance.user];
  175. NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:nil ascending:YES];
  176. self.logindata = [[self.logindata sortedArrayUsingDescriptors:[NSArray arrayWithObjects:sortDescriptor,nil]] mutableCopy];
  177. }
  178. [defaults setObject:self.logindata forKey:@"login_data"];
  179. if(self.checkSavePassword.selected)
  180. {
  181. [defaults setValue:encryptu forKey:@"user"];
  182. [defaults setValue:encryptp forKey:@"password"];
  183. }
  184. [defaults synchronize];
  185. [self dismissViewControllerAnimated:YES completion:^{
  186. {
  187. if(self.returnValue)
  188. self.returnValue(true);
  189. }
  190. }];
  191. }
  192. else
  193. {
  194. NSString* msg=nil;
  195. switch (ret) {
  196. case RESULT_NET_NOTAVAILABLE:
  197. msg = MSG_NET_NOTAVAILABLE;
  198. break;
  199. case RESULT_NET_ERROR:
  200. msg = MSG_NET_ERROR;
  201. break;
  202. case RESULT_FALSE:
  203. msg = MSG_USERAUTH_ERROR;
  204. break;
  205. case RESULT_VER_LOW:
  206. msg = MSG_VER_LOW;
  207. break;
  208. case RESULT_LOGIN_DEVICE:
  209. msg= MSG_LOGIN_DEVICE;
  210. break;
  211. default:
  212. break;
  213. }
  214. // [RAUtils alert_view:msg title:@"Cannot sign-in"];
  215. // [RAUtils message_alert:msg title:@"Cannot sign-in" controller:self];
  216. [RAUtils message_box:@"Cannot sign-in" message:msg completion:nil];
  217. }
  218. }];
  219. // dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
  220. //
  221. //
  222. //
  223. //
  224. // dispatch_async(dispatch_get_main_queue(), ^{
  225. //// [waitalert dismissWithClickedButtonIndex:0 animated:FALSE];
  226. //// [waitalert dismissViewControllerAnimated:YES completion:^{
  227. //
  228. //
  229. //
  230. //
  231. //
  232. //
  233. //
  234. //
  235. //
  236. //// }];
  237. //
  238. //
  239. //
  240. //
  241. // });
  242. // });
  243. // }];
  244. }
  245. - (void)didReceiveMemoryWarning
  246. {
  247. [super didReceiveMemoryWarning];
  248. // Dispose of any resources that can be recreated.
  249. }
  250. #pragma mark - Table view data source
  251. - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath;
  252. {
  253. return 44;
  254. }
  255. - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
  256. {
  257. return 1;
  258. }
  259. - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
  260. {
  261. return self.filterlogindata.count;
  262. }
  263. - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
  264. {
  265. // NSMutableDictionary* up = self.logindata[indexPath.row];
  266. NSString *CellIdentifier = @"LoginListCell";
  267. UITableViewCell * cell= [tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];
  268. NSString* name=self.filterlogindata[indexPath.row];//up[@"name"];
  269. cell.textLabel.text = name;
  270. return cell;
  271. }
  272. - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
  273. {
  274. NSString* name=self.filterlogindata[indexPath.row];
  275. // NSMutableDictionary* up = self.logindata[indexPath.row];
  276. self.edituser.text = name;//up[@"name"];
  277. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  278. NSString * user = [AESCrypt decrypt:[defaults stringForKey:@"user"] password:@"usai"];
  279. if([user isEqualToString:name])
  280. {
  281. NSString * password = [AESCrypt decrypt:[defaults stringForKey:@"password"] password:@"usai"];
  282. self.editpass.text = password;
  283. }
  284. else
  285. {
  286. self.editpass.text=nil;
  287. }
  288. self.showList=false;
  289. self.Loginlist.hidden=true;
  290. self.checkSavePassword.selected=true;
  291. }
  292. #pragma mark UITextFieldDelegate methods
  293. //当用户增,删字符的时候,都会调用此方法<br>//
  294. - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {
  295. self.Loginlist.hidden = NO;
  296. NSString *substring = [NSString stringWithString:textField.text];
  297. substring = [substring stringByReplacingCharactersInRange:range withString:string];
  298. [self searchAutocompleteEntriesWithSubstring:substring];
  299. return YES;
  300. }
  301. - (BOOL)textFieldShouldBeginEditing:(UITextField *)textField
  302. {
  303. return true;
  304. }
  305. - (void)textFieldDidBeginEditing:(UITextField *)textField
  306. {
  307. // self.showList=false;
  308. // self.Loginlist.hidden=true;
  309. }
  310. - (void)textFieldDidEndEditing:(UITextField *)textField
  311. {
  312. self.showList=false;
  313. self.Loginlist.hidden=true;
  314. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  315. NSString * user = [AESCrypt decrypt:[defaults stringForKey:@"user"] password:@"usai"];
  316. if([user isEqualToString:self.edituser.text])
  317. {
  318. NSString * password = [AESCrypt decrypt:[defaults stringForKey:@"password"] password:@"usai"];
  319. self.editpass.text = password;
  320. }
  321. else
  322. {
  323. self.editpass.text = nil;
  324. }
  325. }
  326. #pragma mark - action
  327. //- (IBAction)requestLoginBtnClicked:(UIButton *)sender {
  328. //
  329. // WebViewController *webVC = [self.storyboard instantiateViewControllerWithIdentifier:@"WebViewController"];
  330. // webVC.url = URL_REQUEST_LOGIN;
  331. // webVC.title = @"Request Login";
  332. // webVC.backItemDismiss = YES;
  333. //
  334. //
  335. // UINavigationController *nav = [[UINavigationController alloc] initWithRootViewController:webVC];
  336. // nav.modalPresentationStyle = UIModalPresentationFormSheet;
  337. //
  338. // [self presentViewController:nav animated:YES completion:nil];
  339. //
  340. //}
  341. @end