0efd3c387ffb45a8790d1e93b718ad4b.json 33 KB

1
  1. {"remainingRequest":"D:\\test\\ssi-satoken\\ui\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\test\\ssi-satoken\\ui\\src\\views\\sysManager\\sysMenu\\index.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\test\\ssi-satoken\\ui\\src\\views\\sysManager\\sysMenu\\index.vue","mtime":1697522464403},{"path":"D:\\test\\ssi-satoken\\ui\\node_modules\\babel-loader\\lib\\index.js","mtime":1669864538095},{"path":"D:\\test\\ssi-satoken\\ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1669864538178},{"path":"D:\\test\\ssi-satoken\\ui\\node_modules\\vue-loader\\lib\\index.js","mtime":1697679531049}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:Ly8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KDQoNCmltcG9ydCBUcmVlc2VsZWN0IGZyb20gIkByaW9waGFlL3Z1ZS10cmVlc2VsZWN0IjsNCmltcG9ydCAiQHJpb3BoYWUvdnVlLXRyZWVzZWxlY3QvZGlzdC92dWUtdHJlZXNlbGVjdC5jc3MiOw0KaW1wb3J0IEljb25TZWxlY3QgZnJvbSAiQC9jb21wb25lbnRzL0ljb25TZWxlY3QiOw0KaW1wb3J0IHsgZGVib3VuY2UgfSBmcm9tICdsb2Rhc2gnDQpleHBvcnQgZGVmYXVsdCB7DQogIG5hbWU6ICJNZW51IiwNCiAgZGljdHM6IFsnc3lzX3Nob3dfaGlkZScsICdzeXNfbm9ybWFsX2Rpc2FibGUnXSwNCiAgY29tcG9uZW50czogeyBUcmVlc2VsZWN0LCBJY29uU2VsZWN0IH0sDQogIGRhdGEoKSB7DQogICAgcmV0dXJuIHsNCiAgICAgIHBjT3B0aW9uczogWw0KICAgICAgICB7dmFsdWU6ICdYVEdMJywgbGFiZWw6ICdYVEdMJ30sDQogICAgICAgIHt2YWx1ZTogJ1NKR0wnLCBsYWJlbDogJ1NKR0wnfSwNCiAgICAgICAge3ZhbHVlOiAnU0hHTCcsIGxhYmVsOiAnU0hHTCd9LA0KICAgICAgICB7dmFsdWU6ICdZV0dMJywgbGFiZWw6ICdZV0dMJ30sDQogICAgICAgIHt2YWx1ZTogJ1NKWVcnLCBsYWJlbDogJ1NKWVcnfSwNCiAgICAgICAge3ZhbHVlOiAnWVdQWicsIGxhYmVsOiAnWVdQWid9LA0KICAgICAgICB7dmFsdWU6ICdZV0NaJywgbGFiZWw6ICdZV0NaJ30NCiAgICAgIF0sDQogICAgICAvLyDpga7nvanlsYINCiAgICAgIGxvYWRpbmc6IHRydWUsDQogICAgICAvLyDmmL7npLrmkJzntKLmnaHku7YNCiAgICAgIHNob3dTZWFyY2g6IHRydWUsDQogICAgICAvLyDoj5zljZXooajmoLzmoJHmlbDmja4NCiAgICAgIG1lbnVMaXN0OiBbXSwNCiAgICAgIHN5c1Nob3c6IFsNCiAgICAgICAge3ZhbHVlOiAnMCcsIGxhYmVsOiAn5pi+56S66I+c5Y2VJ30sDQogICAgICAgIHt2YWx1ZTogJzEnLCBsYWJlbDogJ+makOiXj+iPnOWNlSd9DQogICAgICBdLA0KICAgICAgbWVudVN0YXR1czogWw0KICAgICAgICB7dmFsdWU6ICcwJywgbGFiZWw6ICfmraPluLgnfSwNCiAgICAgICAge3ZhbHVlOiAnMScsIGxhYmVsOiAn5YGc55SoJ30NCiAgICAgIF0sDQogICAgICAvLyDoj5zljZXmoJHpgInpobkNCiAgICAgIG1lbnVPcHRpb25zOiBbXSwNCiAgICAgIC8vIOW8ueWHuuWxguagh+mimA0KICAgICAgdGl0bGU6ICIiLA0KICAgICAgLy8g5piv5ZCm5pi+56S65by55Ye65bGCDQogICAgICBvcGVuOiBmYWxzZSwNCiAgICAgIC8vIOaYr+WQpuWxleW8gO+8jOm7mOiupOWFqOmDqOaKmOWPoA0KICAgICAgaXNFeHBhbmRBbGw6IGZhbHNlLA0KICAgICAgLy8g6YeN5paw5riy5p+T6KGo5qC854q25oCBDQogICAgICByZWZyZXNoVGFibGU6IHRydWUsDQogICAgICAvLyDmn6Xor6Llj4LmlbANCiAgICAgIHF1ZXJ5UGFyYW1zOiB7DQogICAgICAgIG1lbnVOYW1lOiB1bmRlZmluZWQsDQogICAgICAgIHZpc2libGU6IHVuZGVmaW5lZA0KICAgICAgfSwNCiAgICAgIC8vIOihqOWNleWPguaVsA0KICAgICAgZm9ybToge30sDQogICAgICAvLyDooajljZXmoKHpqowNCiAgICAgIHJ1bGVzOiB7DQogICAgICAgIG1lbnVOYW1lOiBbDQogICAgICAgICAgeyByZXF1aXJlZDogdHJ1ZSwgbWVzc2FnZTogIuiPnOWNleWQjeensOS4jeiDveS4uuepuiIsIHRyaWdnZXI6ICJibHVyIiB9DQogICAgICAgIF0sDQogICAgICAgIHBjOiBbDQogICAgICAgICAgeyByZXF1aXJlZDogdHJ1ZSwgbWVzc2FnZTogIuWtl+espuagh+ivhuS4jeiDveS4uuepuiIsIHRyaWdnZXI6ICJibHVyIiB9DQogICAgICAgIF0sDQogICAgICAgIG9yZGVyTnVtOiBbDQogICAgICAgICAgeyByZXF1aXJlZDogdHJ1ZSwgbWVzc2FnZTogIuiPnOWNlemhuuW6j+S4jeiDveS4uuepuiIsIHRyaWdnZXI6ICJibHVyIiB9DQogICAgICAgIF0sDQogICAgICAgIHBhdGg6IFsNCiAgICAgICAgICB7IHJlcXVpcmVkOiB0cnVlLCBtZXNzYWdlOiAi6Lev55Sx5Zyw5Z2A5LiN6IO95Li656m6IiwgdHJpZ2dlcjogImJsdXIiIH0NCiAgICAgICAgXQ0KICAgICAgfQ0KICAgIH07DQogIH0sDQogIGNyZWF0ZWQoKSB7DQogICAgdGhpcy5nZXRMaXN0KCkNCiAgfSwNCiAgbWV0aG9kczogew0KICAgIC8vIOWIl+ihqOeKtuaAgeagvOW8j+WMlg0KICAgIHN0YXR1c0Zvcm1hdChyb3csIGNvbHVtbikgew0KICAgICAgbGV0IGJlbG9uZ1RvID0gJ+acquefpeeahOexu+WeiycNCiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5tZW51U3RhdHVzLmxlbmd0aDsgaSsrKSB7DQogICAgICAgIGlmIChyb3cuc3RhdHVzID09ICIwIikgew0KICAgICAgICAgIGJlbG9uZ1RvID0gIuato+W4uCINCiAgICAgICAgfSBlbHNlIGlmIChyb3cuc3RhdHVzID09ICIxIikgew0KICAgICAgICAgIGJlbG9uZ1RvID0gIuWBnOeUqCINCiAgICAgICAgfQ0KICAgICAgfQ0KICAgICAgcmV0dXJuIGJlbG9uZ1RvDQogICAgfSwNCiAgICAvLyDpgInmi6nlm77moIcNCiAgICBzZWxlY3RlZChuYW1lKSB7DQogICAgICB0aGlzLmZvcm0uaWNvbiA9IG5hbWUNCiAgICB9LA0KICAgIC8qKiDmn6Xor6Loj5zljZXliJfooaggKi8NCiAgICBhc3luYyBnZXRMaXN0KCl7DQogICAgICB0aGlzLmxvYWRpbmcgPSB0cnVlOw0KICAgICAgY29uc3QgcGFyYW0gPSB7DQogICAgICAgICAgbWVudU5hbWU6IHRoaXMucXVlcnlQYXJhbXMubWVudU5hbWUNCiAgICAgIH0NCiAgICAgIGNvbnNvbGUubG9nKHBhcmFtKQ0KICAgICAgYXdhaXQgdGhpcy4kYXhpb3MuZ2V0KCcvc3lzTWVudUNvbnRyb2xsZXIvbGlzdCcse3BhcmFtczogcGFyYW19KS50aGVuKChyZXMpID0+IHsNCiAgICAgICAgdGhpcy5tZW51TGlzdCA9IHRoaXMuaGFuZGxlVHJlZShyZXMuZGF0YSwgIm1lbnVJZCIpDQogICAgICAgIHRoaXMubG9hZGluZyA9IGZhbHNlOw0KICAgICAgfSkuY2F0Y2goKGVycm9yKSA9PiB7DQogICAgICAgIHRoaXMubG9hZGluZyA9IGZhbHNlOw0KICAgICAgfSkNCiAgICB9LA0KICAgIC8qKiDovazmjaLoj5zljZXmlbDmja7nu5PmnoQgKi8NCiAgICBub3JtYWxpemVyKG5vZGUpIHsNCiAgICAgIGlmIChub2RlLmNoaWxkcmVuICYmICFub2RlLmNoaWxkcmVuLmxlbmd0aCkgew0KICAgICAgICBkZWxldGUgbm9kZS5jaGlsZHJlbg0KICAgICAgfQ0KICAgICAgcmV0dXJuIHsNCiAgICAgICAgaWQ6IG5vZGUubWVudUlkLA0KICAgICAgICBsYWJlbDogbm9kZS5tZW51TmFtZSwNCiAgICAgICAgY2hpbGRyZW46IG5vZGUuY2hpbGRyZW4NCiAgICAgIH07DQogICAgfSwNCiAgICAvKiog5p+l6K+i6I+c5Y2V5LiL5ouJ5qCR57uT5p6EICovDQogICAgYXN5bmMgZ2V0VHJlZXNlbGVjdCgpIHsNCiAgICAgIGF3YWl0IHRoaXMuJGF4aW9zLmdldCgnL3N5c01lbnVDb250cm9sbGVyL2xpc3QnKS50aGVuKChyZXMpID0+IHsNCiAgICAgICAgdGhpcy5tZW51T3B0aW9ucyA9IFtdDQogICAgICAgIGNvbnN0IG1lbnUgPSB7IG1lbnVJZDogMCwgbWVudU5hbWU6ICfkuLvnsbvnm64nLCBjaGlsZHJlbjogW10gfQ0KICAgICAgICBtZW51LmNoaWxkcmVuID0gdGhpcy5oYW5kbGVUcmVlKHJlcy5kYXRhLCAibWVudUlkIikNCiAgICAgICAgdGhpcy5tZW51T3B0aW9ucy5wdXNoKG1lbnUpDQogICAgICB9KQ0KICAgIH0sDQogICAgLy8g5Y+W5raI5oyJ6ZKuDQogICAgY2FuY2VsKCkgew0KICAgICAgdGhpcy5vcGVuID0gZmFsc2UNCiAgICAgIHRoaXMucmVzZXQoKQ0KICAgIH0sDQogICAgLy8g6KGo5Y2V6YeN572uDQogICAgcmVzZXQoKSB7DQogICAgICB0aGlzLmZvcm0gPSB7DQogICAgICAgIG1lbnVJZDogdW5kZWZpbmVkLA0KICAgICAgICBwYXJlbnRJZDogMCwNCiAgICAgICAgbWVudU5hbWU6IHVuZGVmaW5lZCwNCiAgICAgICAgaWNvbjogdW5kZWZpbmVkLA0KICAgICAgICBtZW51VHlwZTogIk0iLA0KICAgICAgICBvcmRlck51bTogdW5kZWZpbmVkLA0KICAgICAgICBpc0ZyYW1lOiAiMSIsDQogICAgICAgIGlzQ2FjaGU6ICIwIiwNCiAgICAgICAgdmlzaWJsZTogIjAiLA0KICAgICAgICBzdGF0dXM6ICIwIg0KICAgICAgfTsNCiAgICAgIHRoaXMucmVzZXRGb3JtKCJmb3JtIikNCiAgICB9LA0KICAgIC8qKiDmkJzntKLmjInpkq7mk43kvZwgKi8NCiAgICBoYW5kbGVRdWVyeTpkZWJvdW5jZShmdW5jdGlvbigpew0KICAgICAgdGhpcy5nZXRMaXN0KCkNCiAgICB9LDEwMDApLA0KICAgIC8qKiDph43nva7mjInpkq7mk43kvZwgKi8NCiAgICByZXNldFF1ZXJ5KCkgew0KICAgICAgdGhpcy5yZXNldEZvcm0oInF1ZXJ5Rm9ybSIpDQogICAgfSwNCiAgICAvKiog5paw5aKe5oyJ6ZKu5pON5L2cICovDQogICAgaGFuZGxlQWRkOmRlYm91bmNlKGZ1bmN0aW9uKHJvdyl7DQogICAgICB0aGlzLnJlc2V0KCkNCiAgICAgIHRoaXMuZ2V0VHJlZXNlbGVjdCgpOw0KICAgICAgaWYgKHJvdyAhPSBudWxsICYmIHJvdy5tZW51SWQpIHsNCiAgICAgICAgdGhpcy5mb3JtLnBhcmVudElkID0gcm93Lm1lbnVJZA0KICAgICAgfSBlbHNlIHsNCiAgICAgICAgdGhpcy5mb3JtLnBhcmVudElkID0gMA0KICAgICAgfQ0KICAgICAgdGhpcy5vcGVuID0gdHJ1ZQ0KICAgICAgdGhpcy50aXRsZSA9ICLmt7vliqDoj5zljZUiDQogICAgfSw1MDApLA0KICAgIC8qKiDlsZXlvIAv5oqY5Y+g5pON5L2cICovDQogICAgdG9nZ2xlRXhwYW5kQWxsKCkgew0KICAgICAgdGhpcy5yZWZyZXNoVGFibGUgPSBmYWxzZQ0KICAgICAgdGhpcy5pc0V4cGFuZEFsbCA9ICF0aGlzLmlzRXhwYW5kQWxsDQogICAgICB0aGlzLiRuZXh0VGljaygoKSA9PiB7DQogICAgICAgIHRoaXMucmVmcmVzaFRhYmxlID0gdHJ1ZQ0KICAgICAgfSk7DQogICAgfSwNCiAgICAvKiog5L+u5pS55oyJ6ZKu5pON5L2cICovDQogICAgaGFuZGxlVXBkYXRlOmRlYm91bmNlKGFzeW5jIGZ1bmN0aW9uKHJvdyl7DQogICAgICB0aGlzLnJlc2V0KCkNCiAgICAgIHRoaXMuZ2V0VHJlZXNlbGVjdCgpDQoNCiAgICAgIHZhciBzZWFyY2hQYXJhbXMgPSB7DQogICAgICAgICAgbWVudUlkOiByb3cubWVudUlkDQogICAgICB9DQogICAgICBhd2FpdCB0aGlzLiRheGlvcy5nZXQoJy9zeXNNZW51Q29udHJvbGxlci9nZXREZXRhaWxJbmZvJywNCiAgICAgICAgICB7cGFyYW1zOiBzZWFyY2hQYXJhbXN9KS50aGVuKChyZXMpID0+IHsNCiAgICAgICAgdGhpcy5mb3JtID0gcmVzLmRhdGENCiAgICAgICAgaWYgKHRoaXMuZm9ybS5wYyE9bnVsbCl7DQogICAgICAgICAgdGhpcy5mb3JtLnBjID0gdGhpcy5mb3JtLnBjLnNwbGl0KCIsIikNCiAgICAgICAgfQ0KDQogICAgICAgIHRoaXMub3BlbiA9IHRydWUNCiAgICAgICAgdGhpcy50aXRsZSA9ICLkv67mlLnoj5zljZUiDQogICAgICB9KS5jYXRjaCgoZXJyb3IpID0+IHsNCiAgICAgICAgLy8gdGhpcy4kbWVzc2FnZS5lcnJvcign6I635Y+W5pWw5o2u5Ye66ZSZJyArIGVycm9yKQ0KICAgICAgfSkNCiAgICB9LDUwMCksDQogICAgLyoqIOaPkOS6pOaMiemSriAqLw0KICAgIHN1Ym1pdEZvcm06ZGVib3VuY2UoZnVuY3Rpb24oKXsNCiAgICAgIHRoaXMuJHJlZnNbImZvcm0iXS52YWxpZGF0ZShhc3luYyB2YWxpZCA9PiB7DQogICAgICAgIGlmICh2YWxpZCkgew0KICAgICAgICAgIGlmICh0aGlzLmZvcm0ucGMhPW51bGwpew0KICAgICAgICAgICAgdGhpcy5mb3JtLnBjID0gdGhpcy5mb3JtLnBjLmpvaW4oIiwiKQ0KICAgICAgICAgIH0NCiAgICAgICAgICBpZiAodGhpcy5mb3JtLm1lbnVJZCAhPSB1bmRlZmluZWQpIHsNCiAgICAgICAgICAgIGF3YWl0IHRoaXMuJGF4aW9zLnBvc3QoJy9zeXNNZW51Q29udHJvbGxlci91cGRhdGVNZW51JywgdGhpcy5mb3JtKS50aGVuKChyZXMpID0+IHsNCiAgICAgICAgICAgICAgdGhpcy4kbWVzc2FnZS5zdWNjZXNzKCfkv67mlLnmiJDlip/vvIEnKQ0KICAgICAgICAgICAgICB0aGlzLm9wZW4gPSBmYWxzZTsNCiAgICAgICAgICAgICAgdGhpcy5nZXRMaXN0KCk7DQogICAgICAgICAgICB9KS5jYXRjaCgoZXJyb3IpID0+IHsNCiAgICAgICAgICAgICAgLy8gdGhpcy4kbWVzc2FnZS5lcnJvcihlcnJvcikNCiAgICAgICAgICAgIH0pDQogICAgICAgICAgfSBlbHNlIHsNCiAgICAgICAgICAgIGF3YWl0IHRoaXMuJGF4aW9zLnBvc3QoJy9zeXNNZW51Q29udHJvbGxlci9hZGRNZW51JywgdGhpcy5mb3JtKS50aGVuKChyZXMpID0+IHsNCiAgICAgICAgICAgICAgdGhpcy4kbWVzc2FnZS5zdWNjZXNzKCfmlrDlop7miJDlip8nKQ0KICAgICAgICAgICAgICB0aGlzLm9wZW4gPSBmYWxzZTsNCiAgICAgICAgICAgICAgdGhpcy5nZXRMaXN0KCk7DQogICAgICAgICAgICB9KS5jYXRjaCgoZXJyb3IpID0+IHsNCiAgICAgICAgICAgICAgLy8gdGhpcy4kbWVzc2FnZS5lcnJvcihlcnJvcikNCiAgICAgICAgICAgIH0pDQogICAgICAgICAgfQ0KICAgICAgICB9DQogICAgICB9KTsNCiAgICB9LDEwMDApLA0KICAgIC8qKiDliKDpmaTmjInpkq7mk43kvZwgKi8NCiAgICBoYW5kbGVEZWxldGUocm93KSB7DQogICAgICB0aGlzLiRjb25maXJtKCfmmK/lkKbnoa7orqTliKDpmaTlkI3np7DkuLoiJyArIHJvdy5tZW51TmFtZSArICci55qE5pWw5o2u6aG577yfJywgJ+aPkOekuicsIHsNCiAgICAgICAgY29uZmlybUJ1dHRvblRleHQ6ICfnoa7lrponLA0KICAgICAgICBjYW5jZWxCdXR0b25UZXh0OiAn5Y+W5raIJywNCiAgICAgICAgdHlwZTogJ3dhcm5pbmcnLA0KICAgICAgICBiZWZvcmVDbG9zZShhY3Rpb24sIGluc3RhbmNlLCBkb25lKSB7DQogICAgICAgICAgaWYgKGFjdGlvbiA9PT0gImNvbmZpcm0iKSB7DQogICAgICAgICAgICBpbnN0YW5jZS4kcmVmc1siY29uZmlybSJdLiRlbC5vbmNsaWNrID0gKGZ1bmN0aW9uIChlKSB7DQogICAgICAgICAgICAgIGUgPSBlIHx8IHdpbmRvdy5ldmVudDsNCiAgICAgICAgICAgICAgaWYgKGUuZGV0YWlsICE9IDApIHsNCiAgICAgICAgICAgICAgICBkb25lKCk7DQogICAgICAgICAgICAgIH0NCiAgICAgICAgICAgIH0pKCk7DQogICAgICAgICAgfSBlbHNlIHsNCiAgICAgICAgICAgIGRvbmUoKTsNCiAgICAgICAgICB9DQogICAgICAgIH0NCiAgICAgIH0pLnRoZW4oKCkgPT4gew0KICAgICAgICB0aGlzLmRvRGVsZXRlKHJvdykNCiAgICAgIH0pLmNhdGNoKCgpID0+IHsNCiAgICAgIH0pOw0KICAgIH0sDQogICAgLyoqDQogICAgICog5Yig6Zmk5o+Q5LqkDQogICAgICovDQogICAgZG9EZWxldGU6ZGVib3VuY2UoYXN5bmMgZnVuY3Rpb24ocm93KXsNCiAgICAgIGNvbnN0IHBhcmFtID0gew0KICAgICAgICBtZW51SWQ6IHJvdy5tZW51SWQNCiAgICAgIH0NCiAgICAgIGF3YWl0IHRoaXMuJGF4aW9zLnBvc3QoJy9zeXNNZW51Q29udHJvbGxlci9kZWxNZW51JywgdGhpcy4kcXMuc3RyaW5naWZ5KHBhcmFtKSkudGhlbigocmVzKSA9PiB7DQogICAgICAgIHRoaXMuJG1lc3NhZ2Uuc3VjY2Vzcygn5Yig6Zmk5oiQ5Yqf77yBJykNCiAgICAgICAgdGhpcy5nZXRMaXN0KCk7DQogICAgICB9KS5jYXRjaCgoZXJyb3IpID0+IHsNCiAgICAgIH0pDQogICAgICB0aGlzLmxvYWRpbmcgPSBmYWxzZQ0KICAgIH0sMTAwMCkNCiAgfQ0KfQ0K"},{"version":3,"sources":["index.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"index.vue","sourceRoot":"src/views/sysManager/sysMenu","sourcesContent":["<template>\r\n <div class=\"app-container\">\r\n <el-form :model=\"queryParams\" ref=\"queryForm\" size=\"small\" :inline=\"true\" v-show=\"showSearch\">\r\n <el-form-item label=\"菜单名称\" prop=\"menuName\">\r\n <el-input\r\n maxlength=\"50\"\r\n v-model=\"queryParams.menuName\"\r\n placeholder=\"请输入菜单名称\"\r\n clearable\r\n @keyup.enter.native=\"handleQuery\"\r\n />\r\n </el-form-item>\r\n <el-form-item>\r\n <el-button type=\"primary\" icon=\"el-icon-search\" size=\"mini\" @click=\"handleQuery\">搜索</el-button>\r\n <el-button icon=\"el-icon-refresh\" size=\"mini\" @click=\"resetQuery\">重置</el-button>\r\n </el-form-item>\r\n </el-form>\r\n <el-row :gutter=\"10\" class=\"mb8\">\r\n <el-col :span=\"1.5\">\r\n <el-button\r\n type=\"primary\"\r\n plain\r\n icon=\"el-icon-plus\"\r\n size=\"mini\"\r\n @click=\"handleAdd\"\r\n >新增</el-button>\r\n </el-col>\r\n <el-col :span=\"1.5\">\r\n <el-button\r\n type=\"info\"\r\n plain\r\n icon=\"el-icon-sort\"\r\n size=\"mini\"\r\n @click=\"toggleExpandAll\"\r\n >展开/折叠</el-button>\r\n </el-col>\r\n </el-row>\r\n\r\n <el-table\r\n v-if=\"refreshTable\"\r\n v-loading=\"loading\"\r\n :data=\"menuList\"\r\n row-key=\"menuId\"\r\n :default-expand-all=\"isExpandAll\"\r\n :tree-props=\"{children: 'children', hasChildren: 'hasChildren'}\"\r\n >\r\n <el-table-column prop=\"menuName\" label=\"菜单名称\" :show-overflow-tooltip=\"true\" width=\"160\"></el-table-column>\r\n <el-table-column prop=\"icon\" label=\"图标\" align=\"center\" width=\"100\">\r\n <template slot-scope=\"scope\">\r\n <svg-icon :icon-class=\"scope.row.icon\" />\r\n </template>\r\n </el-table-column>\r\n <el-table-column prop=\"pc\" label=\"字符标识\" width=\"200\"></el-table-column>\r\n <el-table-column prop=\"orderNum\" label=\"排序\" width=\"60\"></el-table-column>\r\n <el-table-column prop=\"perms\" label=\"权限标识\" :show-overflow-tooltip=\"true\"></el-table-column>\r\n <el-table-column prop=\"component\" label=\"组件路径\" :show-overflow-tooltip=\"true\"></el-table-column>\r\n<!-- <el-table-column prop=\"status\" label=\"状态\" width=\"80\" :formatter=\"statusFormat\"/>-->\r\n <el-table-column label=\"创建时间\" align=\"center\" prop=\"createTime\">\r\n <template slot-scope=\"scope\">\r\n <span>{{ parseTime(scope.row.createTime) }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column label=\"操作\" align=\"center\" class-name=\"small-padding fixed-width\">\r\n <template slot-scope=\"scope\">\r\n <el-button\r\n size=\"mini\"\r\n type=\"text\"\r\n icon=\"el-icon-edit\"\r\n @click=\"handleUpdate(scope.row)\"\r\n >修改</el-button>\r\n <el-button\r\n size=\"mini\"\r\n type=\"text\"\r\n icon=\"el-icon-plus\"\r\n @click=\"handleAdd(scope.row)\"\r\n >新增</el-button>\r\n <el-button\r\n size=\"mini\"\r\n type=\"text\"\r\n icon=\"el-icon-delete\"\r\n @click=\"handleDelete(scope.row)\"\r\n >删除</el-button>\r\n </template>\r\n </el-table-column>\r\n </el-table>\r\n\r\n <!-- 添加或修改菜单对话框 -->\r\n <el-dialog :title=\"title\" :visible.sync=\"open\" width=\"680px\" append-to-body>\r\n <el-form ref=\"form\" :model=\"form\" :rules=\"rules\" label-width=\"100px\">\r\n <el-row>\r\n <el-col :span=\"24\">\r\n <el-form-item label=\"上级菜单\" prop=\"parentId\">\r\n <treeselect\r\n v-model=\"form.parentId\"\r\n :options=\"menuOptions\"\r\n :normalizer=\"normalizer\"\r\n :show-count=\"true\"\r\n placeholder=\"选择上级菜单\"\r\n />\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"24\">\r\n <el-form-item label=\"菜单类型\" prop=\"menuType\">\r\n <el-radio-group v-model=\"form.menuType\">\r\n <el-radio label=\"M\">目录</el-radio>\r\n <el-radio label=\"C\">菜单</el-radio>\r\n <el-radio label=\"F\">按钮</el-radio>\r\n </el-radio-group>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"24\" v-if=\"form.menuType != 'F'\">\r\n <el-form-item label=\"菜单图标\" prop=\"icon\">\r\n <el-popover\r\n placement=\"bottom-start\"\r\n width=\"460\"\r\n trigger=\"click\"\r\n @show=\"$refs['iconSelect'].reset()\"\r\n >\r\n <IconSelect ref=\"iconSelect\" @selected=\"selected\" />\r\n <el-input slot=\"reference\" v-model=\"form.icon\" placeholder=\"点击选择图标\" readonly>\r\n <svg-icon\r\n v-if=\"form.icon\"\r\n slot=\"prefix\"\r\n :icon-class=\"form.icon\"\r\n class=\"el-input__icon\"\r\n style=\"height: 32px;width: 16px;\"\r\n />\r\n <i v-else slot=\"prefix\" class=\"el-icon-search el-input__icon\" />\r\n </el-input>\r\n </el-popover>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\">\r\n <el-form-item label=\"菜单名称\" prop=\"menuName\">\r\n <el-input v-model=\"form.menuName\" placeholder=\"请输入菜单名称\" maxlength=\"50\"/>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\">\r\n <el-form-item label=\"显示排序\" prop=\"orderNum\">\r\n <el-input-number v-model=\"form.orderNum\" controls-position=\"right\" :min=\"0\" />\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\" v-if=\"form.menuType != 'F'\">\r\n <el-form-item prop=\"isFrame\">\r\n <span slot=\"label\">\r\n <el-tooltip content=\"选择是外链则路由地址需要以`http(s)://`开头\" placement=\"top\">\r\n <i class=\"el-icon-question\"></i>\r\n </el-tooltip>\r\n 是否外链\r\n </span>\r\n <el-radio-group v-model=\"form.isFrame\">\r\n <el-radio label=\"0\">是</el-radio>\r\n <el-radio label=\"1\">否</el-radio>\r\n </el-radio-group>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\" v-if=\"form.menuType != 'F'\">\r\n <el-form-item prop=\"path\">\r\n <span slot=\"label\">\r\n <el-tooltip content=\"访问的路由地址,如:`user`,如外网地址需内链访问则以`http(s)://`开头\" placement=\"top\">\r\n <i class=\"el-icon-question\"></i>\r\n </el-tooltip>\r\n 路由地址\r\n </span>\r\n <el-input v-model=\"form.path\" placeholder=\"请输入路由地址\" maxlength=\"200\"/>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\" v-if=\"form.menuType == 'C'\">\r\n <el-form-item prop=\"component\">\r\n <span slot=\"label\">\r\n <el-tooltip content=\"访问的组件路径,如:`system/user/index`,默认在`views`目录下\" placement=\"top\">\r\n <i class=\"el-icon-question\"></i>\r\n </el-tooltip>\r\n 组件路径\r\n </span>\r\n <el-input v-model=\"form.component\" placeholder=\"请输入组件路径\" maxlength=\"200\"/>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\" v-if=\"form.menuType != 'M'\">\r\n <el-form-item prop=\"perms\">\r\n <el-input v-model=\"form.perms\" placeholder=\"请输入权限标识\" maxlength=\"100\" />\r\n <span slot=\"label\">\r\n <el-tooltip content=\"控制器中定义的权限字符,如:@PreAuthorize(`@ss.hasPermi('system:user:list')`)\" placement=\"top\">\r\n <i class=\"el-icon-question\"></i>\r\n </el-tooltip>\r\n 权限字符\r\n </span>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\" v-if=\"form.menuType == 'C'\">\r\n <el-form-item prop=\"query\">\r\n <el-input v-model=\"form.query\" placeholder=\"请输入路由参数\" maxlength=\"200\" />\r\n <span slot=\"label\">\r\n <el-tooltip content='访问路由的默认传递参数,如:`{\"id\": 1, \"name\": \"ry\"}`' placement=\"top\">\r\n <i class=\"el-icon-question\"></i>\r\n </el-tooltip>\r\n 路由参数\r\n </span>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\" v-if=\"form.menuType == 'C'\">\r\n <el-form-item prop=\"isCache\">\r\n <span slot=\"label\">\r\n <el-tooltip content=\"选择是则会被`keep-alive`缓存,需要匹配组件的`name`和地址保持一致\" placement=\"top\">\r\n <i class=\"el-icon-question\"></i>\r\n </el-tooltip>\r\n 是否缓存\r\n </span>\r\n <el-radio-group v-model=\"form.isCache\">\r\n <el-radio label=\"0\">缓存</el-radio>\r\n <el-radio label=\"1\">不缓存</el-radio>\r\n </el-radio-group>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\" v-if=\"form.menuType != 'F'\" v-show=\"false\">\r\n <el-form-item prop=\"visible\">\r\n <span slot=\"label\">\r\n <el-tooltip content=\"选择隐藏则路由将不会出现在侧边栏,但仍然可以访问\" placement=\"top\">\r\n <i class=\"el-icon-question\"></i>\r\n </el-tooltip>\r\n 显示状态\r\n </span>\r\n <el-radio-group v-model=\"form.visible\">\r\n <el-radio\r\n v-for=\"dict in sysShow\"\r\n :key=\"dict.value\"\r\n :label=\"dict.value\"\r\n >{{dict.label}}</el-radio>\r\n </el-radio-group>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\" v-if=\"form.menuType != 'F'\" v-show=\"false\">\r\n <el-form-item prop=\"status\" >\r\n <span slot=\"label\">\r\n <el-tooltip content=\"选择停用则路由将不会出现在侧边栏,也不能被访问\" placement=\"top\">\r\n <i class=\"el-icon-question\"></i>\r\n </el-tooltip>\r\n 菜单状态\r\n </span>\r\n <el-radio-group v-model=\"form.status\">\r\n <el-radio\r\n v-for=\"dict in menuStatus\"\r\n :key=\"dict.value\"\r\n :label=\"dict.value\"\r\n >{{dict.label}}</el-radio>\r\n </el-radio-group>\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\" v-if=\"form.menuType == 'C'\">\r\n <el-form-item label=\"字符标识\" prop=\"pc\">\r\n <el-select\r\n multiple\r\n v-model=\"form.pc\"\r\n placeholder=\"请选择字符标识\"\r\n >\r\n <el-option\r\n v-for=\"item in pcOptions\"\r\n :key=\"item.value\"\r\n :label=\"item.label\"\r\n :value=\"item.value\">\r\n </el-option>\r\n </el-select>\r\n </el-form-item>\r\n </el-col>\r\n </el-row>\r\n </el-form>\r\n <div slot=\"footer\" class=\"dialog-footer\">\r\n <el-button type=\"primary\" @click=\"submitForm\">确 定</el-button>\r\n <el-button @click=\"cancel\">取 消</el-button>\r\n </div>\r\n </el-dialog>\r\n </div>\r\n</template>\r\n\r\n<script>\r\n\r\nimport Treeselect from \"@riophae/vue-treeselect\";\r\nimport \"@riophae/vue-treeselect/dist/vue-treeselect.css\";\r\nimport IconSelect from \"@/components/IconSelect\";\r\nimport { debounce } from 'lodash'\r\nexport default {\r\n name: \"Menu\",\r\n dicts: ['sys_show_hide', 'sys_normal_disable'],\r\n components: { Treeselect, IconSelect },\r\n data() {\r\n return {\r\n pcOptions: [\r\n {value: 'XTGL', label: 'XTGL'},\r\n {value: 'SJGL', label: 'SJGL'},\r\n {value: 'SHGL', label: 'SHGL'},\r\n {value: 'YWGL', label: 'YWGL'},\r\n {value: 'SJYW', label: 'SJYW'},\r\n {value: 'YWPZ', label: 'YWPZ'},\r\n {value: 'YWCZ', label: 'YWCZ'}\r\n ],\r\n // 遮罩层\r\n loading: true,\r\n // 显示搜索条件\r\n showSearch: true,\r\n // 菜单表格树数据\r\n menuList: [],\r\n sysShow: [\r\n {value: '0', label: '显示菜单'},\r\n {value: '1', label: '隐藏菜单'}\r\n ],\r\n menuStatus: [\r\n {value: '0', label: '正常'},\r\n {value: '1', label: '停用'}\r\n ],\r\n // 菜单树选项\r\n menuOptions: [],\r\n // 弹出层标题\r\n title: \"\",\r\n // 是否显示弹出层\r\n open: false,\r\n // 是否展开,默认全部折叠\r\n isExpandAll: false,\r\n // 重新渲染表格状态\r\n refreshTable: true,\r\n // 查询参数\r\n queryParams: {\r\n menuName: undefined,\r\n visible: undefined\r\n },\r\n // 表单参数\r\n form: {},\r\n // 表单校验\r\n rules: {\r\n menuName: [\r\n { required: true, message: \"菜单名称不能为空\", trigger: \"blur\" }\r\n ],\r\n pc: [\r\n { required: true, message: \"字符标识不能为空\", trigger: \"blur\" }\r\n ],\r\n orderNum: [\r\n { required: true, message: \"菜单顺序不能为空\", trigger: \"blur\" }\r\n ],\r\n path: [\r\n { required: true, message: \"路由地址不能为空\", trigger: \"blur\" }\r\n ]\r\n }\r\n };\r\n },\r\n created() {\r\n this.getList()\r\n },\r\n methods: {\r\n // 列表状态格式化\r\n statusFormat(row, column) {\r\n let belongTo = '未知的类型'\r\n for (let i = 0; i < this.menuStatus.length; i++) {\r\n if (row.status == \"0\") {\r\n belongTo = \"正常\"\r\n } else if (row.status == \"1\") {\r\n belongTo = \"停用\"\r\n }\r\n }\r\n return belongTo\r\n },\r\n // 选择图标\r\n selected(name) {\r\n this.form.icon = name\r\n },\r\n /** 查询菜单列表 */\r\n async getList(){\r\n this.loading = true;\r\n const param = {\r\n menuName: this.queryParams.menuName\r\n }\r\n console.log(param)\r\n await this.$axios.get('/sysMenuController/list',{params: param}).then((res) => {\r\n this.menuList = this.handleTree(res.data, \"menuId\")\r\n this.loading = false;\r\n }).catch((error) => {\r\n this.loading = false;\r\n })\r\n },\r\n /** 转换菜单数据结构 */\r\n normalizer(node) {\r\n if (node.children && !node.children.length) {\r\n delete node.children\r\n }\r\n return {\r\n id: node.menuId,\r\n label: node.menuName,\r\n children: node.children\r\n };\r\n },\r\n /** 查询菜单下拉树结构 */\r\n async getTreeselect() {\r\n await this.$axios.get('/sysMenuController/list').then((res) => {\r\n this.menuOptions = []\r\n const menu = { menuId: 0, menuName: '主类目', children: [] }\r\n menu.children = this.handleTree(res.data, \"menuId\")\r\n this.menuOptions.push(menu)\r\n })\r\n },\r\n // 取消按钮\r\n cancel() {\r\n this.open = false\r\n this.reset()\r\n },\r\n // 表单重置\r\n reset() {\r\n this.form = {\r\n menuId: undefined,\r\n parentId: 0,\r\n menuName: undefined,\r\n icon: undefined,\r\n menuType: \"M\",\r\n orderNum: undefined,\r\n isFrame: \"1\",\r\n isCache: \"0\",\r\n visible: \"0\",\r\n status: \"0\"\r\n };\r\n this.resetForm(\"form\")\r\n },\r\n /** 搜索按钮操作 */\r\n handleQuery:debounce(function(){\r\n this.getList()\r\n },1000),\r\n /** 重置按钮操作 */\r\n resetQuery() {\r\n this.resetForm(\"queryForm\")\r\n },\r\n /** 新增按钮操作 */\r\n handleAdd:debounce(function(row){\r\n this.reset()\r\n this.getTreeselect();\r\n if (row != null && row.menuId) {\r\n this.form.parentId = row.menuId\r\n } else {\r\n this.form.parentId = 0\r\n }\r\n this.open = true\r\n this.title = \"添加菜单\"\r\n },500),\r\n /** 展开/折叠操作 */\r\n toggleExpandAll() {\r\n this.refreshTable = false\r\n this.isExpandAll = !this.isExpandAll\r\n this.$nextTick(() => {\r\n this.refreshTable = true\r\n });\r\n },\r\n /** 修改按钮操作 */\r\n handleUpdate:debounce(async function(row){\r\n this.reset()\r\n this.getTreeselect()\r\n\r\n var searchParams = {\r\n menuId: row.menuId\r\n }\r\n await this.$axios.get('/sysMenuController/getDetailInfo',\r\n {params: searchParams}).then((res) => {\r\n this.form = res.data\r\n if (this.form.pc!=null){\r\n this.form.pc = this.form.pc.split(\",\")\r\n }\r\n\r\n this.open = true\r\n this.title = \"修改菜单\"\r\n }).catch((error) => {\r\n // this.$message.error('获取数据出错' + error)\r\n })\r\n },500),\r\n /** 提交按钮 */\r\n submitForm:debounce(function(){\r\n this.$refs[\"form\"].validate(async valid => {\r\n if (valid) {\r\n if (this.form.pc!=null){\r\n this.form.pc = this.form.pc.join(\",\")\r\n }\r\n if (this.form.menuId != undefined) {\r\n await this.$axios.post('/sysMenuController/updateMenu', this.form).then((res) => {\r\n this.$message.success('修改成功!')\r\n this.open = false;\r\n this.getList();\r\n }).catch((error) => {\r\n // this.$message.error(error)\r\n })\r\n } else {\r\n await this.$axios.post('/sysMenuController/addMenu', this.form).then((res) => {\r\n this.$message.success('新增成功')\r\n this.open = false;\r\n this.getList();\r\n }).catch((error) => {\r\n // this.$message.error(error)\r\n })\r\n }\r\n }\r\n });\r\n },1000),\r\n /** 删除按钮操作 */\r\n handleDelete(row) {\r\n this.$confirm('是否确认删除名称为\"' + row.menuName + '\"的数据项?', '提示', {\r\n confirmButtonText: '确定',\r\n cancelButtonText: '取消',\r\n type: 'warning',\r\n beforeClose(action, instance, done) {\r\n if (action === \"confirm\") {\r\n instance.$refs[\"confirm\"].$el.onclick = (function (e) {\r\n e = e || window.event;\r\n if (e.detail != 0) {\r\n done();\r\n }\r\n })();\r\n } else {\r\n done();\r\n }\r\n }\r\n }).then(() => {\r\n this.doDelete(row)\r\n }).catch(() => {\r\n });\r\n },\r\n /**\r\n * 删除提交\r\n */\r\n doDelete:debounce(async function(row){\r\n const param = {\r\n menuId: row.menuId\r\n }\r\n await this.$axios.post('/sysMenuController/delMenu', this.$qs.stringify(param)).then((res) => {\r\n this.$message.success('删除成功!')\r\n this.getList();\r\n }).catch((error) => {\r\n })\r\n this.loading = false\r\n },1000)\r\n }\r\n}\r\n</script>\r\n"]}]}