"use strict"; var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var __generator = (this && this.__generator) || function (thisArg, body) { var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; function verb(n) { return function (v) { return step([n, v]); }; } function step(op) { if (f) throw new TypeError("Generator is already executing."); while (_) try { if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; if (y = 0, t) op = [op[0] & 2, t.value]; switch (op[0]) { case 0: case 1: t = op; break; case 4: _.label++; return { value: op[1], done: false }; case 5: _.label++; y = op[1]; op = [0]; continue; case 7: op = _.ops.pop(); _.trys.pop(); continue; default: if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } if (t[2]) _.ops.pop(); _.trys.pop(); continue; } op = body.call(thisArg, _); } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; } }; Object.defineProperty(exports, "__esModule", { value: true }); var promise_wx_api_1 = require("../../../../utils/promise-wx-api"); var anime_1 = require("../../../../mixins/anime"); var tempReslove = function () { }; var app = getApp(); Component({ behaviors: [anime_1.default], properties: { gridIdList: { type: Array, value: [], }, showName: { type: String, value: "", }, url: { type: String, value: "", } }, data: { hidden: true, agencyLoading: false, gridInfo: {}, agencyGridList: {}, }, lifetimes: { attached: function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: return [4, app.doAfterLogin()]; case 1: _a.sent(); this.getAgencyData(); return [2]; } }); }); }, detached: function () { }, }, methods: { show: function (needRefresh) { if (needRefresh === void 0) { needRefresh = false; } this.setData({ hidden: false, }); if (needRefresh) { this.getAgencyData(); } return new Promise(function (reslove) { tempReslove = reslove; }); }, hide: function () { return __awaiter(this, void 0, void 0, function () { return __generator(this, function (_a) { switch (_a.label) { case 0: this.animeFadeOut("#root"); return [4, this.animeFadeOutDown("#wrap")]; case 1: _a.sent(); this.setData({ hidden: true }); return [2]; } }); }); }, confirm: function () { var _a = this.getSelectedGrid(), gridIdList = _a.gridIdList, gridInfo = _a.gridInfo; if (gridIdList.length === 0 && Object.keys(gridInfo).length === 0) { return wx.showToast({ title: '未选择网格或组织', icon: 'none', duration: 1500 }); } this.hide(); return tempReslove({ type: "confirm", data: this.getSelectedGrid(), }); }, cancel: function () { this.hide(); return tempReslove({ type: "cancel", data: null, }); }, getSelectedGrid: function () { var agencyGridList = this.data.agencyGridList; var gridIdList = [], gridNameList = [], gridInfo = {}; var fn = function (data, needName) { if (needName === void 0) { needName = true; } if (data.selectedAll && !data.isNone && needName) { gridNameList.push(data.agencyName); needName = false; } data.gridList.forEach(function (item) { if (item.selected) { gridIdList.push(item.gridId); gridInfo = item; if (!data.selectedAll) { gridNameList = [item.gridName]; } } }); data.subAgencyGridList.forEach(function (item) { if (item.selected) { gridInfo = item; gridNameList = [item.agencyName]; } fn(item, needName); }); if (data.selected) { gridInfo = data; gridNameList = [data.agencyName]; } }; fn(agencyGridList); return { gridIdList: gridIdList, gridInfo: gridInfo, showName: gridNameList.join("、"), }; }, computeSelectedAll: function (agencyGridList) { var fn = function (obj) { var selectedAll = true; if (!obj.gridList.every(function (item) { return item.selected; })) { selectedAll = false; } obj.subAgencyGridList.forEach(function (item) { if (!fn(item)) { selectedAll = false; } }); obj.selectedAll = selectedAll; return selectedAll; }; fn(agencyGridList); return agencyGridList; }, shiftSelectGrid: function (e) { var gridId = e.currentTarget.dataset.gridId || e.detail.gridId; var agencyGridList = this.data.agencyGridList; var fn = function (obj) { obj.gridList.forEach(function (item) { if (item.gridId === gridId) { item.selected = !item.selected; } else item.selected = false; }); obj.selected = false; obj.subAgencyGridList.forEach(function (item) { item.selected = false; fn(item); }); }; fn(agencyGridList); this.setData({ agencyGridList: agencyGridList }); }, shiftSelectAgency: function (e) { var agencyId = e.currentTarget.dataset.agencyId || e.detail.agencyId; var agencyGridList = this.data.agencyGridList; var fn = function (obj) { if (agencyId === obj.agencyId) { obj.selected = !obj.selected; } else obj.selected = false; obj.gridList.forEach(function (item) { item.selected = false; }); obj.subAgencyGridList.forEach(function (item) { fn(item); }); }; fn(agencyGridList); this.setData({ agencyGridList: agencyGridList }); }, iniAgencyDataAddSelected: function (obj) { var gridIdList = this.data.gridIdList; var fn = function (obj) { if (!Array.isArray(obj.gridList)) { obj.gridList = []; } if (gridIdList.indexOf(obj.agencyId) !== -1) { obj.selected = true; } obj.gridList.forEach(function (item) { if (gridIdList.indexOf(item.gridId) !== -1) { item.selected = true; } else { item.selected = false; } }); if (!Array.isArray(obj.subAgencyGridList)) { obj.subAgencyGridList = []; } obj.subAgencyGridList.forEach(function (item) { if (gridIdList.indexOf(item.agencyId) !== -1) { item.selected = true; } else { item.selected = false; } fn(item); }); }; fn(obj); return obj; }, iniAgencyDataFilterNoneAgency: function (obj) { var url = this.data.url; var fn = function (obj) { obj.isNone = true; if (obj.gridList.length > 0) { obj.isNone = false; } if (url) obj.isNone = false; obj.subAgencyGridList.forEach(function (item) { if (!fn(item)) { obj.isNone = false; } }); return obj.isNone; }; fn(obj); var fn2 = function (obj) { obj.subAgencyGridList = obj.subAgencyGridList.filter(function (item) { if (!obj.isNone) { fn2(item); } return !obj.isNone; }); }; fn2(obj); return obj; }, formatArrObj: function (arr) { var _this = this; var arr1 = []; if (arr && arr.length > 0) { arr1 = arr.map(function (item) { return __assign(__assign({}, item), { isOpt: true, gridList: [], subAgencyGridList: _this.formatArrObj(item.subAgencyList) }); }); } return arr1; }, getAgencyData: function () { return __awaiter(this, void 0, void 0, function () { var url, _url, _a, _b, code, data, msg, agencyGridList, obj, agencyGridList1, agencyGridList2, agencyGridList3; return __generator(this, function (_c) { switch (_c.label) { case 0: this.setData({ agencyLoading: true, }); url = this.data.url; _url = url || "data/aggregator/org/staffagencygridlist"; return [4, promise_wx_api_1.wxRequestPost(_url, {}, {})]; case 1: _a = _c.sent(), _b = _a.data.data, code = _b.code, data = _b.data, msg = _a.msg; this.setData({ agencyLoading: false, }); if (msg === "success" && code === 0) { agencyGridList = {}; if (url) { obj = __assign(__assign({}, data), { isOpt: true, subAgencyGridList: this.formatArrObj(data.subAgencyList) }); agencyGridList = __assign({}, obj); } else agencyGridList = data.agencyGridList || data; agencyGridList1 = this.iniAgencyDataAddSelected(__assign({}, agencyGridList)); agencyGridList2 = this.iniAgencyDataFilterNoneAgency(__assign({}, agencyGridList1)); agencyGridList3 = this.computeSelectedAll(__assign({}, agencyGridList2)); this.setData({ agencyGridList: agencyGridList3, }); } return [2]; } }); }); }, }, });