show_widget_list.ts 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. import { _decorator, Component, instantiate, Node, Prefab } from 'cc';
  2. import { Attributes } from './Attributes';
  3. import { widget_item } from './widget_item';
  4. import { widget_item_data } from '../../data/data';
  5. import { ClientEvent } from '../clientEvent';
  6. import { config } from '../config';
  7. import { tools } from '../tools';
  8. const { ccclass, property } = _decorator;
  9. @ccclass('show_widget_list')
  10. export class show_widget_list extends Component {
  11. @property(Node) content:Node = null;
  12. @property(Node) btn_close:Node = null;
  13. @property(Prefab) item_prefab:Prefab = null;
  14. private call_back = null;
  15. @property(Node) btn_show_all:Node =null;
  16. @property(Node) btn_hide_all:Node = null;
  17. public show(list){
  18. for (let index = 0; index < list.length; index++) {
  19. const element = list[index];
  20. let item = instantiate(this.item_prefab)
  21. item.parent = this.content;
  22. let item_component = item.getComponent(widget_item)
  23. item_component.initHideDragOtherList()
  24. item_component.initView(element,this.onItemClick.bind(this),null)
  25. item_component.showButtonDelete(true,this.onItemDeleteClick.bind(this))
  26. }
  27. this.btn_close.on(Node.EventType.TOUCH_END,()=>{
  28. this.close()
  29. })
  30. this.btn_show_all.on(Node.EventType.TOUCH_END,()=>{
  31. this.onShowAll()
  32. })
  33. this.btn_hide_all.on(Node.EventType.TOUCH_END,()=>{
  34. this.onHideAll()
  35. })
  36. }
  37. onShowAll(){
  38. for (let index = 0; index < this.content.children.length; index++) {
  39. const item = this.content.children[index];
  40. if(item.getComponent(widget_item).getShowWidgetData()!=null){
  41. let type = item.getComponent(widget_item).getShowWidgetData().type;
  42. if(type!=config.Widget_Type_List.TEXT_SOUND){
  43. item.getComponent(widget_item).setSelectStatus()
  44. }
  45. }
  46. }
  47. }
  48. onHideAll(){
  49. for (let index = 0; index < this.content.children.length; index++) {
  50. const item = this.content.children[index];
  51. if(item.getComponent(widget_item).getShowWidgetData()!=null){
  52. let type = item.getComponent(widget_item).getShowWidgetData().type;
  53. if(type!=config.Widget_Type_List.TEXT_SOUND){
  54. item.getComponent(widget_item).setUnSelectStatus()
  55. }
  56. }
  57. }
  58. }
  59. onItemClick(data:widget_item_data){
  60. ClientEvent.dispatchEvent(config.Event.UpdateAttributesToView,data.att,config.attributes_list_type.active)
  61. }
  62. onItemDeleteClick(item:widget_item) {
  63. let data = item.getData()
  64. tools.show_dialog('是否删除当前控件',()=>{
  65. item.node.removeFromParent()
  66. ClientEvent.dispatchEvent(config.Event.UpdateAttributesToView,data.att,config.attributes_list_type.delete)
  67. })
  68. }
  69. close(){
  70. this.node.destroy()
  71. }
  72. }