show_widget_list.ts 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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.hideDragOtherList()
  24. item_component.hideContainerChilden()
  25. item_component.initView(element,this.onItemClick.bind(this),null)
  26. item_component.showPageNumberName()
  27. item_component.showButtonDelete(true,this.onItemDeleteClick.bind(this))
  28. }
  29. this.btn_close.on(Node.EventType.TOUCH_END,()=>{
  30. this.close()
  31. })
  32. this.btn_show_all.on(Node.EventType.TOUCH_END,()=>{
  33. this.onShowAll()
  34. })
  35. this.btn_hide_all.on(Node.EventType.TOUCH_END,()=>{
  36. this.onHideAll()
  37. })
  38. }
  39. onShowAll(){
  40. for (let index = 0; index < this.content.children.length; index++) {
  41. const item = this.content.children[index];
  42. if(item.getComponent(widget_item).getShowWidgetData()!=null){
  43. let type = item.getComponent(widget_item).getShowWidgetData().type;
  44. if(type!=config.Widget_Type_List.TEXT_SOUND){
  45. item.getComponent(widget_item).setSelectStatus()
  46. }
  47. }
  48. }
  49. }
  50. onHideAll(){
  51. for (let index = 0; index < this.content.children.length; index++) {
  52. const item = this.content.children[index];
  53. if(item.getComponent(widget_item).getShowWidgetData()!=null){
  54. let type = item.getComponent(widget_item).getShowWidgetData().type;
  55. if(type!=config.Widget_Type_List.TEXT_SOUND){
  56. item.getComponent(widget_item).setUnSelectStatus()
  57. }
  58. }
  59. }
  60. }
  61. onItemClick(data:widget_item_data){
  62. ClientEvent.dispatchEvent(config.Event.UpdateAttributesToView,data.att,config.attributes_list_type.active)
  63. }
  64. onItemDeleteClick(item:widget_item) {
  65. let data = item.getData()
  66. tools.show_dialog('是否删除当前控件',()=>{
  67. item.node.removeFromParent()
  68. ClientEvent.dispatchEvent(config.Event.UpdateAttributesToView,data.att,config.attributes_list_type.delete)
  69. })
  70. }
  71. close(){
  72. this.node.destroy()
  73. }
  74. }