index.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", { value: true });
  3. var component_1 = require('./../common/component.js');
  4. var nextTick = function nextTick() {
  5. return new Promise(function (resolve) {
  6. return setTimeout(resolve, 20);
  7. });
  8. };
  9. component_1.VantComponent({
  10. classes: ['title-class', 'content-class'],
  11. relation: {
  12. name: 'collapse',
  13. type: 'ancestor',
  14. linked: function linked(parent) {
  15. this.parent = parent;
  16. }
  17. },
  18. props: {
  19. name: null,
  20. title: null,
  21. value: null,
  22. icon: String,
  23. label: String,
  24. disabled: Boolean,
  25. clickable: Boolean,
  26. border: {
  27. type: Boolean,
  28. value: true
  29. },
  30. isLink: {
  31. type: Boolean,
  32. value: true
  33. }
  34. },
  35. data: {
  36. contentHeight: 0,
  37. expanded: false,
  38. transition: false
  39. },
  40. mounted: function mounted() {
  41. var _this = this;
  42. this.updateExpanded().then(nextTick).then(function () {
  43. var data = { transition: true };
  44. if (_this.data.expanded) {
  45. data.contentHeight = 'auto';
  46. }
  47. _this.set(data);
  48. });
  49. },
  50. methods: {
  51. updateExpanded: function updateExpanded() {
  52. if (!this.parent) {
  53. return Promise.resolve();
  54. }
  55. var _a = this.parent.data,
  56. value = _a.value,
  57. accordion = _a.accordion;
  58. var _b = this.parent.children,
  59. children = _b === void 0 ? [] : _b;
  60. var name = this.data.name;
  61. var index = children.indexOf(this);
  62. var currentName = name == null ? index : name;
  63. var expanded = accordion ? value === currentName : (value || []).some(function (name) {
  64. return name === currentName;
  65. });
  66. var stack = [];
  67. if (expanded !== this.data.expanded) {
  68. stack.push(this.updateStyle(expanded));
  69. }
  70. stack.push(this.set({ index: index, expanded: expanded }));
  71. return Promise.all(stack);
  72. },
  73. updateStyle: function updateStyle(expanded) {
  74. var _this = this;
  75. return this.getRect('.van-collapse-item__content').then(function (rect) {
  76. return rect.height;
  77. }).then(function (height) {
  78. if (expanded) {
  79. return _this.set({
  80. contentHeight: height ? height + "px" : 'auto'
  81. });
  82. }
  83. return _this.set({ contentHeight: height + "px" }).then(nextTick).then(function () {
  84. return _this.set({ contentHeight: 0 });
  85. });
  86. });
  87. },
  88. onClick: function onClick() {
  89. if (this.data.disabled) {
  90. return;
  91. }
  92. var _a = this.data,
  93. name = _a.name,
  94. expanded = _a.expanded;
  95. var index = this.parent.children.indexOf(this);
  96. var currentName = name == null ? index : name;
  97. this.parent.switch(currentName, !expanded);
  98. },
  99. onTransitionEnd: function onTransitionEnd() {
  100. if (this.data.expanded) {
  101. this.set({
  102. contentHeight: 'auto'
  103. });
  104. }
  105. }
  106. }
  107. });
  108. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["Object","value","component_1","require","nextTick","setTimeout","classes","relation","name","type","linked","props","title","icon","label","disabled","clickable","border","isLink","data","contentHeight","expanded","transition","mounted","_this","methods","updateExpanded","Promise","_a","accordion","_b","children","index","currentName","stack","updateStyle","rect","height","onClick","onTransitionEnd"],"mappings":"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","sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar component_1 = require(\"../common/component\");\nvar nextTick = function () { return new Promise(function (resolve) { return setTimeout(resolve, 20); }); };\ncomponent_1.VantComponent({\n    classes: ['title-class', 'content-class'],\n    relation: {\n        name: 'collapse',\n        type: 'ancestor',\n        linked: function (parent) {\n            this.parent = parent;\n        }\n    },\n    props: {\n        name: null,\n        title: null,\n        value: null,\n        icon: String,\n        label: String,\n        disabled: Boolean,\n        clickable: Boolean,\n        border: {\n            type: Boolean,\n            value: true\n        },\n        isLink: {\n            type: Boolean,\n            value: true\n        }\n    },\n    data: {\n        contentHeight: 0,\n        expanded: false,\n        transition: false\n    },\n    mounted: function () {\n        var _this = this;\n        this.updateExpanded()\n            .then(nextTick)\n            .then(function () {\n            var data = { transition: true };\n            if (_this.data.expanded) {\n                data.contentHeight = 'auto';\n            }\n            _this.set(data);\n        });\n    },\n    methods: {\n        updateExpanded: function () {\n            if (!this.parent) {\n                return Promise.resolve();\n            }\n            var _a = this.parent.data, value = _a.value, accordion = _a.accordion;\n            var _b = this.parent.children, children = _b === void 0 ? [] : _b;\n            var name = this.data.name;\n            var index = children.indexOf(this);\n            var currentName = name == null ? index : name;\n            var expanded = accordion\n                ? value === currentName\n                : (value || []).some(function (name) { return name === currentName; });\n            var stack = [];\n            if (expanded !== this.data.expanded) {\n                stack.push(this.updateStyle(expanded));\n            }\n            stack.push(this.set({ index: index, expanded: expanded }));\n            return Promise.all(stack);\n        },\n        updateStyle: function (expanded) {\n            var _this = this;\n            return this.getRect('.van-collapse-item__content')\n                .then(function (rect) { return rect.height; })\n                .then(function (height) {\n                if (expanded) {\n                    return _this.set({\n                        contentHeight: height ? height + \"px\" : 'auto'\n                    });\n                }\n                return _this.set({ contentHeight: height + \"px\" })\n                    .then(nextTick)\n                    .then(function () { return _this.set({ contentHeight: 0 }); });\n            });\n        },\n        onClick: function () {\n            if (this.data.disabled) {\n                return;\n            }\n            var _a = this.data, name = _a.name, expanded = _a.expanded;\n            var index = this.parent.children.indexOf(this);\n            var currentName = name == null ? index : name;\n            this.parent.switch(currentName, !expanded);\n        },\n        onTransitionEnd: function () {\n            if (this.data.expanded) {\n                this.set({\n                    contentHeight: 'auto'\n                });\n            }\n        }\n    }\n});\n"],"file":"index.js"}