EnumSelectViewController.m 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628
  1. //
  2. // CommonEditorEnumViewController.m
  3. // RedAnt ERP Mobile
  4. //
  5. // Created by Ray on 14-7-18.
  6. // Copyright (c) 2014年 United Software Applications, Inc. All rights reserved.
  7. //
  8. #import "EnumSelectViewController.h"
  9. #import "EnumSelectorCell.h"
  10. #import "RAUtils.h"
  11. #import "AppDelegate.h"
  12. #define DEF_CELL_HEIGHT 44
  13. //#define DEF_TABLE_HEIGHT 44
  14. //#define LINE_WIDTH 0
  15. //#define CELL_MARGIN 0
  16. #define LABEL_MARGIN 15
  17. @interface EnumSelectViewController ()
  18. @end
  19. @implementation EnumSelectViewController
  20. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
  21. {
  22. self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
  23. if (self) {
  24. // Custom initialization
  25. }
  26. return self;
  27. }
  28. - (void)viewDidLoad
  29. {
  30. [super viewDidLoad];
  31. // self.max_select = 0;
  32. self.navi_item.title = self.title;
  33. // self.navigationItem.title = self.title;
  34. // Do any additional setup after loading the view.
  35. self.auto_close = true;
  36. if(self.is_dialog)
  37. {
  38. UIBarButtonItem *closeButton = [[UIBarButtonItem alloc] initWithImage:[[UIImage imageNamed:@"close"] imageWithRenderingMode:UIImageRenderingModeAutomatic]
  39. style:UIBarButtonItemStylePlain
  40. target:self
  41. action:@selector( onCloseClick:)];
  42. // [[UIBarButtonItem alloc] initWithTitle:NSLocalizedString(@"Close", nil) style:UIBarButtonItemStylePlain target:self action:@selector(onCloseClick:)];
  43. self.navi_item.rightBarButtonItem = closeButton;
  44. }
  45. else
  46. {
  47. UIBarButtonItem *backButton = [[UIBarButtonItem alloc] initWithImage:[[UIImage imageNamed:@"back"] imageWithRenderingMode:UIImageRenderingModeAutomatic]
  48. style:UIBarButtonItemStylePlain
  49. target:self
  50. action:@selector( onBackClick:)];
  51. // [[UIBarButtonItem alloc] initWithTitle:NSLocalizedString(@"Back", nil) style:UIBarButtonItemStylePlain target:self action:@selector(onBackClick:)];
  52. self.navigationItem.leftBarButtonItem = backButton;
  53. }
  54. self.dirty = false;
  55. UILabel* titleLabel= [[UILabel alloc] initWithFrame:CGRectMake(100, 0, 200
  56. , 44)];
  57. titleLabel.text=self.title;
  58. // titleLabel.backgroundColor =[UIColor yellowColor];
  59. titleLabel.textAlignment=NSTextAlignmentCenter;
  60. //将搜索条放在一个UIView上
  61. UIView *searchView = [[UIView alloc]initWithFrame:CGRectMake(0, 0, 1768, 44)];
  62. searchView.autoresizingMask=UIViewAutoresizingFlexibleLeftMargin|UIViewAutoresizingFlexibleRightMargin|UIViewAutoresizingFlexibleTopMargin|UIViewAutoresizingFlexibleBottomMargin|UIViewAutoresizingFlexibleWidth;
  63. titleLabel.autoresizingMask=UIViewAutoresizingFlexibleLeftMargin|UIViewAutoresizingFlexibleRightMargin;
  64. titleLabel.center=searchView.center;
  65. UISearchBar *searchBar = [[UISearchBar alloc]initWithFrame:CGRectMake(searchView.frame.size.width-200.0f-8.0f,0.0f,200.0f,44.0f)];
  66. searchBar.autoresizingMask=UIViewAutoresizingFlexibleLeftMargin|UIViewAutoresizingFlexibleRightMargin;
  67. searchBar.delegate = self;
  68. [searchBar setPlaceholder:@"filter"];
  69. //searchBar.barTintColor=[UIColor clearColor];
  70. searchBar.searchBarStyle=UISearchBarStyleMinimal;
  71. [searchView addSubview:titleLabel];
  72. [searchView addSubview:searchBar];
  73. self.navigationItem.titleView = searchView;
  74. [[self navigationController] setNavigationBarHidden:self.hide_navibar animated:NO];
  75. }
  76. - (void)onBackClick:(UIButton *)sender {
  77. [self.navigationController popViewControllerAnimated:(false)];
  78. // [self.navigationController dismissViewControllerAnimated:true completion:^{
  79. // ;
  80. // }];
  81. }
  82. - (void)onCloseClick:(UIButton *)sender {
  83. [self dismissViewControllerAnimated:YES
  84. completion:^{
  85. }];
  86. }
  87. - (void)viewWillDisappear:(BOOL)animated
  88. {
  89. [super viewWillDisappear:animated];
  90. if(self.dirty == false)
  91. return;
  92. if (self.delegate && [self.delegate respondsToSelector:@selector(EnumValueChanged:indexPath:)]) {
  93. [self.delegate EnumValueChanged:self.cadedate indexPath:self.updatePosition];
  94. }
  95. if(self.returnValue)
  96. self.returnValue(self.cadedate);
  97. }
  98. - (void)didReceiveMemoryWarning
  99. {
  100. [super didReceiveMemoryWarning];
  101. // Dispose of any resources that can be recreated.
  102. }
  103. -(void)didRotateFromInterfaceOrientation:(UIInterfaceOrientation)fromInterfaceOrientation
  104. {
  105. [self.tableEnum reloadData];
  106. UIApplication * app = [UIApplication sharedApplication];
  107. AppDelegate *appDelegate = (AppDelegate *)[app delegate];
  108. [appDelegate didRotated];
  109. }
  110. #pragma mark - Table view data source
  111. - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
  112. {
  113. return 1;
  114. }
  115. - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
  116. {
  117. // if(self.canbeEmpty)
  118. // return [[self.cadedate valueForKey:@"count"] intValue]+1;
  119. // else
  120. if(self.keywords==nil || self.keywords.length==0)
  121. {
  122. self.filter_count = 0;
  123. return [[self.cadedate valueForKey:@"count"] intValue];
  124. }
  125. else
  126. {
  127. int count = 0;
  128. for (int i=0; i<[[self.cadedate valueForKey:@"count"] intValue]; i++)
  129. {
  130. NSDictionary* val_json = [self.cadedate objectForKey:[NSString stringWithFormat:@"val_%d",i ]];
  131. NSString* value = [val_json valueForKey:@"value"];
  132. NSUInteger location=[[value uppercaseString] rangeOfString:self.keywords].location;
  133. if(location!= NSNotFound)
  134. count++;
  135. }
  136. self.filter_count = count;
  137. return count;
  138. }
  139. }
  140. - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath;
  141. {
  142. NSDictionary* val_json =nil;
  143. if(self.keywords==nil || self.keywords.length==0)
  144. {
  145. val_json=[self.cadedate objectForKey:[NSString stringWithFormat:@"val_%ld",(long)indexPath.row ]];
  146. }
  147. else
  148. {
  149. int count = 0;
  150. for (int i=0; i<[[self.cadedate valueForKey:@"count"] intValue]; i++)
  151. {
  152. if(count>= self.filter_count)
  153. break;
  154. NSDictionary* search_json = [self.cadedate objectForKey:[NSString stringWithFormat:@"val_%d",i ]];
  155. NSString* value = [search_json valueForKey:@"value"];
  156. NSUInteger location=[[value uppercaseString] rangeOfString:self.keywords].location;
  157. if(location!= NSNotFound)
  158. count++;
  159. if(count-1==indexPath.row)
  160. val_json=search_json;
  161. }
  162. }
  163. NSString* value = [val_json valueForKey:@"value"];
  164. float width = tableView.frame.size.width;
  165. width-=40;
  166. CGSize constraintkey = CGSizeMake(width-2*LABEL_MARGIN, 10.0f);//key label width is 40% cell width;
  167. // CGSize constraintval = CGSizeMake(width*0.6-2*LABEL_MARGIN, 20000.0f);//val label width is 60% cell width;
  168. // NSDictionary* item = [self.content get_item_seg:indexPath.section row:indexPath.row];
  169. // NSString* key =[self.content_data valueForKey:@"order_info"];
  170. // [cell.keyLabel sizeToFit];
  171. // NSString* val=[item_json valueForKey:@"val"] ;
  172. // if([val isEqual:[NSNull null]])
  173. // val=@"";
  174. // if(val==nil)
  175. // val=@"";
  176. // if([val isEqualToString:@"null"])
  177. // val=@"";
  178. CGRect frame;
  179. frame.size = constraintkey;
  180. frame.origin.x=0;
  181. frame.origin.y=0;
  182. RTLabel* rtlabel = [[RTLabel alloc] initWithFrame:frame];
  183. // rtlabel.lineSpacing = 10;
  184. // [rtlabel setLineBreakMode: RTTextLineBreakModeWordWrapping];
  185. // rtlabel.lineSpacing = 20.0;
  186. [rtlabel setText: value];
  187. CGSize optimumSize = [rtlabel optimumSize];
  188. // DebugLog(@"%@",key);
  189. // [rtlabel sizeThatFits:constraintkey];
  190. // rtlabel frameHeight:<#(CTFrameRef)#>
  191. // rtlabel
  192. // [rtlabel sizeToFit];
  193. //CGSize newsize= rtlabel.frame.size;
  194. // CGSize sizeval=rtlabel.optimumSize;
  195. // CGSize sizekey = [key sizeWithFont:[UIFont systemFontOfSize:17.0] constrainedToSize:constraintkey lineBreakMode:NSLineBreakByWordWrapping];
  196. // CGSize sizeval = [val sizeWithFont:[UIFont systemFontOfSize:17.0] constrainedToSize:constraintval lineBreakMode:NSLineBreakByWordWrapping];
  197. float height = optimumSize.height;
  198. height = MAX(height+2*LABEL_MARGIN, DEF_CELL_HEIGHT);
  199. return height;
  200. }
  201. //- (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath:(NSIndexPath *)indexPath
  202. //{
  203. // return UITableViewCellEditingStyleNone;
  204. //}
  205. //- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
  206. //{
  207. // //如果两次点击的时间间隔小于1秒,则断定为双击事件
  208. //
  209. // if(tableView.editing==false)
  210. // return;
  211. //
  212. //
  213. // if([tableView numberOfRowsInSection:indexPath.section]<=1)
  214. // return;
  215. // // int between = 1;
  216. // NSUInteger curr = [[NSDate date] timeIntervalSince1970];
  217. //
  218. // if(indexPath.row==self.lasttap.row&&indexPath.section==self.lasttap.section)
  219. // {
  220. // if (curr-self.taptime<1) {
  221. // DebugLog(@"double click!");
  222. // self.lasttap =nil;
  223. //
  224. // NSMutableArray * from;
  225. // NSMutableArray * to ;
  226. // int section;
  227. // if(indexPath.section==0)
  228. // {
  229. // from = self.displayfields;
  230. // to = self.hidefields;
  231. // section = 1;
  232. // }
  233. // else
  234. // {
  235. //
  236. // from = self.hidefields;
  237. // to = self.displayfields;
  238. // section = 0;
  239. // }
  240. // NSIndexPath * toIndexPath = [NSIndexPath indexPathForRow:0 inSection:section];
  241. // // NSIndexPath * headerIndexPath = [NSIndexPath indexPathForRow:0 inSection:indexPath.section];
  242. // // NSIndexPath * headerIndexPath1 = toIndexPath;
  243. //
  244. // id content=from[indexPath.row];
  245. // [tableView beginUpdates];
  246. // [from removeObjectAtIndex:indexPath.row];
  247. // [tableView deleteRowsAtIndexPaths:[NSArray arrayWithObject:indexPath] withRowAnimation:UITableViewRowAnimationFade];
  248. //
  249. // [to insertObject:content atIndex:0];
  250. // [tableView insertRowsAtIndexPaths:[NSArray arrayWithObject:toIndexPath] withRowAnimation:UITableViewRowAnimationFade];
  251. // [tableView endUpdates];
  252. //
  253. // // [tableView reloadRowsAtIndexPaths:[NSArray arrayWithObject:headerIndexPath] withRowAnimation:UITableViewRowAnimationFade];
  254. // // [tableView reloadRowsAtIndexPaths:[NSArray arrayWithObject:headerIndexPath1] withRowAnimation:UITableViewRowAnimationFade];
  255. // [tableView reloadData];
  256. //
  257. //
  258. // }
  259. // self.taptime = curr;
  260. //
  261. //
  262. // }
  263. // else
  264. // {
  265. // self.taptime = curr;
  266. // self.lasttap = indexPath;
  267. // }
  268. //}
  269. - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
  270. {
  271. NSDictionary* val_json =nil;
  272. if(self.keywords==nil || self.keywords.length==0)
  273. {
  274. val_json=[self.cadedate objectForKey:[NSString stringWithFormat:@"val_%ld",(long)indexPath.row ]];
  275. }
  276. else
  277. {
  278. int count = 0;
  279. for (int i=0; i<[[self.cadedate valueForKey:@"count"] intValue]; i++)
  280. {
  281. if(count>= self.filter_count)
  282. break;
  283. NSDictionary* search_json = [self.cadedate objectForKey:[NSString stringWithFormat:@"val_%d",i ]];
  284. NSString* value = [search_json valueForKey:@"value"];
  285. NSUInteger location=[[value uppercaseString] rangeOfString:self.keywords].location;
  286. if(location!= NSNotFound)
  287. count++;
  288. if(count-1==indexPath.row)
  289. val_json=search_json;
  290. }
  291. }
  292. NSString* CellIdentifier = @"EnumSelectorCell";
  293. EnumSelectorCell * cell= [tableView dequeueReusableCellWithIdentifier:CellIdentifier forIndexPath:indexPath];
  294. // NSDictionary* val_json = [self.cadedate objectForKey:[NSString stringWithFormat:@"val_%ld",(long)indexPath.row ]];
  295. NSString* value = [val_json valueForKey:@"value"];
  296. // cell.rtLabel.lineSpacing=10;
  297. cell.rtLabel.text = value;
  298. // cell.labelValue.text = value;
  299. int check = [[val_json valueForKey:@"check" ] intValue];
  300. if(check==1)
  301. cell.img_checkmark.hidden=false;
  302. else
  303. cell.img_checkmark.hidden=true;
  304. return cell;
  305. }
  306. - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
  307. {
  308. EnumSelectorCell* cell = (EnumSelectorCell*)[tableView cellForRowAtIndexPath:indexPath];
  309. cell.selected = false;
  310. self.dirty = true;
  311. if(self.single_select)
  312. {
  313. if(self.keywords==nil || self.keywords.length==0)
  314. {
  315. for(int i=0;i<[[self.cadedate valueForKey:@"count"] intValue];i++)
  316. {
  317. NSMutableDictionary* val_json = [[self.cadedate objectForKey:[NSString stringWithFormat:@"val_%d",i]] mutableCopy];
  318. if(i==indexPath.row)
  319. [val_json setValue:@"1" forKey:@"check"];
  320. else
  321. [val_json setValue:@"0" forKey:@"check"];
  322. [self.cadedate setObject:val_json forKey:[NSString stringWithFormat:@"val_%d",i]];
  323. }
  324. }
  325. else
  326. {
  327. NSMutableDictionary* val_json =nil;
  328. int count = 0;
  329. for (int cc=0; cc<[[self.cadedate valueForKey:@"count"] intValue]; cc++)
  330. {
  331. if(count>= self.filter_count)
  332. break;
  333. NSMutableDictionary* search_json = [[self.cadedate objectForKey:[NSString stringWithFormat:@"val_%d",cc ]] mutableCopy];
  334. NSString* value = [search_json valueForKey:@"value"];
  335. NSUInteger location=[[value uppercaseString] rangeOfString:self.keywords].location;
  336. if(location!= NSNotFound)
  337. count++;
  338. if(count-1==indexPath.row)
  339. val_json=search_json;
  340. }
  341. for (int sc=0;sc<[[self.cadedate valueForKey:@"count"] intValue];sc++)
  342. {
  343. NSMutableDictionary* sc_json = [[self.cadedate objectForKey:[NSString stringWithFormat:@"val_%d",sc ]] mutableCopy];
  344. if ([[sc_json valueForKey:@"value" ] isEqual:[val_json valueForKey:@"value"]] )
  345. [sc_json setValue:@"1" forKey:@"check"];
  346. else
  347. [sc_json setValue:@"0" forKey:@"check"];
  348. [self.cadedate setObject:sc_json forKey:[NSString stringWithFormat:@"val_%d",sc]];
  349. }
  350. }
  351. if(self.auto_close)
  352. {
  353. if(self.navigationController!=nil)
  354. [self.navigationController popViewControllerAnimated:YES];
  355. // [self.navigationController dismissViewControllerAnimated:YES
  356. // completion:^{
  357. //
  358. //
  359. // }];
  360. else
  361. [self dismissViewControllerAnimated:YES
  362. completion:^{
  363. }];
  364. }
  365. }
  366. else
  367. {
  368. NSMutableDictionary* val_json =nil;
  369. if(self.keywords==nil || self.keywords.length==0)
  370. {
  371. val_json=[[self.cadedate objectForKey:[NSString stringWithFormat:@"val_%ld",(long)indexPath.row ]] mutableCopy];
  372. }
  373. else
  374. {
  375. int count = 0;
  376. for (int i=0; i<[[self.cadedate valueForKey:@"count"] intValue]; i++)
  377. {
  378. if(count>= self.filter_count)
  379. break;
  380. NSMutableDictionary* search_json = [[self.cadedate objectForKey:[NSString stringWithFormat:@"val_%d",i ]] mutableCopy];
  381. NSString* value = [search_json valueForKey:@"value"];
  382. NSUInteger location=[[value uppercaseString] rangeOfString:self.keywords].location;
  383. if(location!= NSNotFound)
  384. count++;
  385. if(count-1==indexPath.row)
  386. val_json=search_json;
  387. }
  388. }
  389. // NSMutableDictionary* val_json = [[self.cadedate objectForKey:[NSString stringWithFormat:@"val_%ld",(long)indexPath.row]] mutableCopy];
  390. int check = [[val_json valueForKey:@"check"] intValue];
  391. if(check==1)
  392. [val_json setValue:@"0" forKey:@"check"];
  393. else
  394. {
  395. if([self check_count]>=self.max_select && self.max_select>0)
  396. {
  397. // UIAlertView * alert = [[UIAlertView alloc] initWithTitle: message:[NSString stringWithFormat: delegate:nil cancelButtonTitle:@"OK" otherButtonTitles:nil, nil];
  398. // // UIAlertView *alert=[[UIAlertView alloc]initWithTitle:@"Error!" message:@"User&Password can not be empty!" delegate:nil cancelButtonTitle:NSLocalizedString(@"ok", nil) , nil];
  399. // [alert show];
  400. [RAUtils alert_view:[NSString stringWithFormat:@"%d items at most for this field.",self.max_select ] title:@"Max count reached"];
  401. return;
  402. }
  403. [val_json setValue:@"1" forKey:@"check"];
  404. }
  405. [self.cadedate setObject:val_json forKey:[NSString stringWithFormat:@"val_%ld",(long)indexPath.row]];
  406. }
  407. [self.tableEnum reloadData];
  408. }
  409. -(int) check_count
  410. {
  411. int check_count=0;
  412. // int count = 0;
  413. for (int i=0; i<[[self.cadedate valueForKey:@"count"] intValue]; i++)
  414. {
  415. NSMutableDictionary* val_json = [[self.cadedate objectForKey:[NSString stringWithFormat:@"val_%d",i ]] mutableCopy];
  416. int check = [[val_json valueForKey:@"check"] intValue];
  417. if(check==1)
  418. check_count++;
  419. }
  420. return check_count;
  421. }
  422. #pragma mark - searchBar delegate;
  423. - (void)searchBarSearchButtonClicked:(UISearchBar *)searchBar
  424. {
  425. self.keywords=[searchBar.text uppercaseString];
  426. [self.tableEnum reloadData];
  427. // self.offset = 0;
  428. // [self.content_data removeAllObjects];
  429. // [self loadpage];
  430. // DebugLog(@"search");
  431. }
  432. - (void)searchBar:(UISearchBar *)searchBar textDidChange:(NSString *)searchText
  433. {
  434. if([searchText isEqualToString:@""] && !self.reset)
  435. {
  436. self.keywords=nil;
  437. [self.tableEnum reloadData];
  438. self.reset=true;
  439. }
  440. else
  441. self.reset = false;
  442. }
  443. /*
  444. #pragma mark - Navigation
  445. // In a storyboard-based application, you will often want to do a little preparation before navigation
  446. - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender
  447. {
  448. // Get the new view controller using [segue destinationViewController].
  449. // Pass the selected object to the new view controller.
  450. }
  451. */
  452. @end