FormField.js 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. MWF.xApplication.Organization.Selector = MWF.xApplication.Organization.Selector || {};
  2. MWF.xDesktop.requireApp("Organization", "Actions.RestActions", null, false);
  3. MWF.xDesktop.requireApp("Organization", "Selector.Department", null, false);
  4. MWF.xApplication.Organization.Selector.FormField = new Class({
  5. Extends: MWF.xApplication.Organization.Selector.Department,
  6. options: {
  7. "style": "default",
  8. "count": 0,
  9. "title": "Select Field",
  10. "fieldType": "",
  11. "values": [],
  12. "names": [],
  13. "application": "",
  14. "expand": false
  15. },
  16. loadSelectItems: function(addToNext){
  17. debugger;
  18. if (this.options.application){
  19. this.action.listFormField(this.options.application, function(json){
  20. this.fieldData = json.data;
  21. if (this.options.fieldType){
  22. if (json.data[this.options.fieldType]){
  23. json.data[this.options.fieldType].each(function(data){
  24. data.id = data.name;
  25. var item = this._newItem(data, this, this.itemAreaNode);
  26. }.bind(this));
  27. }
  28. }else{
  29. Object.each(json.data, function(v, k){
  30. var category = this._newItemCategory({"name": k, "data": v}, this, this.itemAreaNode);
  31. }.bind(this));
  32. }
  33. //json.data.each(function(data){
  34. // var category = this._newItem(data, this, this.itemAreaNode);
  35. //}.bind(this));
  36. }.bind(this));
  37. }
  38. },
  39. _scrollEvent: function(y){
  40. return true;
  41. },
  42. _getChildrenItemIds: function(){
  43. return null;
  44. },
  45. _newItemCategory: function(data, selector, item, level){
  46. return new MWF.xApplication.Organization.Selector.FormField.ItemCategory(data, selector, item, level)
  47. },
  48. _listItemByKey: function(callback, failure, key){
  49. var data = [];
  50. if (this.options.fieldType){
  51. data = this.fieldData[this.options.fieldType];
  52. }else{
  53. Object.each(this.fieldData, function(v, k){
  54. data = (data.length) ? data.concat(v) : v
  55. }.bind(this));
  56. }
  57. var searchData = [];
  58. data.each(function(d){
  59. if (d.name.toLowerCase().indexOf(key.toLowerCase())!=-1) searchData.push(d);
  60. }.bind(this));
  61. if (callback) callback.apply(this, [{"data": searchData}]);
  62. //if (callback) callback({"data": {"name": key, "id": key}});
  63. },
  64. _getItem: function(callback, failure, id, async){
  65. if (callback) callback({"data": {"name": id, "id": id}});
  66. },
  67. _newItemSelected: function(data, selector, item){
  68. return new MWF.xApplication.Organization.Selector.FormField.ItemSelected(data, selector, item)
  69. },
  70. _listItemByPinyin: function(callback, failure, key){
  71. this._listItemByKey(callback, failure, key);
  72. },
  73. _newItem: function(data, selector, container, level){
  74. return new MWF.xApplication.Organization.Selector.FormField.Item(data, selector, container, level);
  75. }
  76. });
  77. MWF.xApplication.Organization.Selector.FormField.Item = new Class({
  78. Extends: MWF.xApplication.Organization.Selector.Person.Item,
  79. _getShowName: function(){
  80. return this.data.name;
  81. },
  82. _setIcon: function(){
  83. this.iconNode.setStyle("background-image", "url("+"/x_component_Organization/Selector/$Selector/default/icon/processicon.png)");
  84. },
  85. loadSubItem: function(){
  86. return false;
  87. // this.children = new Element("div", {
  88. // "styles": this.selector.css.selectorItemCategoryChildrenNode
  89. // }).inject(this.node, "after");
  90. // this.children.setStyle("display", "block");
  91. //// if (!this.selector.options.expand) this.children.setStyle("display", "none");
  92. //
  93. // this.selector.action.listProcess(function(subJson){
  94. // subJson.data.each(function(subData){
  95. // var category = this.selector._newItem(subData, this.selector, this.children, this.level+1);
  96. // }.bind(this));
  97. // }.bind(this), null, this.data.id);
  98. }
  99. });
  100. MWF.xApplication.Organization.Selector.FormField.ItemSelected = new Class({
  101. Extends: MWF.xApplication.Organization.Selector.Person.ItemSelected,
  102. _getShowName: function(){
  103. return this.data.name;
  104. },
  105. _setIcon: function(){
  106. this.iconNode.setStyle("background-image", "url("+"/x_component_Organization/Selector/$Selector/default/icon/processicon.png)");
  107. }
  108. });
  109. MWF.xApplication.Organization.Selector.FormField.ItemCategory = new Class({
  110. Extends: MWF.xApplication.Organization.Selector.Identity.ItemCompanyCategory,
  111. _setIcon: function(){
  112. this.iconNode.setStyle("background-image", "url("+"/x_component_Organization/Selector/$Selector/default/icon/applicationicon.png)");
  113. },
  114. loadSub: function(callback){
  115. if (!this.loaded){
  116. var subJson = this.selector.fieldData[this.data.name];
  117. //this.selector.action.listProcess(function(subJson){
  118. subJson.each(function(subData){
  119. //subData.applicationName = this.data.name;
  120. //subData.application = this.data.id;
  121. var category = this.selector._newItem(subData, this.selector, this.children, this.level+1);
  122. }.bind(this));
  123. this.loaded = true;
  124. if (callback) callback();
  125. //}.bind(this), null, this.data.id);
  126. }else{
  127. if (callback) callback();
  128. }
  129. },
  130. _hasChild: function(){
  131. var d = this.selector.fieldData[this.data.name];
  132. return (d && d.length);
  133. }
  134. });