|
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
-
- import mixins from '../util/mixins';
- function searchChildren(children) {
- var results = [];
- for (var index = 0; index < children.length; index++) {
- var child = children[index];
- if (child.isActive && child.isDependent) {
- results.push(child);
- } else {
- results.push.apply(results, _toConsumableArray(searchChildren(child.$children)));
- }
- }
- return results;
- }
- /* @vue/component */
- export default mixins().extend({
- name: 'dependent',
- data: function data() {
- return {
- closeDependents: true,
- isActive: false,
- isDependent: true
- };
- },
-
- watch: {
- isActive: function isActive(val) {
- if (val) return;
- var openDependents = this.getOpenDependents();
- for (var index = 0; index < openDependents.length; index++) {
- openDependents[index].isActive = false;
- }
- }
- },
- methods: {
- getOpenDependents: function getOpenDependents() {
- if (this.closeDependents) return searchChildren(this.$children);
- return [];
- },
- getOpenDependentElements: function getOpenDependentElements() {
- var result = [];
- var openDependents = this.getOpenDependents();
- for (var index = 0; index < openDependents.length; index++) {
- result.push.apply(result, _toConsumableArray(openDependents[index].getClickableDependentElements()));
- }
- return result;
- },
- getClickableDependentElements: function getClickableDependentElements() {
- var result = [this.$el];
- if (this.$refs.content) result.push(this.$refs.content);
- if (this.overlay) result.push(this.overlay);
- result.push.apply(result, _toConsumableArray(this.getOpenDependentElements()));
- return result;
- }
- }
- });
- //# sourceMappingURL=dependent.js.map
|