(function(global2, factory) { typeof exports === "object" && typeof module !== "undefined" ? factory(exports, require("vue"), require("ddei-editor")) : typeof define === "function" && define.amd ? define(["exports", "vue", "ddei-editor"], factory) : (global2 = typeof globalThis !== "undefined" ? globalThis : global2 || self, factory(global2["ddei-flow"] = {}, global2.Vue, global2["ddei-editor"])); })(this, function(exports, vue, ddeiEditor) { "use strict";var __defProp = Object.defineProperty; var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; var __publicField = (obj, key, value) => { __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value); return value; }; var __vite_style__ = document.createElement("style"); __vite_style__.textContent = `@font-face { font-family: "icon-ddei-flow"; /* Project id 4654254 */ src: url('data:application/vnd.ms-fontobject;base64,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AAAAAAAMAAAAAAVcAAAAAAAAAHEAANbvAADW7wAAAGsAAOZ7AADmewAAAGUAAOaBAADmgQAAABkAAOaCAADmggAAABUAAOaDAADmgwAAAAYAAOaFAADmhQAAAEYAAOaGAADmhgAAAEUAAOaHAADmhwAAAEoAAOaIAADmiAAAAEQAAOaKAADmigAAADsAAOaLAADmiwAAAC8AAOaMAADmjAAAADAAAOaNAADmjQAAADEAAOaOAADmjgAAADIAAOaPAADmjwAAAGgAAOaQAADmkAAAADMAAOaRAADmkQAAADQAAOaSAADmkgAAADUAAOaTAADmkwAAADYAAOaUAADmlAAAADcAAOaVAADmlQAAAGYAAOaWAADmlgAAADgAAOaXAADmlwAAAGkAAOaYAADmmAAAADkAAOaZAADmmQAAAGoAAOaaAADmmgAAADoAAOabAADmmwAAADwAAOacAADmnAAAAD0AAOadAADmnQAAAD4AAOaeAADmngAAAD8AAOafAADmnwAAAGIAAOagAADmoAAAAEAAAOahAADmoQAAAEEAAOaiAADmogAAAAMAAOajAADmowAAAEIAAOakAADmpAAAAG4AAOalAADmpQAAAAIAAOamAADmpgAAAEMAAOanAADmpwAAAAUAAOaoAADmqAAAAEcAAOapAADmqQAAAEgAAOaqAADmqgAAAEkAAOarAADmqwAAAEsAAOasAADmrAAAAEwAAOatAADmrQAAAE0AAOauAADmrgAAAE4AAOavAADmrwAAAE8AAOawAADmsAAAAFAAAOaxAADmsQAAAFEAAOayAADmsgAAAFIAAOazAADmswAAAFMAAOa0AADmtAAAAFQAAOa1AADmtQAAAFUAAOa2AADmtgAAAFYAAOa3AADmtwAAACQAAOa4AADmuAAAAFcAAOa5AADmuQAAAGEAAOa6AADmugAAAFgAAOa7AADmuwAAAFkAAOa8AADmvAAAAAQAAOa9AADmvQAAAFoAAOa+AADmvgAAAFsAAOa/AADmvwAAAF0AAObAAADmwAAAAF4AAObBAADmwQAAAAUAAObCAADmwgAAAF8AAObDAADmwwAAAAEAAObEAADmxAAAAAcAAObFAADmxQAAAAgAAObGAADmxgAAAAkAAObHAADmxwAAAAoAAObJAADmyQAAAAsAAObKAADmygAAAAwAAObLAADmywAAAA0AAObOAADmzgAAAGQAAObPAADmzwAAAGAAAObQAADm0AAAAGwAAObRAADm0QAAAA4AAObSAADm0gAAAG0AAObTAADm0wAAAGMAAObYAADm2AAAAA8AAObZAADm2QAAAGcAAObaAADm2gAAABAAAObcAADm3AAAABEAAObdAADm3QAAABIAAObeAADm3gAAABMAAObfAADm3wAAABQAAObgAADm4AAAABYAAObhAADm4QAAABcAAObiAADm4gAAABgAAObjAADm4wAAABoAAObkAADm5AAAABsAAOblAADm5QAAABwAAObmAADm5gAAAB0AAObnAADm5wAAAB4AAObpAADm6QAAAB8AAObsAADm7AAAACAAAObyAADm8gAAACEAAOb1AADm9QAAACIAAOb2AADm9gAAACMAAOb3AADm9wAAACQAAOb4AADm+AAAACUAAOb5AADm+QAAACYAAOb6AADm+gAAACcAAOb7AADm+wAAACgAAOb8AADm/AAAAAoAAOb9AADm/QAAACkAAOb+AADm/gAAACoAAOb/AADm/wAAACsAAOcBAADnAQAAACwAAOcCAADnAgAAAC0AAOcDAADnAwAAAC4AAOgIAADoCAAAAFwAAAAAAagCZAKqAxYDsgbOBzgHoAj0Cc4KGgvQDIANQA2MDmAO3g+sD/QQQBEGEfwSXhLaE4AToBREFNgVVBW4FkIWgBa2F0QX4BhGGfYbkhwSHGYcyB1aHiwhYiHOIgAigiV2JcYl/iZ0KAIoSiiOKRYpgincKmorPCuSK/AsaCzgLVQweDC2MU40UDdSN4Y4MjjKOQQ8GjyOPLI9AD1CPco+Yj6yP2ZAEEBkQJhAxkJiQrBDHEUSRWRGRkaWRuxIqkkASVhJlEoaSl5K3ktUS85MZEyUTLpNKk1KTWpO1AAQAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BIAEvATIBQQAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicBFSc3Ig8BBhQfARYyNj0BNCYXFSc3Ig8BBhQfARYyNj0BNCYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P/vRBWwYEhQcHhQQNCgqGQVoFBYUGBoUEDQoKAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkI/rtiMXcEZQURBWUDCQjKCAlGYjF3BGUFEQVlAwkIyggJAAYAAP/VA6sDKwAUACkANgBLAG8AhwAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgMjIiY9ASMiJj0BNDY7ATU0NjsBMhYdATMyFh0BFAYrARUUBiczNTQ2OwE1IyImPQEjFRQGKwEVMzIWFQIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSiRmCQxFCQwMCUUMCWYJDEUJDAwJRQxZOg0JREQJDToNCURECQ0C6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+HgwJRQwJZgkMRQkMDAlFDAlmCQxFCQwrRAkNOg0JREQJDToNCQAAAAAEAAAAAAOrAsAAAwATAB4ALAAAAREhESUhIgYVERQWMyEyNjURNCYFByc1NDYzITIWHQIUBiMhIiY9ARcWNzMDbf0mAu78/hEZGREDAhEZGf6ZrakTDAEYDBMTDP7oDBOhCAkBAoL9/AIEPhgR/dIRGBgRAi4RGKtkYQ8NEhINMKkNEhINp10FBgAAAAUAAP/VA6sDKwAUACkAOQA8AEYAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJhMhIgYdARQWMyEyNj0BNCYHJzMHNRczFjI3MzcVAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjH/7bBwkJBwElBgkJmVu20msBBgoGAWsC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv+zAkGzwcJCQfPBglkOZh4RAMDRHgAAAcAAP/VA6sDKwAUACkANgBLAFsAXgBoAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmFyEiBh0BFBYzITI2PQE0JgcnMwc1FzMWMjczNxUCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUo8/tsHCQkHASUGCQmZW7bSawEGCgYBawLrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4O6tFdop2RUV2inZFQCwqSUquSkkqLCwqSUquSkkqLMkJBs8HCQkHzwYJZDmYeEQDA0R4ABcAAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQE4AUQBoQHEAdMB+gIHAhUCTwJsAnoAAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnBQYHBgcxFSMVIxUxFSM5ARUjFTEGBxc3Nj8BBwYHFRQXNzU0PwEnFwcWHwEVMxUxFTMVMRUzFTEVMRUzFTMVMxUxFTMVMRcVMxcVMRUzFTMVMRUxFTMxMxUxFTMVMRUxFTMVOQEzFTEVMRUzFTEVMxU5ATMVMRUxFTMXFhcWFzcnJi8BFwcWFzMVMxUzMTMVMxUzFTMWFzMXMxczFTMVFxYXNycmLwEhBwYPARc2NzY/ATY3Nj8BBwYPARc2NzUxNTM1MTUzNTM1MTUxNTM1OQEzNTE1MzUxNTE2Nyc3BxcWHQEHFzY3NSYvAQcXFh8BNyYvASYnJi8BIgcjFSMVIzEjByMVIwcjByMHIxUjMSMVIxUjFSMVIwYHFzc2OwEyHwE3Ji8BIycjJyMnIyYnMSYjEyIvAQYPAQYHDgEuATc2PwE2Nz4BMhYfARYXFgYnMTIfAScGDwEGBzY3NgIAFAkHLCQMICQkDxAmIR8RFBICAgMBISMRErENDxEBAgIBAQIBAQEBAgEBAQEDAQEHGhUoGRsgHR+jCQoOAQEBAwQCAwUFOgwMFRE1WwIBAQECBD4EAwECP1E5DAYBDxEBDAgzExUPDmgmExQBAQIBGR0ODxsdIB4ZnwkUFxQNIRMVBDUYGx8BLRseIx4WEQ4qIgcNByJxEBIYFTALCwkBAgEBAQEBAQMWEDYjAQcHPRIBQTgPEQsJPAMHAwgMEZ8jGx4aFywlMAEBDQ/+hAkRHRYBAQEBDAoyExQcGakOAwI+Bwc8NzkGBgMBAQEBAQEBAQEBAQEBAQEBAQEBAQEDBgQJDDAUFw0Obh0NEQECAQIBAgEWFAIBAgECAxAPEQ0gIR8cAR4dHiIgDAwUGBwFEAgQC0wODxYVLxUSAQEBAQEBFQ05Pj0HBgI/AgECDoAnGRsTEzMFCQMZIQwOsRIIBwYFBQEEAwEDAQIDAwMDAwIDARAOEB8hIgQhIx8REgwMAgECAQIBAw4UFQtsCgZbDRcCHRkFDw0EAhQgASAWAgsOCwI1IxMDDXUJByo7ChMDCg0UFQYDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQhoBQ0XGwEBAQEBAg8RJRobFhRzKCklCxUBKB4eHw6zGhENBwEBAQIBCgECAgICAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQIECAQMDCkYHB4dhDcJCQEBAQEBCgYBAQEBAwQCPQcHDw8PDwYGPgEEBAoCBwQICL4eIBgZKRUXAQEBAQEBAQEBAQICASAjG7UOHxkfDCADDhIgLSqkMRQWGxokCA4FIxsKCTQBAQEBAQEBAQEBAQEBBQU8CAkKCTwHAwMBAQEEAgL+AAdjDRsBIhkFAggOBzdxA3A8BwcIB6tyOQoSngctvSFCCSUpFhUGAAAABQAAAAADSwMgAAgAGgAfADsASQAAASMiJj0BMxUzEyEiJjURNDYzITIfARYVERQGJSERJyEXIi4BPQEjIiY9ATQ2OwE1ND4BFh8BFhQPAQYjJzMyFh0BNycVFAYrARUDKtYNE0C2Af2qDRMTDQF/DgnWChP9vQIWxP6upgQJBl0IDAwIXQYKDARUBgZUBgddXQgLJSULCF0CCRMN1rb9whMNAtUNEwnXCQ3+AQ0TQAHSw94ECQYkCwgvCAwjBgoEAgRPBREGTwVeCwgLIyIKCAsJAAAEAAD/1QOrAysAFAApADUAQQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmARcWNj0BNCYPAQYUHwEWNj0BNCYPAQYUAgBRRkMoKSkoQ0aiRkMoKSkoQ0ZRdGNhODs7OGFj6GNhODs7OGFj/t+BCRISCYEGqIIIEhIIggYCqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODv+SGMGCQrGCgkGYwUQBWMGCQrGCgkGYwUQAAAABAAA/+4DoAMmAGkA6AD1AP4AAAUjIiY9ATQnJg8BBiIvASY0PwE2JyYrASImPQE0NjsBMjc2LwEmND8BNjIfARY3Nj0BNDY7ATIWHQEUFxY/ATYyHwExFhQPAQYXFjsBMhYdARQGKwEiBwYfARYUDwEGIi8BJgcGHQEUBiMnMhceAR0BFBY7ATI2PQE0Njc2Fh8BFhcwMTI/ATY0LwEuATc+ATsBMjY9ATQmKwEiJicmNj8BNjQnMScmIg8BDgEnLgE9ATQmKwEiBh0BFAYHBiYvAS4BByMHBhQfAR4BBw4BKwEiBh0BFBY7ATIWFxYGDwEGFB8BFjI3Mzc2NyIuATQ+ATIeARQOASciBhQWMjY0JgIvVR4sBwkFEhU+FjsWFhEFAwMHGR8rKx8ZBwIFBRIWFjwWPRYRBQcKKx9UHysHCgUSFj0VPBYWEQUDAwgYHywsHxsHAgUFEhYWOxY9FREGBgorH60SDhQaBgRVBAYbFhMuERECBQUCPAICEREICgcmFxwEBgYEGRgmCAkJEREDAzwDCQMREC8WFBsGBFQEBxsWEy4QEQMIAwE8AwMSEAgKByYXGQQGBgQZFyYICQgREQMDOwMIAwERFaMrSSsrSVZIKytIKyg3OE43NxArHxsHAgQFERYWOxY+FREFBworH1QfKwcJBRIWPRY8FRURBQIEBxkfKysfGQcCBQUSFRU8Fz0WEQUGCiwfVR8rBwkFEhY+FTwVFREFAgQHGR8rsQcHJhcbBAYGBBkXJwcJCBERAgEDOwMJAhIQLxUUGwYEVQUGGxYTLhARAwgDPQMDEREICgcmGBgFBgYFGBgmCAkJEBEDAQM8AwgDEhEuFRQbBgRUBAYcFhMuEBEDCAQ7AwMSFUwrSVZIKytIVkkr/ThONzdOOAAFAAAAAAOrAsAADwATADMAaACYAAABISIGFREUFjMhMjY1ETQmAyERIQEhMjY9ATQmLwEmMRcWMTY0JiIGFRQWFwcOAR0BFBYzNw4BDwEGBzEGIwYiLwEmLwEmLwE0JzY3PgImJy4BNzY3NjIXFj8BFhUUBgcOARceARcUDwE0NjcXFh8BFh8BFh8BFjI/ATY/ATY/ATY3NR4BHQEjNTQmIgYdASM1NCYiBh0BIwOB/P4RGRkRAwIRGRkl/SYC2v1oAREGCTApFwITAhoxRjEODAQpMAkGrgEDAwUDBQICCA0IBAUDBAMCAgELCQUHAQUFFxQJAwMWEQwSEwIJFREFBgEBFgoBoR4ZAQUEAgUHAwcJBAsRCwQKBwIGBgMFBBodIgkMCXMJDAkiAsAYEf3SERgYEQIuERj9vgIE/okJBhctSxMKAQkBGUcyMiMRHwwCEkstGAYJlwMEBQQDAgIDAwICAwQDBAUBAgMBAQgKCQEIKxYFBQkHCwUBDg4RHQUCCAYLBAMCAXEfNxABCgYDBQYCBAQBAwMBBAQCBAcDBwkBEDcfCDEGCQkGMTEGCQkGMQAACQAAAAADrQKfAAMAEwAXABsAHwAjACcAKwAvAAABESERJSEiBhURFBYzITI2NRE0JgEzFSMhIzUzByM1MwcjNTMHIzUzByM1MyEzFSMDbP0rAu38/BEYGBEDBBAYGPzuKioCqlVVgFVVgFVVgFVVgFVVAisrKwJf/hgB6EAYEf3qERgYEQIWERj+5zY2NjY2NjY2NjY2AAAOAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BOgFIAAABIwcjBgcXNzY7ARcWHwE3JicjNSM1IzUjJicmIwcGDwEjFSMVByMxIxUjFSMVIxUjFSMVIzEjFSMVIxUjByMVMRUjFQcGBxc3Nj8BJwcGDwEVIxUxFSMVMRUxFSMHFTEHFQcVBwYHFzc2PwEnBwYPARUUFxUWFzcnJjU0PwEnFwcfARUzFhcVMxUxFRYXNycmLwEXBxYXMxUzFTMVMzkBFhcWFzcnJi8BFwceARczFTM2NycHIi8BJQcGDwEXNjc2PwE2Nyc3BwYPARc2PwE1MzcxNTM1MTUzNTkCNTM1MTUzNTE1MzU5AjUzNTE1NzU2Nyc3FQYPARc2NTQvAQcXFh8BNyYnNSYnNSYvAQcXFh8BNyYnIzUjNTEmJwMiLwEGDwEGBw4BLgE3Nj8BNjc+ATIWHwEWFxYGJzEyHwEnBg8BBgc2NzYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0PZQoGWw0XAh0ZBQ8NBAIUIAEgFgILDgsCNSMTAw11CQcqOwoTAwoNFBUGAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkI/ckHYw0bASIZBQIIDgc3cQNwPAcHCAercjkKEp4HLb0hQgklKRYVBgAAAAAHAAD/1QOrAysAFAApADYASwBYAGUAdgAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3Jg4BFB4BPgI0LgEHIyImPQE0NjIWHQEzMhYUBgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSlciOiIiOkQ6IiI6IjFUMTFUYVEvL1EBLwkMDBIMGgkMDALrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4O6tFdop2RUV2inZFQCwqSUquSkkqLCwqSUquSkkqLMIiOkQ6IiI6RDoiNQEwU2FUMAIwUmBSMNgMCUsJDQ0JNQ0SDAAACQAA/9UDqwMrABQAKQA2AEsAWwBfAGsAdwCDAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmEyMiJjURNDY7ATIWFREUBiczESMXIyImNDY7ATIWFAYHIyImNDY7ATIWFAYHIyImNDY7ATIWFAYCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUoS0ggLCwjSCAwMx6yshV4ICwsIXggLCwheCAsLCF4ICwsIXggLCwheCAsLAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7q0V2inZFRXaKdkVALCpJSq5KSSosLCpJSq5KSSos/hoLCAEmCAsLCP7aCAsmAQBPCxALCxALRAsQCwsQC0QLEAsLEAsAAAAACQAAAAADugLbAA8AEwAUABgAHAAgACQAKQAtAAAlISImNRE0NjMhMhYVERQGARMlAzMlMxUjJSM1MwcjNTMHIzUzByM1MxUFMxUjA3j9QBsnJxsCwBsnJ/0lAgK+AgL9AEBAAyKUlNGTk9CTk9GTlAJPQEAZJhsBaxsnJxv+lRsmAar+lwIBZ65rlEBAQEBAQEBAKWsAAAB7AAAAAAO0AsoACQANABEAGwAfACUAKQAtADEANQA2ADcAOAA5ADoAOwA8AD0APgA/AEAAQQBEAEUARgBHAEgASQBKAEsATABNAE4ATwBQAFEAUgBTAFQAVQBWAFcAWABZAFoAWwBcAF0AXgBiAGYAZwBoAGkAagBrAGwAbQBuAG8AcABxAHIAcwB0AHUAdgB3AHgAeQB6AHsAfAB9AH4AfwCAAIEAggCDAIQAhQCGAIcAiACJAIoAiwCMAI0AjgCPAJAAkQCSAJMAlACVAJYAlwCYAJkAmgCbAJwAnQCeAJ8AoAChAKIAowCkAKUApgCnAKgAqQCqAKsArACtALEAAAEjFTMVMzUjNSYrARUzJyMVMycjFSMGHQEzNTMHIxUzFSMVFBczNyMVMzcjFTM3IxUzNyMVMzc5CyIjORk3IxUzESMVMwM5RgczNQOFdV5ACQzJlpbWlZXVlTUDQI2NQEBACzWZlZXWlpbVlZWpaWkLAwIoQEBAQAgECALKQCg/GRBAQEBAGgcIh3CwlUB6EAsyQEBAQEBAQAHqlQFrlgEtEBUAAAAABQAA/9UDqwMrABQAKQA2AEsAUgAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgcVIxUzFTcCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUpAqKh6AusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7q0V2inZFRXaKdkVALCpJSq5KSSosLCpJSq5KSSosr0uMS5EABgAA/9UDqwMrABQAKQA2AEsAcACIAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmAyIvAQcGIi8BJjQ/AScmND8BNjIfATc2Mh8BFhQPARcWFA8BBicXNzYyHwE3JyY0PwEnBwYiLwEHFxYUBwIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJShcJBjExBhIGSAYGMTEGBkgGEgYxMQYSBkgGBjExBgZIBrIpMQYSBjEpMQYGMSkxBhIGMSkwBwcC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+IwcwMAcHRwcSBTExBhIGRwcHMDAHB0cHEgUxMQYSBkcHXSkxBgYxKTEGEgYxKTEGBjEpMQYSBgAAAAQAAAAAA4ADCQADABMAIAAsAAABESERJSEiBhURFBYzITI2NRE0JgEiJjURNDYyFhURFAY3ISImNDYzITIWFAYDPP2KAo79WREZGRECpxIZGf6bDRMTGhMTnv6qDRMTDQFWDRMTAsb9igJ2QxkS/VkSGRkSAqcSGf23Ew0BVQ0TEw3+qw0TqxMaExMaEwAAAAUAAAAAA6sCwAADABMAIwAmADAAAAERIRElISIGFREUFjMhMjY1ETQmBSEiBh0BFBYzITI2PQE0JgcnMwU1FxYzMTI/ARUDbf0mAu78/hEZGREDAhEZGf6h/rQICgoIAUwHCgqtder+/oIFBQUGgQKC/fwCBD4YEf3SERgYEQIuERiACgfqCAoKCOoHCnRJuJVSAwNSlQAACAAAAAADqwLAAAMAEwAxAFgAZABwAHwAiAAAAREhESUhIgYVERQWMyEyNjURNCYFBhUUFxYXFRYXFhUUBgcjNjc2JyYnLgE3Njc2NzM3IwcGBw4BFxYXFhcWBwYHBhY7ATc2NzY1NCcmJyYnJjU0NzY3NiYHIyImNDY7ATIWFAYHIyImNDY7ATIWFAYXIyImNDY7ATIWFAYXIyImNDY7ATIWFAYDbf0mAu78/hEZGREDAhEZGf4AEw4JFBEGCBQNeAgEChAKGRQNAgcSCw5tQbQPEg0TDg0JGBUGCwUNMAQBBMsOEQoODQgVEAYKFQ8XAgFyUAYJCQZQBgkJBkAHCAgHQAYJCRowBgkJBjAGCQkaUAYJCQZQBgkJAoL9/AIEPhgR/dIRGBgRAi4RGJ4bHhkUDBABDQgMEgYSBwwMHRsQFhETChQOCgUeBgoMEi8VDRUSChARJRMBBwgKCxAQGxQMEA0IDRAZGBAOAgZXCQwJCQwJKwkMCQkMCSsJDAkJDAkrCQwJCQwJAAAABgAAAAADqwLAAAMAEwBbAJ0ApgCvAAABESERJSEiBhURFBYzITI2NRE0JgEjIiY9AQcGIi8BJjQ/ASciJj0BNDY7AScmND8BPgEfATc0NjsBMhYdATc2Mh8BFhQPARcyFh0BFAYrARcWFA8BBiIvAQcUBicyFx4BHQEzNTQ+ARYfATcnLgE+ATsBNSMiLgE2PwEnBw4BLgE9ASMVFA4BJi8BBxceAQ4BKwEVMzIeAQYPARc3NjciJjQ2MhYUBiciBhQWMjY0JgNt/SYC7vz+ERkZEQMCERkZ/doeDBIICRoIFQkJBgoMEhIMCQUJCRUJGQkGAhINHgwSCQkZCBYICAcKDRERDQoGCAgWCBkJBwISSggFCAseDBESBwYWBwYEBxAJCgkJEAcEBgcWBgcTEQseDBESBwYWBgcEBxAJCQkJEAcEBwYVBwg8GSMjMyMjGgwSEhkSEgKC/fwCBD4YEf3SERgYEQIuERj+YBIMCgUJCRUJGQkGAhENHg0SCAgaCBYIAQkGCQ0REQ0JBgkJFgkZCQYCEg0eDRIICRkIFgkJBwoNEUYDAhAJCgkJEAcEBgcWBgcTEAsfDBESBwYWBwYEBxAJCQkJEAcEBwYVBwcTEAsfCxETBgYWBgkVIzMjIzMjWxIaEhIaEgAABAAAAAADAQLgABMAIAA1AEIAAAEVFAYjISIGFBYzITIWHQE3NjQnFyImNRE0NjIWFREUBgUVFBYzITIWFAYjISIGHQEnJjQ/AQMiJjURNDYyFhURFAYCGgUD/vERGBgRAQ8DBYoCAjENExMaExP+3gUDAQ8RGBgR/vEDBYoCAoq7DRMTGhMTArRWBAUYIhgFA1aBAwcCvRMNASsNExMN/tUNExZWBAUYIhgFA1eCAgcDgf7CEw0BKw0TEw3+1Q0TAAAAAAUAAAAAA1QC9gAVACMAMQA/AE8AACUjIiY1ETQ2OwEyFhQGKwERMzIWFAYlIicmNj8BNh4BBg8BBjciJyY2PwE2HgEGDwEGNyInJjY/ATYeAQYPAQY3IicmNj8BPgEeAgYPAQYDM+YNExMNzQ0TEw2txg0TE/1rEAoIBAspCxoQBAsqCF4QCggECykLGhAECykJXhAKCAQLKQsbDwQLKQleEAoIBAsqBxEPCgIHBykJNRMNAoANExMaE/3AExoTgA4KGggeCAQWGggeBksNCxoIHggFFRoIHgZLDQsaCB4HBBUbBx4GSg4KGggeBQIHDhEQBR4GAAAABAAAAAADqwLAAAMAEwA6AHkAAAERIRElISIGFREUFjMhMjY1ETQmASMiJj0BNDY/AjYWFxYUBzMyFhUUFR4BFAYHFhUUBgcWFRQGKwE3BwYHDgEdARQWOwE3NjQmKwEiJjQ2OwEyNjQmKwEiJjQ2OwEyNjQmKwEiJjQ2OwEyNjQmKwEiJicmPwE+AScDbf0mAu78/hEZGREDAhEZGf3mWCU1GBUPbQcTBwsLTg8WEBYSDgIRDQEUDlMCaAkJDRAjGK0CAgMBVAYJCQZsAwUFA2wGCQkGhQYICAaFBgkJBmYDBQUDeQUIAQQJFQgGBAKC/fwCBD4YEf3SERgYEQIuERj+cDQlIBgpDApLBQEHESYOFhAGAgIVGxQDBQQNFAMFBA8W/kgGBQgcDyAZIwIDBgUIDQgFBgUJDAkFBQUJDAkFBgUGBAsGDwYSCQABAAAAAAOAAxUADQAAAQYHBgcWHwEBFwEXNjcDgE1NrFcUJhz+WB8BqFcuVgMVJydXKBMmHP5SHgGuVlunAAAABAAAAAADSwMDABgAMQBQAG8AACUiJyYnJjURNDc2NzYyFxYXFhURFAcGBwYDIgcGBwYVERQXFhcWMjc2NzY1ETQnJicmAyInJicmNTQ2MhYUFxYXFjI3Njc2NDYyFhUUBwYHBiciJyYnJjU0NjIWFBcWFxYyNzY3NjQ2MhYVFAcGBwYCAFRKTi0xMS1OSqlKTiwyMixOSlVQQTgiHx8iOEGgQjgiHx8iOEJQVEpOLTETGhMfIjhBoEI4Ih8TGhMyLE5KVVRKTi0xExoTHyI4QaBCOCIfExoTMixOSiMRER8iLQHALSIfERERER8iLf5ALSIfERECoA8MFBIP/kEPEhQNDg8MFBIPAb8PEhQMD/5AEBIfIi0NExMcEhQMDw8MFBIcExMNLSIfEhDgEBIfIi0NExMcEhQMDw8MFBIcExMNLSIfEhAAAAIAAAAAA8MDDwApAGkAACUjIi4BPQE0Njc2NyU2Fh8BFgYHMzIWFRQHHgEVFAYHFhUUBgcWFRQGIwMFBgcOAR0BFB4BMyEyNjQmKwEiJjQ2MyEyNjQmIyEiJjQ2MyEyNjQmIyEiJjQ2OwEyNjQmIyEiLgE2PwE+AScCGtg6Yjk5MRkMAQgRKw8EGwYfyCQzBCg2KyIEKSADLiHB/v0NHCIoKEQpAaMGCQkGyw0TEw0BBgsPDwv++g0TEw0BRA8WFg/+vA0TEw33Cg0NCv7aCxEGBwg0Fg0MWjliOk04YxwQCLgMBA8FJl0jMyQLDAIyIx4vBwwNIDAGCg4kMwJxtAkRFEUnTihEKA0TDRMaEw0TDRMaEw8QDxIbEw4SDgwUFAYkEDQXAAAACQAAAAADqwLAAAMAEwAjACcANwA7AEsATwBTAAABESERJSEiBhURFBYzITI2NRE0JgEhIiY9ATQ2MyEyFh0BFAYlITUhBSEiJj0BNDYzITIWHQEUBiUhNSEXIyImPQE0NjsBMhYdARQGJzM1IychFSEDbf0mAu78/hEZGREDAhEZGf5//sQFBwcFATwFBwf+zAEj/t0BL/7EBQcHBQE8BQcH/swBI/7dV2QFBwcFZAUICFxLSw0BPP7EAoL9/AIEPhgR/dIRGBgRAi4RGP56CAX5BQcHBfkFCBnh+ggFTgUHBwVOBQgZNU4IBeoFBwcF6gUIGdIWXwAHAAAAAAPLAswADwATACMAJwA3ADsAPwAAJSEiJjURNDYzITIWFREUBiUhESEBISImPQE0NjMhMhYdARQGJSE1IRchIiY1ETQ2MyEyFhURFAYnMxEjJyERIQOr/NUNExMNAysNExP86ALr/RUDC/zVDRMTDQMrDRMT/OgC6/0V4P8ADRMTDQEADRMT7b+/IAMr/NULEw0CgA0TEw39gA0TQAJA/YATDcgNExMNyA0TQIjJEw4CgA0TEw39gA4TQgI+If8AAAAAAAQAAP/VA6sDKwAUACkATQBlAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYDIyImPQEjIiY9ATQ2OwE1NDY7ATIWHQEzMhYdARQGKwEVFAYnMzU0NjsBNSMiJj0BIxUUBisBFTMyFhUCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWNBZgkMRQkMDAlFDAlmCQxFCQwMCUUMWToNCURECQ06DQlERAkNAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7/bMMCUUMCWYJDEUJDAwJRQwJZgkMRQkMK0QJDToNCURECQ06DQkAAAMAAAAAA6wCzAAPABIAIwAAASEiBhURFBYzITI2NRE0JgElIRMhIiY1EQEXFjMyPwEBERQGA2b9NB0pKR0CzB0pKf59/sMCeyj9NAIEAVgFBwgECAgBWQQCzCod/fYdKSkdAgodKv7C/v3oBAMB5P7tAwQCBQET/hwDBAADAAD/9QOLAwsADwATAB8AAAUhIiY1ETQ2MyEyFhURFAYlIREhASEiJjQ2MyEyFhQGA2v9Kg0TEw0C1g0TE/09Apb9agIg/lYNExMNAaoNExMLEw0C1g0TEw39Kg0TQAKW/pUTGhMTGhMAAAAHAAD/1QOrAysAFAApADkAPQBJAFUAYQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAyMiJjURNDY7ATIWFREUBiczESMXIyImNDY7ATIWFAYHIyImNDY7ATIWFAYHIyImNDY7ATIWFAYCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWML0ggLCwjSCAwMx6yshV4ICwsIXggLCwheCAsLCF4ICwsIXggLCwheCAsLAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7/a8LCAEmCAsLCP7aCAsmAQBPCxALCxALRAsQCwsQC0QLEAsLEAsAAAYAAP/VA6sDKwAUACkANgBLAFAAZQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgcXByMnNyIPAQ4BHwEeATsBMjY/ATYmLwEmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdEV2RUV2inZFRXZFV0pJKiwsKklKrkpJKiwsKklKV28qiipvBQaYBQQCOwIJBrwGCQI7AgQFmAUC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKizPUIODjgNvBAsFtAUHBwW0BQsEbwMAAAQAAP/VA6sDKwAUACkANQBDAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYTByc1NDYzITIWHQMUBiMhIiY9ARcWPwECAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWMwpKARDAEJDRERDf73DBGZCAibAqspKENGokZDKCkpKENGokZDKCmAOzhhY+hjYTg7OzhhY+hjYTg7/rFfXA4MEREMDCGhDBISDJ5YBQZZAA8AAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQEqATcBSAAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicHMh4BFA4BIi4BND4BNyYOARQeAT4CNC4BByMiJj0BNDYyFh0BMzIWFAYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P0CI6IiI6RDoiIjoiMVQxMVRhUS8vUQEvCQwMEgwaCQwMAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkI+CI6RDoiIjpEOiI1ATBTYVQwAjBSYFIw2AwJSwkNDQk1DRIMAAAAAA4AAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQEiATcAAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnAxcHIyc3Ig8BDgEfAR4BOwEyNj8BNiYvASYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P0G8qiipvBQaYBQQCOwIJBrwGCQI7AgQFmAUDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQj++1CDg44DbwQLBbQFBwcFtAULBG8DAAAABQAA/9UDqwMrABQAKQA2AEMAVAAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAzIeARQOASIuATQ+ATcmDgEUHgE+AjQuAQcjIiY9ATQ2MhYdATMyFhQGAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdCI6IiI6RDoiIjoiMVQxMVRhUS8vUQEvCQwMEgwaCQwMAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7/tMiOkQ6IiI6RDoiNQEwU2FUMAIwUmBSMNgMCUsJDQ0JNQ0SDAAAAAQAAP+1A8wDSwADABQAGQAuAAAJBCIHAQYUFwEWMjcBNjQnASYDFwcjJzciDwEOAR8BHgE7ATI2PwE2Ji8BJgIAAYD+gP6AAYAPC/5aCgoBpgsfCwGlCwv+WgoQbyqKKm8FBpgFBAI7AgkGvAYJAjsCBAWYBQMA/oD+gAGAAcsL/loKHwv+WgsLAaYLHwoBpgv+qVCDg44DbwQLBbQFBwcFtAULBG8DAAMAAP/VA6sDKwAUACkAPQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmDwEOAR8BHgE7ATI2PwE2Ji8BJiICAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWN/mAUEAjsCCQa8BgkCOwIEBZgFDAKrKShDRqJGQygpKShDRqJGQygpgDs4YWPoY2E4Ozs4YWPoY2E4O/9vBAsFtAYGBga0BQsEbwMAAAAFAAD/1QOrAysAFAApADYASwBfAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmDwEOAR8BHgE7ATI2PwE2Ji8BJiICAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUpimAUEAjsCCQa8BgkCOwIEBZgFDALrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4O6tFdop2RUV2inZFQCwqSUquSkkqLCwqSUquSkkqLJRvBAsFtAYGBga0BQsEbwMAAwAAAAADDAK3AB8AWACSAAABJic+ATU0LgEjIgYHBhQWFwcOAR0BFBYzITI2PQE0JiU0PwE2MhcWNzY3FhUUBgcOAR4BFxYXBg8BBg8DBg8BBiIvASYvBSYnNjc+AiYnLgE1ASM1NCYiBh0BIzU0JiIGHQEjNTQ2NxcWHwEWHwIWHwEWHwEWMj8BNj8BNj8BNj8BNj8BNj8BHgEVAmwGBxcbKEQpLUsRCxoYDUlXDgkB8QkOV/7hCAYrJBQiIgUEDyggBwoCCwgVFQIDAgIDCAsFAwQTCA4HBQUEDwkECQcDAhQWCAsBCQgfKAFISA0SDdsNEg1HOTEHAwUDBggRBgYHBwUKBg0UDQYKBQcHBgYJBAQHBwIFBAcxOQGsAwMVOiEoRCkyKhs/OhUGIYdPLAoNDQosUIaXFBMNFQ0UCAICGRsiNgoCDRELAgMHBwYEBQMLCQMCAgYCAgEBAgcHBAoMBgcHBAEMEA0DCjYh/n9eCQ0NCV5eCQ0NCV4VOmYfDwYIBAkHDgQDAwMCAwECAgEDAgMDAwQGBAQGCgMGCQ8fZjoAGAAA/9UDqwMrADsAUABjAGQAfgCoALoA0QDnAPQBGQFEAVIBXwFyAdQB4gHuAf0CDwI1Al4CggKaAAABBg8BIjc2ByMxIxUjByMVIxUjFSMVIxUxFSMxIxUjFSMVIxUjFTkBByMVIzEjFSMHBgcXNzY/ATM/AScHBgcVBxUHFQcVMQYHFzc2PwMnBwYUFxUXFTEVFhcWFzcnJjU3Jx8BBxYXMRUzOQEVMxUxFRYXFhc3JyYvBBcHFh8BMxUzMTMVFzMVMxUzFTMVMxczFTMVMxUzMTMVFxYXNycmLwExJwUHBisBJwcWMzI3MzY/ATY3JzcHBg8BIw8BFzY3MzUzNTM1MzU3NjcnNwcGDwMXNjc1MzU3Njc1NzU2Nyc3BxcWHQEHFzY1JyYvAQcXFh8ENyYvATU5ASM1MTUnNSM5ATUjNTE1JzUxNSMmLwEHFxYfATMXNyYvASM1IycjNSMxIzUjJyM1IzUjNSM1IycjNSM1IzUjJi8BIgcjBgcXNzY7ARc3JgcGBxc3Nj8CMz8BJwcGDwEVFxYXNycmNTQ3NTc1NycXBxYfARUzOQEVMRUzFTEVMxUxFTM5ARUxFTMVMxUxFTMVOQIVMxUxFTMVMRUzOQEVMxUxFTMVMxUzFTMxMxUxFTMVMxUxFTMVMzEzFTMVMxUzFTEVFxYXNycmJzUjLwIXBxY7ATcnJicjNS8CJQcGByMHIw8BFzY/AQcGDwMXNjc1NzY3JzcHFxYXFR8BNyYnNSYnNSYnMScHFxYfAjMVFzcmLwExNSM1IzEjNSM1IzUjNSM1IzEjNSMnJi8BIgcjFSMxIwcjByMHIwcjByMVIzEjFSMVIxUjFSMGBxc3NjsBFzcmIxMjIiY9ASMiJj0BNDY7ATU0NjsBMhYdATMyFh0BFAYrARUUBiczNTQ2OwE1IyImPQEjFRQGKwEVMzIWFQFQIyAKAQEFAQEBAQIBAQEBAQEBAQEBAQIBAQEBCw0KKhgdHgMBAR4fqhMSAgECCgc7CgsTAQESNVUCAQIBAQIGPQYHAT9BHDcXHwEBBAcJDS8UGREBAQEQdCAfIggCAQEFAQICAQIBAgIBAgIKChQVHiMfBB4BPx8iIwwgAhcXEQkHGxUCEwkMoxkbIAMBAR4dMi0BAQEBCAwLKVwKDRIBARM2FRABAgcDAQcDPEM+BgYCPwMBAwpuMBUWEwEBARA3DRQHAQIBAQMBEBTBFR4kHQQBHSIaIhABAQcBAgECBAECAgECAwECAgEPEHAVCwQoKAwgJCQPIAMcwkQoMxMTGwEBAQEaJoULAwEBAQQ+AwEEAQc9QDgOFQUBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEFDQotFxcSAQEBEHUYRlADBiAjIAEDAR8BKhsdHwICAQIeE08+MAkJEgEBEjQgEgMDAzwaOQ0OBgEEPgEJAwMECrQcHR8aAQIBGSoXHg4CAQEBAQIBAQEBARsXbRIOBgUFAQMBAwEDAQMDAwMDAwIDARAOEB8hIg0gAxkXNGYJDEUJDAwJRQwJZgkMRQkMDAlFDFk6DQlERAkNOg0JREQJDQMFEBYIAQMBAQIBAQEBAQEBAQEBAQIBAQoMCi8VGhACARE3ihojAQUIAgoEARgdFB4hIQEDHiHLGCcJChAHDwUGCxUMICElKgInkB4yKAEBAQEFCAsNKhgcHwEDAR6TNRcQBQEBAgEBAQEBAQEBAQQEBjwKDBICEzcGBwI/AwEDBAEEAj5gFRcTAgEQNxUkAQEBAQcLCy+kHiMfAQMeIR0fBwgFEAgDAwIVChXHDB8fJA4gAhcZJSYkvSkYGiEBAwEeHR8gCgEBAQMBAQEBBAEBFhRuOwsNEgITNRMTBwEEAQECAQEBAQEBAQEFBQwBBAs9BgcBPgOcLEYkGhwXAQECFTGuIiMNIA8LFQYgBxAXFgUBASAMuR0hHQcCAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQQNCCwXFx8BAwEegjolPgMECwEBAQ0gExQKAgEKOxE0zh4iHQEDHSIoMg8JDRMQxRodHiMGASAIJCMSCQgSChOKOQ4OFwECARcuGhUKAQEBAQEBAQEBDwgTAgEBAQEBAQEBAQEBBQU8CAkBPgP+IAwJRQwJZgkMRQkMDAlFDAlmCQxFCQwrRAkNOg0JREQJDToNCQAABAAA/9UDqwMrABQAKQAuAEMAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgMXByMnNyIPAQ4BHwEeATsBMjY/ATYmLwEmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdG8qiipvBQaYBQQCOwIJBrwGCQI7AgQFmAUC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv+xlCDg44DbwQLBbQFBwcFtAULBG8DAAAABAAAAAADrQLWAA8AEwAXABsAAAEhIgYVERQWMyEyNjURNCYFIRUhARUhNRE1IRUDgv0AEhkZEgMAERkZ/QQC1f0rAtX9KwLVAtUZEf2qERkZEQJWERnb9AGPW1v91ltbAAAAAAUAAP/VA6sDKwAUACkANgBLAFEAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYDJwM3FxMCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUofZVxnakEC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+tIP+8YR5ASUAAAAAFwAA/9UDqwMsABwATABsAH4AkgCoALcAxQD0AP4BDQEdATgBRAGhAcQB0wH6AgcCFQJPAlICXwAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicFBgcGBzEVIxUjFTEVIzkBFSMVMQYHFzc2PwEHBgcVFBc3NTQ/AScXBxYfARUzFTEVMxUxFTMVMRUxFTMVMxUzFTEVMxUxFxUzFxUxFTMVMxUxFTEVMzEzFTEVMxUxFTEVMxU5ATMVMRUxFTMVMRUzFTkBMxUxFTEVMxcWFxYXNycmLwEXBxYXMxUzFTMxMxUzFTMVMxYXMxczFzMVMxUXFhc3JyYvASEHBg8BFzY3Nj8BNjc2PwEHBg8BFzY3NTE1MzUxNTM1MzUxNTE1MzU5ATM1MTUzNTE1MTY3JzcHFxYdAQcXNjc1Ji8BBxcWHwE3Ji8BJicmLwEiByMVIxUjMSMHIxUjByMHIwcjFSMxIxUjFSMVIxUjBgcXNzY7ATIfATcmLwEjJyMnIycjJicxJiMfASM3Ig8BBhYzITI2LwEmAgAUCQcsJAwgJCQPECYhHxEUEgICAwEhIxESsQ0PEQECAgEBAgEBAQECAQEBAQMBAQcaFSgZGyAdH6MJCg4BAQEDBAIDBQU6DAwVETVbAgEBAQIEPgQDAQI/UTkMBgEPEQEMCDMTFQ8OaCYTFAEBAgEZHQ4PGx0gHhmfCRQXFA0hExUENRgbHwEtGx4jHhYRDioiBw0HInEQEhgVMAsLCQECAQEBAQEBAxYQNiMBBwc9EgFBOA8RCwk8AwcDCAwRnyMbHhoXLCUwAQEND/6ECREdFgEBAQEMCjITFBwZqQ4DAj4HBzw3OQYGAwEBAQEBAQEBAQEBAQEBAQEBAQEBAQMGBAkMMBQXDQ5uHQ0RAQIBAgECARYUAgECAQIDEA8RDSAhHxwBHh0eIiAMDBQYHAUQCBALTA4PFhUvFRIBAQEBAQEVDTk+PQcGAj8CAQIOgCcZGxMTMwUJAxkhDA6xEggHBgUFAQQDAQMBAgMDAwMDAgMBEA4QHyEiBCEjHxESDAwCAQIBAgEDDhQVCwFs12sPB4gIDw8BEA8PB4gIAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkIaAUNFxsBAQEBAQIPESUaGxYUcygpJQsVASgeHh8OsxoRDQcBAQECAQoBAgICAgEBAQECAQEBAQEBAQEBAQEBAQEBAQEBAQECBAgEDAwpGBweHYQ3CQkBAQEBAQoGAQEBAQMEAj0HBw8PDw8GBj4BBAQKAgcECAi+HiAYGSkVFwEBAQEBAQEBAQECAgEgIxu1Dh8ZHwwgAw4SIC0qpDEUFhsaJAgOBSMbCgk0AQEBAQEBAQEBAQEBAQUFPAgJCgk8BwMDAQEBBAICyrr1DewNGhoN7A0AAAAAAwAA/9UDqwMrABQAKQAvAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYDJwM3FxMCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWM8ZVxnakEC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv+SYP+8YR5ASUAAAMAAAAAA6sC1gADABMAIAAAAREhESUhIgYVERQWMyEyNjURNCYBIiY1ETQ2MhYVERQGA2v9KgLr/QASGRkSAwASGRn9mQ0TExoTEwKV/dYCKkAZEf2qERkZEQJWERn9YBMNAlYNExMN/aoNEwAAAAAEAAD/1QOrAysAFAApADYASwAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSgLrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4O6tFdop2RUV2inZFQCwqSUquSkkqLCwqSUquSkkqLAAAAA4AAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQEgAS0AAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnAxcjNyIPAQYWMyEyNi8BJgIAFAkHLCQMICQkDxAmIR8RFBICAgMBISMRErENDxEBAgIBAQIBAQEBAgEBAQEDAQEHGhUoGRsgHR+jCQoOAQEBAwQCAwUFOgwMFRE1WwIBAQECBD4EAwECP1E5DAYBDxEBDAgzExUPDmgmExQBAQIBGR0ODxsdIB4ZnwkUFxQNIRMVBDUYGx8BLRseIx4WEQ4qIgcNByJxEBIYFTALCwkBAgEBAQEBAQMWEDYjAQcHPRIBQTgPEQsJPAMHAwgMEZ8jGx4aFywlMAEBDQ/QbNdrDweICA8PARAPDweICAMrAQUKPgcHAQQJCTwHBQEBAQgDAicGCAoBAQIBAQEBAQEBAQECAQEBBBQUMRUXEg83gQwOGAEBAgQGAQYDBwIFCQgOEBceICAbIsAKFRIpCQ8IDBcIIBUaEQggBbAaHQ4EHhgBAQEQCSUaHiAdlDMQDgEBARIOBgY4Dg8XE1M+BAMCAQEDPgIEBEAREw0LOwUGEBYECQU1jBsgHBgpCwwMAQMBAQEBAQEBAQEBAQEBBAEfIx+wICggIA07PhIJyR4cHiUeEQ0YCAoUCR0bjzQSExoXLCwgAQEJCP7/uvUN7A0aGg3sDQAAAAAIAAAAAAOiAvgADwATABcAGwAfACMAJwArAAABISImNRE0NjMhMhYVERQGAwUTJQUzFSMFIzUzByM1MwcjNTMHIzUzJTMVIwNg/UAbJycbAsAbJycd/UICArz9AkBAAyOUlNGTk9GTk9CUlAJPQEABCSYcAWocJiYc/pYcJgGsAf6XAUNqakBAQEBAQECUagACAAD/1QOrAysAFAApAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYCAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWMCqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODsABQAA/9UDqwMrABQAKQA2AEsAVwAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJg8BBhYzITI2LwEmIgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSm6IBw8PARAPDwiIBx8C6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiyd7A0aGg3sDQAAAAAGAAAAAAOrAtYAAwATACQAKAA3AEUAAAERIRElISIGFREUFjMhMjY1ETQmASEiJj0BNDYzITIWHQEUBiMlMzUjFyIvAS4BPgEfAR4BDgEjMyImNj8BNh4BBg8BBiMDa/0qAuv9ABIZGRIDABIZGf5Y/vkNFBQNAQgNFBQN/v78/H4HBYEHAgoQBoEFBAQKBwEKCgIGgQcPCgIGggUHApX91gIqQBkR/aoRGRkRAlYRGf6YEw65DhQUDrkOFCevdANlBQ8NAgVkBAwLBw0QBWQFAg0PBWUDAAAEAAD/1QOrAysAFAApACoANwAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAyMUHgEyPgE0LgEiDgECAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWN0qy5PXE8uLk9cTy4CqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODv+VS5PLi5PXE8uLk8AAAAGAAD/1QOrAysAFAApADYASwBOAFsAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYHFyM3Ig8BBhYzITI2LwEmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdEV2RUV2inZFRXZFV0pJKiwsKklKrkpJKiwsKklKV2zXaw8HiAgPDwEQDw8HiAgC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKizLuvUN7A0aGg3sDQAAAAYAAAAAA3YDAQAlAF4AagB2AIIAjgAAAQYVFBcWFxYXMRYXFhcWFRQHBgchNjc2JyYnJi8BJicmNzY3NjclIQcGBwYHBgcGBwYXFhcWFxYXFhcWBwYHBgcOARYzITc2NzY3NjU0JyYnJicmJyYnJjU0NzY3NiYFIyImNDY7ATIWFAYHIyImNDY7ATIWFAYXIyImNDY7ATIWFAYXIyImNDY7ATIWFAYCtkURDhwQISANFgoMIR0m/p8iDxEODCIUKgE3ERYIFDYgJQHU/iEQExMbFx0VGQ4LDQwfEiomDxoJCgoTMyc2BQMHBgIZFxwYIBMXEQ8bESQdDRUKDDkmPAgG/tLVCxAQC9ULDw8LqwsPDwurCw8PSoALDw8LgAsQEEvWCw8PC9YLDw8CwE9ZKyQeHBAcGg0WGRwlFR4aFCcuMS4mJhclATAaICI5KhkQQAYICxATGB0hJysoISIUJSIQHBkeHzYpHxUCCwkMEBIZGiAgMyghHhEeFw0VFBkeQUAsJQUQ2g8WDw8WD3IPFhAQFg9yDxYQEBYPchAWDw8WEAAAAAMAAP/VA6sDKwAUACkANQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAwcGFjMhMjYvASYiAgBRRkMoKSkoQ0aiRkMoKSkoQ0ZRdGNhODs7OGFj6GNhODs7OGFji4gHDw8BEA8PCIgHHwKrKShDRqJGQygpKShDRqJGQygpgDs4YWPoY2E4Ozs4YWPoY2E4O/747A0aGg3sDQAEAAD/1QOrAysAFAApACwAOQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAxcjNyIPAQYWMyEyNi8BJgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3Rs12sPB4gIDw8BEA8PB4gIAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7/sq69Q3sDRoaDewNAAAAAAMAAP/gA8sDIQAtAD4ATgAABSImNDYzMjc2NzY0JyYnJiIHBgcGFRQXFg4BJicmNTQ3Njc2MhcWFxYUBwYHBiUiJy4BPwE+Ah4CDwEOASMiLwEuAT4BHwEyHgEOAgIrDRMTDV9SUC8wMC9QUr9SUC4wIwUIGBkGKTk3XmHiYV43OTk3XmH+WwUDDQ0DMwIMEBEMBQIzAhILCQe5CwcNGgu5ChAHBRAUIBMaEzAvT1O+U08vMDAvT1NfUUgMGQwJDFZfcWFeNzk5N15h4mFeNzmHAQMXDc8IDQQEDBAI0AsNBGsGGhcHB2sMEhQNAQAAAAYAAP/VA6sDKwAUACkALAA7AD4ATQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAxUnNyIPAQYUHwEWMjY9ATQmFxUnNyIPAQYUHwEWMjY9ATQmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjsEFbBgSFBweFBA0KCoZBWgUFhQYGhQQNCgoC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv+hmIxdwRlBREFZQMJCMoICUZiMXcEZQURBWUDCQjKCAkAAAYAAP+1A8wDSwADABQAIAAtADoARwAACQQiBwEGFBcBFjI3ATY0JwEmEyEiJjQ2MyEyFhQGByImNRE0NjIWFREUBjciLwEmNDYyHwEWFAYjIiY0PwE2MhYUDwEGAgABgP6A/oABgA8L/loKCgGmCx8LAaULC/5aCpv+qgsPDwsBVgsPD7YLDw8WDw9uCwjyBw8WCPIHD/0LDwfyCBYPB/IIAwD+gP6AAYABywv+WgofC/5aCwsBpgsfCgGmC/4bDxYPDxYPqw8LAVYLDw8L/qoLDzIH8ggWDwfyCBYPDxYI8gcPFgjyBwAaAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BOAFEAaEBxAHTAfoCBwIVAk8CXwJjAm8CewKHAAABIwcjBgcXNzY7ARcWHwE3JicjNSM1IzUjJicmIwcGDwEjFSMVByMxIxUjFSMVIxUjFSMVIzEjFSMVIxUjByMVMRUjFQcGBxc3Nj8BJwcGDwEVIxUxFSMVMRUxFSMHFTEHFQcVBwYHFzc2PwEnBwYPARUUFxUWFzcnJjU0PwEnFwcfARUzFhcVMxUxFRYXNycmLwEXBxYXMxUzFTMVMzkBFhcWFzcnJi8BFwceARczFTM2NycHIi8BJQcGDwEXNjc2PwE2Nyc3BwYPARc2PwE1MzcxNTM1MTUzNTkCNTM1MTUzNTE1MzU5AjUzNTE1NzU2Nyc3FQYPARc2NTQvAQcXFh8BNyYnNSYnNSYvAQcXFh8BNyYnIzUjNTEmJwUGBwYHMRUjFSMVMRUjOQEVIxUxBgcXNzY/AQcGBxUUFzc1ND8BJxcHFh8BFTMVMRUzFTEVMxUxFTEVMxUzFTMVMRUzFTEXFTMXFTEVMxUzFTEVMRUzMTMVMRUzFTEVMRUzFTkBMxUxFTEVMxUxFTMVOQEzFTEVMRUzFxYXFhc3JyYvARcHFhczFTMVMzEzFTMVMxUzFhczFzMXMxUzFRcWFzcnJi8BIQcGDwEXNjc2PwE2NzY/AQcGDwEXNjc1MTUzNTE1MzUzNTE1MTUzNTkBMzUxNTM1MTUxNjcnNwcXFh0BBxc2NzUmLwEHFxYfATcmLwEmJyYvASIHIxUjFSMxIwcjFSMHIwcjByMVIzEjFSMVIxUjFSMGBxc3NjsBMh8BNyYvASMnIycjJyMmJzEmIxMjIiY1ETQ2OwEyFhURFAYnMxEjFyMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGAgAUCQcsJAwgJCQPECYhHxEUEgICAwEhIxESsQ0PEQECAgEBAgEBAQECAQEBAQMBAQcaFSgZGyAdH6MJCg4BAQEDBAIDBQU6DAwVETVbAgEBAQIEPgQDAQI/UTkMBgEPEQEMCDMTFQ8OaCYTFAEBAgEZHQ4PGx0gHhmfCRQXFA0hExUENRgbHwEtGx4jHhYRDioiBw0HInEQEhgVMAsLCQECAQEBAQEBAxYQNiMBBwc9EgFBOA8RCwk8AwcDCAwRnyMbHhoXLCUwAQEND/6ECREdFgEBAQEMCjITFBwZqQ4DAj4HBzw3OQYGAwEBAQEBAQEBAQEBAQEBAQEBAQEBAQMGBAkMMBQXDQ5uHQ0RAQIBAgECARYUAgECAQIDEA8RDSAhHxwBHh0eIiAMDBQYHAUQCBALTA4PFhUvFRIBAQEBAQEVDTk+PQcGAj8CAQIOgCcZGxMTMwUJAxkhDA6xEggHBgUFAQQDAQMBAgMDAwMDAgMBEA4QHyEiBCEjHxESDAwCAQIBAgEDDhQVC2rSCAsLCNIIDAzHrKyFXggLCwheCAsLCF4ICwsIXggLCwheCAsLCF4ICwsDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQhoBQ0XGwEBAQEBAg8RJRobFhRzKCklCxUBKB4eHw6zGhENBwEBAQIBCgECAgICAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQIECAQMDCkYHB4dhDcJCQEBAQEBCgYBAQEBAwQCPQcHDw8PDwYGPgEEBAoCBwQICL4eIBgZKRUXAQEBAQEBAQEBAQICASAjG7UOHxkfDCADDhIgLSqkMRQWGxokCA4FIxsKCTQBAQEBAQEBAQEBAQEBBQU8CAkKCTwHAwMBAQEEAgL+GwsIASYICwsI/toICyYBAE8LEAsLEAtECxALCxALRAsQCwsQCwAEAAAAAANLAyAACAAaAB8AJgAAASMiJj0BMxUzEyEiJjURNDYzITIfARYVERQGJSERJyEXFSMVMxU3AyrWDRNAtgH9qg0TEw0Bfw4J1goT/b0CFsT+rqZwcFQCCRMN1rb9whMNAtUNEwnXCQ3+AQ0TQAHSwy03MDdPAAAABgAA/9UDqwMrABQAKQA2AEsAVwBkAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmEyEiJjQ2MyEyFhQGByImNRE0NjIWFREUBgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSin/AA0TEw0BAA0TE40NExMaExMC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+oBMaExMaE4ATDQEADRMTDf8ADRMAABcAAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQE4AUQBoQHEAdMB+gIHAhUCTwJUAmkAAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnBQYHBgcxFSMVIxUxFSM5ARUjFTEGBxc3Nj8BBwYHFRQXNzU0PwEnFwcWHwEVMxUxFTMVMRUzFTEVMRUzFTMVMxUxFTMVMRcVMxcVMRUzFTMVMRUxFTMxMxUxFTMVMRUxFTMVOQEzFTEVMRUzFTEVMxU5ATMVMRUxFTMXFhcWFzcnJi8BFwcWFzMVMxUzMTMVMxUzFTMWFzMXMxczFTMVFxYXNycmLwEhBwYPARc2NzY/ATY3Nj8BBwYPARc2NzUxNTM1MTUzNTM1MTUxNTM1OQEzNTE1MzUxNTE2Nyc3BxcWHQEHFzY3NSYvAQcXFh8BNyYvASYnJi8BIgcjFSMVIzEjByMVIwcjByMHIxUjMSMVIxUjFSMVIwYHFzc2OwEyHwE3Ji8BIycjJyMnIyYnMSYjHwEHIyc3Ig8BDgEfAR4BOwEyNj8BNiYvASYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P/oQJER0WAQEBAQwKMhMUHBmpDgMCPgcHPDc5BgYDAQEBAQEBAQEBAQEBAQEBAQEBAQEBAwYECQwwFBcNDm4dDREBAgECAQIBFhQCAQIBAgMQDxENICEfHAEeHR4iIAwMFBgcBRAIEAtMDg8WFS8VEgEBAQEBARUNOT49BwYCPwIBAg6AJxkbExMzBQkDGSEMDrESCAcGBQUBBAMBAwECAwMDAwMCAwEQDhAfISIEISMfERIMDAIBAgECAQMOFBULAW8qiipvBQaYBQQCOwIJBrwGCQI7AgQFmAUDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQhoBQ0XGwEBAQEBAg8RJRobFhRzKCklCxUBKB4eHw6zGhENBwEBAQIBCgECAgICAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQIECAQMDCkYHB4dhDcJCQEBAQEBCgYBAQEBAwQCPQcHDw8PDwYGPgEEBAoCBwQICL4eIBgZKRUXAQEBAQEBAQEBAQICASAjG7UOHxkfDCADDhIgLSqkMRQWGxokCA4FIxsKCTQBAQEBAQEBAQEBAQEBBQU8CAkKCTwHAwMBAQEEAgLOUIODjgNvBAsFtAUHBwW0BQsEbwMAAAAYAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BOAFEAaEBxAHTAfoCBwIVAk8CXwJiAmwAAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnBQYHBgcxFSMVIxUxFSM5ARUjFTEGBxc3Nj8BBwYHFRQXNzU0PwEnFwcWHwEVMxUxFTMVMRUzFTEVMRUzFTMVMxUxFTMVMRcVMxcVMRUzFTMVMRUxFTMxMxUxFTMVMRUxFTMVOQEzFTEVMRUzFTEVMxU5ATMVMRUxFTMXFhcWFzcnJi8BFwcWFzMVMxUzMTMVMxUzFTMWFzMXMxczFTMVFxYXNycmLwEhBwYPARc2NzY/ATY3Nj8BBwYPARc2NzUxNTM1MTUzNTM1MTUxNTM1OQEzNTE1MzUxNTE2Nyc3BxcWHQEHFzY3NSYvAQcXFh8BNyYvASYnJi8BIgcjFSMVIzEjByMVIwcjByMHIxUjMSMVIxUjFSMVIwYHFzc2OwEyHwE3Ji8BIycjJyMnIyYnMSYjFyEiBh0BFBYzITI2PQE0JgcnMwc1FzMWMjczNxUCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P/oQJER0WAQEBAQwKMhMUHBmpDgMCPgcHPDc5BgYDAQEBAQEBAQEBAQEBAQEBAQEBAQEBAwYECQwwFBcNDm4dDREBAgECAQIBFhQCAQIBAgMQDxENICEfHAEeHR4iIAwMFBgcBRAIEAtMDg8WFS8VEgEBAQEBARUNOT49BwYCPwIBAg6AJxkbExMzBQkDGSEMDrESCAcGBQUBBAMBAwECAwMDAwMCAwEQDhAfISIEISMfERIMDAIBAgECAQMOFBULlP7bBwkJBwElBgkJmVu20msBBgoGAWsDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQhoBQ0XGwEBAQEBAg8RJRobFhRzKCklCxUBKB4eHw6zGhENBwEBAQIBCgECAgICAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQIECAQMDCkYHB4dhDcJCQEBAQEBCgYBAQEBAwQCPQcHDw8PDwYGPgEEBAoCBwQICL4eIBgZKRUXAQEBAQEBAQEBAQICASAjG7UOHxkfDCADDhIgLSqkMRQWGxokCA4FIxsKCTQBAQEBAQEBAQEBAQEBBQU8CAkKCTwHAwMBAQEEAgLICQbPBwkJB88GCWQ5mHhEAwNEeAAAAgAAAAADqwLEAA4AHgAAAQUGIiclNTQ2MyEyFh0BBxEUBiMhIiY1EQUWNjcGNwOq/moMGw3+dS4gArogLgEtIP1GIC4BkgoXCQrQAmDaBgbUIR4qKh4bQP5bHSkpHQGf0AUBBgRrAAAGAAD/1QOrAysAFAApADYASwBoAHUAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYDIicuAT0BIyImPQE0NjsBNTQ+ARYfARYUDwEGIyczMhYdATcnFRQGKwECAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUpCBQIGCIkIDQ0IiQgMDQVzBQVzBwqIiAkNQUENCYgC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+IgEDCwYyDAmFCQwxBwsEAwWJBg8GiQdwDAkMTk4MCQwAAAYAAP/VA6sDKwAUACkANgBLAFcAZQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJhcHJzU0NjMhMhYdAxQGIyEiJj0BFxY/AQIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSk2koBEMAQkNEREN/vcMEZkICJsC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKizkX1wODBERDAwhoQwSEgyeWAUGWQAAAAADAAAAAAOLAuAACwAXACMAAAEhIiY0NjMhMhYUBgMhIiY0NjMhMhYUBgMhIiY0NjMhMhYUBgNr/VUNExMNAqsNExMN/VUNExMNAqsNExMN/VUNExMNAqsNExMCoBMaExMaE/7rExoTExoT/uoTGhMTGhMAABgAAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQE4AUQBoQHEAdMB+gIHAhUCTwJcAmkCegAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicFBgcGBzEVIxUjFTEVIzkBFSMVMQYHFzc2PwEHBgcVFBc3NTQ/AScXBxYfARUzFTEVMxUxFTMVMRUxFTMVMxUzFTEVMxUxFxUzFxUxFTMVMxUxFTEVMzEzFTEVMxUxFTEVMxU5ATMVMRUxFTMVMRUzFTkBMxUxFTEVMxcWFxYXNycmLwEXBxYXMxUzFTMxMxUzFTMVMxYXMxczFzMVMxUXFhc3JyYvASEHBg8BFzY3Nj8BNjc2PwEHBg8BFzY3NTE1MzUxNTM1MzUxNTE1MzU5ATM1MTUzNTE1MTY3JzcHFxYdAQcXNjc1Ji8BBxcWHwE3Ji8BJicmLwEiByMVIxUjMSMHIxUjByMHIwcjFSMxIxUjFSMVIxUjBgcXNzY7ATIfATcmLwEjJyMnIycjJicxJiMXMh4BFA4BIi4BND4BNyYOARQeAT4CNC4BByMiJj0BNDYyFh0BMzIWFAYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P/oQJER0WAQEBAQwKMhMUHBmpDgMCPgcHPDc5BgYDAQEBAQEBAQEBAQEBAQEBAQEBAQEBAwYECQwwFBcNDm4dDREBAgECAQIBFhQCAQIBAgMQDxENICEfHAEeHR4iIAwMFBgcBRAIEAtMDg8WFS8VEgEBAQEBARUNOT49BwYCPwIBAg6AJxkbExMzBQkDGSEMDrESCAcGBQUBBAMBAwECAwMDAwMCAwEQDhAfISIEISMfERIMDAIBAgECAQMOFBULASI6IiI6RDoiIjoiMVQxMVRhUS8vUQEvCQwMEgwaCQwMAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkIaAUNFxsBAQEBAQIPESUaGxYUcygpJQsVASgeHh8OsxoRDQcBAQECAQoBAgICAgEBAQECAQEBAQEBAQEBAQEBAQEBAQEBAQECBAgEDAwpGBweHYQ3CQkBAQEBAQoGAQEBAQMEAj0HBw8PDw8GBj4BBAQKAgcECAi+HiAYGSkVFwEBAQEBAQEBAQECAgEgIxu1Dh8ZHwwgAw4SIC0qpDEUFhsaJAgOBSMbCgk0AQEBAQEBAQEBAQEBAQUFPAgJCgk8BwMDAQEBBAICwSI6RDoiIjpEOiI1ATBTYVQwAjBSYFIw2AwJSwkNDQk1DRIMAAAAEAAAAAADqwLWAAMAEwAXABsAHwAjACcAKwAvADMANwA7AD8AQwBHAEsAAAERIRElISIGFREUFjMhMjY1ETQmBTMVIyUjNTMHIzUzByM1MwcjNTMHIzUzBTMVIwUzFSMhIzUzByM1MwcjNTMHIzUzByM1MwUzFSMDa/0qAuv9ABIZGRIDABIZGfzuKysCq1ZWgFZWgFZWgFZWgFZWAiorK/0rKysCq1ZWgFZWgFZWgFZWgFZWAiorKwKV/dYCKkAZEf2qERkZEQJWERm7NQE1NTU1NTU1NTUBNaA1NjY2NjY2NjY2ATUAAAIAAAAAA6sCwAADABMAAAERIRElISIGFREUFjMhMjY1ETQmA0P9egLE/P4RGRkRAwIRGRkCWf5OAbJnGBH90hEYGBECLhEYAAMAAP/VA6sDKwAUACkAMAAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAxUjFTMVNwIAUUZDKCkpKENGokZDKCkpKENGUXRjYTg7OzhhY+hjYTg7OzhhY12oqHoCqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODv+5kuMS5EAAAQAAAAAA60CxQADABMAFwAoAAABESERJSEiBhURFBYzITI2NRE0JgcRIRElISIGFREUFjMhMjY1ETQmIwNs/SsC7fz8ERgYEQMEEBgYqP4rAfr94QsQEAsCHwsQEAsChP4ZAedAGBD96REXFxECFxAYqf7rARVAEAv+ogsQEAsBXQwPAAUAAP/VA6sDKwAUACkANgBLAFYAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYHDgEHPgE3FyYnJgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSlcWRxYUSxRzEyUnAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7q0V2inZFRXaKdkVALCpJSq5KSSosLCpJSq5KSSoshz34PRRVFH08eX4AAAAABgAA/9UDqwMrABQAKQA2AEsAVwBjAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmARcWNj0BNCYPAQYUHwEWNj0BNCYPAQYUAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdEV2RUV2inZFRXZFV0pJKiwsKklKrkpJKiwsKklK/vyBCRISCYEGqIIIEhIIggYC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+s2MGCQrGCgkGYwUQBWMGCQrGCgkGYwUQAAQAAP+1A8wDSwADABQAIAAtAAAJBCIHAQYUFwEWMjcBNjQnASYTISImNDYzITIWFAYHIiY1ETQ2MhYVERQGAgABgP6A/oABgA8L/loKCgGmCx8LAaULC/5aCpv+qgsPDwsBVgsPD7YLDw8WDw8DAP6A/oABgAHLC/5aCh8L/loLCwGmCx8KAaYL/hsPFg8PFg+rDwsBVgsPDwv+qgsPAAAGAAD/1QOrAysAFAApADYASwBmAHQAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYTIi8BBg8BBgcOAS4BNzY/ATY3PgEyFhcTFgYnMTIfAScGDwEGBzY3NgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJShQKBlsNFwIdGQUPDQQCEyACIBYCCw4LAmsDDXUJByo7ChMDCg0UFQYC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz9/wdjDRsBIhkFAggOBzZsCHA9BggIB/6pChGeBy29IUIJJSkWFQYAAAAIAAD/1QOrAysAFAApADYASwBOAF0AYABvAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmAxUnNyIPAQYUHwEWMjY9ATQmFxUnNyIPAQYUHwEWMjY9ATQmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdEV2RUV2inZFRXZFV0pJKiwsKklKrkpJKiwsKklKk0FbBgSFBweFBA0KCoZBWgUFhQYGhQQNCgoC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+8WIxdwRlBREFZQMJCMoICUZiMXcEZQURBWUDCQjKCAkAAAAABAAA/7UDzANLAAMAFAAhAC4AAAkEIgcBBhQXARYyNwE2NCcBJgMyHgEUDgEiLgE0PgE3Ig4BFB4BMj4BNC4BAgABgP6A/oABgA8L/loKCgGmCx8LAaULC/5aChAmPyYmP0w/JiY/JjRYNDRYaFg0NFgDAP6A/oABgAHLC/5aCh8L/loLCwGmCx8KAaYL/sAmP0w/JiY/TD8mNTRYaFg0NFhoWDQAAAAAAwAAAAADdgMgAAgAGgAfAAABIyImPQEzFTMTISImNRE0NjMhMh8BFhURFAYlIREnIQNU1g0TQLYB/asNExMNAX8NCtYJE/2+AhXD/q4CCRMN1rb9whMNAtUNEwnXCQ3+AQ0TQAHSwwACAAD/tQPMA0sAAwAUAAAJBCIHAQYUFwEWMjcBNjQnASYCAAGA/oD+gAGADwv+WgoKAaYLHwsBpQsL/loKAwD+gP6AAYABywv+WgofC/5aCwsBpgsfCgGmCwAAAA8AAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQEtATABOgAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicHISIGHQEUFjMhMjY9ATQmByczBzUXMxYyNzM3FQIAFAkHLCQMICQkDxAmIR8RFBICAgMBISMRErENDxEBAgIBAQIBAQEBAgEBAQEDAQEHGhUoGRsgHR+jCQoOAQEBAwQCAwUFOgwMFRE1WwIBAQECBD4EAwECP1E5DAYBDxEBDAgzExUPDmgmExQBAQIBGR0ODxsdIB4ZnwkUFxQNIRMVBDUYGx8BLRseIx4WEQ4qIgcNByJxEBIYFTALCwkBAgEBAQEBAQMWEDYjAQcHPRIBQTgPEQsJPAMHAwgMEZ8jGx4aFywlMAEBDQ89/tsHCQkHASUGCQmZW7bSawEGCgYBawMrAQUKPgcHAQQJCTwHBQEBAQgDAicGCAoBAQIBAQEBAQEBAQECAQEBBBQUMRUXEg83gQwOGAEBAgQGAQYDBwIFCQgOEBceICAbIsAKFRIpCQ8IDBcIIBUaEQggBbAaHQ4EHhgBAQEQCSUaHiAdlDMQDgEBARIOBgY4Dg8XE1M+BAMCAQEDPgIEBEAREw0LOwUGEBYECQU1jBsgHBgpCwwMAQMBAQEBAQEBAQEBAQEBBAEfIx+wICggIA07PhIJyR4cHiUeEQ0YCAoUCR0bjzQSExoXLCwgAQEJCP8JBs8HCQkHzwYJZDmYeEQDA0R4AAAABAAAAAADTgKHABQAFwArAC4AACUiLwEuATU0PwE+AR4BFREUBgcGIycXEQEiLwEuATU0PwE+AR4BFREUBgcGJRcRAb0WEfgMDRn4DyMhExMQDw729wFRFhH3DA0Z9w8kIRMTEQ7++/eLDb0JGw8fE70MAxAfEv6GEx8IBv29AXr+Rg29CRsPHxO9DAMQHxL+hhMfCAb9vQF6AAAABAAA/9UDqwMrABQAKQA4AEUAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJhMiLwEmNDYyHwEeAQ4BKwEiJjQ/ATYyFhQPAQYCAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWMFEg3xDBgkDPIJBQoWDfERGg3xDSMZDPIMAqspKENGokZDKCkpKENGokZDKCmAOzhhY+hjYTg7OzhhY+hjYTg7/bIM8Q0jGQzyCRkYDhgkDPIMGSMN8QwADwAA/9UDqwMrADsAUABjAGQAfgCoALoA0QDnAPQBGQFEAVIBdgGOAAABBg8BIjc2ByMxIxUjByMVIxUjFSMVIxUxFSMxIxUjFSMVIxUjFTkBByMVIzEjFSMHBgcXNzY/ATM/AScHBgcVBxUHFQcVMQYHFzc2PwMnBwYUFxUXFTEVFhcWFzcnJjU3Jx8BBxYXMRUzOQEVMxUxFRYXFhc3JyYvBBcHFh8BMxUzMTMVFzMVMxUzFTMVMxczFTMVMxUzMTMVFxYXNycmLwExJwUHBisBJwcWMzI3MzY/ATY3JzcHBg8BIw8BFzY3MzUzNTM1MzU3NjcnNwcGDwMXNjc1MzU3Njc1NzU2Nyc3BxcWHQEHFzY1JyYvAQcXFh8ENyYvATU5ASM1MTUnNSM5ATUjNTE1JzUxNSMmLwEHFxYfATMXNyYvASM1IycjNSMxIzUjJyM1IzUjNSM1IycjNSM1IzUjJi8BIgcjBgcXNzY7ARc3JhMjIiY9ASMiJj0BNDY7ATU0NjsBMhYdATMyFh0BFAYrARUUBiczNTQ2OwE1IyImPQEjFRQGKwEVMzIWFQFQIyAKAQEFAQEBAQIBAQEBAQEBAQEBAQIBAQEBCw0KKhgdHgMBAR4fqhMSAgECCgc7CgsTAQESNVUCAQIBAQIGPQYHAT9BHDcXHwEBBAcJDS8UGREBAQEQdCAfIggCAQEFAQICAQIBAgIBAgIKChQVHiMfBB4BPx8iIwwgAhcXEQkHGxUCEwkMoxkbIAMBAR4dMi0BAQEBCAwLKVwKDRIBARM2FRABAgcDAQcDPEM+BgYCPwMBAwpuMBUWEwEBARA3DRQHAQIBAQMBEBTBFR4kHQQBHSIaIhABAQcBAgECBAECAgECAwECAgEPEHAVCwQoKAwgJCQPIAMcHWYJDEUJDAwJRQwJZgkMRQkMDAlFDFk6DQlERAkNOg0JREQJDQMFEBYIAQMBAQIBAQEBAQEBAQEBAQIBAQoMCi8VGhACARE3ihojAQUIAgoEARgdFB4hIQEDHiHLGCcJChAHDwUGCxUMICElKgInkB4yKAEBAQEFCAsNKhgcHwEDAR6TNRcQBQEBAgEBAQEBAQEBAQQEBjwKDBICEzcGBwI/AwEDBAEEAj5gFRcTAgEQNxUkAQEBAQcLCy+kHiMfAQMeIR0fBwgFEAgDAwIVChXHDB8fJA4gAhcZJSYkvSkYGiEBAwEeHR8gCgEBAQMBAQEBBAEBFhRuOwsNEgITNRMTBwEEAQECAQEBAQEBAQEFBQwBBAs9BgcBPgP9tAwJRQwJZgkMRQkMDAlFDAlmCQxFCQwrRAkNOg0JREQJDToNCQAEAAD/tQPMA0sAAwAUACEALgAACQQiBwEGFBcBFjI3ATY0JwEmEyIvASY0NjIfARYUBiMiJjQ/ATYyFhQPAQYCAAGA/oD+gAGADwv+WgoKAaYLHwsBpQsL/loKaQsI8gcPFgjyBw/9Cw8H8ggWDwfyCAMA/oD+gAGAAcsL/loKHwv+WgsLAaYLHwoBpgv9ogfyCBYPB/IIFg8PFgjyBw8WCPIHAAMAAAAAA3IDLQAiAGEAngAAASYnPgE1NC4BIyIGBwYVFBYXBw4CHQEUFjMhMjY9ATQuASU0NzY3MTYzMhceATc2NxYVFAYHDgEeARcWFwYPAQYPAwYPAgYiLwEmLwYmJzY3PgImJy4BNQEjNTQmIgYdASE1NCYiBh0BIzU+ATcXFh8BFh8BFh8BFh8BFhcWMxYyPwE2PwE2PwE2PwE2PwE2PwEeARUClQgKISU4Xjg/ZxgPJCESQmQ3Ew0Crg0TNmT+lQsDBjwaFxwWMBcHBhU3LAsNAg8LHh0DBAIEAwwPBgUGBxMLEwoHBgYUDQYHBQoEAhseCw8CDQosNwHFYxIZEv7SEhkSYwFORQkECAMJCwYLBgkHCgoGDgUEEhsSCQ4GCgoICQwFBgkKAwYHCEVOAb0EBBxRLTheOEU5JiotUB0IHmmGSTwNExMNPEmGacEbGwYLHRENCQYBAyIlL0oOAxMWEQEFCgoIBQYGDgwFAwIDBgICAgEDCgkFCQYRCAoJBQIQFhMDDkov/eyBDBISDIGBDBISDIEcUY0rFQgMBQwKBgkEBgUEBAMDAgMDAgMDBAQFBggFBggOBAkMFCqNUQAAAwAA/9UDqwMrABQAKQAvAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYDJwM3FxMCAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWM8ZVxnakECqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODv+SYP+8YR5ASUAAAMAAP/VA6sDKwAUACkANAAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBw4BBz4BNxcmJyYCAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWN0FkcWFEsUcxMlJwKrKShDRqJGQygpKShDRqJGQygpgDs4YWPoY2E4Ozs4YWPoY2E4O/I9+D0UVRR9PHl+AAARAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BLQExAT0BSQFVAAABIwcjBgcXNzY7ARcWHwE3JicjNSM1IzUjJicmIwcGDwEjFSMVByMxIxUjFSMVIxUjFSMVIzEjFSMVIxUjByMVMRUjFQcGBxc3Nj8BJwcGDwEVIxUxFSMVMRUxFSMHFTEHFQcVBwYHFzc2PwEnBwYPARUUFxUWFzcnJjU0PwEnFwcfARUzFhcVMxUxFRYXNycmLwEXBxYXMxUzFTMVMzkBFhcWFzcnJi8BFwceARczFTM2NycHIi8BJQcGDwEXNjc2PwE2Nyc3BwYPARc2PwE1MzcxNTM1MTUzNTkCNTM1MTUzNTE1MzU5AjUzNTE1NzU2Nyc3FQYPARc2NTQvAQcXFh8BNyYnNSYnNSYvAQcXFh8BNyYnIzUjNTEmJwMjIiY1ETQ2OwEyFhURFAYnMxEjFyMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGAgAUCQcsJAwgJCQPECYhHxEUEgICAwEhIxESsQ0PEQECAgEBAgEBAQECAQEBAQMBAQcaFSgZGyAdH6MJCg4BAQEDBAIDBQU6DAwVETVbAgEBAQIEPgQDAQI/UTkMBgEPEQEMCDMTFQ8OaCYTFAEBAgEZHQ4PGx0gHhmfCRQXFA0hExUENRgbHwEtGx4jHhYRDioiBw0HInEQEhgVMAsLCQECAQEBAQEBAxYQNiMBBwc9EgFBOA8RCwk8AwcDCAwRnyMbHhoXLCUwAQEND2fSCAsLCNIIDAzHrKyFXggLCwheCAsLCF4ICwsIXggLCwheCAsLCF4ICwsDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQj95AsIASYICwsI/toICyYBAE8LEAsLEAtECxALCxALRAsQCwsQCwAAAQAAAAADrAKHADMAABM2NzY3NhcWFxYXFhcWFxYXFjc2PwE2NzY3FQYHBgcGJyYnJicmJyYnLgEGBwYHBgcGBzVVICErNyo2Li4dIRQmJBMfGyQsKB4aJRAbDiIgLDQuNTErFhoQHikVJEFJGiIfEiETCQGSTDA/IRgJBx4RGxAhIA8ZERUMCyEfKRYkI8lEKDcYFAkIHw8XDRwmER0hCBgeLRw6IBC9AAAAAAQAAAAAA1ADEAAPAB8ALAA5AAAlISImNTQ+ATsBMh4BFRQGJSIOARUUFjMhMjY1NC4BIyciLgE0PgEyHgEUDgEDIg4BFB4BMj4BNC4BAwr99h0pO2U74DtlOij+bipHKgQCAgoCAylHKnAxVDExVGJTMTFTMSA2ICA2QDUgIDUwKB07ZTo7ZDsdKOAqRyoCAwMCKkcqlTFTY1MxMVNjUzEBKyA2PzYgIDY/NiAAAAAAAwAAAAADSwMgAAwAGQAmAAAlIiY1ETQ2MhYVERQGISImNRE0NjIWFREUBiEiJjURNDYyFhURFAYDKw0TExoTE/7dDRMTGhMT/t4NExMaExM1Ew0Cqw0TEw39VQ0TEw0Cqw0TEw39VQ0TEw0Cqw0TEw39VQ0TAAAABAAA/9UDqwMrABQAKQBGAFQAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgMiLwEGDwEGBw4BLgE3Nj8BNjc+ATIWHwEWFxYGJzEyHwEnBg8BBgc2NzYCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWMJCgZbDRcCHRkFDw0EAhQgASAWAgsOCwI1IxMDDXUJByo7ChMDCg0UFQYC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv9lAdjDRsBIhkFAggOBzdxA3A8BwcIB6tyOQoSngctvSFCCSUpFhUGAAAAAAIAAP/VA6sDKwAUACkAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhYwLrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4OwAE////hgQCA4IAIAA4AE4ATwAAFyImJy4BNj8BPgEXJjY/AT4BHgIGDwEOAScWBg8BDgEnHgE2PwE+AScHBiImND8BJgYPAQ4BFhcBFjY/AT4BLgIGDwEOARc3Nh4CBxftLlQhLB8fLIMufD0THy2DLHd3WCAgLIMufD0THy2DIFWRG0hIG4MgDhNEDSYbDUQoVx+DGxMTGwHGKVgggxoREzVHRxuDIA4TKg4iFwMKl3kjIC12dyyDLR8TPXwugysgIFd3dyyDLR8TPXwugyAjgxoTExqDIFgpRQ0bJg1EEg4fgxtISBsBiBMOIIMbR0c1ExEahR9ZKCsKAxciDi8ABQAA/4oDkwOAABkAKQAzAEQAUAAABSEiJicRNDY7ATU0PgEyHgEdATMyFhURDgEBIgYVERQWMyEyNjURNCYjJSE1NC4BIg4BFRMiJj0BLgE+Ah4BBgcVFAYnIg4BHgI+ATU0JgMz/ZonNwE4JztDcodyQzsnOAE4/XMCBAQCAmYCBAQC/i4BPytKVkoroBIaKjIGPVZJGSEmGh8KEAgEDhMTCxN1NycCACg4PkNyQ0NyQz44KP4AJzcCZQQD/gACBQUCAgADBFk+K0orK0or/dEaEg8MRlc/CS9TUBUZEhrQChMTDgQHEQoNEwAEAAD/iwOSA4YAIwAzAEQAUAAABSEiJicRNDY7ATU0PgIeARcWDgEmJy4BDgEdASEyFhURDgEBIgYVERQWMyEyNjURNCYjASImPQEuAT4CHgEGBxUUBicmDgEUHgE3PgE0JgMz/ZonNwE4JzsxV29uWRkIDCAjCBllbUUB0yc4ATf9cwIEBAICZgIEBAL+zRIaKjIGPVZJGSEmGh8JEQkJEQkNERF1NycCACg4PjllRhoYRTMQIxAMEDIwGlc4Pjgo/gAnNwJlBAP+AAIFBQICAAME/mgaEg8MRlc/CS9TUBUZEhrQAQgQEhAJAQISGRMAAAAABgAA/7UD1ANLABQAOABKAFQAZABuAAABIiY9ATQmKwEiJjQ2OwEyFh0BFAYDISImNRE0NjsBMhYUBisBIgYVERQWMyEyNj0BNDYyFh0BFAYnIyImPQE0PwE2Mh8BFhQPAQYnMzc2LwEmIg8BAyEiJj0BNDY7ATIWHQEUBiczNTQmKwEiBhUC8xEYAwOLERcXEY0jMxg+/dEkMzMkixEXFxGLAwQEAwIvAgQXIhczLoIRFwvlGUcZQRkZ5AxqStgEBEECBQHYKf7pERczI7okMxj/xwQDugIEAbYXEbsDAxghGDMkuxEY/gEyJAKLJDIXIRgDA/11AgQEAroRFxcRuyQxuhcRghAM5BkZQRlHGeULUNgEBUACAtgBNxgQjCQyMiSMEBhQZAIEBAIAAgAA/40D8gNyAAwAGQAAFyImNDcBNjIWFAcBBiEiJwEmNDYyFwEWFAZFFyAQA3URLSEQ/IsRA18XEfyLECEtEQN1ECByIC4QA3YQIS0R/IsQEAN1ES0hEPyLEC4hAAAAAQAAAAAD9QLSABEAACUiJwEmPgIXCQE2Mh4BBwEGAX4TDf66DAEaJA4BJQIpDiQaAQz9tg0uDQFFDSUaAQ3+2wIqDBolDv23DQAAAAUAAP+TA7sDbQAfACkAMwBAAE0AAAUhIiY1ESMiJjQ2OwE1NDYzITIWHQEzMhYUBisBERQGAREUFjMhMjY1ESUhNTQmIyEiBhUBIiY1ETQ2MhYVERQGIyImNRE0NjIWFREUBgL6/gwmNzoRGhoRnTcmAS0mN50SGRkSOjb93wQDAfQCBP5jAToEA/7UAwQBARIZGSQZGdoSGRkkGRltNyYCXxkkGWsmNzcmaxkkGf2hJjYCu/2hAgQEAgJfVmsCBAQC/UsZEgEsEhkZEv7UEhkZEgEsEhkZEv7UEhkAAAAAAQAAAAACuQKnAA8AAAEFHgE+ATURNC4BBgcFBhQBVQEiCRcVDAwVFwn+3g0BYv0IAwkUDAH6DBQJAwj9DCQAAAEAAAAAArkCpwAPAAABJS4BDgEVERQeATY3JTY0Aqv+3gkXFQwMFRcJASINAZ79CAMJFAz+BgwUCQMI/QwkAAAE////gAQdA4AAgADrAPgBBQAABSMiLgE9ATQvASYPAQ4BJi8BLgE2PwE2LgErASIuAT0BND4BOwEyPwE2LwEuATQ2PwE2Mh8BFj8BNj0BND4COwEyHgEdARQfARY/AT4BMhYfAR4BFAYPAQYfARY7ATIeAh0BFA4BKwEiDgEfAR4BFAYPAQ4BJi8BJg4BHQEOASceAR0BFDsBMjY9AT4CFh8BFj8BNjQvAS4BPgE3MzI9ATQrAQYuATY/ATYvASYiDwEOAScuAT0BJisBIh0BFg4BJi8BJg8BBhQfAR4BDgErASIGHQEUFjsBNhYXFgYPAQYWFRcWMj8BPgE3Ii4BND4BMh4BFA4BAyIOAR4CPgE1NC4BAkJqGy8bAwUDAxYTNDQUSxMNDRMWAgMCBCAbLhsbLxsgAwICAgIWDw8PD0oeUx4WAwMEBA8dJRRqHC4bBAUDAxYOJSklDkwODw8OFgICAgEDIBQlHQ8bLhwkAwIDAhYOEBAOShQ0NBMWAwUFATraHSMFagIDASM6PRYWBANMAQEWFQwYMx8iBQUgHzUZDRgWAwNMAgMCFhY9HR4lAQRqBQEjO0AWFAQETAEBFhYMGDQfIAIDAwIgIDULDgwYFgEBSwIEARUWP5g4Xzg4X3BfODhfOCI4GQ0vQj8lHjOAGy8bIgMBAgICFhMODRNKEzU0ExYDBAYcLxtqHC4bBAUCAxYOJiglDkwcHBYCAgIBBAQUJR0PGy8bIAQBAgICFg4PDw5KDiUpJQ4WAwMEBA8dJRRqGy8bBgQDFg4lKCUPShMNDRMWAgQBBAgpO+ULNB8iBQMCCR8zFwsWFQMDSgIDAhYWPTojAQVqBQEjO0AWFQQESwEBFhYMDQs1ICADBQYgNBkNFxQDA0oCAwIWFj45IwMCagMDASMeHUEWFQIEAUsCAhcXCz84X3BfODhfcF84AT4lP0IvDRk4Ih4zHgAAAAASAN4AAQAAAAAAAAATAAAAAQAAAAAAAQAOABMAAQAAAAAAAgAHACEAAQAAAAAAAwAOACgAAQAAAAAABAAOADYAAQAAAAAABQALAEQAAQAAAAAABgAOAE8AAQAAAAAACgArAF0AAQAAAAAACwATAIgAAwABBAkAAAAmAJsAAwABBAkAAQAcAMEAAwABBAkAAgAOAN0AAwABBAkAAwAcAOsAAwABBAkABAAcAQcAAwABBAkABQAWASMAAwABBAkABgAcATkAAwABBAkACgBWAVUAAwABBAkACwAmAatDcmVhdGVkIGJ5IGljb25mb250aWNvbi1kZGVpLWZsb3dSZWd1bGFyaWNvbi1kZGVpLWZsb3dpY29uLWRkZWktZmxvd1ZlcnNpb24gMS4waWNvbi1kZGVpLWZsb3dHZW5lcmF0ZWQgYnkgc3ZnMnR0ZiBmcm9tIEZvbnRlbGxvIHByb2plY3QuaHR0cDovL2ZvbnRlbGxvLmNvbQBDAHIAZQBhAHQAZQBkACAAYgB5ACAAaQBjAG8AbgBmAG8AbgB0AGkAYwBvAG4ALQBkAGQAZQBpAC0AZgBsAG8AdwBSAGUAZwB1AGwAYQByAGkAYwBvAG4ALQBkAGQAZQBpAC0AZgBsAG8AdwBpAGMAbwBuAC0AZABkAGUAaQAtAGYAbABvAHcAVgBlAHIAcwBpAG8AbgAgADEALgAwAGkAYwBvAG4ALQBkAGQAZQBpAC0AZgBsAG8AdwBHAGUAbgBlAHIAYQB0AGUAZAAgAGIAeQAgAHMAdgBnADIAdAB0AGYAIABmAHIAbwBtACAARgBvAG4AdABlAGwAbABvACAAcAByAG8AagBlAGMAdAAuAGgAdAB0AHAAOgAvAC8AZgBvAG4AdABlAGwAbABvAC4AYwBvAG0AAAIAAAAAAAAACgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAbwECAQMBBAEFAQYBBwEIAQkBCgELAQwBDQEOAQ8BEAERARIBEwEUARUBFgEXARgBGQEaARsBHAEdAR4BHwEgASEBIgEjASQBJQEmAScBKAEpASoBKwEsAS0BLgEvATABMQEyATMBNAE1ATYBNwE4ATkBOgE7ATwBPQE+AT8BQAFBAUIBQwFEAUUBRgFHAUgBSQFKAUsBTAFNAU4BTwFQAVEBUgFTAVQBVQFWAVcBWAFZAVoBWwFcAV0BXgFfAWABYQFiAWMBZAFlAWYBZwFoAWkBagFrAWwBbQFuAW8BcAAdc3RhcnQtZXZlbnQtY29tcGVuc2Etbm9uLWludGUVaW50ZXJtZWRpYXRlLWV2ZW50LWM3CXNlbmQtdGFzaxNzdGFydC1ldmVudC1tZXNzYWdlFWludGVybWVkaWF0ZS1ldmVudC10MhZpbnRlcm1lZGlhdGUtZXZlbnQtYzEyCmRhdGEtaW5wdXQUZW5kLWV2ZW50LWNvbXBlbnNhdGkHc2VydmljZQp1c2VyLXRhc2sxD2xhbmUtZGl2aWRlLXR3bxRzdGFydC1ldmVudC1ub24taW50ZRNib3VuZGFyeS1ldmVudC10aW1lFWludGVybWVkaWF0ZS1ldmVudC1jORFsYW5lLWluc2VydC1hYm92ZQVncm91cBVpbnRlcm1lZGlhdGUtZXZlbnQtdDUVYm91bmRhcnktZXZlbnQtY2FuY2VsEnN1Yi1wcm9jZXNzLW1hcmtlcg1zZW5kLXRhc2stYmFrC3NjcmlwdC10YXNrDHNlcnZpY2UtdGFzawN0YWIHY29tbWVudAttYW51YWwtdGFzawhzZXF1ZW5jZQpkYXRhLXN0b3JlBm1hbnVhbBJidXNpbmVzcy1ydWxlLXRhc2sNYnVzaW5lc3MtcnVsZRRzdGFydC1ldmVudC1wYXJhbGxlbAdyZWNlaXZlGXN1Yi1wcm9jZXNzLWV4cGFuZC1tYXJrZXIUc3RhcnQtZXZlbnQtY29uZGl0aW8VaW50ZXJtZWRpYXRlLWV2ZW50LWMzEmVuZC1ldmVudC1tZXNzYWdlMRVzdGFydC1ldmVudC1ub24taW50ZTIVc3RhcnQtZXZlbnQtbm9uLWludGU2EXN0YXJ0LWV2ZW50LXRpbWVyEmdhdGV3YXktZXZlbnRiYXNlZBJlbmQtZXZlbnQtbXVsdGlwbGUVaW50ZXJtZWRpYXRlLWV2ZW50LXQzCXVzZXItaWNvbhZpbnRlcm1lZGlhdGUtZXZlbnQtYzE0FHN0YXJ0LWV2ZW50LW11bHRpcGxlBWNob3JlFGJvdW5kYXJ5LWV2ZW50LWVycm9yFWludGVybWVkaWF0ZS1ldmVudC1jNBFzdGFydC1ldmVudC1lcnJvcgRsYW5lFGludGVybWVkaWF0ZS1ldmVudC1uFXN0YXJ0LWV2ZW50LW5vbi1pbnRlMRFsYW5lLWluc2VydC1iZWxvdw5lbmQtZXZlbnQtbm9uZR9pbnRlcm1lZGlhdGUtdGhyb3ctZXZlbnQtc2lnbmFsDHJlY2VpdmUtdGFzaxNlbmQtZXZlbnQtdGVybWluYXRlFWJvdW5kYXJ5LWV2ZW50LXNpZ25hbAZzY3JpcHQQZW5kLWV2ZW50LXNpZ25hbBJzdGFydC1ldmVudC1zaWduYWwLbG9vcC1tYXJrZXIUc3RhcnQtZXZlbnQtY29tcGVuc2EPZ2F0ZXdheS1jb21wbGV4FmludGVybWVkaWF0ZS1ldmVudC1jMTULZGF0YS1vdXRwdXQZaW50ZXJtZWRpYXRlLWV2ZW50LWM3LWJhaxZpbnRlcm1lZGlhdGUtZXZlbnQtYzExG2JvdW5kYXJ5LWV2ZW50LW1lc3NhZ2UtaW50ZQRzZW5kFWludGVybWVkaWF0ZS1ldmVudC1jMiBpbnRlcm1lZGlhdGUtdGhyb3ctZXZlbnQtbWVzc2FnZRRzZXF1ZW50aWFsLW1pLW1hcmtlchhib3VuZGFyeS1ldmVudC10aW1lLWludGURbGFuZS1kaXZpZGUtdGhyZWUNY2FsbC1hY3Rpdml0eQ5lbmQtZXZlbnQtbGluawt0cmFuc2FjdGlvbhVpbnRlcm1lZGlhdGUtZXZlbnQtdDElaW50ZXJtZWRpYXRlLXRocm93LWV2ZW50LWNvbXBlbnNhdGlvbhBnYXRld2F5LXBhcmFsbGVsFWludGVybWVkaWF0ZS1ldmVudC1jMRtib3VuZGFyeS1ldmVudC1jb21wZW5zYXRpb24KZ2F0ZXdheS1vcgtkYXRhLW9iamVjdAxnYXRld2F5LW5vbmUVc3RhcnQtZXZlbnQtbm9uLWludGUzE2NvbXBlbnNhdGlvbi1tYXJrZXIQZW5kLWV2ZW50LWNhbmNlbBVzdGFydC1ldmVudC1ub24taW50ZTULZ2F0ZXdheS14b3IEdXNlcg9lbmQtZXZlbnQtZXJyb3IUZW5kLWV2ZW50LWVzY2FsYXRpb24Vc3RhcnQtZXZlbnQtbm9uLWludGU0DWFkLWhvYy1tYXJrZXIGdXNlci0xEnBhcmFsbGVsLW1pLW1hcmtlchRzdGFydC1ldmVudC1lc2NhbGF0aRBzdGFydC1ldmVudC1ub25lBGxpbmsEbG9jawZ1bmxvY2sEZWRpdAZjYW5jZWwCb2sFdHJhc2gEbGVmdAVyaWdodAdzZXR0aW5nAAAAAA=='); /* IE9 */ src: url('data:application/vnd.ms-fontobject;base64,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AAAAAAAMAAAAAAVcAAAAAAAAAHEAANbvAADW7wAAAGsAAOZ7AADmewAAAGUAAOaBAADmgQAAABkAAOaCAADmggAAABUAAOaDAADmgwAAAAYAAOaFAADmhQAAAEYAAOaGAADmhgAAAEUAAOaHAADmhwAAAEoAAOaIAADmiAAAAEQAAOaKAADmigAAADsAAOaLAADmiwAAAC8AAOaMAADmjAAAADAAAOaNAADmjQAAADEAAOaOAADmjgAAADIAAOaPAADmjwAAAGgAAOaQAADmkAAAADMAAOaRAADmkQAAADQAAOaSAADmkgAAADUAAOaTAADmkwAAADYAAOaUAADmlAAAADcAAOaVAADmlQAAAGYAAOaWAADmlgAAADgAAOaXAADmlwAAAGkAAOaYAADmmAAAADkAAOaZAADmmQAAAGoAAOaaAADmmgAAADoAAOabAADmmwAAADwAAOacAADmnAAAAD0AAOadAADmnQAAAD4AAOaeAADmngAAAD8AAOafAADmnwAAAGIAAOagAADmoAAAAEAAAOahAADmoQAAAEEAAOaiAADmogAAAAMAAOajAADmowAAAEIAAOakAADmpAAAAG4AAOalAADmpQAAAAIAAOamAADmpgAAAEMAAOanAADmpwAAAAUAAOaoAADmqAAAAEcAAOapAADmqQAAAEgAAOaqAADmqgAAAEkAAOarAADmqwAAAEsAAOasAADmrAAAAEwAAOatAADmrQAAAE0AAOauAADmrgAAAE4AAOavAADmrwAAAE8AAOawAADmsAAAAFAAAOaxAADmsQAAAFEAAOayAADmsgAAAFIAAOazAADmswAAAFMAAOa0AADmtAAAAFQAAOa1AADmtQAAAFUAAOa2AADmtgAAAFYAAOa3AADmtwAAACQAAOa4AADmuAAAAFcAAOa5AADmuQAAAGEAAOa6AADmugAAAFgAAOa7AADmuwAAAFkAAOa8AADmvAAAAAQAAOa9AADmvQAAAFoAAOa+AADmvgAAAFsAAOa/AADmvwAAAF0AAObAAADmwAAAAF4AAObBAADmwQAAAAUAAObCAADmwgAAAF8AAObDAADmwwAAAAEAAObEAADmxAAAAAcAAObFAADmxQAAAAgAAObGAADmxgAAAAkAAObHAADmxwAAAAoAAObJAADmyQAAAAsAAObKAADmygAAAAwAAObLAADmywAAAA0AAObOAADmzgAAAGQAAObPAADmzwAAAGAAAObQAADm0AAAAGwAAObRAADm0QAAAA4AAObSAADm0gAAAG0AAObTAADm0wAAAGMAAObYAADm2AAAAA8AAObZAADm2QAAAGcAAObaAADm2gAAABAAAObcAADm3AAAABEAAObdAADm3QAAABIAAObeAADm3gAAABMAAObfAADm3wAAABQAAObgAADm4AAAABYAAObhAADm4QAAABcAAObiAADm4gAAABgAAObjAADm4wAAABoAAObkAADm5AAAABsAAOblAADm5QAAABwAAObmAADm5gAAAB0AAObnAADm5wAAAB4AAObpAADm6QAAAB8AAObsAADm7AAAACAAAObyAADm8gAAACEAAOb1AADm9QAAACIAAOb2AADm9gAAACMAAOb3AADm9wAAACQAAOb4AADm+AAAACUAAOb5AADm+QAAACYAAOb6AADm+gAAACcAAOb7AADm+wAAACgAAOb8AADm/AAAAAoAAOb9AADm/QAAACkAAOb+AADm/gAAACoAAOb/AADm/wAAACsAAOcBAADnAQAAACwAAOcCAADnAgAAAC0AAOcDAADnAwAAAC4AAOgIAADoCAAAAFwAAAAAAagCZAKqAxYDsgbOBzgHoAj0Cc4KGgvQDIANQA2MDmAO3g+sD/QQQBEGEfwSXhLaE4AToBREFNgVVBW4FkIWgBa2F0QX4BhGGfYbkhwSHGYcyB1aHiwhYiHOIgAigiV2JcYl/iZ0KAIoSiiOKRYpgincKmorPCuSK/AsaCzgLVQweDC2MU40UDdSN4Y4MjjKOQQ8GjyOPLI9AD1CPco+Yj6yP2ZAEEBkQJhAxkJiQrBDHEUSRWRGRkaWRuxIqkkASVhJlEoaSl5K3ktUS85MZEyUTLpNKk1KTWpO1AAQAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BIAEvATIBQQAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicBFSc3Ig8BBhQfARYyNj0BNCYXFSc3Ig8BBhQfARYyNj0BNCYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P/vRBWwYEhQcHhQQNCgqGQVoFBYUGBoUEDQoKAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkI/rtiMXcEZQURBWUDCQjKCAlGYjF3BGUFEQVlAwkIyggJAAYAAP/VA6sDKwAUACkANgBLAG8AhwAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgMjIiY9ASMiJj0BNDY7ATU0NjsBMhYdATMyFh0BFAYrARUUBiczNTQ2OwE1IyImPQEjFRQGKwEVMzIWFQIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSiRmCQxFCQwMCUUMCWYJDEUJDAwJRQxZOg0JREQJDToNCURECQ0C6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+HgwJRQwJZgkMRQkMDAlFDAlmCQxFCQwrRAkNOg0JREQJDToNCQAAAAAEAAAAAAOrAsAAAwATAB4ALAAAAREhESUhIgYVERQWMyEyNjURNCYFByc1NDYzITIWHQIUBiMhIiY9ARcWNzMDbf0mAu78/hEZGREDAhEZGf6ZrakTDAEYDBMTDP7oDBOhCAkBAoL9/AIEPhgR/dIRGBgRAi4RGKtkYQ8NEhINMKkNEhINp10FBgAAAAUAAP/VA6sDKwAUACkAOQA8AEYAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJhMhIgYdARQWMyEyNj0BNCYHJzMHNRczFjI3MzcVAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjH/7bBwkJBwElBgkJmVu20msBBgoGAWsC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv+zAkGzwcJCQfPBglkOZh4RAMDRHgAAAcAAP/VA6sDKwAUACkANgBLAFsAXgBoAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmFyEiBh0BFBYzITI2PQE0JgcnMwc1FzMWMjczNxUCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUo8/tsHCQkHASUGCQmZW7bSawEGCgYBawLrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4O6tFdop2RUV2inZFQCwqSUquSkkqLCwqSUquSkkqLMkJBs8HCQkHzwYJZDmYeEQDA0R4ABcAAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQE4AUQBoQHEAdMB+gIHAhUCTwJsAnoAAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnBQYHBgcxFSMVIxUxFSM5ARUjFTEGBxc3Nj8BBwYHFRQXNzU0PwEnFwcWHwEVMxUxFTMVMRUzFTEVMRUzFTMVMxUxFTMVMRcVMxcVMRUzFTMVMRUxFTMxMxUxFTMVMRUxFTMVOQEzFTEVMRUzFTEVMxU5ATMVMRUxFTMXFhcWFzcnJi8BFwcWFzMVMxUzMTMVMxUzFTMWFzMXMxczFTMVFxYXNycmLwEhBwYPARc2NzY/ATY3Nj8BBwYPARc2NzUxNTM1MTUzNTM1MTUxNTM1OQEzNTE1MzUxNTE2Nyc3BxcWHQEHFzY3NSYvAQcXFh8BNyYvASYnJi8BIgcjFSMVIzEjByMVIwcjByMHIxUjMSMVIxUjFSMVIwYHFzc2OwEyHwE3Ji8BIycjJyMnIyYnMSYjEyIvAQYPAQYHDgEuATc2PwE2Nz4BMhYfARYXFgYnMTIfAScGDwEGBzY3NgIAFAkHLCQMICQkDxAmIR8RFBICAgMBISMRErENDxEBAgIBAQIBAQEBAgEBAQEDAQEHGhUoGRsgHR+jCQoOAQEBAwQCAwUFOgwMFRE1WwIBAQECBD4EAwECP1E5DAYBDxEBDAgzExUPDmgmExQBAQIBGR0ODxsdIB4ZnwkUFxQNIRMVBDUYGx8BLRseIx4WEQ4qIgcNByJxEBIYFTALCwkBAgEBAQEBAQMWEDYjAQcHPRIBQTgPEQsJPAMHAwgMEZ8jGx4aFywlMAEBDQ/+hAkRHRYBAQEBDAoyExQcGakOAwI+Bwc8NzkGBgMBAQEBAQEBAQEBAQEBAQEBAQEBAQEDBgQJDDAUFw0Obh0NEQECAQIBAgEWFAIBAgECAxAPEQ0gIR8cAR4dHiIgDAwUGBwFEAgQC0wODxYVLxUSAQEBAQEBFQ05Pj0HBgI/AgECDoAnGRsTEzMFCQMZIQwOsRIIBwYFBQEEAwEDAQIDAwMDAwIDARAOEB8hIgQhIx8REgwMAgECAQIBAw4UFQtsCgZbDRcCHRkFDw0EAhQgASAWAgsOCwI1IxMDDXUJByo7ChMDCg0UFQYDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQhoBQ0XGwEBAQEBAg8RJRobFhRzKCklCxUBKB4eHw6zGhENBwEBAQIBCgECAgICAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQIECAQMDCkYHB4dhDcJCQEBAQEBCgYBAQEBAwQCPQcHDw8PDwYGPgEEBAoCBwQICL4eIBgZKRUXAQEBAQEBAQEBAQICASAjG7UOHxkfDCADDhIgLSqkMRQWGxokCA4FIxsKCTQBAQEBAQEBAQEBAQEBBQU8CAkKCTwHAwMBAQEEAgL+AAdjDRsBIhkFAggOBzdxA3A8BwcIB6tyOQoSngctvSFCCSUpFhUGAAAABQAAAAADSwMgAAgAGgAfADsASQAAASMiJj0BMxUzEyEiJjURNDYzITIfARYVERQGJSERJyEXIi4BPQEjIiY9ATQ2OwE1ND4BFh8BFhQPAQYjJzMyFh0BNycVFAYrARUDKtYNE0C2Af2qDRMTDQF/DgnWChP9vQIWxP6upgQJBl0IDAwIXQYKDARUBgZUBgddXQgLJSULCF0CCRMN1rb9whMNAtUNEwnXCQ3+AQ0TQAHSw94ECQYkCwgvCAwjBgoEAgRPBREGTwVeCwgLIyIKCAsJAAAEAAD/1QOrAysAFAApADUAQQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmARcWNj0BNCYPAQYUHwEWNj0BNCYPAQYUAgBRRkMoKSkoQ0aiRkMoKSkoQ0ZRdGNhODs7OGFj6GNhODs7OGFj/t+BCRISCYEGqIIIEhIIggYCqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODv+SGMGCQrGCgkGYwUQBWMGCQrGCgkGYwUQAAAABAAA/+4DoAMmAGkA6AD1AP4AAAUjIiY9ATQnJg8BBiIvASY0PwE2JyYrASImPQE0NjsBMjc2LwEmND8BNjIfARY3Nj0BNDY7ATIWHQEUFxY/ATYyHwExFhQPAQYXFjsBMhYdARQGKwEiBwYfARYUDwEGIi8BJgcGHQEUBiMnMhceAR0BFBY7ATI2PQE0Njc2Fh8BFhcwMTI/ATY0LwEuATc+ATsBMjY9ATQmKwEiJicmNj8BNjQnMScmIg8BDgEnLgE9ATQmKwEiBh0BFAYHBiYvAS4BByMHBhQfAR4BBw4BKwEiBh0BFBY7ATIWFxYGDwEGFB8BFjI3Mzc2NyIuATQ+ATIeARQOASciBhQWMjY0JgIvVR4sBwkFEhU+FjsWFhEFAwMHGR8rKx8ZBwIFBRIWFjwWPRYRBQcKKx9UHysHCgUSFj0VPBYWEQUDAwgYHywsHxsHAgUFEhYWOxY9FREGBgorH60SDhQaBgRVBAYbFhMuERECBQUCPAICEREICgcmFxwEBgYEGRgmCAkJEREDAzwDCQMREC8WFBsGBFQEBxsWEy4QEQMIAwE8AwMSEAgKByYXGQQGBgQZFyYICQgREQMDOwMIAwERFaMrSSsrSVZIKytIKyg3OE43NxArHxsHAgQFERYWOxY+FREFBworH1QfKwcJBRIWPRY8FRURBQIEBxkfKysfGQcCBQUSFRU8Fz0WEQUGCiwfVR8rBwkFEhY+FTwVFREFAgQHGR8rsQcHJhcbBAYGBBkXJwcJCBERAgEDOwMJAhIQLxUUGwYEVQUGGxYTLhARAwgDPQMDEREICgcmGBgFBgYFGBgmCAkJEBEDAQM8AwgDEhEuFRQbBgRUBAYcFhMuEBEDCAQ7AwMSFUwrSVZIKytIVkkr/ThONzdOOAAFAAAAAAOrAsAADwATADMAaACYAAABISIGFREUFjMhMjY1ETQmAyERIQEhMjY9ATQmLwEmMRcWMTY0JiIGFRQWFwcOAR0BFBYzNw4BDwEGBzEGIwYiLwEmLwEmLwE0JzY3PgImJy4BNzY3NjIXFj8BFhUUBgcOARceARcUDwE0NjcXFh8BFh8BFh8BFjI/ATY/ATY/ATY3NR4BHQEjNTQmIgYdASM1NCYiBh0BIwOB/P4RGRkRAwIRGRkl/SYC2v1oAREGCTApFwITAhoxRjEODAQpMAkGrgEDAwUDBQICCA0IBAUDBAMCAgELCQUHAQUFFxQJAwMWEQwSEwIJFREFBgEBFgoBoR4ZAQUEAgUHAwcJBAsRCwQKBwIGBgMFBBodIgkMCXMJDAkiAsAYEf3SERgYEQIuERj9vgIE/okJBhctSxMKAQkBGUcyMiMRHwwCEkstGAYJlwMEBQQDAgIDAwICAwQDBAUBAgMBAQgKCQEIKxYFBQkHCwUBDg4RHQUCCAYLBAMCAXEfNxABCgYDBQYCBAQBAwMBBAQCBAcDBwkBEDcfCDEGCQkGMTEGCQkGMQAACQAAAAADrQKfAAMAEwAXABsAHwAjACcAKwAvAAABESERJSEiBhURFBYzITI2NRE0JgEzFSMhIzUzByM1MwcjNTMHIzUzByM1MyEzFSMDbP0rAu38/BEYGBEDBBAYGPzuKioCqlVVgFVVgFVVgFVVgFVVAisrKwJf/hgB6EAYEf3qERgYEQIWERj+5zY2NjY2NjY2NjY2AAAOAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BOgFIAAABIwcjBgcXNzY7ARcWHwE3JicjNSM1IzUjJicmIwcGDwEjFSMVByMxIxUjFSMVIxUjFSMVIzEjFSMVIxUjByMVMRUjFQcGBxc3Nj8BJwcGDwEVIxUxFSMVMRUxFSMHFTEHFQcVBwYHFzc2PwEnBwYPARUUFxUWFzcnJjU0PwEnFwcfARUzFhcVMxUxFRYXNycmLwEXBxYXMxUzFTMVMzkBFhcWFzcnJi8BFwceARczFTM2NycHIi8BJQcGDwEXNjc2PwE2Nyc3BwYPARc2PwE1MzcxNTM1MTUzNTkCNTM1MTUzNTE1MzU5AjUzNTE1NzU2Nyc3FQYPARc2NTQvAQcXFh8BNyYnNSYnNSYvAQcXFh8BNyYnIzUjNTEmJwMiLwEGDwEGBw4BLgE3Nj8BNjc+ATIWHwEWFxYGJzEyHwEnBg8BBgc2NzYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0PZQoGWw0XAh0ZBQ8NBAIUIAEgFgILDgsCNSMTAw11CQcqOwoTAwoNFBUGAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkI/ckHYw0bASIZBQIIDgc3cQNwPAcHCAercjkKEp4HLb0hQgklKRYVBgAAAAAHAAD/1QOrAysAFAApADYASwBYAGUAdgAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3Jg4BFB4BPgI0LgEHIyImPQE0NjIWHQEzMhYUBgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSlciOiIiOkQ6IiI6IjFUMTFUYVEvL1EBLwkMDBIMGgkMDALrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4O6tFdop2RUV2inZFQCwqSUquSkkqLCwqSUquSkkqLMIiOkQ6IiI6RDoiNQEwU2FUMAIwUmBSMNgMCUsJDQ0JNQ0SDAAACQAA/9UDqwMrABQAKQA2AEsAWwBfAGsAdwCDAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmEyMiJjURNDY7ATIWFREUBiczESMXIyImNDY7ATIWFAYHIyImNDY7ATIWFAYHIyImNDY7ATIWFAYCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUoS0ggLCwjSCAwMx6yshV4ICwsIXggLCwheCAsLCF4ICwsIXggLCwheCAsLAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7q0V2inZFRXaKdkVALCpJSq5KSSosLCpJSq5KSSos/hoLCAEmCAsLCP7aCAsmAQBPCxALCxALRAsQCwsQC0QLEAsLEAsAAAAACQAAAAADugLbAA8AEwAUABgAHAAgACQAKQAtAAAlISImNRE0NjMhMhYVERQGARMlAzMlMxUjJSM1MwcjNTMHIzUzByM1MxUFMxUjA3j9QBsnJxsCwBsnJ/0lAgK+AgL9AEBAAyKUlNGTk9CTk9GTlAJPQEAZJhsBaxsnJxv+lRsmAar+lwIBZ65rlEBAQEBAQEBAKWsAAAB7AAAAAAO0AsoACQANABEAGwAfACUAKQAtADEANQA2ADcAOAA5ADoAOwA8AD0APgA/AEAAQQBEAEUARgBHAEgASQBKAEsATABNAE4ATwBQAFEAUgBTAFQAVQBWAFcAWABZAFoAWwBcAF0AXgBiAGYAZwBoAGkAagBrAGwAbQBuAG8AcABxAHIAcwB0AHUAdgB3AHgAeQB6AHsAfAB9AH4AfwCAAIEAggCDAIQAhQCGAIcAiACJAIoAiwCMAI0AjgCPAJAAkQCSAJMAlACVAJYAlwCYAJkAmgCbAJwAnQCeAJ8AoAChAKIAowCkAKUApgCnAKgAqQCqAKsArACtALEAAAEjFTMVMzUjNSYrARUzJyMVMycjFSMGHQEzNTMHIxUzFSMVFBczNyMVMzcjFTM3IxUzNyMVMzc5CyIjORk3IxUzESMVMwM5RgczNQOFdV5ACQzJlpbWlZXVlTUDQI2NQEBACzWZlZXWlpbVlZWpaWkLAwIoQEBAQAgECALKQCg/GRBAQEBAGgcIh3CwlUB6EAsyQEBAQEBAQAHqlQFrlgEtEBUAAAAABQAA/9UDqwMrABQAKQA2AEsAUgAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgcVIxUzFTcCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUpAqKh6AusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7q0V2inZFRXaKdkVALCpJSq5KSSosLCpJSq5KSSosr0uMS5EABgAA/9UDqwMrABQAKQA2AEsAcACIAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmAyIvAQcGIi8BJjQ/AScmND8BNjIfATc2Mh8BFhQPARcWFA8BBicXNzYyHwE3JyY0PwEnBwYiLwEHFxYUBwIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJShcJBjExBhIGSAYGMTEGBkgGEgYxMQYSBkgGBjExBgZIBrIpMQYSBjEpMQYGMSkxBhIGMSkwBwcC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+IwcwMAcHRwcSBTExBhIGRwcHMDAHB0cHEgUxMQYSBkcHXSkxBgYxKTEGEgYxKTEGBjEpMQYSBgAAAAQAAAAAA4ADCQADABMAIAAsAAABESERJSEiBhURFBYzITI2NRE0JgEiJjURNDYyFhURFAY3ISImNDYzITIWFAYDPP2KAo79WREZGRECpxIZGf6bDRMTGhMTnv6qDRMTDQFWDRMTAsb9igJ2QxkS/VkSGRkSAqcSGf23Ew0BVQ0TEw3+qw0TqxMaExMaEwAAAAUAAAAAA6sCwAADABMAIwAmADAAAAERIRElISIGFREUFjMhMjY1ETQmBSEiBh0BFBYzITI2PQE0JgcnMwU1FxYzMTI/ARUDbf0mAu78/hEZGREDAhEZGf6h/rQICgoIAUwHCgqtder+/oIFBQUGgQKC/fwCBD4YEf3SERgYEQIuERiACgfqCAoKCOoHCnRJuJVSAwNSlQAACAAAAAADqwLAAAMAEwAxAFgAZABwAHwAiAAAAREhESUhIgYVERQWMyEyNjURNCYFBhUUFxYXFRYXFhUUBgcjNjc2JyYnLgE3Njc2NzM3IwcGBw4BFxYXFhcWBwYHBhY7ATc2NzY1NCcmJyYnJjU0NzY3NiYHIyImNDY7ATIWFAYHIyImNDY7ATIWFAYXIyImNDY7ATIWFAYXIyImNDY7ATIWFAYDbf0mAu78/hEZGREDAhEZGf4AEw4JFBEGCBQNeAgEChAKGRQNAgcSCw5tQbQPEg0TDg0JGBUGCwUNMAQBBMsOEQoODQgVEAYKFQ8XAgFyUAYJCQZQBgkJBkAHCAgHQAYJCRowBgkJBjAGCQkaUAYJCQZQBgkJAoL9/AIEPhgR/dIRGBgRAi4RGJ4bHhkUDBABDQgMEgYSBwwMHRsQFhETChQOCgUeBgoMEi8VDRUSChARJRMBBwgKCxAQGxQMEA0IDRAZGBAOAgZXCQwJCQwJKwkMCQkMCSsJDAkJDAkrCQwJCQwJAAAABgAAAAADqwLAAAMAEwBbAJ0ApgCvAAABESERJSEiBhURFBYzITI2NRE0JgEjIiY9AQcGIi8BJjQ/ASciJj0BNDY7AScmND8BPgEfATc0NjsBMhYdATc2Mh8BFhQPARcyFh0BFAYrARcWFA8BBiIvAQcUBicyFx4BHQEzNTQ+ARYfATcnLgE+ATsBNSMiLgE2PwEnBw4BLgE9ASMVFA4BJi8BBxceAQ4BKwEVMzIeAQYPARc3NjciJjQ2MhYUBiciBhQWMjY0JgNt/SYC7vz+ERkZEQMCERkZ/doeDBIICRoIFQkJBgoMEhIMCQUJCRUJGQkGAhINHgwSCQkZCBYICAcKDRERDQoGCAgWCBkJBwISSggFCAseDBESBwYWBwYEBxAJCgkJEAcEBgcWBgcTEQseDBESBwYWBgcEBxAJCQkJEAcEBwYVBwg8GSMjMyMjGgwSEhkSEgKC/fwCBD4YEf3SERgYEQIuERj+YBIMCgUJCRUJGQkGAhENHg0SCAgaCBYIAQkGCQ0REQ0JBgkJFgkZCQYCEg0eDRIICRkIFgkJBwoNEUYDAhAJCgkJEAcEBgcWBgcTEAsfDBESBwYWBwYEBxAJCQkJEAcEBwYVBwcTEAsfCxETBgYWBgkVIzMjIzMjWxIaEhIaEgAABAAAAAADAQLgABMAIAA1AEIAAAEVFAYjISIGFBYzITIWHQE3NjQnFyImNRE0NjIWFREUBgUVFBYzITIWFAYjISIGHQEnJjQ/AQMiJjURNDYyFhURFAYCGgUD/vERGBgRAQ8DBYoCAjENExMaExP+3gUDAQ8RGBgR/vEDBYoCAoq7DRMTGhMTArRWBAUYIhgFA1aBAwcCvRMNASsNExMN/tUNExZWBAUYIhgFA1eCAgcDgf7CEw0BKw0TEw3+1Q0TAAAAAAUAAAAAA1QC9gAVACMAMQA/AE8AACUjIiY1ETQ2OwEyFhQGKwERMzIWFAYlIicmNj8BNh4BBg8BBjciJyY2PwE2HgEGDwEGNyInJjY/ATYeAQYPAQY3IicmNj8BPgEeAgYPAQYDM+YNExMNzQ0TEw2txg0TE/1rEAoIBAspCxoQBAsqCF4QCggECykLGhAECykJXhAKCAQLKQsbDwQLKQleEAoIBAsqBxEPCgIHBykJNRMNAoANExMaE/3AExoTgA4KGggeCAQWGggeBksNCxoIHggFFRoIHgZLDQsaCB4HBBUbBx4GSg4KGggeBQIHDhEQBR4GAAAABAAAAAADqwLAAAMAEwA6AHkAAAERIRElISIGFREUFjMhMjY1ETQmASMiJj0BNDY/AjYWFxYUBzMyFhUUFR4BFAYHFhUUBgcWFRQGKwE3BwYHDgEdARQWOwE3NjQmKwEiJjQ2OwEyNjQmKwEiJjQ2OwEyNjQmKwEiJjQ2OwEyNjQmKwEiJicmPwE+AScDbf0mAu78/hEZGREDAhEZGf3mWCU1GBUPbQcTBwsLTg8WEBYSDgIRDQEUDlMCaAkJDRAjGK0CAgMBVAYJCQZsAwUFA2wGCQkGhQYICAaFBgkJBmYDBQUDeQUIAQQJFQgGBAKC/fwCBD4YEf3SERgYEQIuERj+cDQlIBgpDApLBQEHESYOFhAGAgIVGxQDBQQNFAMFBA8W/kgGBQgcDyAZIwIDBgUIDQgFBgUJDAkFBQUJDAkFBgUGBAsGDwYSCQABAAAAAAOAAxUADQAAAQYHBgcWHwEBFwEXNjcDgE1NrFcUJhz+WB8BqFcuVgMVJydXKBMmHP5SHgGuVlunAAAABAAAAAADSwMDABgAMQBQAG8AACUiJyYnJjURNDc2NzYyFxYXFhURFAcGBwYDIgcGBwYVERQXFhcWMjc2NzY1ETQnJicmAyInJicmNTQ2MhYUFxYXFjI3Njc2NDYyFhUUBwYHBiciJyYnJjU0NjIWFBcWFxYyNzY3NjQ2MhYVFAcGBwYCAFRKTi0xMS1OSqlKTiwyMixOSlVQQTgiHx8iOEGgQjgiHx8iOEJQVEpOLTETGhMfIjhBoEI4Ih8TGhMyLE5KVVRKTi0xExoTHyI4QaBCOCIfExoTMixOSiMRER8iLQHALSIfERERER8iLf5ALSIfERECoA8MFBIP/kEPEhQNDg8MFBIPAb8PEhQMD/5AEBIfIi0NExMcEhQMDw8MFBIcExMNLSIfEhDgEBIfIi0NExMcEhQMDw8MFBIcExMNLSIfEhAAAAIAAAAAA8MDDwApAGkAACUjIi4BPQE0Njc2NyU2Fh8BFgYHMzIWFRQHHgEVFAYHFhUUBgcWFRQGIwMFBgcOAR0BFB4BMyEyNjQmKwEiJjQ2MyEyNjQmIyEiJjQ2MyEyNjQmIyEiJjQ2OwEyNjQmIyEiLgE2PwE+AScCGtg6Yjk5MRkMAQgRKw8EGwYfyCQzBCg2KyIEKSADLiHB/v0NHCIoKEQpAaMGCQkGyw0TEw0BBgsPDwv++g0TEw0BRA8WFg/+vA0TEw33Cg0NCv7aCxEGBwg0Fg0MWjliOk04YxwQCLgMBA8FJl0jMyQLDAIyIx4vBwwNIDAGCg4kMwJxtAkRFEUnTihEKA0TDRMaEw0TDRMaEw8QDxIbEw4SDgwUFAYkEDQXAAAACQAAAAADqwLAAAMAEwAjACcANwA7AEsATwBTAAABESERJSEiBhURFBYzITI2NRE0JgEhIiY9ATQ2MyEyFh0BFAYlITUhBSEiJj0BNDYzITIWHQEUBiUhNSEXIyImPQE0NjsBMhYdARQGJzM1IychFSEDbf0mAu78/hEZGREDAhEZGf5//sQFBwcFATwFBwf+zAEj/t0BL/7EBQcHBQE8BQcH/swBI/7dV2QFBwcFZAUICFxLSw0BPP7EAoL9/AIEPhgR/dIRGBgRAi4RGP56CAX5BQcHBfkFCBnh+ggFTgUHBwVOBQgZNU4IBeoFBwcF6gUIGdIWXwAHAAAAAAPLAswADwATACMAJwA3ADsAPwAAJSEiJjURNDYzITIWFREUBiUhESEBISImPQE0NjMhMhYdARQGJSE1IRchIiY1ETQ2MyEyFhURFAYnMxEjJyERIQOr/NUNExMNAysNExP86ALr/RUDC/zVDRMTDQMrDRMT/OgC6/0V4P8ADRMTDQEADRMT7b+/IAMr/NULEw0CgA0TEw39gA0TQAJA/YATDcgNExMNyA0TQIjJEw4CgA0TEw39gA4TQgI+If8AAAAAAAQAAP/VA6sDKwAUACkATQBlAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYDIyImPQEjIiY9ATQ2OwE1NDY7ATIWHQEzMhYdARQGKwEVFAYnMzU0NjsBNSMiJj0BIxUUBisBFTMyFhUCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWNBZgkMRQkMDAlFDAlmCQxFCQwMCUUMWToNCURECQ06DQlERAkNAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7/bMMCUUMCWYJDEUJDAwJRQwJZgkMRQkMK0QJDToNCURECQ06DQkAAAMAAAAAA6wCzAAPABIAIwAAASEiBhURFBYzITI2NRE0JgElIRMhIiY1EQEXFjMyPwEBERQGA2b9NB0pKR0CzB0pKf59/sMCeyj9NAIEAVgFBwgECAgBWQQCzCod/fYdKSkdAgodKv7C/v3oBAMB5P7tAwQCBQET/hwDBAADAAD/9QOLAwsADwATAB8AAAUhIiY1ETQ2MyEyFhURFAYlIREhASEiJjQ2MyEyFhQGA2v9Kg0TEw0C1g0TE/09Apb9agIg/lYNExMNAaoNExMLEw0C1g0TEw39Kg0TQAKW/pUTGhMTGhMAAAAHAAD/1QOrAysAFAApADkAPQBJAFUAYQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAyMiJjURNDY7ATIWFREUBiczESMXIyImNDY7ATIWFAYHIyImNDY7ATIWFAYHIyImNDY7ATIWFAYCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWML0ggLCwjSCAwMx6yshV4ICwsIXggLCwheCAsLCF4ICwsIXggLCwheCAsLAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7/a8LCAEmCAsLCP7aCAsmAQBPCxALCxALRAsQCwsQC0QLEAsLEAsAAAYAAP/VA6sDKwAUACkANgBLAFAAZQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgcXByMnNyIPAQ4BHwEeATsBMjY/ATYmLwEmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdEV2RUV2inZFRXZFV0pJKiwsKklKrkpJKiwsKklKV28qiipvBQaYBQQCOwIJBrwGCQI7AgQFmAUC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKizPUIODjgNvBAsFtAUHBwW0BQsEbwMAAAQAAP/VA6sDKwAUACkANQBDAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYTByc1NDYzITIWHQMUBiMhIiY9ARcWPwECAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWMwpKARDAEJDRERDf73DBGZCAibAqspKENGokZDKCkpKENGokZDKCmAOzhhY+hjYTg7OzhhY+hjYTg7/rFfXA4MEREMDCGhDBISDJ5YBQZZAA8AAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQEqATcBSAAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicHMh4BFA4BIi4BND4BNyYOARQeAT4CNC4BByMiJj0BNDYyFh0BMzIWFAYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P0CI6IiI6RDoiIjoiMVQxMVRhUS8vUQEvCQwMEgwaCQwMAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkI+CI6RDoiIjpEOiI1ATBTYVQwAjBSYFIw2AwJSwkNDQk1DRIMAAAAAA4AAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQEiATcAAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnAxcHIyc3Ig8BDgEfAR4BOwEyNj8BNiYvASYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P0G8qiipvBQaYBQQCOwIJBrwGCQI7AgQFmAUDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQj++1CDg44DbwQLBbQFBwcFtAULBG8DAAAABQAA/9UDqwMrABQAKQA2AEMAVAAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAzIeARQOASIuATQ+ATcmDgEUHgE+AjQuAQcjIiY9ATQ2MhYdATMyFhQGAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdCI6IiI6RDoiIjoiMVQxMVRhUS8vUQEvCQwMEgwaCQwMAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7/tMiOkQ6IiI6RDoiNQEwU2FUMAIwUmBSMNgMCUsJDQ0JNQ0SDAAAAAQAAP+1A8wDSwADABQAGQAuAAAJBCIHAQYUFwEWMjcBNjQnASYDFwcjJzciDwEOAR8BHgE7ATI2PwE2Ji8BJgIAAYD+gP6AAYAPC/5aCgoBpgsfCwGlCwv+WgoQbyqKKm8FBpgFBAI7AgkGvAYJAjsCBAWYBQMA/oD+gAGAAcsL/loKHwv+WgsLAaYLHwoBpgv+qVCDg44DbwQLBbQFBwcFtAULBG8DAAMAAP/VA6sDKwAUACkAPQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmDwEOAR8BHgE7ATI2PwE2Ji8BJiICAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWN/mAUEAjsCCQa8BgkCOwIEBZgFDAKrKShDRqJGQygpKShDRqJGQygpgDs4YWPoY2E4Ozs4YWPoY2E4O/9vBAsFtAYGBga0BQsEbwMAAAAFAAD/1QOrAysAFAApADYASwBfAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmDwEOAR8BHgE7ATI2PwE2Ji8BJiICAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUpimAUEAjsCCQa8BgkCOwIEBZgFDALrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4O6tFdop2RUV2inZFQCwqSUquSkkqLCwqSUquSkkqLJRvBAsFtAYGBga0BQsEbwMAAwAAAAADDAK3AB8AWACSAAABJic+ATU0LgEjIgYHBhQWFwcOAR0BFBYzITI2PQE0JiU0PwE2MhcWNzY3FhUUBgcOAR4BFxYXBg8BBg8DBg8BBiIvASYvBSYnNjc+AiYnLgE1ASM1NCYiBh0BIzU0JiIGHQEjNTQ2NxcWHwEWHwIWHwEWHwEWMj8BNj8BNj8BNj8BNj8BNj8BHgEVAmwGBxcbKEQpLUsRCxoYDUlXDgkB8QkOV/7hCAYrJBQiIgUEDyggBwoCCwgVFQIDAgIDCAsFAwQTCA4HBQUEDwkECQcDAhQWCAsBCQgfKAFISA0SDdsNEg1HOTEHAwUDBggRBgYHBwUKBg0UDQYKBQcHBgYJBAQHBwIFBAcxOQGsAwMVOiEoRCkyKhs/OhUGIYdPLAoNDQosUIaXFBMNFQ0UCAICGRsiNgoCDRELAgMHBwYEBQMLCQMCAgYCAgEBAgcHBAoMBgcHBAEMEA0DCjYh/n9eCQ0NCV5eCQ0NCV4VOmYfDwYIBAkHDgQDAwMCAwECAgEDAgMDAwQGBAQGCgMGCQ8fZjoAGAAA/9UDqwMrADsAUABjAGQAfgCoALoA0QDnAPQBGQFEAVIBXwFyAdQB4gHuAf0CDwI1Al4CggKaAAABBg8BIjc2ByMxIxUjByMVIxUjFSMVIxUxFSMxIxUjFSMVIxUjFTkBByMVIzEjFSMHBgcXNzY/ATM/AScHBgcVBxUHFQcVMQYHFzc2PwMnBwYUFxUXFTEVFhcWFzcnJjU3Jx8BBxYXMRUzOQEVMxUxFRYXFhc3JyYvBBcHFh8BMxUzMTMVFzMVMxUzFTMVMxczFTMVMxUzMTMVFxYXNycmLwExJwUHBisBJwcWMzI3MzY/ATY3JzcHBg8BIw8BFzY3MzUzNTM1MzU3NjcnNwcGDwMXNjc1MzU3Njc1NzU2Nyc3BxcWHQEHFzY1JyYvAQcXFh8ENyYvATU5ASM1MTUnNSM5ATUjNTE1JzUxNSMmLwEHFxYfATMXNyYvASM1IycjNSMxIzUjJyM1IzUjNSM1IycjNSM1IzUjJi8BIgcjBgcXNzY7ARc3JgcGBxc3Nj8CMz8BJwcGDwEVFxYXNycmNTQ3NTc1NycXBxYfARUzOQEVMRUzFTEVMxUxFTM5ARUxFTMVMxUxFTMVOQIVMxUxFTMVMRUzOQEVMxUxFTMVMxUzFTMxMxUxFTMVMxUxFTMVMzEzFTMVMxUzFTEVFxYXNycmJzUjLwIXBxY7ATcnJicjNS8CJQcGByMHIw8BFzY/AQcGDwMXNjc1NzY3JzcHFxYXFR8BNyYnNSYnNSYnMScHFxYfAjMVFzcmLwExNSM1IzEjNSM1IzUjNSM1IzEjNSMnJi8BIgcjFSMxIwcjByMHIwcjByMVIzEjFSMVIxUjFSMGBxc3NjsBFzcmIxMjIiY9ASMiJj0BNDY7ATU0NjsBMhYdATMyFh0BFAYrARUUBiczNTQ2OwE1IyImPQEjFRQGKwEVMzIWFQFQIyAKAQEFAQEBAQIBAQEBAQEBAQEBAQIBAQEBCw0KKhgdHgMBAR4fqhMSAgECCgc7CgsTAQESNVUCAQIBAQIGPQYHAT9BHDcXHwEBBAcJDS8UGREBAQEQdCAfIggCAQEFAQICAQIBAgIBAgIKChQVHiMfBB4BPx8iIwwgAhcXEQkHGxUCEwkMoxkbIAMBAR4dMi0BAQEBCAwLKVwKDRIBARM2FRABAgcDAQcDPEM+BgYCPwMBAwpuMBUWEwEBARA3DRQHAQIBAQMBEBTBFR4kHQQBHSIaIhABAQcBAgECBAECAgECAwECAgEPEHAVCwQoKAwgJCQPIAMcwkQoMxMTGwEBAQEaJoULAwEBAQQ+AwEEAQc9QDgOFQUBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEFDQotFxcSAQEBEHUYRlADBiAjIAEDAR8BKhsdHwICAQIeE08+MAkJEgEBEjQgEgMDAzwaOQ0OBgEEPgEJAwMECrQcHR8aAQIBGSoXHg4CAQEBAQIBAQEBARsXbRIOBgUFAQMBAwEDAQMDAwMDAwIDARAOEB8hIg0gAxkXNGYJDEUJDAwJRQwJZgkMRQkMDAlFDFk6DQlERAkNOg0JREQJDQMFEBYIAQMBAQIBAQEBAQEBAQEBAQIBAQoMCi8VGhACARE3ihojAQUIAgoEARgdFB4hIQEDHiHLGCcJChAHDwUGCxUMICElKgInkB4yKAEBAQEFCAsNKhgcHwEDAR6TNRcQBQEBAgEBAQEBAQEBAQQEBjwKDBICEzcGBwI/AwEDBAEEAj5gFRcTAgEQNxUkAQEBAQcLCy+kHiMfAQMeIR0fBwgFEAgDAwIVChXHDB8fJA4gAhcZJSYkvSkYGiEBAwEeHR8gCgEBAQMBAQEBBAEBFhRuOwsNEgITNRMTBwEEAQECAQEBAQEBAQEFBQwBBAs9BgcBPgOcLEYkGhwXAQECFTGuIiMNIA8LFQYgBxAXFgUBASAMuR0hHQcCAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQQNCCwXFx8BAwEegjolPgMECwEBAQ0gExQKAgEKOxE0zh4iHQEDHSIoMg8JDRMQxRodHiMGASAIJCMSCQgSChOKOQ4OFwECARcuGhUKAQEBAQEBAQEBDwgTAgEBAQEBAQEBAQEBBQU8CAkBPgP+IAwJRQwJZgkMRQkMDAlFDAlmCQxFCQwrRAkNOg0JREQJDToNCQAABAAA/9UDqwMrABQAKQAuAEMAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgMXByMnNyIPAQ4BHwEeATsBMjY/ATYmLwEmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdG8qiipvBQaYBQQCOwIJBrwGCQI7AgQFmAUC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv+xlCDg44DbwQLBbQFBwcFtAULBG8DAAAABAAAAAADrQLWAA8AEwAXABsAAAEhIgYVERQWMyEyNjURNCYFIRUhARUhNRE1IRUDgv0AEhkZEgMAERkZ/QQC1f0rAtX9KwLVAtUZEf2qERkZEQJWERnb9AGPW1v91ltbAAAAAAUAAP/VA6sDKwAUACkANgBLAFEAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYDJwM3FxMCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUofZVxnakEC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+tIP+8YR5ASUAAAAAFwAA/9UDqwMsABwATABsAH4AkgCoALcAxQD0AP4BDQEdATgBRAGhAcQB0wH6AgcCFQJPAlICXwAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicFBgcGBzEVIxUjFTEVIzkBFSMVMQYHFzc2PwEHBgcVFBc3NTQ/AScXBxYfARUzFTEVMxUxFTMVMRUxFTMVMxUzFTEVMxUxFxUzFxUxFTMVMxUxFTEVMzEzFTEVMxUxFTEVMxU5ATMVMRUxFTMVMRUzFTkBMxUxFTEVMxcWFxYXNycmLwEXBxYXMxUzFTMxMxUzFTMVMxYXMxczFzMVMxUXFhc3JyYvASEHBg8BFzY3Nj8BNjc2PwEHBg8BFzY3NTE1MzUxNTM1MzUxNTE1MzU5ATM1MTUzNTE1MTY3JzcHFxYdAQcXNjc1Ji8BBxcWHwE3Ji8BJicmLwEiByMVIxUjMSMHIxUjByMHIwcjFSMxIxUjFSMVIxUjBgcXNzY7ATIfATcmLwEjJyMnIycjJicxJiMfASM3Ig8BBhYzITI2LwEmAgAUCQcsJAwgJCQPECYhHxEUEgICAwEhIxESsQ0PEQECAgEBAgEBAQECAQEBAQMBAQcaFSgZGyAdH6MJCg4BAQEDBAIDBQU6DAwVETVbAgEBAQIEPgQDAQI/UTkMBgEPEQEMCDMTFQ8OaCYTFAEBAgEZHQ4PGx0gHhmfCRQXFA0hExUENRgbHwEtGx4jHhYRDioiBw0HInEQEhgVMAsLCQECAQEBAQEBAxYQNiMBBwc9EgFBOA8RCwk8AwcDCAwRnyMbHhoXLCUwAQEND/6ECREdFgEBAQEMCjITFBwZqQ4DAj4HBzw3OQYGAwEBAQEBAQEBAQEBAQEBAQEBAQEBAQMGBAkMMBQXDQ5uHQ0RAQIBAgECARYUAgECAQIDEA8RDSAhHxwBHh0eIiAMDBQYHAUQCBALTA4PFhUvFRIBAQEBAQEVDTk+PQcGAj8CAQIOgCcZGxMTMwUJAxkhDA6xEggHBgUFAQQDAQMBAgMDAwMDAgMBEA4QHyEiBCEjHxESDAwCAQIBAgEDDhQVCwFs12sPB4gIDw8BEA8PB4gIAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkIaAUNFxsBAQEBAQIPESUaGxYUcygpJQsVASgeHh8OsxoRDQcBAQECAQoBAgICAgEBAQECAQEBAQEBAQEBAQEBAQEBAQEBAQECBAgEDAwpGBweHYQ3CQkBAQEBAQoGAQEBAQMEAj0HBw8PDw8GBj4BBAQKAgcECAi+HiAYGSkVFwEBAQEBAQEBAQECAgEgIxu1Dh8ZHwwgAw4SIC0qpDEUFhsaJAgOBSMbCgk0AQEBAQEBAQEBAQEBAQUFPAgJCgk8BwMDAQEBBAICyrr1DewNGhoN7A0AAAAAAwAA/9UDqwMrABQAKQAvAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYDJwM3FxMCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWM8ZVxnakEC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv+SYP+8YR5ASUAAAMAAAAAA6sC1gADABMAIAAAAREhESUhIgYVERQWMyEyNjURNCYBIiY1ETQ2MhYVERQGA2v9KgLr/QASGRkSAwASGRn9mQ0TExoTEwKV/dYCKkAZEf2qERkZEQJWERn9YBMNAlYNExMN/aoNEwAAAAAEAAD/1QOrAysAFAApADYASwAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSgLrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4O6tFdop2RUV2inZFQCwqSUquSkkqLCwqSUquSkkqLAAAAA4AAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQEgAS0AAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnAxcjNyIPAQYWMyEyNi8BJgIAFAkHLCQMICQkDxAmIR8RFBICAgMBISMRErENDxEBAgIBAQIBAQEBAgEBAQEDAQEHGhUoGRsgHR+jCQoOAQEBAwQCAwUFOgwMFRE1WwIBAQECBD4EAwECP1E5DAYBDxEBDAgzExUPDmgmExQBAQIBGR0ODxsdIB4ZnwkUFxQNIRMVBDUYGx8BLRseIx4WEQ4qIgcNByJxEBIYFTALCwkBAgEBAQEBAQMWEDYjAQcHPRIBQTgPEQsJPAMHAwgMEZ8jGx4aFywlMAEBDQ/QbNdrDweICA8PARAPDweICAMrAQUKPgcHAQQJCTwHBQEBAQgDAicGCAoBAQIBAQEBAQEBAQECAQEBBBQUMRUXEg83gQwOGAEBAgQGAQYDBwIFCQgOEBceICAbIsAKFRIpCQ8IDBcIIBUaEQggBbAaHQ4EHhgBAQEQCSUaHiAdlDMQDgEBARIOBgY4Dg8XE1M+BAMCAQEDPgIEBEAREw0LOwUGEBYECQU1jBsgHBgpCwwMAQMBAQEBAQEBAQEBAQEBBAEfIx+wICggIA07PhIJyR4cHiUeEQ0YCAoUCR0bjzQSExoXLCwgAQEJCP7/uvUN7A0aGg3sDQAAAAAIAAAAAAOiAvgADwATABcAGwAfACMAJwArAAABISImNRE0NjMhMhYVERQGAwUTJQUzFSMFIzUzByM1MwcjNTMHIzUzJTMVIwNg/UAbJycbAsAbJycd/UICArz9AkBAAyOUlNGTk9GTk9CUlAJPQEABCSYcAWocJiYc/pYcJgGsAf6XAUNqakBAQEBAQECUagACAAD/1QOrAysAFAApAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYCAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWMCqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODsABQAA/9UDqwMrABQAKQA2AEsAVwAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJg8BBhYzITI2LwEmIgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSm6IBw8PARAPDwiIBx8C6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiyd7A0aGg3sDQAAAAAGAAAAAAOrAtYAAwATACQAKAA3AEUAAAERIRElISIGFREUFjMhMjY1ETQmASEiJj0BNDYzITIWHQEUBiMlMzUjFyIvAS4BPgEfAR4BDgEjMyImNj8BNh4BBg8BBiMDa/0qAuv9ABIZGRIDABIZGf5Y/vkNFBQNAQgNFBQN/v78/H4HBYEHAgoQBoEFBAQKBwEKCgIGgQcPCgIGggUHApX91gIqQBkR/aoRGRkRAlYRGf6YEw65DhQUDrkOFCevdANlBQ8NAgVkBAwLBw0QBWQFAg0PBWUDAAAEAAD/1QOrAysAFAApACoANwAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAyMUHgEyPgE0LgEiDgECAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWN0qy5PXE8uLk9cTy4CqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODv+VS5PLi5PXE8uLk8AAAAGAAD/1QOrAysAFAApADYASwBOAFsAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYHFyM3Ig8BBhYzITI2LwEmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdEV2RUV2inZFRXZFV0pJKiwsKklKrkpJKiwsKklKV2zXaw8HiAgPDwEQDw8HiAgC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKizLuvUN7A0aGg3sDQAAAAYAAAAAA3YDAQAlAF4AagB2AIIAjgAAAQYVFBcWFxYXMRYXFhcWFRQHBgchNjc2JyYnJi8BJicmNzY3NjclIQcGBwYHBgcGBwYXFhcWFxYXFhcWBwYHBgcOARYzITc2NzY3NjU0JyYnJicmJyYnJjU0NzY3NiYFIyImNDY7ATIWFAYHIyImNDY7ATIWFAYXIyImNDY7ATIWFAYXIyImNDY7ATIWFAYCtkURDhwQISANFgoMIR0m/p8iDxEODCIUKgE3ERYIFDYgJQHU/iEQExMbFx0VGQ4LDQwfEiomDxoJCgoTMyc2BQMHBgIZFxwYIBMXEQ8bESQdDRUKDDkmPAgG/tLVCxAQC9ULDw8LqwsPDwurCw8PSoALDw8LgAsQEEvWCw8PC9YLDw8CwE9ZKyQeHBAcGg0WGRwlFR4aFCcuMS4mJhclATAaICI5KhkQQAYICxATGB0hJysoISIUJSIQHBkeHzYpHxUCCwkMEBIZGiAgMyghHhEeFw0VFBkeQUAsJQUQ2g8WDw8WD3IPFhAQFg9yDxYQEBYPchAWDw8WEAAAAAMAAP/VA6sDKwAUACkANQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAwcGFjMhMjYvASYiAgBRRkMoKSkoQ0aiRkMoKSkoQ0ZRdGNhODs7OGFj6GNhODs7OGFji4gHDw8BEA8PCIgHHwKrKShDRqJGQygpKShDRqJGQygpgDs4YWPoY2E4Ozs4YWPoY2E4O/747A0aGg3sDQAEAAD/1QOrAysAFAApACwAOQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAxcjNyIPAQYWMyEyNi8BJgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3Rs12sPB4gIDw8BEA8PB4gIAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7/sq69Q3sDRoaDewNAAAAAAMAAP/gA8sDIQAtAD4ATgAABSImNDYzMjc2NzY0JyYnJiIHBgcGFRQXFg4BJicmNTQ3Njc2MhcWFxYUBwYHBiUiJy4BPwE+Ah4CDwEOASMiLwEuAT4BHwEyHgEOAgIrDRMTDV9SUC8wMC9QUr9SUC4wIwUIGBkGKTk3XmHiYV43OTk3XmH+WwUDDQ0DMwIMEBEMBQIzAhILCQe5CwcNGgu5ChAHBRAUIBMaEzAvT1O+U08vMDAvT1NfUUgMGQwJDFZfcWFeNzk5N15h4mFeNzmHAQMXDc8IDQQEDBAI0AsNBGsGGhcHB2sMEhQNAQAAAAYAAP/VA6sDKwAUACkALAA7AD4ATQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAxUnNyIPAQYUHwEWMjY9ATQmFxUnNyIPAQYUHwEWMjY9ATQmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjsEFbBgSFBweFBA0KCoZBWgUFhQYGhQQNCgoC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv+hmIxdwRlBREFZQMJCMoICUZiMXcEZQURBWUDCQjKCAkAAAYAAP+1A8wDSwADABQAIAAtADoARwAACQQiBwEGFBcBFjI3ATY0JwEmEyEiJjQ2MyEyFhQGByImNRE0NjIWFREUBjciLwEmNDYyHwEWFAYjIiY0PwE2MhYUDwEGAgABgP6A/oABgA8L/loKCgGmCx8LAaULC/5aCpv+qgsPDwsBVgsPD7YLDw8WDw9uCwjyBw8WCPIHD/0LDwfyCBYPB/IIAwD+gP6AAYABywv+WgofC/5aCwsBpgsfCgGmC/4bDxYPDxYPqw8LAVYLDw8L/qoLDzIH8ggWDwfyCBYPDxYI8gcPFgjyBwAaAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BOAFEAaEBxAHTAfoCBwIVAk8CXwJjAm8CewKHAAABIwcjBgcXNzY7ARcWHwE3JicjNSM1IzUjJicmIwcGDwEjFSMVByMxIxUjFSMVIxUjFSMVIzEjFSMVIxUjByMVMRUjFQcGBxc3Nj8BJwcGDwEVIxUxFSMVMRUxFSMHFTEHFQcVBwYHFzc2PwEnBwYPARUUFxUWFzcnJjU0PwEnFwcfARUzFhcVMxUxFRYXNycmLwEXBxYXMxUzFTMVMzkBFhcWFzcnJi8BFwceARczFTM2NycHIi8BJQcGDwEXNjc2PwE2Nyc3BwYPARc2PwE1MzcxNTM1MTUzNTkCNTM1MTUzNTE1MzU5AjUzNTE1NzU2Nyc3FQYPARc2NTQvAQcXFh8BNyYnNSYnNSYvAQcXFh8BNyYnIzUjNTEmJwUGBwYHMRUjFSMVMRUjOQEVIxUxBgcXNzY/AQcGBxUUFzc1ND8BJxcHFh8BFTMVMRUzFTEVMxUxFTEVMxUzFTMVMRUzFTEXFTMXFTEVMxUzFTEVMRUzMTMVMRUzFTEVMRUzFTkBMxUxFTEVMxUxFTMVOQEzFTEVMRUzFxYXFhc3JyYvARcHFhczFTMVMzEzFTMVMxUzFhczFzMXMxUzFRcWFzcnJi8BIQcGDwEXNjc2PwE2NzY/AQcGDwEXNjc1MTUzNTE1MzUzNTE1MTUzNTkBMzUxNTM1MTUxNjcnNwcXFh0BBxc2NzUmLwEHFxYfATcmLwEmJyYvASIHIxUjFSMxIwcjFSMHIwcjByMVIzEjFSMVIxUjFSMGBxc3NjsBMh8BNyYvASMnIycjJyMmJzEmIxMjIiY1ETQ2OwEyFhURFAYnMxEjFyMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGAgAUCQcsJAwgJCQPECYhHxEUEgICAwEhIxESsQ0PEQECAgEBAgEBAQECAQEBAQMBAQcaFSgZGyAdH6MJCg4BAQEDBAIDBQU6DAwVETVbAgEBAQIEPgQDAQI/UTkMBgEPEQEMCDMTFQ8OaCYTFAEBAgEZHQ4PGx0gHhmfCRQXFA0hExUENRgbHwEtGx4jHhYRDioiBw0HInEQEhgVMAsLCQECAQEBAQEBAxYQNiMBBwc9EgFBOA8RCwk8AwcDCAwRnyMbHhoXLCUwAQEND/6ECREdFgEBAQEMCjITFBwZqQ4DAj4HBzw3OQYGAwEBAQEBAQEBAQEBAQEBAQEBAQEBAQMGBAkMMBQXDQ5uHQ0RAQIBAgECARYUAgECAQIDEA8RDSAhHxwBHh0eIiAMDBQYHAUQCBALTA4PFhUvFRIBAQEBAQEVDTk+PQcGAj8CAQIOgCcZGxMTMwUJAxkhDA6xEggHBgUFAQQDAQMBAgMDAwMDAgMBEA4QHyEiBCEjHxESDAwCAQIBAgEDDhQVC2rSCAsLCNIIDAzHrKyFXggLCwheCAsLCF4ICwsIXggLCwheCAsLCF4ICwsDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQhoBQ0XGwEBAQEBAg8RJRobFhRzKCklCxUBKB4eHw6zGhENBwEBAQIBCgECAgICAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQIECAQMDCkYHB4dhDcJCQEBAQEBCgYBAQEBAwQCPQcHDw8PDwYGPgEEBAoCBwQICL4eIBgZKRUXAQEBAQEBAQEBAQICASAjG7UOHxkfDCADDhIgLSqkMRQWGxokCA4FIxsKCTQBAQEBAQEBAQEBAQEBBQU8CAkKCTwHAwMBAQEEAgL+GwsIASYICwsI/toICyYBAE8LEAsLEAtECxALCxALRAsQCwsQCwAEAAAAAANLAyAACAAaAB8AJgAAASMiJj0BMxUzEyEiJjURNDYzITIfARYVERQGJSERJyEXFSMVMxU3AyrWDRNAtgH9qg0TEw0Bfw4J1goT/b0CFsT+rqZwcFQCCRMN1rb9whMNAtUNEwnXCQ3+AQ0TQAHSwy03MDdPAAAABgAA/9UDqwMrABQAKQA2AEsAVwBkAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmEyEiJjQ2MyEyFhQGByImNRE0NjIWFREUBgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSin/AA0TEw0BAA0TE40NExMaExMC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+oBMaExMaE4ATDQEADRMTDf8ADRMAABcAAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQE4AUQBoQHEAdMB+gIHAhUCTwJUAmkAAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnBQYHBgcxFSMVIxUxFSM5ARUjFTEGBxc3Nj8BBwYHFRQXNzU0PwEnFwcWHwEVMxUxFTMVMRUzFTEVMRUzFTMVMxUxFTMVMRcVMxcVMRUzFTMVMRUxFTMxMxUxFTMVMRUxFTMVOQEzFTEVMRUzFTEVMxU5ATMVMRUxFTMXFhcWFzcnJi8BFwcWFzMVMxUzMTMVMxUzFTMWFzMXMxczFTMVFxYXNycmLwEhBwYPARc2NzY/ATY3Nj8BBwYPARc2NzUxNTM1MTUzNTM1MTUxNTM1OQEzNTE1MzUxNTE2Nyc3BxcWHQEHFzY3NSYvAQcXFh8BNyYvASYnJi8BIgcjFSMVIzEjByMVIwcjByMHIxUjMSMVIxUjFSMVIwYHFzc2OwEyHwE3Ji8BIycjJyMnIyYnMSYjHwEHIyc3Ig8BDgEfAR4BOwEyNj8BNiYvASYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P/oQJER0WAQEBAQwKMhMUHBmpDgMCPgcHPDc5BgYDAQEBAQEBAQEBAQEBAQEBAQEBAQEBAwYECQwwFBcNDm4dDREBAgECAQIBFhQCAQIBAgMQDxENICEfHAEeHR4iIAwMFBgcBRAIEAtMDg8WFS8VEgEBAQEBARUNOT49BwYCPwIBAg6AJxkbExMzBQkDGSEMDrESCAcGBQUBBAMBAwECAwMDAwMCAwEQDhAfISIEISMfERIMDAIBAgECAQMOFBULAW8qiipvBQaYBQQCOwIJBrwGCQI7AgQFmAUDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQhoBQ0XGwEBAQEBAg8RJRobFhRzKCklCxUBKB4eHw6zGhENBwEBAQIBCgECAgICAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQIECAQMDCkYHB4dhDcJCQEBAQEBCgYBAQEBAwQCPQcHDw8PDwYGPgEEBAoCBwQICL4eIBgZKRUXAQEBAQEBAQEBAQICASAjG7UOHxkfDCADDhIgLSqkMRQWGxokCA4FIxsKCTQBAQEBAQEBAQEBAQEBBQU8CAkKCTwHAwMBAQEEAgLOUIODjgNvBAsFtAUHBwW0BQsEbwMAAAAYAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BOAFEAaEBxAHTAfoCBwIVAk8CXwJiAmwAAAEjByMGBxc3NjsBFxYfATcmJyM1IzUjNSMmJyYjBwYPASMVIxUHIzEjFSMVIxUjFSMVIxUjMSMVIxUjFSMHIxUxFSMVBwYHFzc2PwEnBwYPARUjFTEVIxUxFTEVIwcVMQcVBxUHBgcXNzY/AScHBg8BFRQXFRYXNycmNTQ/AScXBx8BFTMWFxUzFTEVFhc3JyYvARcHFhczFTMVMxUzOQEWFxYXNycmLwEXBx4BFzMVMzY3JwciLwElBwYPARc2NzY/ATY3JzcHBg8BFzY/ATUzNzE1MzUxNTM1OQI1MzUxNTM1MTUzNTkCNTM1MTU3NTY3JzcVBg8BFzY1NC8BBxcWHwE3Jic1Jic1Ji8BBxcWHwE3JicjNSM1MSYnBQYHBgcxFSMVIxUxFSM5ARUjFTEGBxc3Nj8BBwYHFRQXNzU0PwEnFwcWHwEVMxUxFTMVMRUzFTEVMRUzFTMVMxUxFTMVMRcVMxcVMRUzFTMVMRUxFTMxMxUxFTMVMRUxFTMVOQEzFTEVMRUzFTEVMxU5ATMVMRUxFTMXFhcWFzcnJi8BFwcWFzMVMxUzMTMVMxUzFTMWFzMXMxczFTMVFxYXNycmLwEhBwYPARc2NzY/ATY3Nj8BBwYPARc2NzUxNTM1MTUzNTM1MTUxNTM1OQEzNTE1MzUxNTE2Nyc3BxcWHQEHFzY3NSYvAQcXFh8BNyYvASYnJi8BIgcjFSMVIzEjByMVIwcjByMHIxUjMSMVIxUjFSMVIwYHFzc2OwEyHwE3Ji8BIycjJyMnIyYnMSYjFyEiBh0BFBYzITI2PQE0JgcnMwc1FzMWMjczNxUCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P/oQJER0WAQEBAQwKMhMUHBmpDgMCPgcHPDc5BgYDAQEBAQEBAQEBAQEBAQEBAQEBAQEBAwYECQwwFBcNDm4dDREBAgECAQIBFhQCAQIBAgMQDxENICEfHAEeHR4iIAwMFBgcBRAIEAtMDg8WFS8VEgEBAQEBARUNOT49BwYCPwIBAg6AJxkbExMzBQkDGSEMDrESCAcGBQUBBAMBAwECAwMDAwMCAwEQDhAfISIEISMfERIMDAIBAgECAQMOFBULlP7bBwkJBwElBgkJmVu20msBBgoGAWsDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQhoBQ0XGwEBAQEBAg8RJRobFhRzKCklCxUBKB4eHw6zGhENBwEBAQIBCgECAgICAQEBAQIBAQEBAQEBAQEBAQEBAQEBAQEBAQIECAQMDCkYHB4dhDcJCQEBAQEBCgYBAQEBAwQCPQcHDw8PDwYGPgEEBAoCBwQICL4eIBgZKRUXAQEBAQEBAQEBAQICASAjG7UOHxkfDCADDhIgLSqkMRQWGxokCA4FIxsKCTQBAQEBAQEBAQEBAQEBBQU8CAkKCTwHAwMBAQEEAgLICQbPBwkJB88GCWQ5mHhEAwNEeAAAAgAAAAADqwLEAA4AHgAAAQUGIiclNTQ2MyEyFh0BBxEUBiMhIiY1EQUWNjcGNwOq/moMGw3+dS4gArogLgEtIP1GIC4BkgoXCQrQAmDaBgbUIR4qKh4bQP5bHSkpHQGf0AUBBgRrAAAGAAD/1QOrAysAFAApADYASwBoAHUAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYDIicuAT0BIyImPQE0NjsBNTQ+ARYfARYUDwEGIyczMhYdATcnFRQGKwECAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWN0RXZFRXaKdkVFdkVXSkkqLCwqSUquSkkqLCwqSUpCBQIGCIkIDQ0IiQgMDQVzBQVzBwqIiAkNQUENCYgC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+IgEDCwYyDAmFCQwxBwsEAwWJBg8GiQdwDAkMTk4MCQwAAAYAAP/VA6sDKwAUACkANgBLAFcAZQAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBzIeARQOASIuATQ+ATciBwYHBhQXFhcWMjc2NzY0JyYnJhcHJzU0NjMhMhYdAxQGIyEiJj0BFxY/AQIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSk2koBEMAQkNEREN/vcMEZkICJsC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKizkX1wODBERDAwhoQwSEgyeWAUGWQAAAAADAAAAAAOLAuAACwAXACMAAAEhIiY0NjMhMhYUBgMhIiY0NjMhMhYUBgMhIiY0NjMhMhYUBgNr/VUNExMNAqsNExMN/VUNExMNAqsNExMN/VUNExMNAqsNExMCoBMaExMaE/7rExoTExoT/uoTGhMTGhMAABgAAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQE4AUQBoQHEAdMB+gIHAhUCTwJcAmkCegAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicFBgcGBzEVIxUjFTEVIzkBFSMVMQYHFzc2PwEHBgcVFBc3NTQ/AScXBxYfARUzFTEVMxUxFTMVMRUxFTMVMxUzFTEVMxUxFxUzFxUxFTMVMxUxFTEVMzEzFTEVMxUxFTEVMxU5ATMVMRUxFTMVMRUzFTkBMxUxFTEVMxcWFxYXNycmLwEXBxYXMxUzFTMxMxUzFTMVMxYXMxczFzMVMxUXFhc3JyYvASEHBg8BFzY3Nj8BNjc2PwEHBg8BFzY3NTE1MzUxNTM1MzUxNTE1MzU5ATM1MTUzNTE1MTY3JzcHFxYdAQcXNjc1Ji8BBxcWHwE3Ji8BJicmLwEiByMVIxUjMSMHIxUjByMHIwcjFSMxIxUjFSMVIxUjBgcXNzY7ATIfATcmLwEjJyMnIycjJicxJiMXMh4BFA4BIi4BND4BNyYOARQeAT4CNC4BByMiJj0BNDYyFh0BMzIWFAYCABQJBywkDCAkJA8QJiEfERQSAgIDASEjERKxDQ8RAQICAQECAQEBAQIBAQEBAwEBBxoVKBkbIB0fowkKDgEBAQMEAgMFBToMDBURNVsCAQEBAgQ+BAMBAj9ROQwGAQ8RAQwIMxMVDw5oJhMUAQECARkdDg8bHSAeGZ8JFBcUDSETFQQ1GBsfAS0bHiMeFhEOKiIHDQcicRASGBUwCwsJAQIBAQEBAQEDFhA2IwEHBz0SAUE4DxELCTwDBwMIDBGfIxseGhcsJTABAQ0P/oQJER0WAQEBAQwKMhMUHBmpDgMCPgcHPDc5BgYDAQEBAQEBAQEBAQEBAQEBAQEBAQEBAwYECQwwFBcNDm4dDREBAgECAQIBFhQCAQIBAgMQDxENICEfHAEeHR4iIAwMFBgcBRAIEAtMDg8WFS8VEgEBAQEBARUNOT49BwYCPwIBAg6AJxkbExMzBQkDGSEMDrESCAcGBQUBBAMBAwECAwMDAwMCAwEQDhAfISIEISMfERIMDAIBAgECAQMOFBULASI6IiI6RDoiIjoiMVQxMVRhUS8vUQEvCQwMEgwaCQwMAysBBQo+BwcBBAkJPAcFAQEBCAMCJwYICgEBAgEBAQEBAQEBAQIBAQEEFBQxFRcSDzeBDA4YAQECBAYBBgMHAgUJCA4QFx4gIBsiwAoVEikJDwgMFwggFRoRCCAFsBodDgQeGAEBARAJJRoeIB2UMxAOAQEBEg4GBjgODxcTUz4EAwIBAQM+AgQEQBETDQs7BQYQFgQJBTWMGyAcGCkLDAwBAwEBAQEBAQEBAQEBAQEEAR8jH7AgKCAgDTs+EgnJHhweJR4RDRgIChQJHRuPNBITGhcsLCABAQkIaAUNFxsBAQEBAQIPESUaGxYUcygpJQsVASgeHh8OsxoRDQcBAQECAQoBAgICAgEBAQECAQEBAQEBAQEBAQEBAQEBAQEBAQECBAgEDAwpGBweHYQ3CQkBAQEBAQoGAQEBAQMEAj0HBw8PDw8GBj4BBAQKAgcECAi+HiAYGSkVFwEBAQEBAQEBAQECAgEgIxu1Dh8ZHwwgAw4SIC0qpDEUFhsaJAgOBSMbCgk0AQEBAQEBAQEBAQEBAQUFPAgJCgk8BwMDAQEBBAICwSI6RDoiIjpEOiI1ATBTYVQwAjBSYFIw2AwJSwkNDQk1DRIMAAAAEAAAAAADqwLWAAMAEwAXABsAHwAjACcAKwAvADMANwA7AD8AQwBHAEsAAAERIRElISIGFREUFjMhMjY1ETQmBTMVIyUjNTMHIzUzByM1MwcjNTMHIzUzBTMVIwUzFSMhIzUzByM1MwcjNTMHIzUzByM1MwUzFSMDa/0qAuv9ABIZGRIDABIZGfzuKysCq1ZWgFZWgFZWgFZWgFZWAiorK/0rKysCq1ZWgFZWgFZWgFZWgFZWAiorKwKV/dYCKkAZEf2qERkZEQJWERm7NQE1NTU1NTU1NTUBNaA1NjY2NjY2NjY2ATUAAAIAAAAAA6sCwAADABMAAAERIRElISIGFREUFjMhMjY1ETQmA0P9egLE/P4RGRkRAwIRGRkCWf5OAbJnGBH90hEYGBECLhEYAAMAAP/VA6sDKwAUACkAMAAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmAxUjFTMVNwIAUUZDKCkpKENGokZDKCkpKENGUXRjYTg7OzhhY+hjYTg7OzhhY12oqHoCqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODv+5kuMS5EAAAQAAAAAA60CxQADABMAFwAoAAABESERJSEiBhURFBYzITI2NRE0JgcRIRElISIGFREUFjMhMjY1ETQmIwNs/SsC7fz8ERgYEQMEEBgYqP4rAfr94QsQEAsCHwsQEAsChP4ZAedAGBD96REXFxECFxAYqf7rARVAEAv+ogsQEAsBXQwPAAUAAP/VA6sDKwAUACkANgBLAFYAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYHDgEHPgE3FyYnJgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJSlcWRxYUSxRzEyUnAusyMFJVxFVSMDIyMFJVxFVSMDJAOzhhY+hjYTg7OzhhY+hjYTg7q0V2inZFRXaKdkVALCpJSq5KSSosLCpJSq5KSSoshz34PRRVFH08eX4AAAAABgAA/9UDqwMrABQAKQA2AEsAVwBjAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmARcWNj0BNCYPAQYUHwEWNj0BNCYPAQYUAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdEV2RUV2inZFRXZFV0pJKiwsKklKrkpJKiwsKklK/vyBCRISCYEGqIIIEhIIggYC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+s2MGCQrGCgkGYwUQBWMGCQrGCgkGYwUQAAQAAP+1A8wDSwADABQAIAAtAAAJBCIHAQYUFwEWMjcBNjQnASYTISImNDYzITIWFAYHIiY1ETQ2MhYVERQGAgABgP6A/oABgA8L/loKCgGmCx8LAaULC/5aCpv+qgsPDwsBVgsPD7YLDw8WDw8DAP6A/oABgAHLC/5aCh8L/loLCwGmCx8KAaYL/hsPFg8PFg+rDwsBVgsPDwv+qgsPAAAGAAD/1QOrAysAFAApADYASwBmAHQAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgcyHgEUDgEiLgE0PgE3IgcGBwYUFxYXFjI3Njc2NCcmJyYTIi8BBg8BBgcOAS4BNzY/ATY3PgEyFhcTFgYnMTIfAScGDwEGBzY3NgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhY3RFdkVFdop2RUV2RVdKSSosLCpJSq5KSSosLCpJShQKBlsNFwIdGQUPDQQCEyACIBYCCw4LAmsDDXUJByo7ChMDCg0UFQYC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz9/wdjDRsBIhkFAggOBzZsCHA9BggIB/6pChGeBy29IUIJJSkWFQYAAAAIAAD/1QOrAysAFAApADYASwBOAF0AYABvAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYHMh4BFA4BIi4BND4BNyIHBgcGFBcWFxYyNzY3NjQnJicmAxUnNyIPAQYUHwEWMjY9ATQmFxUnNyIPAQYUHwEWMjY9ATQmAgBiVVIwMjIwUlXEVVIwMjIwUlVidGNhODs7OGFj6GNhODs7OGFjdEV2RUV2inZFRXZFV0pJKiwsKklKrkpJKiwsKklKk0FbBgSFBweFBA0KCoZBWgUFhQYGhQQNCgoC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODurRXaKdkVFdop2RUAsKklKrkpJKiwsKklKrkpJKiz+8WIxdwRlBREFZQMJCMoICUZiMXcEZQURBWUDCQjKCAkAAAAABAAA/7UDzANLAAMAFAAhAC4AAAkEIgcBBhQXARYyNwE2NCcBJgMyHgEUDgEiLgE0PgE3Ig4BFB4BMj4BNC4BAgABgP6A/oABgA8L/loKCgGmCx8LAaULC/5aChAmPyYmP0w/JiY/JjRYNDRYaFg0NFgDAP6A/oABgAHLC/5aCh8L/loLCwGmCx8KAaYL/sAmP0w/JiY/TD8mNTRYaFg0NFhoWDQAAAAAAwAAAAADdgMgAAgAGgAfAAABIyImPQEzFTMTISImNRE0NjMhMh8BFhURFAYlIREnIQNU1g0TQLYB/asNExMNAX8NCtYJE/2+AhXD/q4CCRMN1rb9whMNAtUNEwnXCQ3+AQ0TQAHSwwACAAD/tQPMA0sAAwAUAAAJBCIHAQYUFwEWMjcBNjQnASYCAAGA/oD+gAGADwv+WgoKAaYLHwsBpQsL/loKAwD+gP6AAYABywv+WgofC/5aCwsBpgsfCgGmCwAAAA8AAP/VA6sDLAAcAEwAbAB+AJIAqAC3AMUA9AD+AQ0BHQEtATABOgAAASMHIwYHFzc2OwEXFh8BNyYnIzUjNSM1IyYnJiMHBg8BIxUjFQcjMSMVIxUjFSMVIxUjFSMxIxUjFSMVIwcjFTEVIxUHBgcXNzY/AScHBg8BFSMVMRUjFTEVMRUjBxUxBxUHFQcGBxc3Nj8BJwcGDwEVFBcVFhc3JyY1ND8BJxcHHwEVMxYXFTMVMRUWFzcnJi8BFwcWFzMVMxUzFTM5ARYXFhc3JyYvARcHHgEXMxUzNjcnByIvASUHBg8BFzY3Nj8BNjcnNwcGDwEXNj8BNTM3MTUzNTE1MzU5AjUzNTE1MzUxNTM1OQI1MzUxNTc1NjcnNxUGDwEXNjU0LwEHFxYfATcmJzUmJzUmLwEHFxYfATcmJyM1IzUxJicHISIGHQEUFjMhMjY9ATQmByczBzUXMxYyNzM3FQIAFAkHLCQMICQkDxAmIR8RFBICAgMBISMRErENDxEBAgIBAQIBAQEBAgEBAQEDAQEHGhUoGRsgHR+jCQoOAQEBAwQCAwUFOgwMFRE1WwIBAQECBD4EAwECP1E5DAYBDxEBDAgzExUPDmgmExQBAQIBGR0ODxsdIB4ZnwkUFxQNIRMVBDUYGx8BLRseIx4WEQ4qIgcNByJxEBIYFTALCwkBAgEBAQEBAQMWEDYjAQcHPRIBQTgPEQsJPAMHAwgMEZ8jGx4aFywlMAEBDQ89/tsHCQkHASUGCQmZW7bSawEGCgYBawMrAQUKPgcHAQQJCTwHBQEBAQgDAicGCAoBAQIBAQEBAQEBAQECAQEBBBQUMRUXEg83gQwOGAEBAgQGAQYDBwIFCQgOEBceICAbIsAKFRIpCQ8IDBcIIBUaEQggBbAaHQ4EHhgBAQEQCSUaHiAdlDMQDgEBARIOBgY4Dg8XE1M+BAMCAQEDPgIEBEAREw0LOwUGEBYECQU1jBsgHBgpCwwMAQMBAQEBAQEBAQEBAQEBBAEfIx+wICggIA07PhIJyR4cHiUeEQ0YCAoUCR0bjzQSExoXLCwgAQEJCP8JBs8HCQkHzwYJZDmYeEQDA0R4AAAABAAAAAADTgKHABQAFwArAC4AACUiLwEuATU0PwE+AR4BFREUBgcGIycXEQEiLwEuATU0PwE+AR4BFREUBgcGJRcRAb0WEfgMDRn4DyMhExMQDw729wFRFhH3DA0Z9w8kIRMTEQ7++/eLDb0JGw8fE70MAxAfEv6GEx8IBv29AXr+Rg29CRsPHxO9DAMQHxL+hhMfCAb9vQF6AAAABAAA/9UDqwMrABQAKQA4AEUAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJhMiLwEmNDYyHwEeAQ4BKwEiJjQ/ATYyFhQPAQYCAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWMFEg3xDBgkDPIJBQoWDfERGg3xDSMZDPIMAqspKENGokZDKCkpKENGokZDKCmAOzhhY+hjYTg7OzhhY+hjYTg7/bIM8Q0jGQzyCRkYDhgkDPIMGSMN8QwADwAA/9UDqwMrADsAUABjAGQAfgCoALoA0QDnAPQBGQFEAVIBdgGOAAABBg8BIjc2ByMxIxUjByMVIxUjFSMVIxUxFSMxIxUjFSMVIxUjFTkBByMVIzEjFSMHBgcXNzY/ATM/AScHBgcVBxUHFQcVMQYHFzc2PwMnBwYUFxUXFTEVFhcWFzcnJjU3Jx8BBxYXMRUzOQEVMxUxFRYXFhc3JyYvBBcHFh8BMxUzMTMVFzMVMxUzFTMVMxczFTMVMxUzMTMVFxYXNycmLwExJwUHBisBJwcWMzI3MzY/ATY3JzcHBg8BIw8BFzY3MzUzNTM1MzU3NjcnNwcGDwMXNjc1MzU3Njc1NzU2Nyc3BxcWHQEHFzY1JyYvAQcXFh8ENyYvATU5ASM1MTUnNSM5ATUjNTE1JzUxNSMmLwEHFxYfATMXNyYvASM1IycjNSMxIzUjJyM1IzUjNSM1IycjNSM1IzUjJi8BIgcjBgcXNzY7ARc3JhMjIiY9ASMiJj0BNDY7ATU0NjsBMhYdATMyFh0BFAYrARUUBiczNTQ2OwE1IyImPQEjFRQGKwEVMzIWFQFQIyAKAQEFAQEBAQIBAQEBAQEBAQEBAQIBAQEBCw0KKhgdHgMBAR4fqhMSAgECCgc7CgsTAQESNVUCAQIBAQIGPQYHAT9BHDcXHwEBBAcJDS8UGREBAQEQdCAfIggCAQEFAQICAQIBAgIBAgIKChQVHiMfBB4BPx8iIwwgAhcXEQkHGxUCEwkMoxkbIAMBAR4dMi0BAQEBCAwLKVwKDRIBARM2FRABAgcDAQcDPEM+BgYCPwMBAwpuMBUWEwEBARA3DRQHAQIBAQMBEBTBFR4kHQQBHSIaIhABAQcBAgECBAECAgECAwECAgEPEHAVCwQoKAwgJCQPIAMcHWYJDEUJDAwJRQwJZgkMRQkMDAlFDFk6DQlERAkNOg0JREQJDQMFEBYIAQMBAQIBAQEBAQEBAQEBAQIBAQoMCi8VGhACARE3ihojAQUIAgoEARgdFB4hIQEDHiHLGCcJChAHDwUGCxUMICElKgInkB4yKAEBAQEFCAsNKhgcHwEDAR6TNRcQBQEBAgEBAQEBAQEBAQQEBjwKDBICEzcGBwI/AwEDBAEEAj5gFRcTAgEQNxUkAQEBAQcLCy+kHiMfAQMeIR0fBwgFEAgDAwIVChXHDB8fJA4gAhcZJSYkvSkYGiEBAwEeHR8gCgEBAQMBAQEBBAEBFhRuOwsNEgITNRMTBwEEAQECAQEBAQEBAQEFBQwBBAs9BgcBPgP9tAwJRQwJZgkMRQkMDAlFDAlmCQxFCQwrRAkNOg0JREQJDToNCQAEAAD/tQPMA0sAAwAUACEALgAACQQiBwEGFBcBFjI3ATY0JwEmEyIvASY0NjIfARYUBiMiJjQ/ATYyFhQPAQYCAAGA/oD+gAGADwv+WgoKAaYLHwsBpQsL/loKaQsI8gcPFgjyBw/9Cw8H8ggWDwfyCAMA/oD+gAGAAcsL/loKHwv+WgsLAaYLHwoBpgv9ogfyCBYPB/IIFg8PFgjyBw8WCPIHAAMAAAAAA3IDLQAiAGEAngAAASYnPgE1NC4BIyIGBwYVFBYXBw4CHQEUFjMhMjY9ATQuASU0NzY3MTYzMhceATc2NxYVFAYHDgEeARcWFwYPAQYPAwYPAgYiLwEmLwYmJzY3PgImJy4BNQEjNTQmIgYdASE1NCYiBh0BIzU+ATcXFh8BFh8BFh8BFh8BFhcWMxYyPwE2PwE2PwE2PwE2PwE2PwEeARUClQgKISU4Xjg/ZxgPJCESQmQ3Ew0Crg0TNmT+lQsDBjwaFxwWMBcHBhU3LAsNAg8LHh0DBAIEAwwPBgUGBxMLEwoHBgYUDQYHBQoEAhseCw8CDQosNwHFYxIZEv7SEhkSYwFORQkECAMJCwYLBgkHCgoGDgUEEhsSCQ4GCgoICQwFBgkKAwYHCEVOAb0EBBxRLTheOEU5JiotUB0IHmmGSTwNExMNPEmGacEbGwYLHRENCQYBAyIlL0oOAxMWEQEFCgoIBQYGDgwFAwIDBgICAgEDCgkFCQYRCAoJBQIQFhMDDkov/eyBDBISDIGBDBISDIEcUY0rFQgMBQwKBgkEBgUEBAMDAgMDAgMDBAQFBggFBggOBAkMFCqNUQAAAwAA/9UDqwMrABQAKQAvAAABMhcWFxYUBwYHBiInJicmNDc2NzY3IgcGBwYUFxYXFjI3Njc2NCcmJyYDJwM3FxMCAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWM8ZVxnakECqykoQ0aiRkMoKSkoQ0aiRkMoKYA7OGFj6GNhODs7OGFj6GNhODv+SYP+8YR5ASUAAAMAAP/VA6sDKwAUACkANAAAATIXFhcWFAcGBwYiJyYnJjQ3Njc2NyIHBgcGFBcWFxYyNzY3NjQnJicmBw4BBz4BNxcmJyYCAFFGQygpKShDRqJGQygpKShDRlF0Y2E4Ozs4YWPoY2E4Ozs4YWN0FkcWFEsUcxMlJwKrKShDRqJGQygpKShDRqJGQygpgDs4YWPoY2E4Ozs4YWPoY2E4O/I9+D0UVRR9PHl+AAARAAD/1QOrAywAHABMAGwAfgCSAKgAtwDFAPQA/gENAR0BLQExAT0BSQFVAAABIwcjBgcXNzY7ARcWHwE3JicjNSM1IzUjJicmIwcGDwEjFSMVByMxIxUjFSMVIxUjFSMVIzEjFSMVIxUjByMVMRUjFQcGBxc3Nj8BJwcGDwEVIxUxFSMVMRUxFSMHFTEHFQcVBwYHFzc2PwEnBwYPARUUFxUWFzcnJjU0PwEnFwcfARUzFhcVMxUxFRYXNycmLwEXBxYXMxUzFTMVMzkBFhcWFzcnJi8BFwceARczFTM2NycHIi8BJQcGDwEXNjc2PwE2Nyc3BwYPARc2PwE1MzcxNTM1MTUzNTkCNTM1MTUzNTE1MzU5AjUzNTE1NzU2Nyc3FQYPARc2NTQvAQcXFh8BNyYnNSYnNSYvAQcXFh8BNyYnIzUjNTEmJwMjIiY1ETQ2OwEyFhURFAYnMxEjFyMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGByMiJjQ2OwEyFhQGAgAUCQcsJAwgJCQPECYhHxEUEgICAwEhIxESsQ0PEQECAgEBAgEBAQECAQEBAQMBAQcaFSgZGyAdH6MJCg4BAQEDBAIDBQU6DAwVETVbAgEBAQIEPgQDAQI/UTkMBgEPEQEMCDMTFQ8OaCYTFAEBAgEZHQ4PGx0gHhmfCRQXFA0hExUENRgbHwEtGx4jHhYRDioiBw0HInEQEhgVMAsLCQECAQEBAQEBAxYQNiMBBwc9EgFBOA8RCwk8AwcDCAwRnyMbHhoXLCUwAQEND2fSCAsLCNIIDAzHrKyFXggLCwheCAsLCF4ICwsIXggLCwheCAsLCF4ICwsDKwEFCj4HBwEECQk8BwUBAQEIAwInBggKAQECAQEBAQEBAQEBAgEBAQQUFDEVFxIPN4EMDhgBAQIEBgEGAwcCBQkIDhAXHiAgGyLAChUSKQkPCAwXCCAVGhEIIAWwGh0OBB4YAQEBEAklGh4gHZQzEA4BAQESDgYGOA4PFxNTPgQDAgEBAz4CBARAERMNCzsFBhAWBAkFNYwbIBwYKQsMDAEDAQEBAQEBAQEBAQEBAQQBHyMfsCAoICANOz4SCckeHB4lHhENGAgKFAkdG480EhMaFywsIAEBCQj95AsIASYICwsI/toICyYBAE8LEAsLEAtECxALCxALRAsQCwsQCwAAAQAAAAADrAKHADMAABM2NzY3NhcWFxYXFhcWFxYXFjc2PwE2NzY3FQYHBgcGJyYnJicmJyYnLgEGBwYHBgcGBzVVICErNyo2Li4dIRQmJBMfGyQsKB4aJRAbDiIgLDQuNTErFhoQHikVJEFJGiIfEiETCQGSTDA/IRgJBx4RGxAhIA8ZERUMCyEfKRYkI8lEKDcYFAkIHw8XDRwmER0hCBgeLRw6IBC9AAAAAAQAAAAAA1ADEAAPAB8ALAA5AAAlISImNTQ+ATsBMh4BFRQGJSIOARUUFjMhMjY1NC4BIyciLgE0PgEyHgEUDgEDIg4BFB4BMj4BNC4BAwr99h0pO2U74DtlOij+bipHKgQCAgoCAylHKnAxVDExVGJTMTFTMSA2ICA2QDUgIDUwKB07ZTo7ZDsdKOAqRyoCAwMCKkcqlTFTY1MxMVNjUzEBKyA2PzYgIDY/NiAAAAAAAwAAAAADSwMgAAwAGQAmAAAlIiY1ETQ2MhYVERQGISImNRE0NjIWFREUBiEiJjURNDYyFhURFAYDKw0TExoTE/7dDRMTGhMT/t4NExMaExM1Ew0Cqw0TEw39VQ0TEw0Cqw0TEw39VQ0TEw0Cqw0TEw39VQ0TAAAABAAA/9UDqwMrABQAKQBGAFQAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgMiLwEGDwEGBw4BLgE3Nj8BNjc+ATIWHwEWFxYGJzEyHwEnBg8BBgc2NzYCAGJVUjAyMjBSVcRVUjAyMjBSVWJ0Y2E4Ozs4YWPoY2E4Ozs4YWMJCgZbDRcCHRkFDw0EAhQgASAWAgsOCwI1IxMDDXUJByo7ChMDCg0UFQYC6zIwUlXEVVIwMjIwUlXEVVIwMkA7OGFj6GNhODs7OGFj6GNhODv9lAdjDRsBIhkFAggOBzdxA3A8BwcIB6tyOQoSngctvSFCCSUpFhUGAAAAAAIAAP/VA6sDKwAUACkAAAEyFxYXFhQHBgcGIicmJyY0NzY3NjciBwYHBhQXFhcWMjc2NzY0JyYnJgIAYlVSMDIyMFJVxFVSMDIyMFJVYnRjYTg7OzhhY+hjYTg7OzhhYwLrMjBSVcRVUjAyMjBSVcRVUjAyQDs4YWPoY2E4Ozs4YWPoY2E4OwAE////hgQCA4IAIAA4AE4ATwAAFyImJy4BNj8BPgEXJjY/AT4BHgIGDwEOAScWBg8BDgEnHgE2PwE+AScHBiImND8BJgYPAQ4BFhcBFjY/AT4BLgIGDwEOARc3Nh4CBxftLlQhLB8fLIMufD0THy2DLHd3WCAgLIMufD0THy2DIFWRG0hIG4MgDhNEDSYbDUQoVx+DGxMTGwHGKVgggxoREzVHRxuDIA4TKg4iFwMKl3kjIC12dyyDLR8TPXwugysgIFd3dyyDLR8TPXwugyAjgxoTExqDIFgpRQ0bJg1EEg4fgxtISBsBiBMOIIMbR0c1ExEahR9ZKCsKAxciDi8ABQAA/4oDkwOAABkAKQAzAEQAUAAABSEiJicRNDY7ATU0PgEyHgEdATMyFhURDgEBIgYVERQWMyEyNjURNCYjJSE1NC4BIg4BFRMiJj0BLgE+Ah4BBgcVFAYnIg4BHgI+ATU0JgMz/ZonNwE4JztDcodyQzsnOAE4/XMCBAQCAmYCBAQC/i4BPytKVkoroBIaKjIGPVZJGSEmGh8KEAgEDhMTCxN1NycCACg4PkNyQ0NyQz44KP4AJzcCZQQD/gACBQUCAgADBFk+K0orK0or/dEaEg8MRlc/CS9TUBUZEhrQChMTDgQHEQoNEwAEAAD/iwOSA4YAIwAzAEQAUAAABSEiJicRNDY7ATU0PgIeARcWDgEmJy4BDgEdASEyFhURDgEBIgYVERQWMyEyNjURNCYjASImPQEuAT4CHgEGBxUUBicmDgEUHgE3PgE0JgMz/ZonNwE4JzsxV29uWRkIDCAjCBllbUUB0yc4ATf9cwIEBAICZgIEBAL+zRIaKjIGPVZJGSEmGh8JEQkJEQkNERF1NycCACg4PjllRhoYRTMQIxAMEDIwGlc4Pjgo/gAnNwJlBAP+AAIFBQICAAME/mgaEg8MRlc/CS9TUBUZEhrQAQgQEhAJAQISGRMAAAAABgAA/7UD1ANLABQAOABKAFQAZABuAAABIiY9ATQmKwEiJjQ2OwEyFh0BFAYDISImNRE0NjsBMhYUBisBIgYVERQWMyEyNj0BNDYyFh0BFAYnIyImPQE0PwE2Mh8BFhQPAQYnMzc2LwEmIg8BAyEiJj0BNDY7ATIWHQEUBiczNTQmKwEiBhUC8xEYAwOLERcXEY0jMxg+/dEkMzMkixEXFxGLAwQEAwIvAgQXIhczLoIRFwvlGUcZQRkZ5AxqStgEBEECBQHYKf7pERczI7okMxj/xwQDugIEAbYXEbsDAxghGDMkuxEY/gEyJAKLJDIXIRgDA/11AgQEAroRFxcRuyQxuhcRghAM5BkZQRlHGeULUNgEBUACAtgBNxgQjCQyMiSMEBhQZAIEBAIAAgAA/40D8gNyAAwAGQAAFyImNDcBNjIWFAcBBiEiJwEmNDYyFwEWFAZFFyAQA3URLSEQ/IsRA18XEfyLECEtEQN1ECByIC4QA3YQIS0R/IsQEAN1ES0hEPyLEC4hAAAAAQAAAAAD9QLSABEAACUiJwEmPgIXCQE2Mh4BBwEGAX4TDf66DAEaJA4BJQIpDiQaAQz9tg0uDQFFDSUaAQ3+2wIqDBolDv23DQAAAAUAAP+TA7sDbQAfACkAMwBAAE0AAAUhIiY1ESMiJjQ2OwE1NDYzITIWHQEzMhYUBisBERQGAREUFjMhMjY1ESUhNTQmIyEiBhUBIiY1ETQ2MhYVERQGIyImNRE0NjIWFREUBgL6/gwmNzoRGhoRnTcmAS0mN50SGRkSOjb93wQDAfQCBP5jAToEA/7UAwQBARIZGSQZGdoSGRkkGRltNyYCXxkkGWsmNzcmaxkkGf2hJjYCu/2hAgQEAgJfVmsCBAQC/UsZEgEsEhkZEv7UEhkZEgEsEhkZEv7UEhkAAAAAAQAAAAACuQKnAA8AAAEFHgE+ATURNC4BBgcFBhQBVQEiCRcVDAwVFwn+3g0BYv0IAwkUDAH6DBQJAwj9DCQAAAEAAAAAArkCpwAPAAABJS4BDgEVERQeATY3JTY0Aqv+3gkXFQwMFRcJASINAZ79CAMJFAz+BgwUCQMI/QwkAAAE////gAQdA4AAgADrAPgBBQAABSMiLgE9ATQvASYPAQ4BJi8BLgE2PwE2LgErASIuAT0BND4BOwEyPwE2LwEuATQ2PwE2Mh8BFj8BNj0BND4COwEyHgEdARQfARY/AT4BMhYfAR4BFAYPAQYfARY7ATIeAh0BFA4BKwEiDgEfAR4BFAYPAQ4BJi8BJg4BHQEOASceAR0BFDsBMjY9AT4CFh8BFj8BNjQvAS4BPgE3MzI9ATQrAQYuATY/ATYvASYiDwEOAScuAT0BJisBIh0BFg4BJi8BJg8BBhQfAR4BDgErASIGHQEUFjsBNhYXFgYPAQYWFRcWMj8BPgE3Ii4BND4BMh4BFA4BAyIOAR4CPgE1NC4BAkJqGy8bAwUDAxYTNDQUSxMNDRMWAgMCBCAbLhsbLxsgAwICAgIWDw8PD0oeUx4WAwMEBA8dJRRqHC4bBAUDAxYOJSklDkwODw8OFgICAgEDIBQlHQ8bLhwkAwIDAhYOEBAOShQ0NBMWAwUFATraHSMFagIDASM6PRYWBANMAQEWFQwYMx8iBQUgHzUZDRgWAwNMAgMCFhY9HR4lAQRqBQEjO0AWFAQETAEBFhYMGDQfIAIDAwIgIDULDgwYFgEBSwIEARUWP5g4Xzg4X3BfODhfOCI4GQ0vQj8lHjOAGy8bIgMBAgICFhMODRNKEzU0ExYDBAYcLxtqHC4bBAUCAxYOJiglDkwcHBYCAgIBBAQUJR0PGy8bIAQBAgICFg4PDw5KDiUpJQ4WAwMEBA8dJRRqGy8bBgQDFg4lKCUPShMNDRMWAgQBBAgpO+ULNB8iBQMCCR8zFwsWFQMDSgIDAhYWPTojAQVqBQEjO0AWFQQESwEBFhYMDQs1ICADBQYgNBkNFxQDA0oCAwIWFj45IwMCagMDASMeHUEWFQIEAUsCAhcXCz84X3BfODhfcF84AT4lP0IvDRk4Ih4zHgAAAAASAN4AAQAAAAAAAAATAAAAAQAAAAAAAQAOABMAAQAAAAAAAgAHACEAAQAAAAAAAwAOACgAAQAAAAAABAAOADYAAQAAAAAABQALAEQAAQAAAAAABgAOAE8AAQAAAAAACgArAF0AAQAAAAAACwATAIgAAwABBAkAAAAmAJsAAwABBAkAAQAcAMEAAwABBAkAAgAOAN0AAwABBAkAAwAcAOsAAwABBAkABAAcAQcAAwABBAkABQAWASMAAwABBAkABgAcATkAAwABBAkACgBWAVUAAwABBAkACwAmAatDcmVhdGVkIGJ5IGljb25mb250aWNvbi1kZGVpLWZsb3dSZWd1bGFyaWNvbi1kZGVpLWZsb3dpY29uLWRkZWktZmxvd1ZlcnNpb24gMS4waWNvbi1kZGVpLWZsb3dHZW5lcmF0ZWQgYnkgc3ZnMnR0ZiBmcm9tIEZvbnRlbGxvIHByb2plY3QuaHR0cDovL2ZvbnRlbGxvLmNvbQBDAHIAZQBhAHQAZQBkACAAYgB5ACAAaQBjAG8AbgBmAG8AbgB0AGkAYwBvAG4ALQBkAGQAZQBpAC0AZgBsAG8AdwBSAGUAZwB1AGwAYQByAGkAYwBvAG4ALQBkAGQAZQBpAC0AZgBsAG8AdwBpAGMAbwBuAC0AZABkAGUAaQAtAGYAbABvAHcAVgBlAHIAcwBpAG8AbgAgADEALgAwAGkAYwBvAG4ALQBkAGQAZQBpAC0AZgBsAG8AdwBHAGUAbgBlAHIAYQB0AGUAZAAgAGIAeQAgAHMAdgBnADIAdAB0AGYAIABmAHIAbwBtACAARgBvAG4AdABlAGwAbABvACAAcAByAG8AagBlAGMAdAAuAGgAdAB0AHAAOgAvAC8AZgBvAG4AdABlAGwAbABvAC4AYwBvAG0AAAIAAAAAAAAACgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAbwECAQMBBAEFAQYBBwEIAQkBCgELAQwBDQEOAQ8BEAERARIBEwEUARUBFgEXARgBGQEaARsBHAEdAR4BHwEgASEBIgEjASQBJQEmAScBKAEpASoBKwEsAS0BLgEvATABMQEyATMBNAE1ATYBNwE4ATkBOgE7ATwBPQE+AT8BQAFBAUIBQwFEAUUBRgFHAUgBSQFKAUsBTAFNAU4BTwFQAVEBUgFTAVQBVQFWAVcBWAFZAVoBWwFcAV0BXgFfAWABYQFiAWMBZAFlAWYBZwFoAWkBagFrAWwBbQFuAW8BcAAdc3RhcnQtZXZlbnQtY29tcGVuc2Etbm9uLWludGUVaW50ZXJtZWRpYXRlLWV2ZW50LWM3CXNlbmQtdGFzaxNzdGFydC1ldmVudC1tZXNzYWdlFWludGVybWVkaWF0ZS1ldmVudC10MhZpbnRlcm1lZGlhdGUtZXZlbnQtYzEyCmRhdGEtaW5wdXQUZW5kLWV2ZW50LWNvbXBlbnNhdGkHc2VydmljZQp1c2VyLXRhc2sxD2xhbmUtZGl2aWRlLXR3bxRzdGFydC1ldmVudC1ub24taW50ZRNib3VuZGFyeS1ldmVudC10aW1lFWludGVybWVkaWF0ZS1ldmVudC1jORFsYW5lLWluc2VydC1hYm92ZQVncm91cBVpbnRlcm1lZGlhdGUtZXZlbnQtdDUVYm91bmRhcnktZXZlbnQtY2FuY2VsEnN1Yi1wcm9jZXNzLW1hcmtlcg1zZW5kLXRhc2stYmFrC3NjcmlwdC10YXNrDHNlcnZpY2UtdGFzawN0YWIHY29tbWVudAttYW51YWwtdGFzawhzZXF1ZW5jZQpkYXRhLXN0b3JlBm1hbnVhbBJidXNpbmVzcy1ydWxlLXRhc2sNYnVzaW5lc3MtcnVsZRRzdGFydC1ldmVudC1wYXJhbGxlbAdyZWNlaXZlGXN1Yi1wcm9jZXNzLWV4cGFuZC1tYXJrZXIUc3RhcnQtZXZlbnQtY29uZGl0aW8VaW50ZXJtZWRpYXRlLWV2ZW50LWMzEmVuZC1ldmVudC1tZXNzYWdlMRVzdGFydC1ldmVudC1ub24taW50ZTIVc3RhcnQtZXZlbnQtbm9uLWludGU2EXN0YXJ0LWV2ZW50LXRpbWVyEmdhdGV3YXktZXZlbnRiYXNlZBJlbmQtZXZlbnQtbXVsdGlwbGUVaW50ZXJtZWRpYXRlLWV2ZW50LXQzCXVzZXItaWNvbhZpbnRlcm1lZGlhdGUtZXZlbnQtYzE0FHN0YXJ0LWV2ZW50LW11bHRpcGxlBWNob3JlFGJvdW5kYXJ5LWV2ZW50LWVycm9yFWludGVybWVkaWF0ZS1ldmVudC1jNBFzdGFydC1ldmVudC1lcnJvcgRsYW5lFGludGVybWVkaWF0ZS1ldmVudC1uFXN0YXJ0LWV2ZW50LW5vbi1pbnRlMRFsYW5lLWluc2VydC1iZWxvdw5lbmQtZXZlbnQtbm9uZR9pbnRlcm1lZGlhdGUtdGhyb3ctZXZlbnQtc2lnbmFsDHJlY2VpdmUtdGFzaxNlbmQtZXZlbnQtdGVybWluYXRlFWJvdW5kYXJ5LWV2ZW50LXNpZ25hbAZzY3JpcHQQZW5kLWV2ZW50LXNpZ25hbBJzdGFydC1ldmVudC1zaWduYWwLbG9vcC1tYXJrZXIUc3RhcnQtZXZlbnQtY29tcGVuc2EPZ2F0ZXdheS1jb21wbGV4FmludGVybWVkaWF0ZS1ldmVudC1jMTULZGF0YS1vdXRwdXQZaW50ZXJtZWRpYXRlLWV2ZW50LWM3LWJhaxZpbnRlcm1lZGlhdGUtZXZlbnQtYzExG2JvdW5kYXJ5LWV2ZW50LW1lc3NhZ2UtaW50ZQRzZW5kFWludGVybWVkaWF0ZS1ldmVudC1jMiBpbnRlcm1lZGlhdGUtdGhyb3ctZXZlbnQtbWVzc2FnZRRzZXF1ZW50aWFsLW1pLW1hcmtlchhib3VuZGFyeS1ldmVudC10aW1lLWludGURbGFuZS1kaXZpZGUtdGhyZWUNY2FsbC1hY3Rpdml0eQ5lbmQtZXZlbnQtbGluawt0cmFuc2FjdGlvbhVpbnRlcm1lZGlhdGUtZXZlbnQtdDElaW50ZXJtZWRpYXRlLXRocm93LWV2ZW50LWNvbXBlbnNhdGlvbhBnYXRld2F5LXBhcmFsbGVsFWludGVybWVkaWF0ZS1ldmVudC1jMRtib3VuZGFyeS1ldmVudC1jb21wZW5zYXRpb24KZ2F0ZXdheS1vcgtkYXRhLW9iamVjdAxnYXRld2F5LW5vbmUVc3RhcnQtZXZlbnQtbm9uLWludGUzE2NvbXBlbnNhdGlvbi1tYXJrZXIQZW5kLWV2ZW50LWNhbmNlbBVzdGFydC1ldmVudC1ub24taW50ZTULZ2F0ZXdheS14b3IEdXNlcg9lbmQtZXZlbnQtZXJyb3IUZW5kLWV2ZW50LWVzY2FsYXRpb24Vc3RhcnQtZXZlbnQtbm9uLWludGU0DWFkLWhvYy1tYXJrZXIGdXNlci0xEnBhcmFsbGVsLW1pLW1hcmtlchRzdGFydC1ldmVudC1lc2NhbGF0aRBzdGFydC1ldmVudC1ub25lBGxpbmsEbG9jawZ1bmxvY2sEZWRpdAZjYW5jZWwCb2sFdHJhc2gEbGVmdAVyaWdodAdzZXR0aW5nAAAAAA==') format('embedded-opentype'), url('data:application/x-font-woff2;charset=utf-8;base64,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') format('woff2'), url('data:font/woff;base64,d09GRgABAAAAADaQAAsAAAAAtQAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAADsAAABUIIslek9TLzIAAAFEAAAARAAAAGAtBErYY21hcAAAAYgAAANTAAAIAImwQ5ZnbHlmAAAE3AAAK58AAJ2oa/t7KmhlYWQAADB8AAAAMQAAADYpz8/5aGhlYQAAMLAAAAAgAAAAJAf7BApobXR4AAAw0AAAABgAAAG8vB3//mxvY2EAADDoAAAA4AAAAODtuxjgbWF4cAAAMcgAAAAfAAAAIAH0AqduYW1lAAAx6AAAAVoAAAKvOqa++HBvc3QAADNEAAADTAAACB4rUm0LeJxjYGRgYOBiMGCwY2BycfMJYeDLSSzJY5BiYGGAAJA8MpsxJzM9kYEDxgPKsYBpDiBmg4gCACY7BUgAeJxjYGFhYJzAwMrAwNTJdIaBgaEfQjO+ZjBi5ACKMrAyM2AFAWmuKQwHrr1/wcHc8L+BgYH5DgOQZGBEUcQEAH5WDUl4nOXV+bOVAwDG8e+5t3IjS0SSuG1URIhS2VLZKkqWuGTfmeHXfqqmNC0KJUuL5UaKNi122WqSKTTTpAkhz6mZZsw0ky1cz3ue+3P+gO6Zz517zrz33PO+93meF2gKVNvp1gSq6in5J0pz/Wqp8no1h1Zeb1J6zM9r/fBxW37VaI3TRK3TBm3WNpW1W3u0Vw3l6l01DQ2NR4zReE3Sem3UVm1vPGJfuZQjDvhVqvylWjrRjXoWsJxVfNn42MFOH/Egd9OGY2nGIAZyJQPoy5n04CzO5j7OoSfnch69uIfe3M/5PEAf+nEBF3IRd3Axl/jM+vMIVVzqq3AZl3MFVzGYIQzlaq5hGMO5lhFcx/X+FDdwOzcy0ud+EzdzC7f6d0b5Ux5CDc19hQ6jBYdzF7fxEEfwMHdyJPdyFC05mmNoxXG05nhOoC0n0o6TONnn1p4OdPR7d+YUTqWL36Wrz/Y0X/PunEGdL0Kz/7lKB8NXi+Jb07rGZ48WyQonAI0OZwGNCacCjQ3nA40LJwWND2cGTQinBz0ezhGaGE4UmhTOFpocThmaEs4bmhpOHnoinEE0LZxGND2cS/RkOKHoqXBW0dPh1KIZ4fyimeEko2fCmUazwulGz4Zzjp4LJx49H84+eiHcAjQ73Ac0J9wMNDfcETQv3Bb0Yrg36KVwg9DLUWyIXgm3CtWH+4Xmh5uGXg13Dr0WxQZpQbiH6PVwI9HCcDfRonBL0RvhvqI3w81Fi8MdRkvCbUZLw71Gy8INR8vDXUdvhVuPVoT7j1aGlwCtCm8CWh1uMHo7vBPonfBioHfD24HeC68Iej+KLdUH4WVBH4Y3Bn0UXhu0Jrw76OOoXLdPwluEPo1it/VZeJ/Q5+GlQmvDm4XWRbHvWh/eMfRFFM3ThvC2oY3hlUObwnuHvgovH/o6vIHom/Aaos3hXURbwwuJvg1vJdoWXk20Pbyf6LvwkqLvw5uKfgivK9oR3ln0Y3hx0U/h7UU/h1cY7QzvMfolvMxI4Y1G5fBao93h3UZ7wguO9oa3HO0Lrzr6Lbzv6Peo5OSP8OajP8Prj/4K3wfQ/vAdAf0dlf/RP+G7BPo3fL9ADeE7B+VSFPfzclX4bkK5OnxfYVdNUPcfkV/aVgB4nO19CZRkVXnwXd6+VL1Xr169Wrr2rqreu6urq2t6uqenB2ZhZmBmGGYBBxiWAWGGTVYlRocZWQTRRBjUGBHUKDCAmhCMEBQVTRQTkQjx4ElCckxiMHoO/hqJoR7/d9+r6rV6pgfr/08cppb77rv3vnf3b7vfdy8yEHrjBXqY9qEOdCq6DL0HfRg9gL6Evol+iVys4yTO4EE8jFchhPNiXhCd2ug4diJpXCuW8lXvWywV86IQxHk7b4v5MrtMf5t3Yt4us2jvBStxiaW3/bAyc0W7LNrivPiwY0ecWqlYHYEQR0xjuxJx7Aqk94IHsSNGnIrtfcdwxJkOTWEWPForiblBXGDvckbZayGk5t+txNVKrVytVNl/jDQ8s25qVZbY9hJXRwax2Khzlf1mblkDlIslbJdquSAWwmkcGR5dgUeKzoIQgsKy2NepZTo7g0YxmzbDIUIozubN0Bf1oIkJwRh+DYdiLMbtrlgik0x/WlYCLIgjlOeXa5ptVnexRISb5CgmK08f0wQMb9CkimUHA5cUrTB7SywZCCaSmVTsk3LYCetZy+aq0UQa9ydS+VTEDPTkRF3MvcMIRe0hVZX9fCGbiDGax6K4IoRXLQuaqjxBRSpp5ifziVTc6SsMYawH3V+u2iVwN4vizZyuKLesehvP3ywI3g3txbwyKYqYk+UJkYc3SpSUBEnBzRwadeTC4bLthIK1m7RAlNVGwAIVCS9LAcNJZTKJ3NOKHeqWg5LmSBk7bkoZ/gvxZIBLQWpsyIV4KpO8u2KwtgkFBGFZIOhYZ0CTwMvpJOG4KdPS1XFeMCKczFc/kMh0RLtVTWNtO+vD4XQ+/YVMVyajj0+G5G+nOlKFlKlHJSUsJxMfGglZUOu+DMay5D55QfkG7iLe5C+isvQdSV477x4JjfnUi8KoG42ijehKdCvMnWEYnJEwDG8hV4L5MlKD8VjLsfswixlm9yMsRhxO4XAA5wbwyCRumYLmc8UV2HNGYC5WmTMcSeIKc8JCL8wboVTxgqt+UtsLhXiboAu2bx0aHh7auv2ZpueCay88f9n4+LLzL/xJ03PtmuvXrLn+duas2blhfU9fX8/6DY82PZ0Xy9oaWdPkNZo84z1ruS6vXi3rjQv56ZxMPM/UnEw8z+FGNuBMzcnE87ipeZk0vL0z+cAFwYdjDj1MnkYUWSiF+qDNzaxZyOYE2wxHKtnh0ao5UuTFEjQM3EWSJCzks6x5nEitQi+vF8nPX3fNWMykBFz3Y488aGk4qlmW5v5Es+6XYH4cqL8OUy5q1p83o1GTDJjRw3vOD+qhkD70IHM/dw4P/Y/4OWNgDE2gtccyAiwoM3SkV2YGN8RSRaw6FUhRqS21A9Puj0RZFnFBkOWP7Xr8+X1YUAS8b4md4n5XFr7Hnv+eIO8Z++g7V1O6+p0IiQvG9i50LrqkvaPbaUPtjzx8J36rtjnygP12q4Zzjopjl+HV+H78DP47/BsiEptsJpeRG09g3CNhXB6Gjlj2qgrumFe1RlUgAipSa9QhwioBaZr/sl96/w7q5jRCvJjy7FRjuOmbc+fMqnajMcqNJoFb9gVvM0l2dlN4ZfNup+vOXK8NcLM9yl6TOQDLRZZwpuaDuMjemBMb3Sx6nSx615kh0Bgvw/4T+ZL3LZbKxbwFPQO5C2IAD2C/QJOAONKsG4VSGZ4oedFQzuOLVHmfbCYjLLmmDFvhjtiDAUqAPpmojQnCXFKg+aECJ2tDYUcPXJHUobreNxL2rtQImnomm+7AqWQql9G0cLSDNyRDPTUQjNiDdsh/ha2PTa4QBbISHgnsL8USllXhZRrLaoEvhiRR4HkMDQJNQtkHGtcIGOlsjsvm02ZI0/wsaSBsq5cpwi7dIckYH9Q5Es7gTISoAZVU8xbVr5PFnnHFoooetoXjmPK6hNedhF/+oFmIJyLha7q6C6qNu1KpdODP4qYuenVTYGySmaE5/0M4idO07mhHKvm+mix7YQD8/RG7QhSD8BGEScxxChE5SfpKKhONddvOrDcQnMkn/jyQjqW1DA2EMv09nymHI4l4pxTg8wlFHpmTIc9PSLICvUFZ1TlCXCReqCdwLsYTKSDW3kGvmhBFSTx89ZgSulfsfyp7klzojtgNOgJomo00gyQUR2k0jtYznMBoFgAxQCYUgaRhxAxMYSByhELWLGUdwK1zqMNJzKZ4GGZ2vuSRiLWSTw/Snhd1a+pxXH9Itywdvzcgv6hY9adI5Bn30c9ysnCOpGnSOYKicdsEYZsgnnOOpBYKqnQOkS39xcfrX7d08oJuyX8v64DFrCn8/Df+ER7rVKVBScsLCke4zbwpbObPVSU1n1MkVfbotFk0RBWtOhbqAbCgRxM02KppP0Gnrz25q7u76+S1n2p6Tl9IFrj/dJMcCsk3CQ8ckEIh6YBADs95xPPsb0EOnXKhICvfUmThQt7gZ/l9uvONn9P7aBFdin6CfoVc6Da/8UusaAByi4CGRkvFXtzsEqhPI5R1XG20EcqIdyfih5a9/nIijWDoLWiORi+yV4qMRIL+HHZSmBFLkM57TW3UA+dD5WF4D6BQgPOTuBHplaBUZHB/pFQuFYE5DeASGyxelPdGUSiyhwCnsAZOYUAVjSivKIAnmhwtUGPQRx4Z55N0pZwQBkYX2NzB7ak+UeZD9mRkPBIxeUrFWLq3Nx0DAMOHIpGJyAoIFZXe9LZ0r6hA0Ap7wk8oRdN9felEI+E4RJiCAAkfCQXCcYHbzgmJiDVgmhBPJggxTUkRi04HJwhcLFqUZNk0KZ2gMjWNwUg4IXDbOJE9YZhUoniC0pDhPRHznnDgCYk9Mc5iTfvTvet7e9fvOKW395TertqyTbWa0csKw/EmK8ykPVNqmZU6MmFDEOFmV8+2JxxWPUHpS29vJJy0ZyX8ogj5J/z8SyLLH8D8OJVJyBi0WZG388J0kVdQ6tcxGuUFgY96dYQYDJWUaMgcsP1KCh2NJ7hxqKN9aqMWO9b31lk1Ni1rwBLGHwWBP6oA1f5RmHnzuCOaNbO4QXfDKCs7kTJ0KKQJRxwYCh5ZXgtgRiSUhbw3Er3fSAlICVIsMbKiNjrMRnEEYAw8AuPTgUELI5PRMI0fG5z+r1Zl4zdfZZnMutKbZnFiBeDMXqpfgk1BHup2iEXi5bXlgMZ1D8nCo5hSnvKESLrE8RTwD8GqzIsAdp2wTGnE1EIWkaHxAcZHFHx/KoZ5jvAiFWVONVVOEQnQADwXT+ZkTb4G/jny9GwGr/4VwrnvlwWnf6OlYBnH1g0P5820RkIb+6OC/BHK8SxXyv4c3AA+B6yryFjqjfC8LKo8DgTMJAB7QWXo8R3pmgEYh/ICYEkoPWAaGBdQHGzU0lIZWBKh7LsIeYwtfYR80uNpHZQAHJBHJdSLBltzt4AW8tl8tSLO+2chnF5W7yU/e/11VjHKGdHo6z/v6SEPbd++f9aP9Pb2kt1uFP9kChrhFa8RImbU/ffRmQ9CgaPyM8vxKSe4lyNxL/QtSotfdIKWlaX6t5dMAraQuZyJLkLXt1fmMjdFMYDDKTxJRhgh4BMtDfFiWGiLAGZnbnkut3w1c3LlbeXytvNPHxw8HQ/KmhbS4uC2RRTz9UYW4FTx0BnnbxsiQ1vP2zr0Q03eKOu6XNVDmgdjF8i0dqN96AZ0sL1tbOV9cp3RUYxYL1XMvANhfgggy0X8bWnx0POSqkrPA0H/Vw8/fPO57GYxpz1y27gq4SJ7pfuSpBYx2qwaKvxWz7mw8e3juCfIjzy6JIyigFMyqBP6oh+hwgyL47UZtgq0UgBkVpiH4GyeYbh31qcSpVKCPA1uvUDIVwipo6kpmrv77u/fdddzd931/bvuJpunpmLFBN7HUrqHEkX8kPsRgt/+6L67pxqf7n1QpN/zyvUY+Q6UUEemh3sLXqnKwLWMohpahsbQcuDJJtAKNIlWoingZVajNWgtWodOAU5tA4ylU9FpaBPajLag09FWdAbahrajHWgnzOGz0NtgpJ2NzkHnogvQxejtQJFdivbCyLsMXY6uQFeiq9A70NXoGnQtug7m+w3onehd6EYo17vR7wPGfS/aj25CB2CUvg/djG5Bt6Lb0PvR7egO9AF0J/og+hD6A/SHgJfvQnejQ+ge9BGg9z6G/gh9HP0x+gS6F30S3YfuR59Cn0afQX+CPos+Bxj8QfQQOoweRo+gLzLszbAkYKsiWzoo5b1/HqizCmtyiMsDuq3UwDfnP6bm8mMx5jXhT8fWipUqvfm6c6dk7dv33PPioUMvHKrSqTvvhHZWqx87dOjFe+554dChBy+9VKWki7W+xEnkO1NdK2MGu4uL0q1XfeHQ1I2GOtzoHvzKIbzvHtxv2GiBrJ3N361tho02q2ytLdNw6oEHbmzL/Pr8xg9s/MMWa01XwSho71oT0Clik4stNZnWmse5Al3veBxpyfECal58yUsusgK0pc0cjyAOCacI7AqX0Lz7P+1mt2VwPYd5h0SxPWAsLw7Bu9aJId7Lc504//6c2dlOe6fXo/ZT2aPdM4utR2EfwPngrZZlYJ8Bu7BAJ+q3kw/Wz2JsEPlcKBZzP65bVtyy7nV9cc0OcMm3INH1J8dC9bMgRYilq38J4razFO5h3TrMnohb07Kk5vpYHhXR0CIrZAvXX/iqE6kwkYK9cJnsfvcxSVEkfKqoKI9c94rrHuB5XripxVLZfkV8hSV9RVSuXf8Xh7ZSuvUQQtKccpUBMu6BUfxubxy3Kh3wojBCgZ73GMw8jNNSk++sAQQSPaaTUfYRNpoj415M1RvLjC9gd8XFUK2ziH9hrZEVkMOmIIX1d0qcYiixsE7EkBq4fNVjwZBuBXQ5agsqrw9xmHs2YCoBXbINQbGDDsFXb2HsnedMiZIkToEvPsRumROfjm3RhPcmUrGwZmBd0kJCSNS0ZMKImJYSDih8SlC00KCt2yHFMAsWFiVFNYwEJNcl3YhFjQARdgJ/C7/eVhfoBmFOX+wCPPFZ9PlFxq1HGM5AhqZsywMBkxiAQVOmNQMrmqIspynGEoEK8iVYlYaYsgZdyQRW1TzAJI+tY/yRt4IdwB4XlcJMJGVXAHIxVosBtiKbP/CqpgBqQXfVX0ppIUmOSzY0LbRSSJN5WbblmCyQkA5xshyTItAVim6auiJIcBOTRRLaIPGSmtLMEIwkUeBEQ1Zk2RA5QYwIomU2owSRRclelCjYojQRy+cr+XwcsoqFQi060j0vpCnTZTD1lB6SpDhki2VBZoWAixxpFhAiWQFlmRVwLSVzi2Go6dklnCmGF6WalgAllG1WoEp+Vygegl8TPmHysgedqugk6GfbWxEXvF72em6k5MyGT7ztR/nJkn5n09kpSJyn7qusljhI+dsJKftAy/1HngKnCeHuq1747U/6EeSxHRwfzUV5uuMmYNqeAuDV6wGvF3Qr0ozaeYCI9Cb367Mj0TRM20b+C9kA0cpAg20GmnEWnc1Gm+nxLYWcL/n0Ro1QO/rdJE4Rdksr/8ay/BvmPPItcOv7DEXi1G41bnBqj3TurLtuuXmXCM7c9YhmUCGi2C1XLZ3s9+pdfxqc/QElLqUkLgKusFFX2Q1vz9yInJ0QU8IGLxlPxIBpwCxfoOuwHOjCI8zRkdGVZNSjB5j+R9hOMTGvBzwj3jJAzQOZvoQXetyTEnutdxR/qcgaqbRwsv3bmYVq1A5eLlqiqm4KRoxIKABDHAiNM8glsqwb+egjTICxjQG6yyjP08uY72aYduCA72IW9i5eAs7flgSu1fS5aqSQiXZrykYei2YxEDEEQuxEmPKczpxgxD1F4KWOYCaWJxR8usQLPAA5wE3MFXiBU4WgEJIRbuBpG6h8hNmaMoAh7DD5D91/2mkP7wwXO9wz0/iBnQM7qF0q7eyyIGBrCj+6Y9fnpvtiI6XAuZSBzr8SRqBHdUEPNIShDpsaDBtRj8KCm2kaCxL5VJaPnRgcm6G/2JzynisdOZqgbRs29ZfL/Zs2PLhhU9/wcN+mDdu3rFqWS6dzy1bdd5LvOWmLlwrG3XQo+L20i0XkTTOd68dP9+fSpun53SnPT+4LauFQ0F0VDIX1gOfHXwW/FnSnjBCkg0HewW5ZVAfMHHgqZLy8eBRCxGvHb9AgULKXerPYW5lgaL3gLWoI/vgVU9iePYDzlG+M3xRmA785UH1/Pjvf7w9g8Hv4BQYwif9w+QVjY+WYhiWzN8glhPRfd1a4rtHeHNedoQPZr7l1vSPX1bW6G3+aDc9nPfJLUINB1f2N518djESC7l8y/68VXVfcl1RTEKWRiK69beyC5actu7DDkP5C44J88Zx8pVPVyHA+NShqemZIUAKdFfKOx2QzvKa0qWt1l27p0Pq+GzSCoYQVCAW0cFjoNEacaX55ho4rASc6DpT/ZuAuW0OBrA8FfJjOFgmrWb5FmDO9ZOiHlYD3K2Xt7ELi573uM7wo8ngCXPe7OO/+Ax5cELRzDwvYw0vS2Rs36njCfabVPL5R4v+bpftvXor9828kfhO72QQ31U0S/wq7eQVuno/sZnIwqPez5LuenKBZ75ULZQQFbw2jRf3mpWPylxKkpYdff4H1HGWo5fWfkJ/WbaouCHr5DeR1NXN/9tWvZmjv6y+oDXCu18GdIlP1/Zb+1+wenKnbvm0FmrEB6yQymX0DNfTUZvFsp6GLjoVf+/+g+beqjbp99T9bmvYe9fr2Ya9vQ9C3C9alcCHrr3YD7VgBPgRD/9GL6yPJ7u4k+S647u+73yC/11UfIRw+kxclTpLwWRz5bk+y/l9eIiXZ437drf+Eo/jH7s8oR3hsuR2UY3m/8St6B1W9cZUGomKR8TTNmO2r97BuJS8yYmAFuae+l2TcHd7oYJyZ2ojSWbIpco97aJoHE+fpBa5A69F2dP6xjoD/h1JEte1ywvrnlyYJXCjL2HJsc2MJkhxHzHs62QHM1rYZJgCqj61gtkeqfWXP7T1X8sJHeY6ME1n4S0GGK8d/lG+LLOJ7Ww4e/CC9klP5xxhcfIxXuSvpQn2Kk49J03RGG5bOaMOuxEvUpxj6zH2mhj1+xf21Zn5Mkj6+VI2KL+4+O6CZpqZl72f82L1n8sJZMAOPtq7Yg2snVhaPvLJ4LGs5x9HC4nNHW1M6jtcTX1vSStdS1u1zuHZidh1x3f4IOOR4mk2L4rLjeBq5/9MaxS5YYzoZbTsmmq3tq+ttWj93/25pgIPRGH9Ov0s3ArUcRjE0AGwolxMxVJRpAjJ9Qlw80szA+1344v3AMb9NUfBn1bSK/0RlN8biAw35z+BnWbo0OKrKnmSPuw+27Ck6p59WHEsftSh2bolU0HsXll1bIhn0hlcDAT6LjrWNaHd7qeDWNW0D/XtBq3ZoB+V79/xW8vlFjXwJ+LUzAYchXCxNAjc8AKwxq/CMsmJjDavgrVs6EWiEhl5iii0SMflukAoNndpBvjitxlhdqJNYndZhJAvUGJu/FLbJZYDZEl2ru/s3mmo8qq/fGZDxq3Jgp/vPktDbGc7leC7YlREVokq2TZjaoKTylLOkgMhDlMzJIiXhiKQCREp34VNO0UP6j+C/bqwsUp4KkikIMOQVQQ/rggKjXxBkjhMBsnJieQw/TKm9PAv5D/ckVi63heytm/uYTKpvyy0fCVu6rYclQmKJ3KhCdFMlFJ7neKrKUBDBQ1GiyCka5MBhzdCpMpp133sugwXn+q69/OJ0UJCglAHOt1uApygzYuAEjhMUKsjB9MXLUXR6HI8DJ3ch2gPUxgPoCfR99O/olziGV+OteDe+Gv8A/wv+Oa6TIKmSc8kB8kdMChvEudqoT2GIMzRGebaZiz2Gm3YvTVqi4pETHnUB34YxEC2xGWA7Hi3hExm1UhoDPVFmtESDyPAJCs4zFvLNeZrkhl1p+sozRj3lEi8KvZBbpDJcq8yiN/IeAVKp+t9aI5gyOx7vtkFtNK17qqUGhcExW53qGIyycrVUzY/hqu8rA9HVoEEqjmfPU80zUqTcuPrfafrMMw5qkm61YqNhSKVJZzUaYISVo9Y0jYJGmDGOat41TJ7InIjKtO1U006q4TbNn+DOzwLqMEjg/eNMKQCKN0iAOGOWSj5J1myTWqMxHHuG5CqVS6y+BFqbVbhcbVS3+fWq3jSDKjcMoBYxgoI35K3fQmaGt+QzQNjw02TbLPoGq7rSE02mgNxIpR+yQgQTRRxXVAvIlep2ZryDibBCEPHKVR01Jw2UiCjrg+GYyaibazPpnETYm4ln6MN+ihK2U/k0l8Ir07m8liGOY8piwiaWrH0aCEWWUXK4n2UtaWr32YoewtgatQ2YsxSLdOLkSUEgKymmyhVDdsRi+dT0sMhKQrER/pqd6kxyOJmL5wygPlm2nJezN4WDxlW2ynV1efRrhnZ8fXVXxbI8i5t48WbVM16ZpEBOiSumlgVsHi/y4XWl33GYDZRxXXTtFipk8hnIPo17Esk0yy1lbZ4ckmVIERrJhABuTMTH9IAAb8cyABHlsY5kOs7I2x4nFZhlyJNwLgcykOcx9b9zzab0DI05I0uRXVLeiEiMSJzXoYqmDNpxg2Czdns8j3mJKByOJsOpbBbTVPbZaElWDDHIC6qtZbKFHlL6g9Rwl1dlSdV7oh1peGnqrqpj8LPfDTBxQtFCxKoJotc5HObI5Hm2YxHoHruTpRFVdfAz0PUsn2RalHhDgqrZiv1XWjrdGYCRECsUO5/qjsazLI9kmg1Kn87lMI6ErxhXdcihalkiC5jOnOc1zKlsDE7SP+5b2xnvcCDWLj+ay+uZoGoLGdFwIlDcjPblZDYptrSYmvvhdKnPcbyqHlhemKScCoF6xgorBCvj5sjfpnJJTJO5ruGgrFvGN+PJVF7AGakzH5KlkGLdPhYIOFBCZyBuK9NvDUrW7Lw9mykos5tZmvx4rgxs4NhkYEeiW5dGFf22cj/3W4vwHVxD//9FTzbN9P8XSMb5rJ3FdrZqVrM2PVBHTA2IIrYMy5EX6r3+n7wQM+sPeZpEO8zYj36JP7RrV/3FXbta68+d3mYNshKtwWBvB4WZvujst+9d1R7NrscOuq++7124wNrgzdhnbyW7T0hKTthnt9M+O43z3o4x3uQ+3iRKv+tG2Piyv98XFG+TgkFsBJnnOBaEHTe21t954lf6f+rxODgeKp2D6waPiUo4Fiw2cSx4yl0/jYloQ7fjxYbO8NE1htliNPlpE+2DW/9YQ6/uUP1F0jM1G+/Xz7N04q1TM4PvhboIDPe3FfO3Bee3Bdsvae0jg/tPYPQjr30cx/jpubcQfHffmAsXfR38T5HXpvmMpp0x4zfmaMNQ3iowWyt+ngEWM8qi582yv0rWTyLkL+tkaormPfMrZoF1t2d+heViB97bUSx2uPd0FPHD2P0IPnnv3oZ5z917mS7gLLh0DDBpiRL7JUrnW/BGO9sti5+eTO2RwV9xm+gPYOk2Md0W0PmJWeNEmIOfOlEXqqE1S9M6zBcq1byTY5tLTHp8dgDnK7lZatf5BajMPdP9bz0c1rHEXNd9/fX3iPxNIlEM4SYeaAYRKwoRbhKD4B7gxRYYz/2oFfhyIBxmTunz19KL+KBO+D2cpoq6we/hiR7kL1qgQ9ODasemkRVO4eFJPDKAc4Glas5ce3hg89mbBzxnqSoz2wcaDwxsRq30pTahXe3Wl5oP79uhJTUfzrZllD47B6D54/R6ilEBnYv2ouvRAfRBtq7g2Q5FnLJnH+QpT2d9AyKfd/PaqpBlTeF/fUOipjGRGMDQFF6iaYuiWVZF/DFaFZHH15iBDiOb0SOKlk0W3U/mgmZAy4V7cM2MSOHRTAH/wM0alpVwknYsoOpaOtRTDMZlRbEqpVGeAmMTczqiGcsxgwmzM6nbijZWnJAE9/kXVMNQX2A6yoebzob9zLcfIja+yHzMIU9vPqu3M9VhdMT1SKyjYKfi4dJAeaBYdAp4KJ7JjfXEjClBUg0rmsyWeruyuXAhZ3TEUunR7rRNVFkzQrF4JlPpyqbMlKPb4Vhq1VRfgTdeCkaC8Ls6GDGMmYvBAo0FtHj1mGacOBtqLmm+3TEHLi5xwr3WHFFz4UMfGjs2+eKbm0Vvcp64LXiel+mzNIv60STACMR7qqwz5fNtEqDQATw9lmcqV8iVBvBKPElShElI89MQHKBHgBDPHGf31i2DQ0ODW7Z+deuWgaE8L0VjQvdY7dzz/+X8c2tjzOPu4qmu0wrRDFPjSYWEVFn8MkDhuPplxRB5I5wBpmVocPMZXzljM3vX5jN2n36KFtNkbcfudzTf4r3uVkwd/XuSznGaIT2n6tw+Ie6I4j4tBJhiAVzsQ+NQ69OOqb+WtJPvkvrwC4tukbvUzrzlaNvNevWd0c3IQC8vR+ta6WdYs3SYxTlWp54Nn2+lJzD4xNbKPRO9IylufNx9iAERvAPcx1U204NXqNIvxGCEOXU1KP5CijDniHocCR9IHG68SGUvHW4+yaKab0TxNyGj3U0uJFeS3yO3nuDrTkhq27qT5pvWwj+OOObfdYnu3qXbOhzHsoDjRtbrJpZkaNK012zuqVlcwo6a/g4gR9wu86qrti2+K2Z/bajWmmfbifa0eZehxbB8W5i37llWcHc2BM1tWY29z7eR2t94t87yeXPrstvIpSew/Qls39512beEzv/vOj7Hb0WbheMGff/tIjpQ0TfF911ALjuBBU5ggXZigaOcS3ICEfyvQQR3tz7f5QQW+N+PBf665blDpLHu+AwKoBTAdR74pELTcB2Lpm+6XjX5yGhNqNGH3L1aQnevG8iQJzIDuD9TXwuXDyuOrDxHzntJEH6QTfX0pBJT7i62NwT+5HM8Frh9rfizS9B17d5PsbTE4xnawrCdxBNBer+k6+BoOn8Nz18jKrfdJuurVunybe3h3XKYqsKwJt8sa2VR5Sj/fiEovF+8SpO1TZvAac33tnlvB2fRnQza0IqntdjnoB1N9+NWmyCgph7YHeRlpAIP7O+HMrP/yGL+fXVv20dy2FPxau0nDUbb/Wnj+kpzc5I3Q2edTS49cUrVCTqrzXTWW3P/it91ogu/hfffOG7Ir68tbT8AY44e2NxzSSqNfdlORus8feJWe/i22MCd/T29wkVOMPH2d5+vIfb6z3t7yeEdO/bP+pGe3t56b+vwFipiT1ZxtfnB1fuq06ec4OoM3envtdeyLvTk+o3kmVm745Gz3E34T98+e5e7ebouQ8emjdDYfXxJai7nsP3Fl6jd8m/eFuLTNmbfbPRlV+t6ii3CFh4p84Dbi39T/2eme0TSnvs+N4b/fSpq1P/DdByTOEb0Qfen2J4yVPdTLAE+Rwu20LPc0WZNtgAWIcppl1L6zsi6SHhj+BqrUGoLIXjritdWhLeHf3/iXe9Bi6wTXdjeFln8JLU2NI/7+vxz1trCaPzZYqewcQt0YI5F/+UYtVyOWZ+lVX9ejK5t87pf6/OEHGvhaUJt6ODwnFN8rAxpnOKzb94ZPm3p9/obs0/LGb1MumqFIEmi+6BizjssR2qhE3sOOo/tydtWHr59GmJHbua7flv9saNMqFePql02f++f7CJ7/8xtM49m91Wij7j3T3FlsbjyVOYUR84cGTnzEuYccX493UgPTrWRHpwZnvn66XX9o67q022N5fzD/nK+rrwoW/WvEPsb7qOLL+V7tgkz7dGiLY5U4yPVDYp/9P0P+/EQXn6C4z7i/odvGTn9irecnPuNluLhBg27idwKM9IBLmSA7cHOFJWr3mEUKcwmvSjkS46JW4QXIPipiPmapsdeC+azlmUEA//1a3x6xPw1BP062AlBZsD9n1/foT8lJ4Jp6ymNGumQe4uVloT6U/hGd+0iEQtsLJd59jJL3591WjXXP/ZirnLuklgCPqS/qkU7tV/IvBLRXzXj+qt6Pqb9YqlblNX/VPMfkGPRAHuPFsvDG6dh1ZH2d7oef/DEbk5t283pxEZGb2ojo+SJTYEW3RSo/tiSNthZEg1ovSkzgkuP2Wag/qmW9gE+/Xc17Uc5dD66d/6egP4JxmQWYTCACwzwlkcr7AiiRXYGJP7OgEKrnQGz0zsDMtHCzOnG3hmulUV2BzwkKdnCsnOXrXx7FPBK6KQ9NaAxH9Wt0T3uIZUKE3GnIzLkQHlrfapOgmoqCRQHR7WgwAuipVqKKAhhXRB5hSOJlBokutJXw9+8MBQLuc+DcyHetEbmJCqrgirIoqIIAZ4LJUJyQFAUSdZ4YJupIEprNuGnOK7j9H4oy5qxYk//lqSUuvSW9ROMGJ5Yf8ulX0skBDXJDiLCNFcY3BCgVsQEwkKReEEIaDwlVGDCTKrIvCyYElyIEbFoYMNg/T9vYstZN/lux+l39tqSxmuKIHMCz3FMjsx+HMcL8DIpwMlauOfO09uyP8OScGJjf4YlCsrm7M8wq3wjx8RVzpZALc1EdJaMaWkl/cVsKZK5BF6ijFfg9Xj7CX7iiLsenLD10INvP2Erwc5t/vHSzrLAjfNMbkUVhCzPXnjGkpjtQuutssII9A53atoRD+Cm3XF1eybbW+sZHRhIZsPFTiud6OzrSsULRiKQy/SNDFTLvZG4keq2O1etj+fSoawl4w+fOrQyG5XFlJkwsplgzLQ1NZvujnTmv726qxYNy1I66OgdRTOZlaKp/o7lGeMpNM07baEGUPRp37bVO1FnhB3DN+wdtlTIBbDdEPszfFry5Ty+zIfOlvZQhR23Mn7R+MvjFy3vcq/oWdfDAT1IaPe6nqu8VcELziiXzyhnRjOZ0alqJlMd6kpC0vE948mulyE1wwxwOVQ+40KWEBzcmxldyZKDMyPnYfYbGoox643CbFludtEb7ywfdhLdPzRPpPOv1aNoTHj+BXzc2mPcAfxYTntfkuBQXvI56ks9p+XupZ9J/lvsz7Gkyi2xyIh74403bgEoeQBlgLNm5ywjJ8cmkneylzPrGL8ALkX8S6px7BeUlZGoRS80AnSsFzzgJwZElSKi87OBbdm+dLrv4MC7V1jp/oN9N9xwZiYzfZvZ/oeJU05JHMwErNV6MaGv7tqZPphgm6Z+q/vMzMG4aVXXrfOiewI5hyofeVc+03/9DX0H+9PWincPHOzNZHbeMHObyR9kujgHM2d2r9ETRX11KACvgwzwbVYgczCxbl3VMuM3p8/q6lWokwsMeutmt9O76H6YCd0Aa1YDJ+6dX1Qym7plw97pmmwKAJict3xXyFb9TStsi7GLA8zKGzOlFKEEgSnCyOcirdT/qFTDy0rjJ19969Unj5eW4WX1awC6EnIxc90BvLJ3w44NvfeF4j3Dwood62PZYjytGBIXYIchXVcrEdS1bPLkq0+G3+SyLheVauQijrqI8DwhiHJnTfZu6IVf/fvxUFBbu3OlPHjGFjsWij+nWFaAE00FZiCbf3fQD9NbUL5lTQmj25kJ+wBme39nW1cZz6+or18Cs3F2Tcs7r7zirJikZfJS7KLL1+C/g0rX5lT6b+ZUVjZl+Omm2azs2EVr49E1FSNvaMbwUHznspb1di+ZX18sGSEDMHMoZjXXAf+c/gD4rjCM7w0Ac/agK2C+eSKAmQMZPfafZuceezlT8abODNTWFx74Zzj7JzdXat42CkFMswuOf/OyEGzyf8wopXew9ds785XoZP37nZVKp3d/BxDxlAwSzsk5lYEDpqP+a2xdbFUs9mNt74YfctwqwuMfdrv/YTqV/BOdlegbf8XRJ4BZf9wxn6Q0mo1WOp80oy4e7iR3dA47Wcinfh1r4CfY25/sLD/hmAcM7ccxeOe62L+qW37I8VOE/BDXosYHOoeHOz9gRLfsYQ94MOlO+gt6tYcXGBwYqXkMKLCp2VzJY00dxpqucTIGvc7szxqv32HS3Y75+h1Gtt+k1xmZqzMDBr2e3UHYdCJjIIuaOP1X5HlGWRfYCyeJI0MOKQw54PdYuvuEhuOdAVwg3YHOONbqj+sDOl6jF+JYd39EerR4IVD/kt7Yc/Uu+iS9HDAum7dTbIcC/9yxBgE5rdxaaRxiGhbw9Dhm85adYCjYc/aCy89Z1PyNqxVry8143PxErYj7i7VPMLWJ5aP1fwIa8peEcy/Ey2Ew/oByQD3FYp2x2Ev+5fJakewGz75irVbcB576/cVR8mT9fm/4796xj13rG2Mh3Mfe6P6AuTN+1Gwr8mXyOSYlxHwKACuUjNE3vBDG23FOdmwgax0ZkDC+oA7caljDv9HCMpXqWuf85wtsRkOdAHLXCqMj5LD7j83ncU7H9/rPu8LM8wwv7OeSABf3o5+i1zC0N984TxIGOwPwRSYFZnh4gElVvRiP3oEQFjMy2pgjcGFRZNwHpGEvyEfd7BxVmEEQwiKZZMGT0Po2YmGhkUuRASMP7UACZjm2AoBPxH/ziL+XRq0yDHn0YsEvkT8d4RFWKjYDkzjiv8pfYGxIggX/xFZ2sisrRsR2mMSBrb7NI858OD6AyUl7E4MJylMasUZGwhstXbcihBIukxhIQEyGMuWkCFMy2pA6IxVhDHowWQjv7RhIcOypQKG7EDg1EAwGIh7jnwkXksHEQEcnMPMkEjCMwIbwyIgVAaYFL38pmef3AruTX74iEuHoqRhHbC1aSed4PpOuxvQovP9U9lxkRTJVwNxeHufHpyJhjmNJI1p0JJ1hxCCQiGpAi0Yw3ghww46s/Oiy3cuW7b6KOctyy2L64EkrC6nKfqhAjon/SMQK6NYGq8oKwgkdgwm//ATKX+yC8nd0eKXnOK/0UG3Oe4pVa4NXw5mKQ6zAsXp3FYIb/ObiMCd1j/+rOgIVoUROVxw1YlO6wa/J8jzmGxWxOW6jVxFdBTKX8kJmJKY74WbSybE8JXsptE8quSpiw3s3EuI46spG1cDBk4WVJw3qsWW5VCWF/i9drUT1AHicY2BkYGAA4oBliR3x/DZfGbhZGEDgsZfrbxj9////BhZZ5jYgl4OBCSQKAE9UDJsAAAB4nGNgZGBgbvjfwBDDIvP///9/LLIMQBEUkA8ApekHDHicY2FgYGAZxYMM//9PUI3M//8A1FEF1QAAAAABqAJkAqoDFgOyBs4HOAegCPQJzgoaC9AMgA1ADYwOYA7eD6wP9BBAEQYR/BJeEtoTgBOgFEQU2BVUFbgWQhaAFrYXRBfgGEYZ9huSHBIcZhzIHVoeLCFiIc4iACKCJXYlxiX+JnQoAihKKI4pFimCKdwqais8K5Ir8CxoLOAtVDB4MLYxTjRQN1I3hjgyOMo5BDwaPI48sj0APUI9yj5iPrI/ZkAQQGRAmEDGQmJCsEMcRRJFZEZGRpZG7EiqSQBJWEmUShpKXkreS1RLzkxkTJRMuk0qTUpNak7UeJxjYGRgYMhnms1QzQACTEDMBYQMDP/BfAYALmMCngB4nH2Py07CQBiFT7lIhMSFJq5YjDEhJoZyWZjIFgNLExLZuSjtFEraTjMdILyB7+Aj+BQ+iL6AL+GhjCawoM38853zX/oXwCW+4WD/XPHs2cEF1Z5LqOHGcpn+neUK+cFyFQ08WT6j/2y5jnu8Wm5w4hsnOJVzqhbeLTto4tNyib1flsv0fyxX0HRqlqu4dm4tn9F/tFzH1Hmx3EDL+Rhq6RkZiNlWRL5KQ5Wa3d0OAhm1w1htJnK+ij19aB6qqdR5pFLRc7uHibFMpf4bn6/nfWNCEWqViBG/I+NYiUyrpfSNuzAmG3Q6ofVdXyUYQkPCg2EMIDDDljGCD4UUYRHNv26zJmBlRAoR09tgQj3HisrjrFOVp3JTao2c3q5CoAcX3ZMdY+q06DrePseaG/XpGlYLHs2OhDSy/yM5YzdFICtySzo+fReLoivDAB2+4VG9W+yT/AKrK35GAAB4nHVVZ2PbNhDVcyQ5lqzYluUkTpomHelIyraS7YzuvTK6m3QXJC8SIhBgQFB2/n3BVZEqwg+SeMA93L17D2qttYqn13I/Cms4hTY66GIdp7GBHvrYxABnsIVt7GCIXYywh7M4h/PYxwVcxHO4hOdxGVfwAl7ES3gZV/EKXsVreB3XcB1vwMObeAtvY4wJDnCII9zATdzCbbyDd/Ee3scH+BAf4WN8gk/xGT7HF/gSX+FrfIM7uIt7uI9v8R2+xw/4ET/hZ/yCB3iIX/Ebfscf+BN/4W/8AwYfAUIQHmGKGTgeYw6BCBIKcetSYpg2Hi1IGi9QUUwyYZ5U0uPS0F72oSMKOTNUbbq5kZAMPcOS+W49O6IkYVNnjpmcdSGNJ72QGWaPilMzykCbdRi+npBe8IB6qf2RHzneEkySF/IFD8kzx2pUr6EqfNdXqQyZfloVwCN3M7d3cjguLb7xmK8W1JlqlcbONo72VnADJgMSwyT1vVirwDLgRUzPSQ/+48jz2byfBJrHJn/fLFvKX04Z5q/bdiML1o+YTJnI46cTepKSxS4ISozS1C3Wh36acJmdpFNRoAwaoQYhMdNMCBLrmgLiC9qvl0onMbNVFhWPmkqQITdcOTk7GC5HVQ59vOeawsQZvbFTj2aT0cOphT9mJas+Syisn5EKw2PhVtbBRi4Nbit2a+yw0ViF1QlmltLRyjhJa6WdPR82is73tTPljBybpbPtcUNpPgl1fGbZo91FlxtYZqbVcbma8KlkYrOcYWG9ZW6WxKXNWVVnkdYtxLe9TCjiw3qVRagvlIrdeigcuVUNKgsIOnFTftTPVatSY32977xDMle4k8cXV7ooJZaT2M5s5RzQ5Moz2SsBRoWnDLcei3jZ5XnHRZGftNO4ZmaaaBBYJ3ksMDZmntZmJ7ic941mlh+7qKRTp+Orz6xved0puV0RXBnX2ez/OKpD9CoIpcs5+I8pMJtVOJOaU6EHu3WYkqCabIrLzpl61K/QT6wxMkduLfNyt9Sud0osk/kZTqzDAQu9mQrKArq5v8fDipDl7BoKrUC3VyCpnY2nLVQw76Yy+2pbLk23aGZNzTt2csmsLeiR6Wg+nRn7n2MMl9NW61/Z9cD6') format('woff'), url('data:font/ttf;base64,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AADmjwAAAGgAAOaQAADmkAAAADMAAOaRAADmkQAAADQAAOaSAADmkgAAADUAAOaTAADmkwAAADYAAOaUAADmlAAAADcAAOaVAADmlQAAAGYAAOaWAADmlgAAADgAAOaXAADmlwAAAGkAAOaYAADmmAAAADkAAOaZAADmmQAAAGoAAOaaAADmmgAAADoAAOabAADmmwAAADwAAOacAADmnAAAAD0AAOadAADmnQAAAD4AAOaeAADmngAAAD8AAOafAADmnwAAAGIAAOagAADmoAAAAEAAAOahAADmoQAAAEEAAOaiAADmogAAAAMAAOajAADmowAAAEIAAOakAADmpAAAAG4AAOalAADmpQAAAAIAAOamAADmpgAAAEMAAOanAADmpwAAAAUAAOaoAADmqAAAAEcAAOapAADmqQAAAEgAAOaqAADmqgAAAEkAAOarAADmqwAAAEsAAOasAADmrAAAAEwAAOatAADmrQAAAE0AAOauAADmrgAAAE4AAOavAADmrwAAAE8AAOawAADmsAAAAFAAAOaxAADmsQAAAFEAAOayAADmsgAAAFIAAOazAADmswAAAFMAAOa0AADmtAAAAFQAAOa1AADmtQAAAFUAAOa2AADmtgAAAFYAAOa3AADmtwAAACQAAOa4AADmuAAAAFcAAOa5AADmuQAAAGEAAOa6AADmugAAAFgAAOa7AADmuwAAAFkAAOa8AADmvAAAAAQAAOa9AADmvQAAAFoAAOa+AADmvgAAAFsAAOa/AADmvwAAAF0AAObAAADmwAAAAF4AAObBAADmwQAAAAUAAObCAADmwgAAAF8AAObDAADmwwAAAAEAAObEAADmxAAAAAcAAObFAADmxQAAAAgAAObGAADmxgAAAAkAAObHAADmxwAAAAoAAObJAADmyQAAAAsAAObKAADmygAAAAwAAObLAADmywAAAA0AAObOAADmzgAAAGQAAObPAADmzwAAAGAAAObQAADm0AAAAGwAAObRAADm0QAAAA4AAObSAADm0gAAAG0AAObTAADm0wAAAGMAAObYAADm2AAAAA8AAObZAADm2QAAAGcAAObaAADm2gAAABAAAObcAADm3AAAABEAAObdAADm3QAAABIAAObeAADm3gAAABMAAObfAADm3wAAABQAAObgAADm4AAAABYAAObhAADm4QAAABcAAObi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LgAwAGkAYwBvAG4ALQBkAGQAZQBpAC0AZgBsAG8AdwBHAGUAbgBlAHIAYQB0AGUAZAAgAGIAeQAgAHMAdgBnADIAdAB0AGYAIABmAHIAbwBtACAARgBvAG4AdABlAGwAbABvACAAcAByAG8AagBlAGMAdAAuAGgAdAB0AHAAOgAvAC8AZgBvAG4AdABlAGwAbABvAC4AYwBvAG0AAAIAAAAAAAAACgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAbwECAQMBBAEFAQYBBwEIAQkBCgELAQwBDQEOAQ8BEAERARIBEwEUARUBFgEXARgBGQEaARsBHAEdAR4BHwEgASEBIgEjASQBJQEmAScBKAEpASoBKwEsAS0BLgEvATABMQEyATMBNAE1ATYBNwE4ATkBOgE7ATwBPQE+AT8BQAFBAUIBQwFEAUUBRgFHAUgBSQFKAUsBTAFNAU4BTwFQAVEBUgFTAVQBVQFWAVcBWAFZAVoBWwFcAV0BXgFfAWABYQFiAWMBZAFlAWYBZwFoAWkBagFrAWwBbQFuAW8BcAAdc3RhcnQtZXZlbnQtY29tcGVuc2Etbm9uLWludGUVaW50ZXJtZWRpYXRlLWV2ZW50LWM3CXNlbmQtdGFzaxNzdGFydC1ldmVudC1tZXNzYWdlFWludGVybWVkaWF0ZS1ldmVudC10MhZpbnRlcm1lZGlhdGUtZXZlbnQtYzEyCmRhdGEtaW5wdXQUZW5kLWV2ZW50LWNvbXBlbnNhdGkHc2VydmljZQp1c2VyLXRhc2sxD2xhbmUtZGl2aWRlLXR3bxRzdGFydC1ldmVudC1ub24taW50ZRNib3VuZGFyeS1ldmVudC10aW1lFWludGVybWVkaWF0ZS1ldmVudC1jORFsYW5lLWluc2VydC1hYm92ZQVncm91cBVpbnRlcm1lZGlhdGUtZXZlbnQtdDUVYm91bmRhcnktZXZlbnQtY2FuY2VsEnN1Yi1wcm9jZXNzLW1hcmtlcg1zZW5kLXRhc2stYmFrC3NjcmlwdC10YXNrDHNlcnZpY2UtdGFzawN0YWIHY29tbWVudAttYW51YWwtdGFzawhzZXF1ZW5jZQpkYXRhLXN0b3JlBm1hbnVhbBJidXNpbmVzcy1ydWxlLXRhc2sNYnVzaW5lc3MtcnVsZRRzdGFydC1ldmVudC1wYXJhbGxlbAdyZWNlaXZlGXN1Yi1wcm9jZXNzLWV4cGFuZC1tYXJrZXIUc3RhcnQtZXZlbnQtY29uZGl0aW8VaW50ZXJtZWRpYXRlLWV2ZW50LWMzEmVuZC1ldmVudC1tZXNzYWdlMRVzdGFydC1ldmVudC1ub24taW50ZTIVc3RhcnQtZXZlbnQtbm9uLWludGU2EXN0YXJ0LWV2ZW50LXRpbWVyEmdhdGV3YXktZXZlbnRiYXNlZBJlbmQtZXZlbnQtbXVsdGlwbGUVaW50ZXJtZWRpYXRlLWV2ZW50LXQzCXVzZXItaWNvbhZpbnRlcm1lZGlhdGUtZXZlbnQtYzE0FHN0YXJ0LWV2ZW50LW11bHRpcGxlBWNob3JlFGJvdW5kYXJ5LWV2ZW50LWVycm9yFWludGVybWVkaWF0ZS1ldmVudC1jNBFzdGFydC1ldmVudC1lcnJvcgRsYW5lFGludGVybWVkaWF0ZS1ldmVudC1uFXN0YXJ0LWV2ZW50LW5vbi1pbnRlMRFsYW5lLWluc2VydC1iZWxvdw5lbmQtZXZlbnQtbm9uZR9pbnRlcm1lZGlhdGUtdGhyb3ctZXZlbnQtc2lnbmFsDHJlY2VpdmUtdGFzaxNlbmQtZXZlbnQtdGVybWluYXRlFWJvdW5kYXJ5LWV2ZW50LXNpZ25hbAZzY3JpcHQQZW5kLWV2ZW50LXNpZ25hbBJzdGFydC1ldmVudC1zaWduYWwLbG9vcC1tYXJrZXIUc3RhcnQtZXZlbnQtY29tcGVuc2EPZ2F0ZXdheS1jb21wbGV4FmludGVybWVkaWF0ZS1ldmVudC1jMTULZGF0YS1vdXRwdXQZaW50ZXJtZWRpYXRlLWV2ZW50LWM3LWJhaxZpbnRlcm1lZGlhdGUtZXZlbnQtYzExG2JvdW5kYXJ5LWV2ZW50LW1lc3NhZ2UtaW50ZQRzZW5kFWludGVybWVkaWF0ZS1ldmVudC1jMiBpbnRlcm1lZGlhdGUtdGhyb3ctZXZlbnQtbWVzc2FnZRRzZXF1ZW50aWFsLW1pLW1hcmtlchhib3VuZGFyeS1ldmVudC10aW1lLWludGURbGFuZS1kaXZpZGUtdGhyZWUNY2FsbC1hY3Rpdml0eQ5lbmQtZXZlbnQtbGluawt0cmFuc2FjdGlvbhVpbnRlcm1lZGlhdGUtZXZlbnQtdDElaW50ZXJtZWRpYXRlLXRocm93LWV2ZW50LWNvbXBlbnNhdGlvbhBnYXRld2F5LXBhcmFsbGVsFWludGVybWVkaWF0ZS1ldmVudC1jMRtib3VuZGFyeS1ldmVudC1jb21wZW5zYXRpb24KZ2F0ZXdheS1vcgtkYXRhLW9iamVjdAxnYXRld2F5LW5vbmUVc3RhcnQtZXZlbnQtbm9uLWludGUzE2NvbXBlbnNhdGlvbi1tYXJrZXIQZW5kLWV2ZW50LWNhbmNlbBVzdGFydC1ldmVudC1ub24taW50ZTULZ2F0ZXdheS14b3IEdXNlcg9lbmQtZXZlbnQtZXJyb3IUZW5kLWV2ZW50LWVzY2FsYXRpb24Vc3RhcnQtZXZlbnQtbm9uLWludGU0DWFkLWhvYy1tYXJrZXIGdXNlci0xEnBhcmFsbGVsLW1pLW1hcmtlchRzdGFydC1ldmVudC1lc2NhbGF0aRBzdGFydC1ldmVudC1ub25lBGxpbmsEbG9jawZ1bmxvY2sEZWRpdAZjYW5jZWwCb2sFdHJhc2gEbGVmdAVyaWdodAdzZXR0aW5nAAAAAA==') format('truetype'), url('') format('svg'); } .icon-ddei-flow { font-family: "icon-ddei-flow" !important; font-size: 16px; font-style: normal; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } .icon-ddei-flow-start-event-compensa-non-inte:before { content: "\\e6c3"; } .icon-ddei-flow-intermediate-event-c7:before { content: "\\e6a5"; } .icon-ddei-flow-send-task:before { content: "\\e6a2"; } .icon-ddei-flow-start-event-message:before { content: "\\e6bc"; } .icon-ddei-flow-intermediate-event-t2:before { content: "\\e6c1"; } .icon-ddei-flow-intermediate-event-c12:before { content: "\\e683"; } .icon-ddei-flow-data-input:before { content: "\\e6c4"; } .icon-ddei-flow-end-event-compensati:before { content: "\\e6c5"; } .icon-ddei-flow-service:before { content: "\\e6c6"; } .icon-ddei-flow-user-task1:before { content: "\\e6c7"; } .icon-ddei-flow-lane-divide-two:before { content: "\\e6c9"; } .icon-ddei-flow-start-event-non-inte:before { content: "\\e6ca"; } .icon-ddei-flow-boundary-event-time:before { content: "\\e6cb"; } .icon-ddei-flow-intermediate-event-c9:before { content: "\\e6d1"; } .icon-ddei-flow-lane-insert-above:before { content: "\\e6d8"; } .icon-ddei-flow-group:before { content: "\\e6da"; } .icon-ddei-flow-intermediate-event-t5:before { content: "\\e6dc"; } .icon-ddei-flow-boundary-event-cancel:before { content: "\\e6dd"; } .icon-ddei-flow-sub-process-marker:before { content: "\\e6de"; } .icon-ddei-flow-send-task-bak:before { content: "\\e6df"; } .icon-ddei-flow-script-task:before { content: "\\e682"; } .icon-ddei-flow-service-task:before { content: "\\e6e0"; } .icon-ddei-flow-tab:before { content: "\\e6e1"; } .icon-ddei-flow-comment:before { content: "\\e6e2"; } .icon-ddei-flow-manual-task:before { content: "\\e681"; } .icon-ddei-flow-sequence:before { content: "\\e6e3"; } .icon-ddei-flow-data-store:before { content: "\\e6e4"; } .icon-ddei-flow-manual:before { content: "\\e6e5"; } .icon-ddei-flow-business-rule-task:before { content: "\\e6e6"; } .icon-ddei-flow-business-rule:before { content: "\\e6e7"; } .icon-ddei-flow-start-event-parallel:before { content: "\\e6e9"; } .icon-ddei-flow-receive:before { content: "\\e6ec"; } .icon-ddei-flow-sub-process-expand-marker:before { content: "\\e6f2"; } .icon-ddei-flow-start-event-conditio:before { content: "\\e6f5"; } .icon-ddei-flow-intermediate-event-c3:before { content: "\\e6f6"; } .icon-ddei-flow-end-event-message1:before { content: "\\e6f7"; } .icon-ddei-flow-start-event-non-inte2:before { content: "\\e6f8"; } .icon-ddei-flow-start-event-non-inte6:before { content: "\\e6f9"; } .icon-ddei-flow-start-event-timer:before { content: "\\e6fa"; } .icon-ddei-flow-gateway-eventbased:before { content: "\\e6fb"; } .icon-ddei-flow-user-task:before { content: "\\e6fc"; } .icon-ddei-flow-end-event-multiple:before { content: "\\e6fd"; } .icon-ddei-flow-intermediate-event-t3:before { content: "\\e6fe"; } .icon-ddei-flow-user-icon:before { content: "\\e6ff"; } .icon-ddei-flow-intermediate-event-c14:before { content: "\\e701"; } .icon-ddei-flow-start-event-multiple:before { content: "\\e702"; } .icon-ddei-flow-chore:before { content: "\\e703"; } .icon-ddei-flow-boundary-event-error:before { content: "\\e68b"; } .icon-ddei-flow-intermediate-event-c4:before { content: "\\e68c"; } .icon-ddei-flow-start-event-error:before { content: "\\e68d"; } .icon-ddei-flow-lane:before { content: "\\e68e"; } .icon-ddei-flow-intermediate-event-n:before { content: "\\e690"; } .icon-ddei-flow-start-event-non-inte1:before { content: "\\e691"; } .icon-ddei-flow-lane-insert-below:before { content: "\\e692"; } .icon-ddei-flow-end-event-none:before { content: "\\e693"; } .icon-ddei-flow-intermediate-throw-event-signal:before { content: "\\e694"; } .icon-ddei-flow-receive-task:before { content: "\\e696"; } .icon-ddei-flow-end-event-terminate:before { content: "\\e698"; } .icon-ddei-flow-boundary-event-signal:before { content: "\\e69a"; } .icon-ddei-flow-script:before { content: "\\e68a"; } .icon-ddei-flow-end-event-signal:before { content: "\\e69b"; } .icon-ddei-flow-start-event-signal:before { content: "\\e69c"; } .icon-ddei-flow-loop-marker:before { content: "\\e69d"; } .icon-ddei-flow-start-event-compensa:before { content: "\\e69e"; } .icon-ddei-flow-gateway-complex:before { content: "\\e6a0"; } .icon-ddei-flow-intermediate-event-c15:before { content: "\\e6a1"; } .icon-ddei-flow-data-output:before { content: "\\e6a3"; } .icon-ddei-flow-intermediate-event-c7-bak:before { content: "\\e6a6"; } .icon-ddei-flow-intermediate-event-c11:before { content: "\\e688"; } .icon-ddei-flow-boundary-event-message:before { content: "\\e6a7"; } .icon-ddei-flow-boundary-event-message-inte:before { content: "\\e686"; } .icon-ddei-flow-send:before { content: "\\e685"; } .icon-ddei-flow-intermediate-event-c2:before { content: "\\e6a8"; } .icon-ddei-flow-intermediate-throw-event-message:before { content: "\\e6a9"; } .icon-ddei-flow-sequential-mi-marker:before { content: "\\e6aa"; } .icon-ddei-flow-boundary-event-time-inte:before { content: "\\e687"; } .icon-ddei-flow-lane-divide-three:before { content: "\\e6ab"; } .icon-ddei-flow-call-activity:before { content: "\\e6ac"; } .icon-ddei-flow-end-event-link:before { content: "\\e6ad"; } .icon-ddei-flow-transaction:before { content: "\\e6ae"; } .icon-ddei-flow-intermediate-event-t1:before { content: "\\e6af"; } .icon-ddei-flow-intermediate-throw-event-compensation:before { content: "\\e6b0"; } .icon-ddei-flow-gateway-parallel:before { content: "\\e6b1"; } .icon-ddei-flow-intermediate-event-c1:before { content: "\\e6b2"; } .icon-ddei-flow-boundary-event-compensation:before { content: "\\e6b3"; } .icon-ddei-flow-gateway-or:before { content: "\\e6b4"; } .icon-ddei-flow-data-object:before { content: "\\e6b5"; } .icon-ddei-flow-gateway-none:before { content: "\\e6b6"; } .icon-ddei-flow-end-event-message:before { content: "\\e6b7"; } .icon-ddei-flow-start-event-non-inte3:before { content: "\\e6b8"; } .icon-ddei-flow-compensation-marker:before { content: "\\e6ba"; } .icon-ddei-flow-end-event-cancel:before { content: "\\e6bb"; } .icon-ddei-flow-start-event-non-inte5:before { content: "\\e6bd"; } .icon-ddei-flow-gateway-xor:before { content: "\\e6be"; } .icon-ddei-flow-user:before { content: "\\e808"; } .icon-ddei-flow-end-event-error:before { content: "\\e6bf"; } .icon-ddei-flow-end-event-escalation:before { content: "\\e6c0"; } .icon-ddei-flow-start-event-non-inte4:before { content: "\\e6c2"; } .icon-ddei-flow-ad-hoc-marker:before { content: "\\e6cf"; } .icon-ddei-flow-user-1:before { content: "\\e6b9"; } .icon-ddei-flow-parallel-mi-marker:before { content: "\\e69f"; } .icon-ddei-flow-start-event-escalati:before { content: "\\e6d3"; } .icon-ddei-flow-start-event-none:before { content: "\\e6ce"; } .icon-ddei-flow-link:before { content: "\\e67b"; } .icon-ddei-flow-lock:before { content: "\\e695"; } .icon-ddei-flow-unlock:before { content: "\\e6d9"; } .icon-ddei-flow-edit:before { content: "\\e68f"; } .icon-ddei-flow-cancel:before { content: "\\e697"; } .icon-ddei-flow-ok:before { content: "\\e699"; } .icon-ddei-flow-trash:before { content: "\\d6ef"; } .icon-ddei-flow-left:before { content: "\\e6d0"; } .icon-ddei-flow-right:before { content: "\\e6d2"; } .icon-ddei-flow-setting:before { content: "\\e6a4"; } .ddei-flow-bpmn-viewer-inclusive-gateway[data-v-aa8661cf] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-inclusive-gateway .icon-ddei-flow[data-v-aa8661cf] { width: 100%; height: 100%; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-boundary-event[data-v-7f22a8f2] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-boundary-event .icon-ddei-flow[data-v-7f22a8f2] { margin-left: -3px; margin-top: -3px; width: calc(100% + 6px); height: calc(100% + 6px); fill: var(--borderColor); } .ddei-flow-bpmn-viewer-businessrule-task[data-v-44e6c2a4] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-businessrule-task .title[data-v-44e6c2a4] { height: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-businessrule-task .title .icon-ddei-flow[data-v-44e6c2a4] { position: absolute; left: 0px; top: 0px; width: 24px; height: 24px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-businessrule-task .title .text[data-v-44e6c2a4] { flex: 1; text-align: center; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-businessrule-task .markers[data-v-44e6c2a4] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-businessrule-task .markers .icon-ddei-flow[data-v-44e6c2a4] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-callactivity-task[data-v-ec0e7c21] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-callactivity-task .title[data-v-ec0e7c21] { height: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-callactivity-task .title .icon-ddei-flow[data-v-ec0e7c21] { position: absolute; left: 0px; top: 0px; width: 24px; height: 24px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-callactivity-task .title .text[data-v-ec0e7c21] { flex: 1; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-callactivity-task .view[data-v-ec0e7c21] { display: flex; justify-content: center; align-items: center; height: calc(100% - 20px); background-repeat: no-repeat; background-position: center; background-size: contain; } .ddei-flow-bpmn-viewer-callactivity-task .view .text[data-v-ec0e7c21] { flex: 1; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-callactivity-task .markers[data-v-ec0e7c21] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-callactivity-task .markers .icon-ddei-flow[data-v-ec0e7c21] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-chore-subprocess[data-v-8b8a1ced] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-chore-subprocess .content[data-v-8b8a1ced] { width: 100%; height: 100%; overflow: hidden; display: flex; flex-direction: column; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-chore-subprocess .content .text[data-v-8b8a1ced] { flex: 1; text-align: center; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-chore-subprocess .content .top[data-v-8b8a1ced] { flex: 0 0 20px; width: 100%; border-bottom: var(--borderWidth) var(--borderType) var(--borderColor); } .ddei-flow-bpmn-viewer-chore-subprocess .content .bottom[data-v-8b8a1ced] { flex: 0 0 20px; width: 100%; border-top: var(--borderWidth) var(--borderType) var(--borderColor); } .ddei-flow-bpmn-viewer-chore-subprocess .content .middle[data-v-8b8a1ced] { flex: 1; height: 100%; width: 100%; display: flex; justify-content: center; align-items: center; position: relative; } .ddei-flow-bpmn-viewer-chore-subprocess .content .middle-locked[data-v-8b8a1ced] { width: 12px; height: 12px; font-size: 12px; opacity: 0.5; right: 10px; top: 10px; position: absolute; color: var(--fontColor); } .ddei-flow-bpmn-viewer-chore-subprocess .content .middle .markers[data-v-8b8a1ced] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-chore-subprocess .content .middle .markers .icon-ddei-flow[data-v-8b8a1ced] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-chore-task[data-v-547a6caf] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-chore-task .content[data-v-547a6caf] { width: 100%; height: 100%; overflow: hidden; display: flex; flex-direction: column; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-chore-task .content .text[data-v-547a6caf] { flex: 1; text-align: center; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-chore-task .content .top[data-v-547a6caf] { flex: 0 0 20px; width: 100%; border-bottom: var(--borderWidth) var(--borderType) var(--borderColor); } .ddei-flow-bpmn-viewer-chore-task .content .bottom[data-v-547a6caf] { flex: 0 0 20px; width: 100%; border-top: var(--borderWidth) var(--borderType) var(--borderColor); } .ddei-flow-bpmn-viewer-chore-task .content .middle[data-v-547a6caf] { flex: 1; height: 100%; width: 100%; display: flex; justify-content: center; align-items: center; position: relative; } .ddei-flow-bpmn-viewer-chore-task .content .middle .markers[data-v-547a6caf] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-chore-task .content .middle .markers .icon-ddei-flow[data-v-547a6caf] { width: 16px; height: 16px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-complex-gateway[data-v-e6c1fdb1] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-complex-gateway .icon-ddei-flow[data-v-e6c1fdb1] { width: 100%; height: 100%; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-end-event[data-v-8f354e18] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-end-event .icon-ddei-flow[data-v-8f354e18] { margin-left: -3px; margin-top: -3px; width: calc(100% + 6px); height: calc(100% + 6px); fill: var(--borderColor); } .ddei-flow-bpmn-viewer-eventbased-gateway[data-v-6f4a01e3] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-eventbased-gateway .icon-ddei-flow[data-v-6f4a01e3] { width: 100%; height: 100%; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-exclusive-gateway[data-v-7986eca0] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-exclusive-gateway .icon-ddei-flow[data-v-7986eca0] { width: 100%; height: 100%; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-group[data-v-b5dc3b04] { position: absolute; font-size: 14px; pointer-events: none; user-select: none; display: none; color: black; font-family: var(--fontFamily); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-group .content-header-locked[data-v-b5dc3b04] { width: 12px; height: 12px; font-size: 12px; opacity: 0.5; color: var(--fontColor); position: absolute; right: 5px; top: 5px; } .ddei-flow-bpmn-viewer-group .border-svg[data-v-b5dc3b04] { position: absolute; left: 0; top: 0; width: 100%; height: 100%; } .ddei-flow-bpmn-viewer-group .border-svg rect[data-v-b5dc3b04] { fill: none; stroke: var(--borderColor); stroke-width: 2px; stroke-dasharray: 10,5,1,5; } .ddei-flow-bpmn-viewer-group .title[data-v-b5dc3b04] { font-size: 16px; height: 100%; display: flex; justify-content: center; align-items: center; overflow: hidden; padding: 0 5px; word-break: break-word; text-overflow: ellipsis; } .ddei-flow-bpmn-viewer-group .title-expand[data-v-b5dc3b04] { font-size: 16px; width: 100%; height: 24px; padding: 10px; display: flex; justify-content: center; align-items: center; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; } .ddei-flow-bpmn-viewer-inter-catch-event[data-v-e679db61] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-inter-catch-event .icon-ddei-flow[data-v-e679db61] { margin-left: -3px; margin-top: -3px; width: calc(100% + 6px); height: calc(100% + 6px); fill: var(--borderColor); } .ddei-flow-bpmn-viewer-inter-throw-event[data-v-c8fcaa16] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-inter-throw-event .icon-ddei-flow[data-v-c8fcaa16] { margin-left: -3px; margin-top: -3px; width: calc(100% + 6px); height: calc(100% + 6px); fill: var(--borderColor); } .ddei-flow-bpmn-viewer-manual-task[data-v-3083fc81] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-manual-task .title[data-v-3083fc81] { height: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-manual-task .title .icon-ddei-flow[data-v-3083fc81] { position: absolute; left: 0px; top: 0px; width: 24px; height: 24px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-manual-task .title .text[data-v-3083fc81] { flex: 1; text-align: center; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-manual-task .markers[data-v-3083fc81] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-manual-task .markers .icon-ddei-flow[data-v-3083fc81] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-message[data-v-58a6b5ba] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-message .icon-ddei-flow[data-v-58a6b5ba] { margin-top: -8px; margin-left: -8px; width: calc(100% + 16px); height: calc(100% + 16px); } .ddei-flow-bpmn-viewer-parallel-gateway[data-v-4d21627c] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-parallel-gateway .icon-ddei-flow[data-v-4d21627c] { width: 100%; height: 100%; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-receive-task[data-v-e2cb14b8] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-receive-task .title[data-v-e2cb14b8] { height: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-receive-task .title .icon-ddei-flow[data-v-e2cb14b8] { position: absolute; left: 0px; top: 0px; width: 24px; height: 24px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-receive-task .title .text[data-v-e2cb14b8] { flex: 1; text-align: center; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-receive-task .markers[data-v-e2cb14b8] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-receive-task .markers .icon-ddei-flow[data-v-e2cb14b8] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-script-task[data-v-10d59418] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-script-task .title[data-v-10d59418] { height: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-script-task .title .icon-ddei-flow[data-v-10d59418] { position: absolute; left: 0px; top: 0px; width: 24px; height: 24px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-script-task .title .text[data-v-10d59418] { flex: 1; text-align: center; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-script-task .markers[data-v-10d59418] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-script-task .markers .icon-ddei-flow[data-v-10d59418] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-send-task[data-v-451d2857] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-send-task .title[data-v-451d2857] { height: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-send-task .title .icon-ddei-flow[data-v-451d2857] { position: absolute; left: 0px; top: 0px; width: 24px; height: 24px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-send-task .title .text[data-v-451d2857] { flex: 1; text-align: center; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-send-task .markers[data-v-451d2857] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-send-task .markers .icon-ddei-flow[data-v-451d2857] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-sequence-flow-icon[data-v-f97bf8f3] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-sequence-flow-icon .icon-svg[data-v-f97bf8f3] { width: 100%; height: 100%; position: absolute; } .ddei-flow-bpmn-viewer-service-task[data-v-1f1f502d] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-service-task .title[data-v-1f1f502d] { height: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-service-task .title .icon-ddei-flow[data-v-1f1f502d] { position: absolute; left: 0px; top: 0px; width: 24px; height: 24px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-service-task .title .text[data-v-1f1f502d] { flex: 1; text-align: center; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-service-task .markers[data-v-1f1f502d] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-service-task .markers .icon-ddei-flow[data-v-1f1f502d] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-start-event[data-v-81a6686d] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-start-event .icon-ddei-flow[data-v-81a6686d] { margin-left: -3px; margin-top: -3px; width: calc(100% + 6px); height: calc(100% + 6px); fill: var(--borderColor); } .ddei-flow-bpmn-viewer-subprocess[data-v-9fa95600] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-subprocess-event[data-v-9fa95600] { border-style: dashed !important; } .ddei-flow-bpmn-viewer-subprocess-event .trans[data-v-9fa95600] { border-style: dashed !important; } .ddei-flow-bpmn-viewer-subprocess .trans[data-v-9fa95600] { width: calc(100% - 10px); height: calc(100% - 10px); position: absolute; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); left: 5px; top: 5px; } .ddei-flow-bpmn-viewer-subprocess .markers[data-v-9fa95600] { height: 24px; width: 100%; display: flex; justify-content: center; align-items: start; padding-top: 4px; } .ddei-flow-bpmn-viewer-subprocess .markers-transaction[data-v-9fa95600] { padding-top: 2px !important; } .ddei-flow-bpmn-viewer-subprocess .markers .icon-ddei-flow[data-v-9fa95600] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-subprocess .title[data-v-9fa95600] { font-size: 13px; height: calc(100% - 24px); width: 100%; display: flex; border-bottom: var(--borderWidth) var(--borderType) var(--borderColor); justify-content: center; align-items: center; overflow: hidden; padding: 0 2px; word-break: break-word; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-subprocess .title-transaction[data-v-9fa95600] { width: calc(100% - 10px) !important; margin-left: 5px !important; } .ddei-flow-bpmn-viewer-subprocess .content[data-v-9fa95600] { height: calc(100% - 24px); display: flex; justify-content: center; align-items: center; flex-direction: column; } .ddei-flow-bpmn-viewer-subprocess .content-header[data-v-9fa95600] { padding: 10px; flex: 0 0 30px; height: 20px; width: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-subprocess .content-header-title[data-v-9fa95600] { flex: 1; height: 20px; font-size: 12px; opacity: 0.5; overflow: hidden; word-break: break-word; text-overflow: ellipsis; text-align: left; color: var(--fontColor); font-family: var(--fontFamily); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-subprocess .content-header-locked[data-v-9fa95600] { flex: 0 0 12px; height: 12px; font-size: 12px; opacity: 0.5; color: var(--fontColor); } .ddei-flow-bpmn-viewer-subprocess .content-elements[data-v-9fa95600] { flex: 1; } .ddei-flow-bpmn-viewer-user-task[data-v-0b07ef9d] { background: var(--fillColor); position: absolute; color: var(--text); font-size: 14px; border: var(--borderWidth) var(--borderType) var(--borderColor); border-radius: var(--borderRound); pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-user-task .title[data-v-0b07ef9d] { height: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-user-task .title .icon-ddei-flow[data-v-0b07ef9d] { position: absolute; left: 0px; top: 0px; width: 24px; height: 24px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-user-task .title .text[data-v-0b07ef9d] { flex: 1; text-align: center; white-space: nowrap; padding: 2px; overflow: hidden; text-overflow: ellipsis; color: var(--fontColor); font-family: var(--fontFamily); font-size: var(--fontSize); font-style: var(--fontStyle); font-weight: var(--fontWeight); text-decoration: var(--textDecoration); } .ddei-flow-bpmn-viewer-user-task .markers[data-v-0b07ef9d] { position: absolute; left: 0px; bottom: 0px; width: 100%; height: 20px; display: flex; justify-content: center; align-items: center; } .ddei-flow-bpmn-viewer-user-task .markers .icon-ddei-flow[data-v-0b07ef9d] { width: 14px; height: 14px; fill: var(--borderColor); } .ddei-flow-bpmn-viewer-user[data-v-9e90d175] { position: absolute; pointer-events: none; user-select: none; display: none; } .ddei-flow-bpmn-viewer-user .icon-ddei-flow[data-v-9e90d175] { margin-left: -10px; margin-top: -13px; width: calc(100% + 20px); height: calc(100% + 28px); } .ddei-flow-element-setting-dialog[data-v-2d6bc3f8] { width: 200px; background: var(--panel-background); display: none; position: absolute; z-index: 99901; border: 1px solid var(--panel-border); box-shadow: 0px 2px 24px 0px hsla(0, 0%, 0%, 0.25); border-radius: 6px; color: black; } .ddei-flow-element-setting-dialog .content[data-v-2d6bc3f8] { width: 100%; height: 100%; overflow-y: auto; overflow-x: hidden; display: flex; flex-direction: column; justify-content: start; align-items: center; } .ddei-flow-element-setting-dialog .content .row[data-v-2d6bc3f8] { flex: 0 1 20px; margin: 0 5px; width: 100%; } .ddei-flow-element-setting-dialog .content .row[data-v-2d6bc3f8]:hover { background: #e6e4e4; cursor: pointer; } .ddei-flow-element-setting-dialog .content .row .icon-ddei-flow[data-v-2d6bc3f8] { opacity: 0.5; } .ddei-flow-element-setting-dialog .content .row .icon-ddei-flow[data-v-2d6bc3f8]:hover { opacity: 1; } .ddei-flow-element-setting-dialog .content .row .change-bpmn-sub-type[data-v-2d6bc3f8] { display: flex; justify-content: center; align-items: center; font-size: 12px; height: 20px; } .ddei-flow-element-setting-dialog .content .row .change-bpmn-sub-type-text[data-v-2d6bc3f8] { flex: 1; text-wrap: nowrap; } .ddei-flow-element-setting-dialog .content .row .change-bpmn-sub-type .icon-ddei-flow[data-v-2d6bc3f8] { flex: 0 0 12px; margin: 0 10px; } .ddei-flow-element-setting-dialog .content .row .change-bpmn-marker[data-v-2d6bc3f8] { font-size: 12px; height: 20px; width: 150px; margin-left: 18px; } .ddei-flow-element-setting-dialog .content .row .change-bpmn-marker .chk_state[data-v-2d6bc3f8] { border: 1px solid var(--panel-title); width: 12px; height: 12px; margin-top: 4px; float: left; box-sizing: border-box; background: var(--panel-background); } .ddei-flow-element-setting-dialog .content .row .change-bpmn-marker .chk_state_checked[data-v-2d6bc3f8] { border: 1px solid var(--panel-title); width: 12px; height: 12px; margin-top: 4px; float: left; background-color: var(--dot); box-sizing: border-box; color: #fff; } .ddei-flow-element-setting-dialog .content .row .change-bpmn-marker .chk_state_checked span[data-v-2d6bc3f8] { margin-top: -3.5px; margin-left: 0.5px; display: block; font-size: 11px; } .ddei-flow-element-setting-dialog .content .row .quick-button[data-v-2d6bc3f8] { height: 20px; width: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-element-setting-dialog .content .row .quick-button .icon[data-v-2d6bc3f8] { width: 14px; height: 14px; opacity: 0.5; } .ddei-flow-element-setting-dialog .content .row .quick-button .icon[data-v-2d6bc3f8]:hover { opacity: 1; } .ddei-flow-element-setting-dialog .content .row .quick-button-text[data-v-2d6bc3f8] { margin-right: 5px; color: black; font-size: 12px; } .ddei-flow-element-setting-dialog .content .row .change-point-type[data-v-2d6bc3f8] { height: 20px; width: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-element-setting-dialog .content .row .change-point-type .icon-ddei-flow[data-v-2d6bc3f8] { width: 14px; height: 14px; } .ddei-flow-element-setting-dialog .content .row .change-point-type-title[data-v-2d6bc3f8] { margin-right: 5px; color: black; font-size: 12px; } .ddei-flow-element-setting-dialog .content .row .change-point-type-text[data-v-2d6bc3f8] { color: black; font-size: 12px; } .ddei-flow-element-setting-dialog .content .row .change-property-text[data-v-2d6bc3f8] { height: 20px; width: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-element-setting-dialog .content .row .change-property-text-title[data-v-2d6bc3f8] { flex: 0 0 40px; color: black; font-size: 12px; } .ddei-flow-element-setting-dialog .content .row .change-property-text-input[data-v-2d6bc3f8] { flex: 1; color: black; font-size: 12px; text-align: left; } .ddei-flow-element-setting-dialog .content .row .change-property-text-input input[data-v-2d6bc3f8] { width: 95%; height: 18px; background: white; color: black; } .ddei-flow-element-setting-dialog .content .row .change-property-text-input input[data-v-2d6bc3f8]::placeholder { color: grey; } .ddei-flow-element-setting-dialog .content .row .change-property-textarea[data-v-2d6bc3f8] { height: 60px; width: 100%; display: flex; justify-content: center; align-items: center; } .ddei-flow-element-setting-dialog .content .row .change-property-textarea-title[data-v-2d6bc3f8] { flex: 0 0 40px; color: black; font-size: 12px; } .ddei-flow-element-setting-dialog .content .row .change-property-textarea-input[data-v-2d6bc3f8] { flex: 1; color: black; font-size: 12px; text-align: left; } .ddei-flow-element-setting-dialog .content .row .change-property-textarea-input textarea[data-v-2d6bc3f8] { background: white; color: black; width: 95%; height: 55px; } .ddei-flow-element-setting-dialog .content .row .change-property-textarea-input textarea[data-v-2d6bc3f8]::placeholder { color: grey; } .ddei-flow-setting-button-dialog[data-v-09abda49] { display: none; position: absolute; z-index: 99900; } .ddei-flow-setting-button-dialog .content[data-v-09abda49] { width: 100%; height: 100%; display: flex; justify-content: start; align-items: center; } .ddei-flow-setting-button-dialog .content .icon-ddei-flow[data-v-09abda49] { width: 11px; height: 11px; opacity: 0.5; margin-bottom: 2px; margin-right: 2px; } .ddei-flow-setting-button-dialog .content .icon-ddei-flow[data-v-09abda49]:hover { opacity: 1; cursor: pointer; } `; document.head.appendChild(__vite_style__); const en_US = { ddei: { flow: { startevent: "Start", endevent: "End", boundaryevent: "Bound", intermediatecatchevent: "InCatch", intermediatethrowevent: "InThrow", time: "Time", timeduration: "During", timecron: "CRON", errorcode: "ECode", condition: "Cond", conditionexpress: "Cond Express", startnode: "Start", exchange: "Exchange", endnode: "End", overview: "Overview", unlimited: "Unlimited", ordering: "Ordering", loop: "Loop", message: "Message", messagename: "Message Name", signal: "Signal", signalname: "Signal Name", multiins: "Multi Instance", insnum: "InsNum", parallel: "Parallel", notInterrupting: "No Interrupt", compensation: "Compensation", datacoll: "Data Collection", busicls: "Class", dataobj: "DataObj", datastore: "DataStore", user: "User", complexgateway: "Complex", parallelgateway: "Parallel", exclusivegateway: "Exclusive", inclusivegateway: "Inclusive", eventbasedgateway: "Event", group: "Group", sequence: "Sequence", task: "Task", usertask: "User", servicetask: "Service", sendtask: "Send", scripttask: "Script", receivetask: "Receive", manualtask: "Manual", choretask: "Chore", subprocess: "SubProc", eventsubprocess: "Event SubProcess", transsubprocess: "Transaction", choresubprocess: "ChoreProc", calltask: "Call", busitask: "BusiRule", loading: "Loading", property: { notInterrupting: "No Interrupt", dataType: "DataType", capacity: "Capacity", language: "Script Language", script: "Script", humanperformer: "Performer", potentialowner: "Potential", sender: "Sender", receiver: "Receiver", custom: "Custom", ds: { timedate: "TimeDate", timeduration: "Duration", timecron: "CRON", timer: "Timer", message: "Message", signal: "Signal", link: "Link", parallel: "Parallel", multiple: "Multiple", compensation: "Compensation", default: "Default", error: "Error", escalation: "Escalation", condition: "Condition", defaultcondition: "Default Condition", association: "Association", cancel: "Cancel", stop: "Stop", input: "Input", output: "Output", string: "String", integer: "Integer", long: "Long", float: "Float", double: "Double", boolean: "Boolean", datetime: "DateTime", custom: "Custom", noninit: "Non-Init", event: "Event", transaction: "Transaction" } }, groups: { bpmn: "BPMN", bpmndesc: "The process shape defined by the BPMN standard is used to draw standard workflows such as Activiti and JBPM" } } } }; const __vite_glob_0_0$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: en_US }, Symbol.toStringTag, { value: "Module" })); const zh_CN = { ddei: { flow: { startevent: "开始事件", endevent: "结束事件", boundaryevent: "边界事件", intermediatecatchevent: "中间捕获", intermediatethrowevent: "中间抛出", time: "时间", timeduration: "周期", timecron: "CRON", errorcode: "错误码", condition: "条件", conditionexpress: "条件表达式", startnode: "起点", exchange: "交换", endnode: "终点", overview: "预览", unlimited: "无限容量", ordering: "顺序执行", loop: "循环", message: "消息", messagename: "消息名称", signal: "信号", signalname: "信号名称", multiins: "多实例", insnum: "实例数", parallel: "并行", notInterrupting: "非中断", compensation: "补偿", datacoll: "数据集合", busicls: "业务类", dataobj: "数据对象", datastore: "数据存储", user: "用户", complexgateway: "复杂网关", parallelgateway: "并行网关", exclusivegateway: "排他网关", inclusivegateway: "包容网关", eventbasedgateway: "事件网关", group: "分组", sequence: "控制流", task: "任务", usertask: "用户任务", servicetask: "服务任务", sendtask: "发送任务", scripttask: "脚本任务", receivetask: "接收任务", manualtask: "手工任务", choretask: "编排任务", subprocess: "子流程", eventsubprocess: "事件子流程", transsubprocess: "事务子流程", choresubprocess: "编排子流程", calltask: "调用", busitask: "业务规则", loading: "加载中", escalation: "升级", escalname: "事件", property: { notInterrupting: "非中断", dataType: "数据类型", capacity: "容量", language: "语言", script: "脚本", humanperformer: "执行人", potentialowner: "候选人", sender: "发送人", receiver: "接收人", custom: "自定义", ds: { timer: "定时器", timedate: "固定时间", timeduration: "周期执行", timecron: "CRON", message: "消息", signal: "信号", link: "链接", parallel: "并行", multiple: "多次", compensation: "补偿", default: "默认", error: "错误", escalation: "升级", condition: "条件", defaultcondition: "缺省条件", association: "协会", cancel: "取消", stop: "终止", input: "输入", output: "输出", string: "字符串", integer: "整数", long: "长整数", float: "单精度", double: "双精度", boolean: "布尔", datetime: "时间", custom: "自定义", noninit: "未初始化", event: "事件", transaction: "事务" } }, groups: { bpmn: "BPMN", bpmndesc: "BPMN标准定义的流程形状,用于绘制标准的Activiti、JBPM等工作流" } } } }; const __vite_glob_0_1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: zh_CN }, Symbol.toStringTag, { value: "Module" })); const iconfont = ""; window._iconfont_svg_string_4654254 = '', ((c) => { var h = (v = (v = document.getElementsByTagName("script"))[v.length - 1]).getAttribute("data-injectcss"), v = v.getAttribute("data-disable-injectsvg"); if (!v) { var l, a, m, z, o, s = function(h2, v2) { v2.parentNode.insertBefore(h2, v2); }; if (h && !c.__iconfont__svg__cssinject__) { c.__iconfont__svg__cssinject__ = true; try { document.write(""); } catch (h2) { console && console.log(h2); } } l = function() { var h2, v2 = document.createElement("div"); v2.innerHTML = c._iconfont_svg_string_4654254, (v2 = v2.getElementsByTagName("svg")[0]) && (v2.setAttribute("aria-hidden", "true"), v2.style.position = "absolute", v2.style.width = 0, v2.style.height = 0, v2.style.overflow = "hidden", v2 = v2, (h2 = document.body).firstChild ? s(v2, h2.firstChild) : h2.appendChild(v2)); }, document.addEventListener ? ~["complete", "loaded", "interactive"].indexOf(document.readyState) ? setTimeout(l, 0) : (a = function() { document.removeEventListener("DOMContentLoaded", a, false), l(); }, document.addEventListener("DOMContentLoaded", a, false)) : document.attachEvent && (m = l, z = c.document, o = false, t(), z.onreadystatechange = function() { "complete" == z.readyState && (z.onreadystatechange = null, e()); }); } function e() { o || (o = true, m()); } function t() { try { z.documentElement.doScroll("left"); } catch (h2) { return void setTimeout(t, 50); } e(); } })(window); const _sfc_main$q = { name: "ddei-flow-bpmn-viewer-inclusive-gateway", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnInclusiveGatewayViewer_vue_vue_type_style_index_0_scoped_aa8661cf_lang = ""; const _export_sfc = (sfc, props) => { const target = sfc.__vccOpts || sfc; for (const [key, val] of props) { target[key] = val; } return target; }; const _hoisted_1$q = { ref: "divElement", class: "ddei-flow-bpmn-viewer-inclusive-gateway", title: "包容网关" }; function _sfc_render$q(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$q, _cache[0] || (_cache[0] = [ vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-gateway-or" }) ], -1) ]), 512); } const BpmnInclusiveGatewayViewer = /* @__PURE__ */ _export_sfc(_sfc_main$q, [["render", _sfc_render$q], ["__scopeId", "data-v-aa8661cf"]]); const InclusiveGateway = { id: "1000203", name: "ddei.flow.inclusivegateway", code: "inclusive_gateway", desc: "bpmn中的InclusiveGateway", from: "100040", subject: "bpmn", define: { width: 50, height: 50, bpmnBaseType: "Gateway", bpmnType: "InclusiveGateway", ext: { sample: { eqrat: true }, attrs: [ { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, viewer: BpmnInclusiveGatewayViewer, icon: `` }; const __vite_glob_0_0 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: InclusiveGateway }, Symbol.toStringTag, { value: "Module" })); const showSettingButton = function(operate, data2, ddInstance, evt) { var _a; let rs = new ddeiEditor.DDeiFuncCallResult(); rs.state = 2; let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); if (editor) { let model = data2.model; if (((_a = editor.ddInstance.stage.selectedModels) == null ? void 0 : _a.size) > 0) { if (!editor.ddInstance.stage.selectedModels.has(model.id)) { if (editor.ddInstance.stage.selectedModels.size == 1) { model = Array.from(editor.ddInstance.stage.selectedModels.values())[0]; } else { return rs; } } } editor.tempOperateModel = model; let stageRatio = model.getStageRatio(); let modelPos = ddeiEditor.DDeiUtil.getModelsDomAbsPosition([model]); let editorEle = document.getElementById(editor.id); let editorPos = ddeiEditor.DDeiUtil.getDomAbsPosition(editorEle); let left = modelPos.left + modelPos.width + 6.5 * (stageRatio - 1) - editorPos.left; let top = modelPos.top + 6.5 * (stageRatio - 1) - editorPos.top; if (model.bpmnBaseType == "Event") { left = modelPos.left + modelPos.width + 12 * (stageRatio - 1) - editorPos.left; } let settingBtnEle = document.getElementById(editor.id + "_ddei-flow-setting-button-dialog"); if (!settingBtnEle || settingBtnEle.style.display == "none" || editor.tempPopData && editor.tempPopData["ddei-flow-setting-button-dialog"] && editor.tempPopData["ddei-flow-setting-button-dialog"].model != model) { ddeiEditor.DDeiEditorUtil.showDialog(editor, "ddei-flow-setting-button-dialog", { group: "ddei-flow-setting-button", model }, { type: 99, left, top, hiddenMask: true }, null, true, true); } ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-element-setting-dialog"); } return rs; }; const changeSettingButtonPos = function(operate, data2, ddInstance, evt) { var _a; let rs = new ddeiEditor.DDeiFuncCallResult(); rs.state = 2; let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); if (editor) { let model = data2.model; if (((_a = editor.ddInstance.stage.selectedModels) == null ? void 0 : _a.size) > 0) { if (!editor.ddInstance.stage.selectedModels.has(model.id)) { if (editor.ddInstance.stage.selectedModels.size == 1) { model = Array.from(editor.ddInstance.stage.selectedModels.values())[0]; } else { return rs; } } } let stageRatio = model.getStageRatio(); let modelPos = ddeiEditor.DDeiUtil.getModelsDomAbsPosition([model]); let editorEle = document.getElementById(editor.id); let editorPos = ddeiEditor.DDeiUtil.getDomAbsPosition(editorEle); let left = modelPos.left + modelPos.width + 6.5 * (stageRatio - 1) - editorPos.left; let top = modelPos.top + 6.5 * (stageRatio - 1) - editorPos.top; if (model.bpmnBaseType == "Event") { left = modelPos.left + modelPos.width + 12 * (stageRatio - 1) - editorPos.left; } let settingBtnEle = document.getElementById(editor.id + "_ddei-flow-setting-button-dialog"); if (settingBtnEle) { ddeiEditor.DDeiEditorUtil.displayDialog(editor, "ddei-flow-setting-button-dialog", { group: "ddei-flow-setting-button", model }, { type: 99, left, top, hiddenMask: true }, null, true, true); } ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-element-setting-dialog"); } return rs; }; const getIncludeModels = function(subProcessModel, modelLinks, first = true) { if (!modelLinks) { modelLinks = []; } let stage = subProcessModel.stage; let models = []; if (subProcessModel.allowIncludeModel) { if (!subProcessModel.includeModels) { subProcessModel.includeModels = []; } else { subProcessModel.includeModels.forEach((subModelId) => { if (subProcessModel.isShadowControl) { subModelId += "_shadow"; } let subModel = stage.getModelById(subModelId); if (subModel) { models.push(subModel); if (subModel.allowIncludeModel) { let mds = getIncludeModels(subModel, modelLinks, false); models.push(...mds); } } }); } } if (subProcessModel.bpmnBaseType == "Activity") { if (!subProcessModel.attachModels) { subProcessModel.attachModels = []; } else { subProcessModel.attachModels.forEach((subModelId) => { if (subProcessModel.isShadowControl) { subModelId += "_shadow"; } let subModel = stage.getModelById(subModelId); if (subModel) { models.push(subModel); } }); } } return models; }; const getParentModels = function(model) { let returnArray = []; if (model == null ? void 0 : model.includePModelId) { let stage = model.stage; let pModel = stage.getModelById(model.includePModelId); returnArray.push(pModel); let pModels = getParentModels(pModel); returnArray.push(...pModels); } return returnArray; }; const updateCallActivityView = function(stage, layer, dragParentActiveIds) { let pModels = /* @__PURE__ */ new Map(); dragParentActiveIds.forEach((parentActId) => { let pModel = stage.getModelById(parentActId); pModels.set(pModel.id, pModel); let pModelList = getParentModels(pModel); pModelList.forEach((pm) => { pModels.set(pm.id, pm); }); }); let subModels = layer.getSubModels(null, 20); subModels.forEach((sm) => { if (sm.bpmnType == "CallActivityTask" && pModels.has(sm.upActivityId)) { delete sm.upActivityId; } }); }; const lineObiCheck = function(model, param) { let line = param.line; if (model) { let ignoreCodes = ["1000501", "1000506", "1000507", "1000505", "1000504"]; if (ignoreCodes.indexOf(model.modelCode) != -1 || model.depModel && ignoreCodes.indexOf(model.depModel.modelCode)) { return false; } } if (line) { let distLinks = line.stage.getDistModelLinks(line.id); if (distLinks) { let len = distLinks.length; let includeModels = getIncludeModels(model); for (let i = 0; i < len; i++) { if (!distLinks[i].disabled) { if (distLinks[i].sm == model) { return true; } else if (includeModels.indexOf(distLinks[i].sm) != -1) { return false; } } } if (model.includePModelId) { let parentModels = getParentModels(model); for (let i = 0; i < len; i++) { if (!distLinks[i].disabled && parentModels.indexOf(distLinks[i].sm) != -1) { return false; } } } } } else { let otherModel = param.model; if (otherModel) { let subprocessIncludeModels = getIncludeModels(otherModel); if (subprocessIncludeModels.indexOf(model) != -1) { return false; } if (model.attachPModel == otherModel.id || model.id == otherModel.attachPModel) { return false; } } } return true; }; const _sfc_main$p = { name: "ddei-flow-bpmn-viewer-boundary-event", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnBoundaryEventViewer_vue_vue_type_style_index_0_scoped_7f22a8f2_lang = ""; const _hoisted_1$p = { ref: "divElement", class: "ddei-flow-bpmn-viewer-boundary-event", title: "边界事件" }; const _hoisted_2$k = { class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_3$j = { key: 0, "xlink:href": "#icon-ddei-flow-boundary-event-message" }; const _hoisted_4$i = { key: 1, "xlink:href": "#icon-ddei-flow-boundary-event-message-inte" }; const _hoisted_5$g = { key: 2, "xlink:href": "#icon-ddei-flow-boundary-event-time" }; const _hoisted_6$g = { key: 3, "xlink:href": "#icon-ddei-flow-boundary-event-time-inte" }; const _hoisted_7$g = { key: 4, "xlink:href": "#icon-ddei-flow-boundary-event-signal" }; const _hoisted_8$g = { key: 5, "xlink:href": "#icon-ddei-flow-boundary-event-error" }; const _hoisted_9$8 = { key: 6, "xlink:href": "#icon-ddei-flow-boundary-event-compensation" }; const _hoisted_10$6 = { key: 7, "xlink:href": "#icon-ddei-flow-boundary-event-cancel" }; const _hoisted_11$5 = { key: 8, "xlink:href": "#icon-ddei-flow-intermediate-event-c1" }; const _hoisted_12$4 = { key: 9, "xlink:href": "#icon-ddei-flow-intermediate-event-c12" }; const _hoisted_13$4 = { key: 10, "xlink:href": "#icon-ddei-flow-intermediate-event-c7" }; const _hoisted_14$3 = { key: 11, "xlink:href": "#icon-ddei-flow-intermediate-event-c14" }; const _hoisted_15$3 = { key: 12, "xlink:href": "#icon-ddei-flow-intermediate-event-c3" }; const _hoisted_16$2 = { key: 13, "xlink:href": "#icon-ddei-flow-intermediate-event-c11" }; function _sfc_render$p(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$p, [ (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$k, [ (!$props.model.bpmnSubType || $props.model.bpmnSubType == 1) && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_3$j)) : vue.createCommentVNode("", true), (!$props.model.bpmnSubType || $props.model.bpmnSubType == 1) && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_4$i)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 2 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_5$g)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 2 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_6$g)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 3 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_7$g)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 4 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_8$g)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 5 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_9$8)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 6 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_10$6)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 7 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_11$5)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 7 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_12$4)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 8 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_13$4)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 8 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_14$3)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 9 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_15$3)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 9 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_16$2)) : vue.createCommentVNode("", true) ])) ], 512); } const BpmnBoundaryEventViewer = /* @__PURE__ */ _export_sfc(_sfc_main$p, [["render", _sfc_render$p], ["__scopeId", "data-v-7f22a8f2"]]); const boundaryEvent = { "id": "1000004", "name": "ddei.flow.boundaryevent", "code": "boundaryevent", "desc": "bpmn中的BoundaryEvent", "from": "1000001", subject: "bpmn", "define": { width: 40, height: 40, bpmnBaseType: "Event", bpmnSubType: 1, bpmnType: "BoundaryEvent", ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "编码,一般用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "boundaryevent", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称,一般用于显示", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.boundaryevent", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "bpmnSubType", "name": "ddei.type", "desc": "子类型,用于区分中间节点的不同作用", "controlType": "combox", "dataType": "integer", "dataSource": [ { "text": "ddei.flow.property.ds.message", "value": 1 }, { "text": "ddei.flow.property.ds.timer", "value": 2 }, { "text": "ddei.flow.property.ds.signal", "value": 3 }, { "text": "ddei.flow.property.ds.error", "value": 4 }, { "text": "ddei.flow.property.ds.compensation", "value": 5 }, { "text": "ddei.flow.property.ds.cancel", "value": 6 }, { "text": "ddei.flow.property.ds.escalation", "value": 7 }, { "text": "ddei.flow.property.ds.parallel", "value": 8 }, { "text": "ddei.flow.property.ds.multiple", "value": 9 } ], "itemStyle": { width: 130, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "notInterrupting", "text": "ddei.flow.property.notInterrupting", "desc": "非中断将不会终止运行,默认中断", "controlType": "switch-checkbox", "dataType": "integer", "display": "column", "hiddenTitle": true, "defaultValue": 0, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.boundaryevent", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnBoundaryEventViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: boundaryEvent }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$o = { name: "ddei-flow-bpmn-viewer-businessrule-task", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; } else { this.$refs["divElement"].style.borderColor = ""; } } } }; const bpmnBusinessruleTaskViewer_vue_vue_type_style_index_0_scoped_44e6c2a4_lang = ""; const _hoisted_1$o = { ref: "divElement", class: "ddei-flow-bpmn-viewer-businessrule-task" }; const _hoisted_2$j = { class: "title" }; const _hoisted_3$i = { class: "text" }; const _hoisted_4$h = { class: "markers" }; const _hoisted_5$f = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_6$f = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_7$f = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_8$f = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; function _sfc_render$o(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$o, [ vue.createElementVNode("div", _hoisted_2$j, [ _cache[0] || (_cache[0] = vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-business-rule" }) ], -1)), vue.createElementVNode("div", _hoisted_3$i, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : "ddei.flow.busitask")), 1) ]), vue.createElementVNode("div", _hoisted_4$h, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_5$f, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_6$f, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$f, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$f, _cache[4] || (_cache[4] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ], 512); } const BpmnBusinessRuleTaskViewer = /* @__PURE__ */ _export_sfc(_sfc_main$o, [["render", _sfc_render$o], ["__scopeId", "data-v-44e6c2a4"]]); const businessruleTask = { id: "1000071", name: "ddei.flow.busitask", code: "busisrule_task", desc: "bpmn中的BusinessRuleTask", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "BusinessTask", width: 110, height: 70, border: { round: 5 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "busirule_task", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.busitask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.busitask", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnBusinessRuleTaskViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_2 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: businessruleTask }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$n = { name: "ddei-flow-bpmn-viewer-callactivity-task", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, methods: { refreshView(model, vNode, tempShape, composeRender) { if (this.model.activityId) { if (this.model.upActivityId != this.model.activityId) { this.model.upActivityId = this.model.activityId; let viewModel = this.model.stage.getModelById(this.model.activityId); if (viewModel) { viewModel = this.getCallActivityTask(viewModel); if (this.model.displayView) { this.$refs["viewDiv"].innerHTML = this.editor.i18n("ddei.flow.loading"); setTimeout(() => { this.editor.flow.toImage([viewModel]).then((html) => { if (html) { this.$refs["viewDiv"].innerHTML = ""; this.$refs["viewDiv"].style.backgroundImage = "url(" + html + ")"; } }); }, 30); } else { this.$refs["viewDiv"].style.backgroundImage = ""; this.$refs["viewDiv"].innerHTML = "
" + (viewModel.name ? viewModel.name : viewModel.code ? viewModel.code : viewModel.id) + "
"; } } } } }, getCallActivityTask(model) { if (model.bpmnType == "CallActivityTask") { if (model.activityId) { let viewModel = this.model.stage.getModelById(model.activityId); if (viewModel) { model = this.getCallActivityTask(viewModel); } } } return model; }, refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; } else { this.$refs["divElement"].style.borderColor = ""; } } } }; const bpmnCallactivityTaskViewer_vue_vue_type_style_index_0_scoped_ec0e7c21_lang = ""; const _hoisted_1$n = { ref: "divElement", class: "ddei-flow-bpmn-viewer-callactivity-task" }; const _hoisted_2$i = { key: 0, class: "title" }; const _hoisted_3$h = { class: "text" }; const _hoisted_4$g = { key: 1, ref: "viewDiv", class: "view" }; const _hoisted_5$e = { class: "markers" }; const _hoisted_6$e = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_7$e = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_8$e = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_9$7 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; function _sfc_render$n(_ctx, _cache, $props, $setup, $data, $options) { var _a; return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$n, [ !$props.model || !$props.model.activityId ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2$i, [ vue.createElementVNode("div", _hoisted_3$h, vue.toDisplayString($props.editor.i18n("ddei.flow.calltask")), 1) ])) : vue.createCommentVNode("", true), ((_a = $props.model) == null ? void 0 : _a.activityId) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_4$g, null, 512)) : vue.createCommentVNode("", true), vue.createElementVNode("div", _hoisted_5$e, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_6$e, _cache[0] || (_cache[0] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$e, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$e, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_9$7, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ], 512); } const BpmnCallActivityTaskViewer = /* @__PURE__ */ _export_sfc(_sfc_main$n, [["render", _sfc_render$n], ["__scopeId", "data-v-ec0e7c21"]]); const callactivityTask = { id: "1000081", name: "ddei.flow.calltask", code: "call", desc: "bpmn中的CallaAtivityTask", from: "100002", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "CallActivityTask", width: 130, height: 80, border: { round: 5 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "call", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "调用", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.calltask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" }, { "code": "borderWidth", "name": "ddei.property.width", "desc": "图形的边框的粗细,0为无边框", "controlType": "range", "min": 0, "max": 10, "step": 0.1, "mapping": ["border.width"], "dataType": "integer", "defaultValue": 5 }, { "code": "borderRound", "name": "ddei.property.round", "desc": "图形的边框的是否为为圆角的弧度", "controlType": "range", "mapping": ["border.round"], "min": 0, "max": 30, "step": 1, "defaultValue": 5, "dataType": "integer" }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.calltask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ], groups: [ { "name": "ddei.data", icon: "icon-a-ziyuan409", subGroups: [ { "name": "ddei.basic", attrs: ["code", "name", "desc"] } ] } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnCallActivityTaskViewer, icon: `` }; const __vite_glob_0_3 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: callactivityTask }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$m = { name: "ddei-flow-bpmn-viewer-chore-subprocess", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, data() { return { topUsers: null, bottomUsers: null }; }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["content"].style.border = "1px solid green"; } else { this.$refs["content"].style.border = ""; } }, isInRect(model) { let contentElement = this.$refs["content"]; let contentPos = ddeiEditor.DDeiUtil.getDomAbsPosition(contentElement, this.editor); let pvs = model.operatePVS; let stage = model.stage; contentPos.left -= stage.wpv.x; contentPos.top -= stage.wpv.y; for (let i = 0; i < pvs.length; i++) { let p = pvs[i]; if (contentPos.left <= p.x && contentPos.left + contentElement.clientWidth >= p.x && contentPos.top <= p.y && contentPos.top + contentElement.clientHeight >= p.y) { return true; } } return false; }, refreshView() { if (this.model.topUser) { let users = this.model.topUser.split(","); let topUsers = []; users == null ? void 0 : users.forEach((user2) => { if (user2) { topUsers.push({ name: user2 }); } }); this.topUsers = topUsers; } if (this.model.bottomUser) { let users = this.model.bottomUser.split(","); let bottomUsers = []; users == null ? void 0 : users.forEach((user2) => { if (user2) { bottomUsers.push({ name: user2 }); } }); this.bottomUsers = bottomUsers; } } } }; const bpmnChoreSubprocessViewer_vue_vue_type_style_index_0_scoped_8b8a1ced_lang = ""; const _hoisted_1$m = { ref: "divElement", class: "ddei-flow-bpmn-viewer-chore-subprocess" }; const _hoisted_2$h = { class: "content" }; const _hoisted_3$g = { class: "top" }; const _hoisted_4$f = { class: "text" }; const _hoisted_5$d = { class: "middle", ref: "content" }; const _hoisted_6$d = { key: 0, class: "text" }; const _hoisted_7$d = { key: 1, class: "icon-ddei-flow middle-locked", "aria-hidden": "true" }; const _hoisted_8$d = { class: "markers" }; const _hoisted_9$6 = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_10$5 = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_11$4 = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_12$3 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_13$3 = { key: 4, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_14$2 = { class: "bottom" }; const _hoisted_15$2 = { class: "text" }; function _sfc_render$m(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$m, [ vue.createElementVNode("div", _hoisted_2$h, [ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.topUsers, (user2) => { return vue.openBlock(), vue.createElementBlock("div", _hoisted_3$g, [ vue.createElementVNode("div", _hoisted_4$f, vue.toDisplayString(user2.name), 1) ]); }), 256)), vue.createElementVNode("div", _hoisted_5$d, [ !$props.model.isExpand ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6$d, vue.toDisplayString($props.model.name ? $props.model.name : "编排子流程"), 1)) : vue.createCommentVNode("", true), $props.model.lock == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$d, _cache[0] || (_cache[0] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-lock" }, null, -1) ]))) : vue.createCommentVNode("", true), vue.createElementVNode("div", _hoisted_8$d, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_9$6, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_10$5, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_11$4, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_12$3, _cache[4] || (_cache[4] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), _cache[6] || (_cache[6] = vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sub-process-marker" }) ], -1)), $props.model.isAdHoc == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_13$3, _cache[5] || (_cache[5] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-ad-hoc-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ], 512), (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.bottomUsers, (user2) => { return vue.openBlock(), vue.createElementBlock("div", _hoisted_14$2, [ vue.createElementVNode("div", _hoisted_15$2, vue.toDisplayString(user2.name), 1) ]); }), 256)) ]) ], 512); } const BpmnChoreSubProcessViewer = /* @__PURE__ */ _export_sfc(_sfc_main$m, [["render", _sfc_render$m], ["__scopeId", "data-v-8b8a1ced"]]); const choreographySubprocess = { id: "1000102", name: "ddei.flow.choresubprocess", code: "chor_subprocess", desc: "bpmn中的ChoreographySubProcess", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "ChoreographySubProcess", allowIncludeModel: 1, width: 300, height: 240, otherWidth: 120, otherHeight: 130, isExpand: 1, border: { round: 5 }, topUser: "ddei.flow.property.sender", bottomUser: "ddei.flow.property.receiver", ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "chor_subprocess", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.choresubprocess", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "isAdHoc", "name": "ddei.flow.property.custom", "desc": "是否为自定义流程", "controlType": "switch-checkbox", "dataType": "integer", "display": "column", "hiddenTitle": true, "defaultValue": 0, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.choresubprocess", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnChoreSubProcessViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_4 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: choreographySubprocess }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$l = { name: "ddei-flow-bpmn-viewer-chore-task", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, data() { return { topUsers: null, bottomUsers: null }; }, methods: { refreshView() { if (this.model.topUser) { let users = this.model.topUser.split(","); let topUsers = []; users == null ? void 0 : users.forEach((user2) => { if (user2) { topUsers.push({ name: user2 }); } }); this.topUsers = topUsers; } if (this.model.bottomUser) { let users = this.model.bottomUser.split(","); let bottomUsers = []; users == null ? void 0 : users.forEach((user2) => { if (user2) { bottomUsers.push({ name: user2 }); } }); this.bottomUsers = bottomUsers; } }, refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; } else { this.$refs["divElement"].style.borderColor = ""; } } } }; const bpmnChoreTaskViewer_vue_vue_type_style_index_0_scoped_547a6caf_lang = ""; const _hoisted_1$l = { ref: "divElement", class: "ddei-flow-bpmn-viewer-chore-task" }; const _hoisted_2$g = { class: "content" }; const _hoisted_3$f = { class: "top" }; const _hoisted_4$e = { class: "text" }; const _hoisted_5$c = { class: "middle" }; const _hoisted_6$c = { class: "text" }; const _hoisted_7$c = { class: "markers" }; const _hoisted_8$c = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_9$5 = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_10$4 = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_11$3 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_12$2 = { class: "bottom" }; const _hoisted_13$2 = { class: "text" }; function _sfc_render$l(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$l, [ vue.createElementVNode("div", _hoisted_2$g, [ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.topUsers, (user2) => { return vue.openBlock(), vue.createElementBlock("div", _hoisted_3$f, [ vue.createElementVNode("div", _hoisted_4$e, vue.toDisplayString(user2.name), 1) ]); }), 256)), vue.createElementVNode("div", _hoisted_5$c, [ vue.createElementVNode("div", _hoisted_6$c, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : "ddei.flow.choretask")), 1), vue.createElementVNode("div", _hoisted_7$c, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$c, _cache[0] || (_cache[0] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_9$5, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_10$4, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_11$3, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ]), (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList($data.bottomUsers, (user2) => { return vue.openBlock(), vue.createElementBlock("div", _hoisted_12$2, [ vue.createElementVNode("div", _hoisted_13$2, vue.toDisplayString(user2.name), 1) ]); }), 256)) ]) ], 512); } const BpmnChoreTaskViewer = /* @__PURE__ */ _export_sfc(_sfc_main$l, [["render", _sfc_render$l], ["__scopeId", "data-v-547a6caf"]]); const choreographyTask = { id: "1000101", name: "ddei.flow.choretask", code: "chor_task", desc: "bpmn中的ChoreographyTask", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "ChoreographyTask", width: 120, height: 130, border: { round: 5 }, topUser: "ddei.flow.property.sender", bottomUser: "ddei.flow.property.receiver", ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "chor_task", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.choretask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.choretask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnChoreTaskViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_5 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: choreographyTask }, Symbol.toStringTag, { value: "Module" })); const comment = { id: "1000701", name: "ddei.control.comment", code: "comment", desc: "bpmn中的注释", from: "103008", subject: "bpmn", define: { width: 110, height: 70, bpmnBaseType: "Comment", bpmnType: "Comment", text: "ddei.control.comment" }, icon: `` }; const __vite_glob_0_6 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: comment }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$k = { name: "ddei-flow-bpmn-viewer-complex-gateway", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnComplexGatewayViewer_vue_vue_type_style_index_0_scoped_e6c1fdb1_lang = ""; const _hoisted_1$k = { ref: "divElement", class: "ddei-flow-bpmn-viewer-complex-gateway", title: "复杂网关" }; function _sfc_render$k(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$k, _cache[0] || (_cache[0] = [ vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-gateway-complex" }) ], -1) ]), 512); } const BpmnComplexGatewayViewer = /* @__PURE__ */ _export_sfc(_sfc_main$k, [["render", _sfc_render$k], ["__scopeId", "data-v-e6c1fdb1"]]); const complexGateway = { id: "1000204", name: "ddei.flow.complexgateway", code: "complex_gateway", desc: "bpmn中的ComplexGateway", from: "100040", subject: "bpmn", define: { width: 50, height: 50, bpmnBaseType: "Gateway", bpmnType: "ComplexGateway", ext: { sample: { eqrat: true }, attrs: [ { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, viewer: BpmnComplexGatewayViewer, icon: `` }; const __vite_glob_0_7 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: complexGateway }, Symbol.toStringTag, { value: "Module" })); const dataObject = { id: "1000501", name: "ddei.flow.dataobj", code: "data", desc: "bpmn中的数据对象", from: "100500", subject: "bpmn", define: { width: 30, height: 39, dataType: 1, bpmnBaseType: "Other", bpmnType: "DataObject", bpmnSubType: 1, name: "ddei.flow.dataobj", //2为极坐标,以cpv为圆心,半径r采样获得点,在以width/100、height/100的的原始比例进行缩放 poly: 2, //采样信息 sample: { //依附图形的初始化配置,如果产生依附图形,则会在配置的位置生成 depPos: { type: 8 //位置5中心点,6789上右下左 }, depProps: { "8": "name" //映射属性 }, //一圈4次采样 loop: 4, //初始次采样的开始角度 angle: 0, //半径距离 r: 50, //允许文本输入 textInput: 1, //采样的规则,多组采样返回多组规则 rules: [ `(i, sample, pvs, model, ovs){ let weight = 25 let x=sample.x,y=sample.y switch(i){ case 0: pvs.push({begin:1,x:x,y:y,select:1,clip:1,oppoint:2,stroke:1,fill:1}); break; case 1: pvs[0].y=y pvs.push({x:x,y:y,select:1,clip:1,stroke:1,oppoint:2,fill:1}); break; case 2: pvs[1].x=x pvs.push({x:x,y:y,select:1,clip:1,stroke:1,oppoint:2,fill:1}); break; case 3: pvs[2].y=y x = pvs[0].x pvs.push({x:x-weight,y:y,select:1,clip:1,stroke:1,oppoint:2,fill:1}); pvs.push({x:x,y:y+weight,select:1,clip:1,stroke:1,oppoint:2,op2close:1,fill:1,end:1}); break; } }`, `(i, sample, pvs, model, ovs){ if(i==3){ pvs.push({x:25,y:sample.y,stroke:1,type:1,begin:1}); pvs.push({x:25,y:sample.y+25,stroke:1,type:1}); pvs.push({x:50,y:sample.y+25,stroke:1,type:1}); pvs.push({x:50,y:sample.y+25,end:1}); } }`, //输入输出箭头 `(i, sample, pvs, model, ovs){ if(model.bpmnSubType == 2 || model.bpmnSubType == 3){ switch(i){ case 3: let fill = model.bpmnSubType == 3 ? 1 : 0 let stroke = model.bpmnSubType == 2 ? 1 : 0 pvs.push({begin:1,x:-35,y:-30,stroke:stroke,fill:fill,fillColor:'border'}); pvs.push({x:-15,y:-30,stroke:stroke}); pvs.push({x:-15,y:-35,stroke:stroke}); pvs.push({x:0,y:-25,stroke:stroke}); pvs.push({x:-15,y:-15,stroke:stroke}); pvs.push({x:-15,y:-20,stroke:stroke}); pvs.push({end:1,x:-35,y:-20,stroke:stroke}); break; } } }`, //数据集合图标 `(i, sample, pvs, model, ovs){ if(model.isCollection){ switch(i){ case 3: let fill = 1 let stroke = 1 pvs.push({begin:1,x:0,y:25,stroke:stroke,fill:fill,fillColor:'border'}); pvs.push({x:0,y:43,stroke:stroke}); pvs.push({x:0,y:43,stroke:stroke}); pvs.push({end:1,x:0,y:25,stroke:stroke}); pvs.push({begin:1,x:-8,y:25,stroke:stroke,fill:fill,fillColor:'border'}); pvs.push({x:-8,y:43,stroke:stroke}); pvs.push({x:-8,y:43,stroke:stroke}); pvs.push({end:1,x:-8,y:25,stroke:stroke}); pvs.push({begin:1,x:8,y:25,stroke:stroke,fill:fill,fillColor:'border'}); pvs.push({x:8,y:43,stroke:stroke}); pvs.push({x:8,y:43,stroke:stroke}); pvs.push({end:1,x:8,y:25,stroke:stroke}); break; } } }`, //文本 `(i, sample, pvs, model, ovs){ if(sample.textInput){ let weight = 25 let x=sample.x,y=sample.y switch(i){ case 0: pvs.push({begin:1,x:x,y:y,text:1}); break; case 1: pvs[0].y=y pvs.push({x:x,y:y,text:1}); break; case 2: pvs[1].x=x pvs.push({x:x,y:y,text:1}); break; case 3: pvs[2].y=y+weight x = pvs[0].x pvs.push({x:x,y:pvs[2].y,text:1}); break; } } }` ] }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "编码,一般用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "data", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称,一般用于显示", "controlType": "text", "dataType": "string", "defaultValue": "数据", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "bpmnSubType", "name": "ddei.type", "desc": "控件的主体显示文本", "controlType": "combox", "dataType": "integer", "dataSource": [ { "text": "ddei.flow.property.ds.default", "value": 1 }, { "text": "ddei.flow.property.ds.input", "value": 2 }, { "text": "ddei.flow.property.ds.output", "value": 3 } ], "itemStyle": { width: 80, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "dataType", "name": "ddei.flow.property.datatype", "desc": "数据的类型,可以是内置类型,也可以由外部定义", "controlType": "combox", "dataType": "integer", "dataSource": [ { text: "ddei.flow.property.ds.string", "value": 1 }, { "text": "ddei.flow.property.ds.integer", "value": 2 }, { "text": "ddei.flow.property.ds.long", "value": 3 }, { "text": "ddei.flow.property.ds.float", "value": 4 }, { "text": "ddei.flow.property.ds.double", "value": 5 }, { "text": "ddei.flow.property.ds.boolean", "value": 6 }, { "text": "ddei.flow.property.ds.datetime", "value": 7 }, { "text": "ddei.flow.property.ds.custom", "value": 8 } ], "itemStyle": { width: 100, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "isCollection", "name": "ddei.flow.datacoll", "desc": "是否为数据集合", "controlType": "switch-checkbox", "dataType": "integer", "display": "column", "hiddenTitle": true, "defaultValue": 0, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "数据对象节点", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, icon: ``, filters: { LINE_OBI_FILTER: lineObiCheck }, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_8 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: dataObject }, Symbol.toStringTag, { value: "Module" })); const datastore = { id: "1000506", name: "ddei.flow.datastore", code: "ds", desc: "bpmn中的数据存储", from: "103010", subject: "bpmn", define: { width: 50, height: 30, bpmnBaseType: "Other", bpmnType: "DataStore", name: "ddei.flow.datastore", ext: { sample: { //依附图形的初始化配置,如果产生依附图形,则会在配置的位置生成 depPos: { type: 8 //位置5中心点,6789上右下左 }, depProps: { "8": "name" //映射属性 } }, attrs: [ { "code": "code", "name": "ddei.code", "desc": "编码,一般用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "ds", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称,一般用于显示", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.datastore", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "isUnlimited", "name": "ddei.flow.unlimited", "desc": "是否无限容量", "controlType": "switch-checkbox", "dataType": "integer", "display": "column", "hiddenTitle": true, "defaultValue": 0, "type": [2] //类别,1图形,2业务,3事件 }, { "code": "capacity", "name": "ddei.flow.property.capacity", "desc": "数据存储的大小", "controlType": "text", "dataType": "integer", "defaultValue": 1, "type": [2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "消息节点", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_9 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: datastore }, Symbol.toStringTag, { value: "Module" })); const datastore1 = { id: "1000507", name: "ddei.flow.datastore", code: "ds", desc: "bpmn中的消息", from: "103011", subject: "bpmn", define: { width: 50, height: 30, bpmnBaseType: "Other", bpmnType: "DataStore", name: "ddei.flow.datastore", ext: { sample: { //依附图形的初始化配置,如果产生依附图形,则会在配置的位置生成 depPos: { type: 8 //位置5中心点,6789上右下左 }, depProps: { "8": "name" //映射属性 } }, attrs: [ { "code": "code", "name": "ddei.code", "desc": "编码,一般用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "ds", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称,一般用于显示", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.datastore", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "消息节点", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_10 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: datastore1 }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$j = { name: "ddei-flow-bpmn-viewer-end-event", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnEndEventViewer_vue_vue_type_style_index_0_scoped_8f354e18_lang = ""; const _hoisted_1$j = { ref: "divElement", class: "ddei-flow-bpmn-viewer-end-event", title: "结束事件" }; const _hoisted_2$f = { class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_3$e = { key: 0, "xlink:href": "#icon-ddei-flow-end-event-none" }; const _hoisted_4$d = { key: 1, "xlink:href": "#icon-ddei-flow-end-event-message" }; const _hoisted_5$b = { key: 2, "xlink:href": "#icon-ddei-flow-end-event-signal" }; const _hoisted_6$b = { key: 3, "xlink:href": "#icon-ddei-flow-end-event-multiple" }; const _hoisted_7$b = { key: 4, "xlink:href": "#icon-ddei-flow-end-event-escalation" }; const _hoisted_8$b = { key: 5, "xlink:href": "#icon-ddei-flow-end-event-error" }; const _hoisted_9$4 = { key: 6, "xlink:href": "#icon-ddei-flow-end-event-compensati" }; const _hoisted_10$3 = { key: 7, "xlink:href": "#icon-ddei-flow-end-event-cancel" }; const _hoisted_11$2 = { key: 8, "xlink:href": "#icon-ddei-flow-end-event-terminate" }; function _sfc_render$j(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$j, [ (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$f, [ !$props.model.bpmnSubType || $props.model.bpmnSubType == 1 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_3$e)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 2 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_4$d)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 3 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_5$b)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 4 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_6$b)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 5 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_7$b)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 6 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_8$b)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 7 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_9$4)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 8 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_10$3)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 9 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_11$2)) : vue.createCommentVNode("", true) ])) ], 512); } const BpmnEndEventViewer = /* @__PURE__ */ _export_sfc(_sfc_main$j, [["render", _sfc_render$j], ["__scopeId", "data-v-8f354e18"]]); const endEvent = { id: "1000003", name: "ddei.flow.endevent", code: "end", desc: "bpmn中的EndEvent", from: "1000001", subject: "bpmn", define: { width: 40, height: 40, bpmnBaseType: "Event", bpmnType: "EndEvent", bpmnSubType: 1, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "编码,一般用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "end", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称,一般用于显示", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.endevent", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "bpmnSubType", "name": "ddei.type", "desc": "控件的主体显示文本", "controlType": "combox", "dataType": "integer", "dataSource": [ { "text": "ddei.flow.property.ds.default", "value": 1 }, { "text": "ddei.flow.property.ds.message", "value": 2 }, { "text": "ddei.flow.property.ds.signal", "value": 3 }, { "text": "ddei.flow.property.ds.multiple", "value": 4 }, { "text": "ddei.flow.property.ds.escalation", "value": 5 }, { "text": "ddei.flow.property.ds.error", "value": 6 }, { "text": "ddei.flow.property.ds.compensation", "value": 7 }, { "text": "ddei.flow.property.ds.cancel", "value": 8 }, { "text": "ddei.flow.property.ds.stop", "value": 9 } ], "itemStyle": { width: 80, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.endevent", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, viewer: BpmnEndEventViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_11 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: endEvent }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$i = { name: "ddei-flow-bpmn-viewer-eventbased-gateway", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnEventbasedGatewayViewer_vue_vue_type_style_index_0_scoped_6f4a01e3_lang = ""; const _hoisted_1$i = { ref: "divElement", class: "ddei-flow-bpmn-viewer-eventbased-gateway", title: "事件网关" }; function _sfc_render$i(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$i, _cache[0] || (_cache[0] = [ vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-gateway-eventbased" }) ], -1) ]), 512); } const BpmnEventBasedGatewayViewer = /* @__PURE__ */ _export_sfc(_sfc_main$i, [["render", _sfc_render$i], ["__scopeId", "data-v-6f4a01e3"]]); const eventbasedGateway = { id: "1000205", name: "ddei.flow.eventbasedgateway", code: "eventbased_gateway", desc: "bpmn中的EventBasedGateway", from: "100040", subject: "bpmn", define: { width: 50, height: 50, bpmnBaseType: "Gateway", bpmnType: "EventBasedGateway", ext: { sample: { eqrat: true }, attrs: [ { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, viewer: BpmnEventBasedGatewayViewer, icon: `` }; const __vite_glob_0_12 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: eventbasedGateway }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$h = { name: "ddei-flow-bpmn-viewer-exclusive-gateway", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnExclusiveGatewayViewer_vue_vue_type_style_index_0_scoped_7986eca0_lang = ""; const _hoisted_1$h = { ref: "divElement", class: "ddei-flow-bpmn-viewer-exclusive-gateway", title: "排他网关" }; function _sfc_render$h(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$h, _cache[0] || (_cache[0] = [ vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-gateway-xor" }) ], -1) ]), 512); } const BpmnExclusiveGatewayViewer = /* @__PURE__ */ _export_sfc(_sfc_main$h, [["render", _sfc_render$h], ["__scopeId", "data-v-7986eca0"]]); const exclusiveGateway = { id: "1000202", name: "ddei.flow.exclusivegateway", code: "exclusive_gateway", desc: "bpmn中的ExclusiveGateway", from: "100040", subject: "bpmn", define: { width: 50, height: 50, bpmnBaseType: "Gateway", bpmnType: "ExclusiveGateway", ext: { sample: { eqrat: true }, attrs: [ { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, viewer: BpmnExclusiveGatewayViewer, icon: `` }; const __vite_glob_0_13 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: exclusiveGateway }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$g = { name: "ddei-flow-bpmn-viewer-group", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["rectSvg"].children[0].style.stroke = "green"; } else { this.$refs["rectSvg"].children[0].style.stroke = ""; } } } }; const bpmnGroupViewer_vue_vue_type_style_index_0_scoped_b5dc3b04_lang = ""; const _hoisted_1$g = { ref: "divElement", class: "ddei-flow-bpmn-viewer-group" }; const _hoisted_2$e = { class: "border-svg", ref: "rectSvg" }; const _hoisted_3$d = { key: 1, class: "icon-ddei-flow content-header-locked", "aria-hidden": "true" }; function _sfc_render$g(_ctx, _cache, $props, $setup, $data, $options) { var _a; return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$g, [ (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$e, _cache[0] || (_cache[0] = [ vue.createElementVNode("rect", { rx: "10", ry: "10", width: "100%", height: "100%", x: "0", y: "0" }, null, -1) ]), 512)), ((_a = $props.model) == null ? void 0 : _a.name) ? (vue.openBlock(), vue.createElementBlock("div", { key: 0, class: vue.normalizeClass({ "title": !$props.model.isExpand, "title-expand": $props.model.isExpand }) }, vue.toDisplayString($props.model.name), 3)) : vue.createCommentVNode("", true), $props.model.lock == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_3$d, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-lock" }, null, -1) ]))) : vue.createCommentVNode("", true) ], 512); } const BpmnGroupViewer = /* @__PURE__ */ _export_sfc(_sfc_main$g, [["render", _sfc_render$g], ["__scopeId", "data-v-b5dc3b04"]]); const group = { id: "1000401", name: "ddei.flow.group", code: "group", desc: "bpmn中的Group", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Group", bpmnType: "Group", allowIncludeModel: 1, width: 400, height: 320, otherWidth: 110, otherHeight: 70, isExpand: 1, border: { round: 10 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "group", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "分组标题", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.group", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.group", "type": [1, 2] //类别,1图形,2业务,3事件 } ], groups: [ { "name": "ddei.data", icon: "icon-a-ziyuan409", subGroups: [ { "name": "ddei.basic", attrs: ["code", "name", "desc"] } ] } ] } }, viewer: BpmnGroupViewer, filters: { LINE_OBI_FILTER: lineObiCheck }, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_14 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: group }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$f = { name: "ddei-flow-bpmn-viewer-inter-catch-event", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnIntermediateCatchEventViewer_vue_vue_type_style_index_0_scoped_e679db61_lang = ""; const _hoisted_1$f = { ref: "divElement", class: "ddei-flow-bpmn-viewer-inter-catch-event", title: "中间捕获事件" }; const _hoisted_2$d = { class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_3$c = { key: 0, "xlink:href": "#icon-ddei-flow-boundary-event-time" }; const _hoisted_4$c = { key: 1, "xlink:href": "#icon-ddei-flow-boundary-event-message" }; const _hoisted_5$a = { key: 2, "xlink:href": "#icon-ddei-flow-boundary-event-signal" }; const _hoisted_6$a = { key: 3, "xlink:href": "#icon-ddei-flow-intermediate-event-c2" }; const _hoisted_7$a = { key: 4, "xlink:href": "#icon-ddei-flow-intermediate-event-c7" }; const _hoisted_8$a = { key: 5, "xlink:href": "#icon-ddei-flow-intermediate-event-c3" }; function _sfc_render$f(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$f, [ (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$d, [ !$props.model.bpmnSubType || $props.model.bpmnSubType == 1 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_3$c)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 2 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_4$c)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 3 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_5$a)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 4 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_6$a)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 5 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_7$a)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 6 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_8$a)) : vue.createCommentVNode("", true) ])) ], 512); } const BpmnIntermediateCatchEventViewer = /* @__PURE__ */ _export_sfc(_sfc_main$f, [["render", _sfc_render$f], ["__scopeId", "data-v-e679db61"]]); const intermediateCatchEvent = { "id": "1000002", "name": "ddei.flow.intermediatecatchevent", "code": "icatchevt", "desc": "bpmn中的IntermediateCatchEvent", "from": "1000001", subject: "bpmn", "define": { width: 40, height: 40, bpmnBaseType: "Event", bpmnSubType: 1, bpmnType: "IntermediateCatchEvent", ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "编码,一般用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "icatchevt", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称,一般用于显示", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.intermediatecatchevent", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "bpmnSubType", "name": "ddei.type", "desc": "子类型,用于区分中间节点的不同作用", "controlType": "combox", "dataType": "integer", "dataSource": [ { "text": "ddei.flow.property.ds.timer", "value": 1 }, { "text": "ddei.flow.property.ds.message", "value": 2 }, { "text": "ddei.flow.property.ds.signal", "value": 3 }, { "text": "ddei.flow.property.ds.link", "value": 4 }, { "text": "ddei.flow.property.ds.parallel", "value": 5 }, { "text": "ddei.flow.property.ds.multiple", "value": 6 } ], "itemStyle": { width: 130, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.intermediatecatchevent", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, viewer: BpmnIntermediateCatchEventViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_15 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: intermediateCatchEvent }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$e = { name: "ddei-flow-bpmn-viewer-inter-throw-event", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnIntermediateThrowEventViewer_vue_vue_type_style_index_0_scoped_c8fcaa16_lang = ""; const _hoisted_1$e = { ref: "divElement", class: "ddei-flow-bpmn-viewer-inter-throw-event", title: "中间抛出事件" }; const _hoisted_2$c = { class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_3$b = { key: 0, "xlink:href": "#icon-ddei-flow-intermediate-event-n" }; const _hoisted_4$b = { key: 1, "xlink:href": "#icon-ddei-flow-intermediate-throw-event-message" }; const _hoisted_5$9 = { key: 2, "xlink:href": "#icon-ddei-flow-intermediate-throw-event-signal" }; const _hoisted_6$9 = { key: 3, "xlink:href": "#icon-ddei-flow-intermediate-throw-event-compensation" }; const _hoisted_7$9 = { key: 4, "xlink:href": "#icon-ddei-flow-intermediate-event-t3" }; const _hoisted_8$9 = { key: 5, "xlink:href": "#icon-ddei-flow-intermediate-event-t1" }; const _hoisted_9$3 = { key: 6, "xlink:href": "#icon-ddei-flow-intermediate-event-t5" }; function _sfc_render$e(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$e, [ (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$c, [ !$props.model.bpmnSubType || $props.model.bpmnSubType == 1 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_3$b)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 2 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_4$b)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 3 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_5$9)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 4 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_6$9)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 5 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_7$9)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 6 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_8$9)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 7 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_9$3)) : vue.createCommentVNode("", true) ])) ], 512); } const BpmnIntermediateThrowEventViewer = /* @__PURE__ */ _export_sfc(_sfc_main$e, [["render", _sfc_render$e], ["__scopeId", "data-v-c8fcaa16"]]); const intermediateThrowEvent = { "id": "1000005", "name": "ddei.flow.intermediatethrowevent", "code": "ithrowevt", "desc": "bpmn中的IntermediateThrowEvent", "from": "1000001", subject: "bpmn", "define": { width: 40, height: 40, bpmnBaseType: "Event", bpmnSubType: 1, bpmnType: "IntermediateThrowEvent", ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "编码,一般用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "ithrowevt", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称,一般用于显示", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.intermediatethrowevent", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "bpmnSubType", "name": "ddei.type", "desc": "子类型,用于区分中间节点的不同作用", "controlType": "combox", "dataType": "integer", "dataSource": [ { "text": "ddei.flow.property.ds.default", "value": 1 }, { "text": "ddei.flow.property.ds.message", "value": 2 }, { "text": "ddei.flow.property.ds.signal", "value": 3 }, { "text": "ddei.flow.property.ds.compensation", "value": 4 }, { "text": "ddei.flow.property.ds.multiple", "value": 5 }, { "text": "ddei.flow.property.ds.escalation", "value": 6 }, { "text": "ddei.flow.property.ds.link", "value": 7 } ], "itemStyle": { width: 130, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.intermediatethrowevent", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, viewer: BpmnIntermediateThrowEventViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_16 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: intermediateThrowEvent }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$d = { name: "ddei-flow-bpmn-viewer-manual-task", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; } else { this.$refs["divElement"].style.borderColor = ""; } } } }; const bpmnManualTaskViewer_vue_vue_type_style_index_0_scoped_3083fc81_lang = ""; const _hoisted_1$d = { ref: "divElement", class: "ddei-flow-bpmn-viewer-manual-task" }; const _hoisted_2$b = { class: "title" }; const _hoisted_3$a = { class: "text" }; const _hoisted_4$a = { class: "markers" }; const _hoisted_5$8 = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_6$8 = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_7$8 = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_8$8 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; function _sfc_render$d(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$d, [ vue.createElementVNode("div", _hoisted_2$b, [ _cache[0] || (_cache[0] = vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-manual" }) ], -1)), vue.createElementVNode("div", _hoisted_3$a, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : "ddei.flow.manualtask")), 1) ]), vue.createElementVNode("div", _hoisted_4$a, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_5$8, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_6$8, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$8, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$8, _cache[4] || (_cache[4] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ], 512); } const BpmnManualTaskViewer = /* @__PURE__ */ _export_sfc(_sfc_main$d, [["render", _sfc_render$d], ["__scopeId", "data-v-3083fc81"]]); const manualTask = { id: "1000051", name: "ddei.flow.manualtask", code: "manual_task", desc: "bpmn中的ManualTask", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "ManualTask", width: 110, height: 70, border: { round: 5 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "manual_task", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.manualtask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.manualtask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnManualTaskViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_17 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: manualTask }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$c = { name: "ddei-flow-bpmn-viewer-message", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnMessageViewer_vue_vue_type_style_index_0_scoped_58a6b5ba_lang = ""; const _hoisted_1$c = { ref: "divElement", class: "ddei-flow-bpmn-viewer-message", title: "消息" }; const _hoisted_2$a = { class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_3$9 = { key: 0, "xlink:href": "#icon-ddei-flow-receive" }; const _hoisted_4$9 = { key: 1, "xlink:href": "#icon-ddei-flow-send" }; function _sfc_render$c(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$c, [ (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$a, [ $props.model.bpmnSubType == 1 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_3$9)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 2 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_4$9)) : vue.createCommentVNode("", true) ])) ], 512); } const BpmnMessageViewer = /* @__PURE__ */ _export_sfc(_sfc_main$c, [["render", _sfc_render$c], ["__scopeId", "data-v-58a6b5ba"]]); const message = { id: "1000505", name: "ddei.flow.message", code: "msg", desc: "bpmn中的消息", from: "100103", subject: "bpmn", define: { width: 32, height: 24, bpmnBaseType: "Other", bpmnType: "Message", bpmnSubType: 1, name: "ddei.flow.message", ext: { sample: { //依附图形的初始化配置,如果产生依附图形,则会在配置的位置生成 depPos: { type: 8 //位置5中心点,6789上右下左 }, depProps: { "8": "name" //映射属性 } }, attrs: [ { "code": "code", "name": "ddei.code", "desc": "编码,一般用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "msg", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称,一般用于显示", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.message", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "bpmnSubType", "name": "ddei.type", "desc": "", "controlType": "combox", "dataType": "integer", "dataSource": [ { "text": "ddei.flow.property.ds.default", "value": 1 }, { "text": "ddei.flow.property.ds.noninit", "value": 2 } ], "itemStyle": { width: 100, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.message", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, viewer: BpmnMessageViewer, icon: ``, filters: { LINE_OBI_FILTER: lineObiCheck }, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_18 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: message }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$b = { name: "ddei-flow-bpmn-viewer-parallel-gateway", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnParallelGatewayViewer_vue_vue_type_style_index_0_scoped_4d21627c_lang = ""; const _hoisted_1$b = { ref: "divElement", class: "ddei-flow-bpmn-viewer-parallel-gateway", title: "并行网关" }; function _sfc_render$b(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$b, _cache[0] || (_cache[0] = [ vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-gateway-parallel" }) ], -1) ]), 512); } const BpmnParallelGatewayViewer = /* @__PURE__ */ _export_sfc(_sfc_main$b, [["render", _sfc_render$b], ["__scopeId", "data-v-4d21627c"]]); const parallelGateway = { id: "1000201", name: "ddei.flow.parallelgateway", code: "parallel_gateway", desc: "bpmn中的ParallelGateway", from: "100040", subject: "bpmn", define: { width: 50, height: 50, bpmnBaseType: "Gateway", bpmnType: "ParallelGateway", ext: { sample: { eqrat: true }, attrs: [ { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, viewer: BpmnParallelGatewayViewer, icon: `` }; const __vite_glob_0_19 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: parallelGateway }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$a = { name: "ddei-flow-bpmn-viewer-receive-task", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; } else { this.$refs["divElement"].style.borderColor = ""; } } } }; const bpmnReceiveTaskViewer_vue_vue_type_style_index_0_scoped_e2cb14b8_lang = ""; const _hoisted_1$a = { ref: "divElement", class: "ddei-flow-bpmn-viewer-receive-task" }; const _hoisted_2$9 = { class: "title" }; const _hoisted_3$8 = { class: "text" }; const _hoisted_4$8 = { class: "markers" }; const _hoisted_5$7 = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_6$7 = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_7$7 = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_8$7 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; function _sfc_render$a(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$a, [ vue.createElementVNode("div", _hoisted_2$9, [ _cache[0] || (_cache[0] = vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-receive" }) ], -1)), vue.createElementVNode("div", _hoisted_3$8, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : "ddei.flow.receivetask")), 1) ]), vue.createElementVNode("div", _hoisted_4$8, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_5$7, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_6$7, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$7, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$7, _cache[4] || (_cache[4] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ], 512); } const BpmnReceiveTaskViewer = /* @__PURE__ */ _export_sfc(_sfc_main$a, [["render", _sfc_render$a], ["__scopeId", "data-v-e2cb14b8"]]); const receiveTask = { id: "1000061", name: "ddei.flow.receivetask", code: "receive_task", desc: "bpmn中的ReceiveTask", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "ReceiveTask", width: 110, height: 70, border: { round: 5 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "receive_task", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.receivetask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.receivetask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnReceiveTaskViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_20 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: receiveTask }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$9 = { name: "ddei-flow-bpmn-viewer-script-task", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; } else { this.$refs["divElement"].style.borderColor = ""; } } } }; const bpmnScriptTaskViewer_vue_vue_type_style_index_0_scoped_10d59418_lang = ""; const _hoisted_1$9 = { ref: "divElement", class: "ddei-flow-bpmn-viewer-script-task" }; const _hoisted_2$8 = { class: "title" }; const _hoisted_3$7 = { class: "text" }; const _hoisted_4$7 = { class: "markers" }; const _hoisted_5$6 = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_6$6 = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_7$6 = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_8$6 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; function _sfc_render$9(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$9, [ vue.createElementVNode("div", _hoisted_2$8, [ _cache[0] || (_cache[0] = vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-script" }) ], -1)), vue.createElementVNode("div", _hoisted_3$7, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : "ddei.flow.scripttask")), 1) ]), vue.createElementVNode("div", _hoisted_4$7, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_5$6, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_6$6, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$6, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$6, _cache[4] || (_cache[4] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ], 512); } const BpmnScriptTaskViewer = /* @__PURE__ */ _export_sfc(_sfc_main$9, [["render", _sfc_render$9], ["__scopeId", "data-v-10d59418"]]); const scriptTask = { id: "1000021", name: "ddei.flow.scripttask", code: "script_task", desc: "bpmn中的ScriptTask", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "ScriptTask", width: 110, height: 70, border: { round: 5 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "script_task", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.scripttask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "scriptFormat", "name": "ddei.flow.property.language", "desc": "脚本采用的语言", "controlType": "textarea", "dataType": "string", "defaultValue": "groovy", "type": [2] //类别,1图形,2业务,3事件 }, { "code": "script", "name": "ddei.flow.property.script", "desc": "脚本内容", "controlType": "textarea", "dataType": "string", "defaultValue": "", "type": [2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.scripttask", "type": [2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnScriptTaskViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_21 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: scriptTask }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$8 = { name: "ddei-flow-bpmn-viewer-send-task", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; } else { this.$refs["divElement"].style.borderColor = ""; } } } }; const bpmnSendTaskViewer_vue_vue_type_style_index_0_scoped_451d2857_lang = ""; const _hoisted_1$8 = { ref: "divElement", class: "ddei-flow-bpmn-viewer-send-task" }; const _hoisted_2$7 = { class: "title" }; const _hoisted_3$6 = { class: "text" }; const _hoisted_4$6 = { class: "markers" }; const _hoisted_5$5 = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_6$5 = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_7$5 = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_8$5 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; function _sfc_render$8(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$8, [ vue.createElementVNode("div", _hoisted_2$7, [ _cache[0] || (_cache[0] = vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-send" }) ], -1)), vue.createElementVNode("div", _hoisted_3$6, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : "ddei.flow.sendtask")), 1) ]), vue.createElementVNode("div", _hoisted_4$6, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_5$5, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_6$5, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$5, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$5, _cache[4] || (_cache[4] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ], 512); } const BpmnSendTaskViewer = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["render", _sfc_render$8], ["__scopeId", "data-v-451d2857"]]); const sendTask = { id: "1000041", name: "ddei.flow.sendtask", code: "send_task", desc: "bpmn中的SendTask", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "SendTask", width: 110, height: 70, border: { round: 5 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "send_task", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.sendtask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.sendtask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnSendTaskViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_22 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: sendTask }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$7 = { name: "ddei-flow-bpmn-viewer-sequence-flow-icon", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, data() { return { type: 0, lineColor: "black", lineWidth: 1 }; }, mounted() { this.refreshView(); }, methods: { refreshView(model, vNode, tempShape, composeRender) { var _a, _b; let lineModel = this.model.pModel; if (lineModel) { this.type = lineModel.bpmnSubType; if (this.type) { let color = (_a = lineModel.render) == null ? void 0 : _a.getCachedValue("color"); if (!color) { color = ddeiEditor.DDeiUtil.getStyleValue("canvas-control-border", this.editor.ddInstance); } this.lineWidth = (_b = lineModel.render) == null ? void 0 : _b.getCachedValue("width"); } } } } }; const bpmnSequenceFlowIconViewer_vue_vue_type_style_index_0_scoped_f97bf8f3_lang = ""; const _hoisted_1$7 = { ref: "divElement", class: "ddei-flow-bpmn-viewer-sequence-flow-icon" }; const _hoisted_2$6 = { key: 0, class: "icon-svg" }; function _sfc_render$7(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$7, [ $data.type == 3 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$6, [ vue.createElementVNode("line", { x1: "0", y1: "0", x2: "12", y2: "12", style: vue.normalizeStyle({ "stroke": $data.lineColor, "stroke-width": $data.lineWidth }) }, null, 4) ])) : vue.createCommentVNode("", true) ], 512); } const BpmnSequenceFlowIconViewer = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["render", _sfc_render$7], ["__scopeId", "data-v-f97bf8f3"]]); const sequenceFlowIcon = { id: "100060101", name: "控制流图标", code: "seqicon", desc: "bpmn中控制流的子图标", from: "100103", subject: "bpmn", define: { width: 12, height: 12, bpmnBaseType: "Other", bpmnType: "ICON" }, viewer: BpmnSequenceFlowIconViewer, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_23 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: sequenceFlowIcon }, Symbol.toStringTag, { value: "Module" })); const sequenceFlow = { id: "1000601", name: "ddei.flow.sequence", code: "seq", desc: "bpmn中的SequenceFlow", from: "100401", subject: "bpmn", define: { type: 2, bpmnBaseType: "Sequence", bpmnSubType: 1, ep: { type: 51 }, pvs: [ { x: -75, y: 0, z: 1 }, { x: 0, y: 0, z: 1 }, { x: 75, y: 0, z: 1 } ], cpv: { x: 0, y: 0 }, //组合控件 composes: [ { width: 12, height: 12, id: "100060101", cIndex: 1, initCPV: { x: 0, y: 0, z: 1 } } ], //操作点 ovs: [ { //约束,控制点的移动路径和位置 constraint: { type: 5, //不允许移动,固定路径位置,沿路径方向,固定在等比例或者等长度位置(长度不足则按照0.5比例位置) pvs: ["pvs[0]", "pvs[1]"], //定义路径 rate: 0.15 //固定比例 // len: 30 //固定长度 }, //联动,点移动后控制的其它点 links: [ { type: 2, //同步中心点 pvs: ["composes[0]"] } ] } ], ext: { sample: { //依附图形的初始化配置,如果产生依附图形,则会在配置的位置生成 depPos: { type: 3 //位置5中心点,6789上右下左 }, depProps: { "3": "name" //映射属性 } }, attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "seq", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.sequence", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "bpmnSubType", "name": "ddei.type", "desc": "控件的主体显示文本", "controlType": "combox", "dataType": "integer", "dataSource": [ { "text": "ddei.flow.property.ds.default", "value": 1 }, { "text": "ddei.flow.property.ds.condition", "value": 2 }, { "text": "ddei.flow.property.ds.defaultcondition", "value": 3 }, { "text": "ddei.flow.property.ds.message", "value": 4 }, { "text": "ddei.flow.property.ds.association", "value": 5 } ], "itemStyle": { width: 100, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.sequence", "type": [1, 2] //类别,1图形,2业务,3事件 } ], groups: [ { "name": "ddei.data", icon: "icon-a-ziyuan409", subGroups: [ { "name": "ddei.basic", attrs: ["code", "name", "bpmnSubType", "desc"] } ] } ] } }, icon: `` }; const __vite_glob_0_24 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: sequenceFlow }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$6 = { name: "ddei-flow-bpmn-viewer-service-task", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; } else { this.$refs["divElement"].style.borderColor = ""; } } } }; const bpmnServiceTaskViewer_vue_vue_type_style_index_0_scoped_1f1f502d_lang = ""; const _hoisted_1$6 = { ref: "divElement", class: "ddei-flow-bpmn-viewer-service-task" }; const _hoisted_2$5 = { class: "title" }; const _hoisted_3$5 = { class: "text" }; const _hoisted_4$5 = { class: "markers" }; const _hoisted_5$4 = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_6$4 = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_7$4 = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_8$4 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; function _sfc_render$6(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$6, [ vue.createElementVNode("div", _hoisted_2$5, [ _cache[0] || (_cache[0] = vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-service" }) ], -1)), vue.createElementVNode("div", _hoisted_3$5, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : "ddei.flow.servicetask")), 1) ]), vue.createElementVNode("div", _hoisted_4$5, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_5$4, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_6$4, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$4, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$4, _cache[4] || (_cache[4] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ], 512); } const BpmnServiceTaskViewer = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["render", _sfc_render$6], ["__scopeId", "data-v-1f1f502d"]]); const serviceTask = { id: "1000031", name: "ddei.flow.servicetask", code: "service_task", desc: "bpmn中的ServiceTask", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "ServiceTask", width: 110, height: 70, border: { round: 5 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "service_task", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.servicetask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.servicetask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnServiceTaskViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_25 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: serviceTask }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$5 = { name: "ddei-flow-bpmn-viewer-start-gateway", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnStartEventViewer_vue_vue_type_style_index_0_scoped_81a6686d_lang = ""; const _hoisted_1$5 = { ref: "divElement", class: "ddei-flow-bpmn-viewer-start-event", title: "开始事件" }; const _hoisted_2$4 = { class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_3$4 = { key: 0, "xlink:href": "#icon-ddei-flow-start-event-none" }; const _hoisted_4$4 = { key: 1, "xlink:href": "#icon-ddei-flow-start-event-message" }; const _hoisted_5$3 = { key: 2, "xlink:href": "#icon-ddei-flow-start-event-non-inte3" }; const _hoisted_6$3 = { key: 3, "xlink:href": "#icon-ddei-flow-start-event-timer" }; const _hoisted_7$3 = { key: 4, "xlink:href": "#icon-ddei-flow-start-event-non-inte2" }; const _hoisted_8$3 = { key: 5, "xlink:href": "#icon-ddei-flow-start-event-conditio" }; const _hoisted_9$2 = { key: 6, "xlink:href": "#icon-ddei-flow-start-event-non-inte4" }; const _hoisted_10$2 = { key: 7, "xlink:href": "#icon-ddei-flow-start-event-signal" }; const _hoisted_11$1 = { key: 8, "xlink:href": "#icon-ddei-flow-start-event-non-inte1" }; const _hoisted_12$1 = { key: 9, "xlink:href": "#icon-ddei-flow-start-event-multiple" }; const _hoisted_13$1 = { key: 10, "xlink:href": "#icon-ddei-flow-start-event-non-inte6" }; const _hoisted_14$1 = { key: 11, "xlink:href": "#icon-ddei-flow-start-event-parallel" }; const _hoisted_15$1 = { key: 12, "xlink:href": "#icon-ddei-flow-start-event-non-inte5" }; const _hoisted_16$1 = { key: 13, "xlink:href": "#icon-ddei-flow-start-event-escalati" }; const _hoisted_17$1 = { key: 14, "xlink:href": "#icon-ddei-flow-start-event-non-inte" }; const _hoisted_18$1 = { key: 15, "xlink:href": "#icon-ddei-flow-start-event-error" }; const _hoisted_19$1 = { key: 16, "xlink:href": "#icon-ddei-flow-start-event-compensa" }; const _hoisted_20$1 = { key: 17, "xlink:href": "#icon-ddei-flow-start-event-compensa-non-inte" }; function _sfc_render$5(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$5, [ (vue.openBlock(), vue.createElementBlock("svg", _hoisted_2$4, [ !$props.model.bpmnSubType || $props.model.bpmnSubType == 1 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_3$4)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 2 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_4$4)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 2 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_5$3)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 3 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_6$3)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 3 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_7$3)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 4 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_8$3)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 4 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_9$2)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 5 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_10$2)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 5 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_11$1)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 6 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_12$1)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 6 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_13$1)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 7 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_14$1)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 7 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_15$1)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 8 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_16$1)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 8 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_17$1)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 9 ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_18$1)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 10 && !$props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_19$1)) : vue.createCommentVNode("", true), $props.model.bpmnSubType == 10 && $props.model.notInterrupting ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_20$1)) : vue.createCommentVNode("", true) ])) ], 512); } const BpmnStartEventViewer = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["render", _sfc_render$5], ["__scopeId", "data-v-81a6686d"]]); const startEvent = { "id": "1000001", "name": "ddei.flow.startevent", "code": "start", "desc": "bpmn中的StartEvent", "from": "100103", subject: "bpmn", "define": { width: 40, height: 40, bpmnBaseType: "Event", bpmnType: "StartEvent", bpmnSubType: 1, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "start", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.startevent", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "bpmnSubType", "name": "ddei.type", "desc": "控件的主体显示文本", "controlType": "combox", "dataType": "integer", "dataSource": [ { "text": "ddei.flow.property.ds.default", "value": 1 }, { "text": "ddei.flow.property.ds.message", "value": 2 }, { "text": "ddei.flow.property.ds.timer", "value": 3 }, { "text": "ddei.flow.property.ds.condition", "value": 4 }, { "text": "ddei.flow.property.ds.signal", "value": 5 }, { "text": "ddei.flow.property.ds.multiple", "value": 6 }, { "text": "ddei.flow.property.ds.parallel", "value": 7 }, { "text": "ddei.flow.property.ds.escalation", "value": 8 }, { "text": "ddei.flow.property.ds.error", "value": 9 }, { "text": "ddei.flow.property.ds.compensation", "value": 10 } ], "itemStyle": { width: 100, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "notInterrupting", "text": "ddei.flow.property.notInterrupting", "desc": "非中断将不会终止运行,默认中断", "controlType": "switch-checkbox", "dataType": "integer", "display": "column", "hiddenTitle": true, "defaultValue": 0, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.startevent", "type": [1, 2] //类别,1图形,2业务,3事件 } ], groups: [ { "name": "ddei.data", icon: "icon-a-ziyuan409", subGroups: [ { "name": "ddei.basic", attrs: ["code", "name", "bpmnSubType", "desc"] } ] } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnStartEventViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_26 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: startEvent }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$4 = { name: "ddei-flow-bpmn-viewer-subprocess", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, data() { return {}; }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; if (this.$refs["transactionBorderElement"]) { this.$refs["transactionBorderElement"].style.borderColor = "green"; } } else { this.$refs["divElement"].style.borderColor = ""; if (this.$refs["transactionBorderElement"]) { this.$refs["transactionBorderElement"].style.borderColor = ""; } } } } }; const bpmnSubprocessViewer_vue_vue_type_style_index_0_scoped_9fa95600_lang = ""; const _hoisted_1$4 = { key: 0, ref: "transactionBorderElement", class: "trans" }; const _hoisted_2$3 = { key: 2, ref: "content", class: "content" }; const _hoisted_3$3 = { class: "content-header" }; const _hoisted_4$3 = { class: "content-header-title" }; const _hoisted_5$2 = { key: 0, class: "icon-ddei-flow content-header-locked", "aria-hidden": "true" }; const _hoisted_6$2 = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_7$2 = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_8$2 = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_9$1 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_10$1 = { key: 4, class: "icon-ddei-flow", "aria-hidden": "true" }; function _sfc_render$4(_ctx, _cache, $props, $setup, $data, $options) { var _a, _b; return vue.openBlock(), vue.createElementBlock("div", { ref: "divElement", class: vue.normalizeClass({ "ddei-flow-bpmn-viewer-subprocess": true, "ddei-flow-bpmn-viewer-subprocess-event": $props.model.bpmnSubType == 2 }) }, [ $props.model.bpmnSubType == 3 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_1$4, null, 512)) : vue.createCommentVNode("", true), !$props.model.isExpand ? (vue.openBlock(), vue.createElementBlock("div", { key: 1, class: vue.normalizeClass({ "title": true, "title-transaction": ((_a = $props.model) == null ? void 0 : _a.bpmnSubType) == 3 }) }, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : $props.model.bpmnSubType == 3 ? "ddei.flow.transsubprocess" : $props.model.bpmnSubType == 2 ? "ddei.flow.eventsubprocess" : "ddei.flow.subprocess")), 3)) : vue.createCommentVNode("", true), $props.model.isExpand ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2$3, [ vue.createElementVNode("div", _hoisted_3$3, [ vue.createElementVNode("div", _hoisted_4$3, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : ((_b = $props.model) == null ? void 0 : _b.bpmnSubType) == 3 ? "ddei.flow.transsubprocess" : $props.model.bpmnSubType == 2 ? "ddei.flow.eventsubprocess" : "ddei.flow.subprocess")), 1), $props.model.lock == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_5$2, _cache[0] || (_cache[0] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-lock" }, null, -1) ]))) : vue.createCommentVNode("", true) ]), _cache[1] || (_cache[1] = vue.createElementVNode("div", { class: "content-elements" }, null, -1)) ], 512)) : vue.createCommentVNode("", true), vue.createElementVNode("div", { class: vue.normalizeClass({ "markers": true, "markers-transaction": $props.model.bpmnSubType == 3 }) }, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_6$2, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$2, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$2, _cache[4] || (_cache[4] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_9$1, _cache[5] || (_cache[5] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), _cache[7] || (_cache[7] = vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sub-process-marker" }) ], -1)), $props.model.bpmnSubType == 4 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_10$1, _cache[6] || (_cache[6] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-ad-hoc-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ], 2) ], 2); } const BpmnSubProcessViewer = /* @__PURE__ */ _export_sfc(_sfc_main$4, [["render", _sfc_render$4], ["__scopeId", "data-v-9fa95600"]]); const subprocess = { id: "1000091", name: "ddei.flow.subprocess", code: "subprocess", desc: "bpmn中的SubProcess", from: "1000011", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnSubType: 1, bpmnType: "SubProcess", allowIncludeModel: 1, width: 300, height: 200, otherWidth: 110, otherHeight: 70, isExpand: 1, border: { round: 5 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "subprocess", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.subprocess", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "bpmnSubType", "name": "ddei.type", "desc": "控件的主体显示文本", "controlType": "combox", "dataType": "integer", "dataSource": [ { "text": "ddei.flow.property.ds.default", "value": 1 }, { "text": "ddei.flow.property.ds.event", "value": 2 }, { "text": "ddei.flow.property.ds.transaction", "value": 3 }, { "text": "ddei.flow.property.ds.custom", "value": 4 } ], "itemStyle": { width: 100, height: 25, col: 2, row: 0 }, "defaultValue": 1, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.subprocess", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ], groups: [ { "name": "ddei.data", icon: "icon-a-ziyuan409", subGroups: [ { "name": "ddei.basic", attrs: ["code", "name", "isLoop", "isTransaction", "multiInstance", "isParallel", "isCompensation", "desc"] } ] } ] } }, viewer: BpmnSubProcessViewer, filters: { LINE_OBI_FILTER: lineObiCheck }, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_27 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: subprocess }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$3 = { name: "ddei-flow-bpmn-viewer-user-task", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } }, methods: { refreshDragState(type) { if (type == 1) { this.$refs["divElement"].style.borderColor = "green"; } else { this.$refs["divElement"].style.borderColor = ""; } } } }; const bpmnUserTaskViewer_vue_vue_type_style_index_0_scoped_0b07ef9d_lang = ""; const _hoisted_1$3 = { ref: "divElement", class: "ddei-flow-bpmn-viewer-user-task" }; const _hoisted_2$2 = { class: "title" }; const _hoisted_3$2 = { class: "text" }; const _hoisted_4$2 = { class: "markers" }; const _hoisted_5$1 = { key: 0, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_6$1 = { key: 1, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_7$1 = { key: 2, class: "icon-ddei-flow", "aria-hidden": "true" }; const _hoisted_8$1 = { key: 3, class: "icon-ddei-flow", "aria-hidden": "true" }; function _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$3, [ vue.createElementVNode("div", _hoisted_2$2, [ _cache[0] || (_cache[0] = vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-user" }) ], -1)), vue.createElementVNode("div", _hoisted_3$2, vue.toDisplayString($props.editor.i18n($props.model.name ? $props.model.name : "ddei.flow.usertask")), 1) ]), vue.createElementVNode("div", _hoisted_4$2, [ $props.model.isLoop == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_5$1, _cache[1] || (_cache[1] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-loop-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel != 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_6$1, _cache[2] || (_cache[2] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-sequential-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.multiInstance == 1 && $props.model.isParallel == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_7$1, _cache[3] || (_cache[3] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-parallel-mi-marker" }, null, -1) ]))) : vue.createCommentVNode("", true), $props.model.isCompensation == 1 ? (vue.openBlock(), vue.createElementBlock("svg", _hoisted_8$1, _cache[4] || (_cache[4] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-compensation-marker" }, null, -1) ]))) : vue.createCommentVNode("", true) ]) ], 512); } const BpmnUserTaskViewer = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["render", _sfc_render$3], ["__scopeId", "data-v-0b07ef9d"]]); const userTask = { id: "1000011", name: "ddei.flow.usertask", code: "user_task", desc: "bpmn中的UserTask", from: "100002", subject: "bpmn", define: { bpmnBaseType: "Activity", bpmnType: "UserTask", width: 110, height: 70, border: { round: 5 }, ext: { attrs: [ { "code": "code", "name": "ddei.code", "desc": "用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "user_task", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "任务的名称", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.usertask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "humanPerformer", "name": "ddei.flow.property.humanperformer", "desc": "任务的执行人", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.property.humanperformer", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "potentialOwner", "name": "ddei.flow.property.potentialowner", "desc": "任务的候选人", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.property.potentialowner", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "isLoop", "name": "dde.flow.loop", "desc": "dde.flow.loop", "controlType": "switch-checkbox", "dataType": "integer", "hiddenTitle": true, "display": "column", "defaultValue": 0, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "multiInstance", "name": "ddei.flow.multiins", "desc": "执行人是多个实例", "controlType": "switch-checkbox", "dataType": "integer", "defaultValue": 0, "hiddenTitle": true, "display": "column", "type": [1, 2], //类别,1图形,2业务,3事件 "cascadeDisplay": { 0: { hidden: ["isParallel"] }, 1: { show: ["isParallel"] }, default: { hidden: ["isParallel"] }, empty: { hidden: ["isParallel"] } } }, { "code": "isParallel", "name": "ddei.flow.parallel", "desc": "多个执行人是否并行执行", "controlType": "switch-checkbox", "dataType": "integer", "display": "column", "hiddenTitle": true, "defaultValue": 0, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "isCompensation", "name": "ddei.flow.compensation", "desc": "是否为补偿", "controlType": "switch-checkbox", "dataType": "integer", "display": "column", "hiddenTitle": true, "defaultValue": 0, "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.usertask", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "border.color", "name": "ddei.color", "desc": "图形的边框显示颜色,在高级设置中,可以分别设置不同方向边框的样式", "controlType": "color-combo", "dataType": "string", "defaultValue": "black" } ], groups: [ { "name": "ddei.data", icon: "icon-a-ziyuan409", subGroups: [ { "name": "ddei.basic", attrs: ["code", "name", "isLoop", "multiInstance", "isParallel", "isCompensation", "desc"] } ] } ] } }, filters: { LINE_OBI_FILTER: lineObiCheck }, viewer: BpmnUserTaskViewer, icon: ``, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_28 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: userTask }, Symbol.toStringTag, { value: "Module" })); const _sfc_main$2 = { name: "ddei-flow-bpmn-viewer-user", props: { model: { type: Object, default: null }, editor: { type: Object, default: null } } }; const bpmnUserViewer_vue_vue_type_style_index_0_scoped_9e90d175_lang = ""; const _hoisted_1$2 = { ref: "divElement", class: "ddei-flow-bpmn-viewer-user", title: "用户" }; function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) { return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$2, _cache[0] || (_cache[0] = [ vue.createElementVNode("svg", { class: "icon-ddei-flow", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-user" }) ], -1) ]), 512); } const BpmnUserViewer = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["render", _sfc_render$2], ["__scopeId", "data-v-9e90d175"]]); const user = { id: "1000504", name: "ddei.flow.user", code: "user", desc: "bpmn中的用户对象", from: "100103", subject: "bpmn", define: { width: 30, height: 45, bpmnBaseType: "Other", bpmnType: "User", name: "ddei.flow.user", ext: { sample: { //依附图形的初始化配置,如果产生依附图形,则会在配置的位置生成 depPos: { type: 8 //位置5中心点,6789上右下左 }, depProps: { "8": "name" //映射属性 } }, attrs: [ { "code": "code", "name": "ddei.code", "desc": "编码,一般用于业务标识", "controlType": "text", "dataType": "string", "defaultValue": "user", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "name", "name": "ddei.name", "desc": "名称,一般用于显示", "controlType": "text", "dataType": "string", "defaultValue": "ddei.flow.user", "type": [1, 2] //类别,1图形,2业务,3事件 }, { "code": "desc", "name": "ddei.description", "desc": "备注说明", "controlType": "textarea", "dataType": "string", "defaultValue": "ddei.flow.user", "type": [1, 2] //类别,1图形,2业务,3事件 } ] } }, viewer: BpmnUserViewer, icon: ``, filters: { LINE_OBI_FILTER: lineObiCheck }, EVENT_MOUSE_MOVE_IN_CONTROL: showSettingButton }; const __vite_glob_0_29 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: user }, Symbol.toStringTag, { value: "Module" })); const bpmn = { "id": "1000", "name": "ddei.flow.groups.bpmn", "code": "bpmn-flow-shapes", "desc": "ddei.flow.groups.bpmndesc", "orderNo": 1, "subject": "flow", //当前分组下所有控件 "controls": [ { "id": "1000001", "orderNo": 1 }, { "id": "1000004", "orderNo": 2 }, { "id": "1000002", "orderNo": 3 }, { "id": "1000005", "orderNo": 4 }, { "id": "1000003", "orderNo": 5 }, { "id": "1000011", "orderNo": 11 }, { "id": "1000021", "orderNo": 21 }, { "id": "1000031", "orderNo": 31 }, { "id": "1000041", "orderNo": 41 }, { "id": "1000051", "orderNo": 51 }, { "id": "1000061", "orderNo": 61 }, { "id": "1000071", "orderNo": 71 }, { "id": "1000081", "orderNo": 81 }, { "id": "1000091", "orderNo": 91 }, { "id": "1000101", "orderNo": 101 }, { "id": "1000102", "orderNo": 102 }, { "id": "1000201", "orderNo": 201 }, { "id": "1000202", "orderNo": 202 }, { "id": "1000203", "orderNo": 203 }, { "id": "1000204", "orderNo": 204 }, { "id": "1000205", "orderNo": 205 }, { "id": "1000401", "orderNo": 401 }, { "id": "1000501", "orderNo": 501 }, { "id": "1000504", "orderNo": 504 }, { "id": "1000505", "orderNo": 505 }, { "id": "1000506", "orderNo": 506 }, { "id": "1000507", "orderNo": 507 }, { "id": "1000601", "orderNo": 601 }, { "id": "1000701", "orderNo": 701 } ] }; const __vite_glob_1_0 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, default: bpmn }, Symbol.toStringTag, { value: "Module" })); const control_ctx = /* @__PURE__ */ Object.assign({ "./bpmn/Inclusive-gateway.ts": __vite_glob_0_0, "./bpmn/boundary-event.ts": __vite_glob_0_1, "./bpmn/businessrule-task.ts": __vite_glob_0_2, "./bpmn/callactivity-task.ts": __vite_glob_0_3, "./bpmn/choreography-subprocess.ts": __vite_glob_0_4, "./bpmn/choreography-task.ts": __vite_glob_0_5, "./bpmn/comment.ts": __vite_glob_0_6, "./bpmn/complex-gateway.ts": __vite_glob_0_7, "./bpmn/data-object.ts": __vite_glob_0_8, "./bpmn/datastore.ts": __vite_glob_0_9, "./bpmn/datastore1.ts": __vite_glob_0_10, "./bpmn/end-event.ts": __vite_glob_0_11, "./bpmn/eventbased-gateway.ts": __vite_glob_0_12, "./bpmn/exclusive-gateway.ts": __vite_glob_0_13, "./bpmn/group.ts": __vite_glob_0_14, "./bpmn/intermediate-catch-event.ts": __vite_glob_0_15, "./bpmn/intermediate-throw-event.ts": __vite_glob_0_16, "./bpmn/manual-task.ts": __vite_glob_0_17, "./bpmn/message.ts": __vite_glob_0_18, "./bpmn/parallel-gateway.ts": __vite_glob_0_19, "./bpmn/receive-task.ts": __vite_glob_0_20, "./bpmn/script-task.ts": __vite_glob_0_21, "./bpmn/send-task.ts": __vite_glob_0_22, "./bpmn/sequence-flow-icon.ts": __vite_glob_0_23, "./bpmn/sequence-flow.ts": __vite_glob_0_24, "./bpmn/service-task.ts": __vite_glob_0_25, "./bpmn/start-event.ts": __vite_glob_0_26, "./bpmn/subprocess.ts": __vite_glob_0_27, "./bpmn/user-task.ts": __vite_glob_0_28, "./bpmn/user.ts": __vite_glob_0_29 }); const group_ctx = /* @__PURE__ */ Object.assign({ "./groups/bpmn.ts": __vite_glob_1_0 }); const _DDeiFlowControls = class _DDeiFlowControls extends ddeiEditor.DDeiPluginBase { constructor() { super(...arguments); __publicField(this, "controls", /* @__PURE__ */ new Map()); } getControls(editor) { let extOptions = this.getOptions(); let controls = /* @__PURE__ */ new Map(); let controls1 = new Map(editor.controls); for (let i in control_ctx) { let control = control_ctx[i].default; if (control) { let c = ddeiEditor.cloneDeep(control); controls.set(control.id, c); controls1.set(control.id, c); if (extOptions && extOptions[control.id]) { for (let x in extOptions[control.id]) { c.define[x] = extOptions[control.id][x]; } } } } controls.forEach((control) => { ddeiEditor.loadControlByFrom(controls1, control); }); this.controls = controls; return controls; } getGroups(editor) { if (!this.controls) { this.getControls(editor); } let groups = []; for (let path in group_ctx) { groups.push(group_ctx[path].default); } ddeiEditor.loadAndSortGroup(groups, this.controls); return groups; } static modify(fn) { return _DDeiFlowControls.defaultIns.modify(fn); } static configuration(options) { if (options) { let controls = new _DDeiFlowControls(options); return controls; } return _DDeiFlowControls; } }; /** * 缺省实例 */ __publicField(_DDeiFlowControls, "defaultIns", new _DDeiFlowControls(null)); let DDeiFlowControls = _DDeiFlowControls; const _DDeiFlowLifeCycle = class _DDeiFlowLifeCycle extends ddeiEditor.DDeiLifeCycle { constructor() { super(...arguments); __publicField(this, "name", "ddei-flow-lifecycle"); /** * 鼠标移动进入控件的钩子,该插件由它来进行整体分发 */ __publicField(this, "EVENT_MOUSE_MOVE_IN_CONTROL", new ddeiEditor.DDeiFuncData("ddei-flow-mouse-move-in-control", 1, (operateType, data2, ddInstance, evt) => { return this.mouseMoveInControl(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_MOUSE_OPERATING", new ddeiEditor.DDeiFuncData("ddei-flow-hidden-eles", 1, (operateType, data2, ddInstance, evt) => { return this.mouseOperating(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CONTROL_DRAGING", new ddeiEditor.DDeiFuncData("ddei-flow-control-draging", 1, (operateType, data2, ddInstance, evt) => { return this.controlDraging(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CONTROL_DRAG_AFTER", new ddeiEditor.DDeiFuncData("ddei-flow-control-drag-after", 1, (operateType, data2, ddInstance, evt) => { return this.controlDragAfter(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CONTROL_CREATE_AFTER", new ddeiEditor.DDeiFuncData("ddei-flow-control-create-after", 1, (operateType, data2, ddInstance, evt) => { return this.controlCreateAfter(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CONTROL_CREATE_BEFORE", new ddeiEditor.DDeiFuncData("ddei-flow-control-create-before", 1, (operateType, data2, ddInstance, evt) => { return this.controlCreateBefore(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_COPY_BEFORE", new ddeiEditor.DDeiFuncData("ddei-flow-copy-before", 1, (operateType, data2, ddInstance, evt) => { return this.controlCopyBefore(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CONTROL_DRAG_BEFORE", new ddeiEditor.DDeiFuncData("ddei-flow-control-drag-before", 1, (operateType, data2, ddInstance, evt) => { return this.controlDragBefore(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CONTROL_ROTATE_BEFORE", new ddeiEditor.DDeiFuncData("ddei-flow-control-rotate-before", 1, (operateType, data2, ddInstance, evt) => { return this.controlDragBefore(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CLOSE_FILE_AFTER", new ddeiEditor.DDeiFuncData("ddei-flow-hidden-eles", 1, (operateType, data2, ddInstance, evt) => { return this.hiddenTempElements(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CONTROL_DEL_AFTER", new ddeiEditor.DDeiFuncData("ddei-flow-control-del-after", 1, (operateType, data2, ddInstance, evt) => { return this.controlDelAfter(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CONTROL_SELECT_BEFORE", new ddeiEditor.DDeiFuncData("ddei-flow-control-select-before", 1, (operateType, data2, ddInstance, evt) => { return this.controlSelectBefore(operateType, data2, ddInstance, evt); })); __publicField(this, "EVENT_CONTROL_DBL_CLICK", new ddeiEditor.DDeiFuncData("ddei-flow-control-dbl-click", 1, (operateType, data2, ddInstance, evt) => { return this.controlDblClick(operateType, data2, ddInstance, evt); })); __publicField(this, "dragModels", null); /** * 鼠标移动进入画布的钩子 */ __publicField(this, "EVENT_MOUSE_MOVE_IN_LAYER", new ddeiEditor.DDeiFuncData("ddei-flow-mouse-move-in-control", 1, (operateType, data2, ddInstance, evt) => { return this.mouseMoveInLayer(operateType, data2, ddInstance, evt); })); } /** * 控件双击 * @param operateType * @param data * @param ddInstance * @param evt * @returns */ controlDblClick(operateType, data2, ddInstance, evt) { if ((data2 == null ? void 0 : data2.models) && data2.models.length > 0) { let model = data2.models[0]; if (model.bpmnBaseType == "Event" || model.bpmnBaseType == "Activity" || model.bpmnBaseType == "Gateway" || model.bpmnBaseType == "Group") { let result = new ddeiEditor.DDeiFuncCallResult(); result.state = -1; return result; } } } /** * 拖拽中 */ controlDraging(operateType, data2, ddInstance, evt) { var _a, _b; if (this.markHiddenPanel) { let toolBoxs = document.getElementsByClassName("ddei-core-panel-toolbox-simple"); for (let i = 0; i < toolBoxs.length; i++) { toolBoxs[i].style.display = "none"; } let topMenus = document.getElementsByClassName("ddei-core-panel-topmenu-simple"); for (let i = 0; i < topMenus.length; i++) { topMenus[i].style.display = "none"; } delete this.markHiddenPanel; } if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) { let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); let models = [...data2.models]; if ((models == null ? void 0 : models.length) == 1 && (models[0].bpmnType == "StartEvent" || models[0].bpmnType == "BoundaryEvent")) { let evtModel = data2.models[0]; let activities = editor.activities; let attachModel = null; for (let n = 0; n < activities.length; n++) { let subModel = activities[n]; let k = editor.viewerMap.get(subModel.id); if (!attachModel && evtModel.isInRect(subModel.essBounds.x, subModel.essBounds.y, subModel.essBounds.x + subModel.essBounds.width, subModel.essBounds.y + subModel.essBounds.height) && (Math.abs(subModel.essBounds.x - evtModel.cpv.x) <= 3 || Math.abs(subModel.essBounds.x1 - evtModel.cpv.x) <= 3 || Math.abs(subModel.essBounds.y - evtModel.cpv.y) <= 3 || Math.abs(subModel.essBounds.y1 - evtModel.cpv.y) <= 3)) { attachModel = subModel; k.component.ctx.refreshDragState(1); } else { k.component.ctx.refreshDragState(0); } } } if (((_a = editor.desigingSubProecsses) == null ? void 0 : _a.length) > 0) { let model = models[0]; for (let i = 0; i < ((_b = editor.desigingSubProecsses) == null ? void 0 : _b.length); i++) { let containerModel = editor.desigingSubProecsses[i]; let isIn = false; if (model.isInRect(containerModel.essBounds.x, containerModel.essBounds.y, containerModel.essBounds.x + containerModel.essBounds.width, containerModel.essBounds.y + containerModel.essBounds.height)) { let k = editor.viewerMap.get(containerModel.id); if (!k.component.ctx.isInRect || k.component.ctx.isInRect && k.component.ctx.isInRect(model)) { k.component.ctx.refreshDragState(1); isIn = true; } } if (!isIn) { let k = editor.viewerMap.get(containerModel.id); k.component.ctx.refreshDragState(0); } } } this.hiddenTempElements(operateType, data2, ddInstance, evt); } } controlCopyBefore(operateType, data2, ddInstance, evt) { var _a; if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) { if (((_a = data2.models) == null ? void 0 : _a.size) > 0) { let lines = []; data2.models.forEach((model) => { if (model.allowIncludeModel) { let models = getIncludeModels(model); models.forEach((m) => { data2.models.set(m.id, m); let links2 = m.stage.getSourceModelLinks(m.id); links2 == null ? void 0 : links2.forEach((lk) => { if (lines.indexOf(lk.dm) == -1) { lines.push(lk.dm); } else { if (!data2.models.has(lk.dm.id)) { data2.models.set(lk.dm.id, lk.dm); } } }); }); let links = model.stage.getSourceModelLinks(model.id); links == null ? void 0 : links.forEach((lk) => { if (lines.indexOf(lk.dm) == -1) { lines.push(lk.dm); } else { if (!data2.models.has(lk.dm.id)) { data2.models.set(lk.dm.id, lk.dm); } } }); } }); } } } controlCreateBefore(operateType, data2, ddInstance, evt) { var _a; if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) { if (((_a = data2.models) == null ? void 0 : _a.length) > 0) { this.markHiddenPanel = true; this.dragModels = data2.models; this.resetSubProcesses(data2, ddInstance); } } } /** * 修改模型ID * @param stage 舞台 * @param item 控件 * @return 新的ID */ changeModelId(stage, item) { let newId = ""; while (true) { stage.idIdx++; if (item.id.indexOf("_") != -1) { newId = item.id.substring(0, item.id.lastIndexOf("_")) + "_" + stage.idIdx; } else { newId = item.id + "_cp_" + stage.idIdx; } if (!stage.getModelById(newId)) { break; } } item.oldId = item.id; item.id = newId; item.unicode = ddeiEditor.DDeiUtil.getUniqueCode(); let accuContainer = item.getAccuContainer(); if ((accuContainer == null ? void 0 : accuContainer.baseModelType) == "DDeiContainer") { let midList = []; let models = /* @__PURE__ */ new Map(); accuContainer.midList.forEach((mid) => { let model = accuContainer.models.get(mid); let modelNewId = this.changeModelId(stage, model); models.set(modelNewId, model); midList.push(modelNewId); }); accuContainer.models = models; accuContainer.midList = midList; } else if ((accuContainer == null ? void 0 : accuContainer.baseModelType) == "DDeiTable") { for (let i = 0; i < accuContainer.rows; i++) { let rowObj = accuContainer.rows[i]; for (let j = 0; j < rowObj.length; j++) { let accuContainer2 = rowObj[j].getAccuContainer(); let midList = []; let models = /* @__PURE__ */ new Map(); accuContainer2.midList.forEach((mid) => { let model = accuContainer2.models.get(mid); let modelNewId = this.changeModelId(stage, model); models.set(modelNewId, model); midList.push(modelNewId); }); accuContainer2.models = models; accuContainer2.midList = midList; } } } return newId; } /** * 拖拽前 */ controlDragBefore(operateType, data2, ddInstance, evt) { var _a; if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) { if (((_a = data2.models) == null ? void 0 : _a.length) > 0) { let toolBoxs = document.getElementsByClassName("ddei-core-panel-toolbox-simple"); for (let i = 0; i < toolBoxs.length; i++) { toolBoxs[i].style.display = "none"; } let topMenus = document.getElementsByClassName("ddei-core-panel-topmenu-simple"); for (let i = 0; i < topMenus.length; i++) { topMenus[i].style.display = "none"; } data2.models.forEach((model) => { let models = getIncludeModels(model); models.forEach((m) => { data2.models.push(m); }); }); this.dragModels = [...data2.models]; this.resetSubProcesses(data2, ddInstance); } } } resetSubProcesses(data2, ddInstance) { let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); let layer = data2.models[0].layer ? data2.models[0].layer : editor.ddInstance.stage.layers[editor.ddInstance.stage.layerIndex]; let subModels = layer.getSubModels(null, 20); editor.desigingSubProecsses = []; editor.activities = []; subModels == null ? void 0 : subModels.forEach((mds) => { if (mds.allowIncludeModel) { if (data2.models.indexOf(mds) == -1) { if (!mds.lock && mds.isExpand) { editor.desigingSubProecsses.push(mds); } } } if (mds.bpmnBaseType == "Activity") { editor.activities.push(mds); } }); editor.desigingSubProecsses.sort((a, b) => { if ((a == null ? void 0 : a.render) && (b == null ? void 0 : b.render)) { return a.render.tempZIndex - b.render.tempZIndex; } return 0; }); editor.activities.sort((a, b) => { if ((a == null ? void 0 : a.render) && (b == null ? void 0 : b.render)) { return a.render.tempZIndex - b.render.tempZIndex; } return 0; }); } modelsToTreeRoot(models, stage) { let treeRoot = []; let cachedModel = {}; models.forEach((model) => { if (model.baseModelType != "DDeiLine") { if (model.pModel == model.layer && !model.includePModelId) { if (treeRoot.indexOf(model)) { treeRoot.push(model); } } else if (model.pModel != model.layer && !model.includePModelId) { if (models.indexOf(model.pModel) == -1) { if (treeRoot.indexOf(model)) { treeRoot.push(model); } } } else if (model.includePModelId) { let includePModelId = model.includePModelId; let include = false; while (includePModelId) { let ipm = cachedModel[includePModelId]; if (!ipm) { ipm = stage.getModelById(includePModelId); cachedModel[includePModelId] = ipm; } if (ipm) { if (models.indexOf(ipm) != -1) { include = true; break; } includePModelId = ipm.includePModelId; } else { break; } } if (!include) { if (treeRoot.indexOf(model)) { treeRoot.push(model); } } } } }); return treeRoot; } changeNodeZIndexDeep(model, parentNode, stage) { var _a; let len = parentNode.includeModels.length; let oldZindex = model.zIndex ? model.zIndex : len; model.zIndex = parentNode.zIndex ? parentNode.zIndex + oldZindex : oldZindex; (_a = model.includeModels) == null ? void 0 : _a.forEach((imid) => { let imodel = stage.getModelById(imid); if (imodel) { this.changeNodeZIndexDeep(imodel, model, stage); } }); let links = stage.getSourceModelLinks(model.id); links == null ? void 0 : links.forEach((link) => { this.changeNodeZIndexDeep(link.dm, parentNode, stage); }); } controlCreateAfter(operateType, data2, ddInstance, evt) { var _a; (_a = this.dragModels) == null ? void 0 : _a.forEach((dmodel) => { var _a2; if (dmodel.includePModelId) { for (let k = 0; k < ((_a2 = this.dragModels) == null ? void 0 : _a2.length); k++) { if (this.dragModels[k].oldId == dmodel.includePModelId) { let subProcessModel = this.dragModels[k]; dmodel.includePModelId = subProcessModel.id; let oldIndex = subProcessModel.includeModels.indexOf(dmodel.oldId); if (oldIndex != -1) { subProcessModel.includeModels.splice(oldIndex, 1, dmodel.id); } break; } } } }); this.controlDragAfter(operateType, data2, ddInstance, evt); } /** * 拖拽后 */ controlDragAfter(operateType, data2, ddInstance, evt) { var _a, _b, _c, _d, _e, _f, _g; if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) { let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); let attachModel = null; if (((_a = data2.models) == null ? void 0 : _a.length) == 1 && (data2.models[0].bpmnType == "StartEvent" || data2.models[0].bpmnType == "BoundaryEvent")) { let evtModel = data2.models[0]; let activities = editor.activities; let stage = evtModel.stage; let id = evtModel.id; if (id.indexOf("_shadow") != -1) { id = id.substring(0, id.indexOf("_shadow")); evtModel = stage.getModelById(id); } if (evtModel.attachPModel) { let oldattachPModel = stage.getModelById(evtModel.attachPModel); (_c = oldattachPModel.attachModels) == null ? void 0 : _c.splice((_b = oldattachPModel.attachModels) == null ? void 0 : _b.indexOf(evtModel.id)); delete evtModel.attachPModel; } for (let n = 0; n < activities.length; n++) { let subModel = activities[n]; let k = editor.viewerMap.get(subModel.id); if (!attachModel && evtModel.isInRect(subModel.essBounds.x, subModel.essBounds.y, subModel.essBounds.x + subModel.essBounds.width, subModel.essBounds.y + subModel.essBounds.height) && (Math.abs(subModel.essBounds.x - evtModel.cpv.x) <= 3 || Math.abs(subModel.essBounds.x1 - evtModel.cpv.x) <= 3 || Math.abs(subModel.essBounds.y - evtModel.cpv.y) <= 3 || Math.abs(subModel.essBounds.y1 - evtModel.cpv.y) <= 3)) { evtModel.attachPModel = subModel.id; if (!subModel.attachModels) { subModel.attachModels = []; } subModel.attachModels.push(evtModel.id); attachModel = subModel; } k.component.ctx.refreshDragState(0); } } if (((_d = editor.desigingSubProecsses) == null ? void 0 : _d.length) > 0 && ((_e = this.dragModels) == null ? void 0 : _e.length) > 0) { let dragParentActiveIds = []; let dragContainerModel = null; let model = this.dragModels[0]; let stage = ddInstance.stage; for (let i = 0; i < editor.desigingSubProecsses.length; i++) { let containerModel = editor.desigingSubProecsses[i]; let k = editor.viewerMap.get(containerModel.id); if (attachModel != containerModel && model.isInRect(containerModel.essBounds.x, containerModel.essBounds.y, containerModel.essBounds.x + containerModel.essBounds.width, containerModel.essBounds.y + containerModel.essBounds.height)) { if (!k.component.ctx.isInRect || k.component.ctx.isInRect && k.component.ctx.isInRect(model)) { dragContainerModel = containerModel; } } k.component.ctx.refreshDragState(0); } let pid; if (dragContainerModel) { pid = dragContainerModel.id; if (pid.indexOf("_shadow") != -1) { pid = pid.substring(0, pid.indexOf("_shadow")); } } let dmodels = []; (_f = this.dragModels) == null ? void 0 : _f.forEach((dm) => { let id = dm.id; if (id.indexOf("_shadow") != -1) { id = id.substring(0, id.indexOf("_shadow")); dmodels.push(stage.getModelById(id)); } else { dmodels.push(dm); } }); let treeRoots = this.modelsToTreeRoot(dmodels, stage); treeRoots == null ? void 0 : treeRoots.forEach((dmodel) => { var _a2; if (dmodel.depModel) { return; } let id = dmodel.id; if (id.indexOf("_shadow") != -1) { id = id.substring(0, id.indexOf("_shadow")); } let dSourceModel = stage.getModelById(id); if (dSourceModel) { if (dSourceModel.includePModelId) { let includePModel = null; for (let n = 0; n < editor.desigingSubProecsses.length; n++) { if (editor.desigingSubProecsses[n].id == dSourceModel.includePModelId) { includePModel = editor.desigingSubProecsses[n]; break; } } if (includePModel && includePModel.includeModels.indexOf(id) != -1) { includePModel.includeModels.splice(includePModel.includeModels.indexOf(id), 1); } dragParentActiveIds.push(dSourceModel.includePModelId); delete dSourceModel.includePModelId; delete dSourceModel.render.tempZIndex; } if (dragContainerModel) { if (!dragContainerModel.includeModels) { dragContainerModel.includeModels = []; } if (dragContainerModel.includeModels.indexOf(id) == -1) { dragContainerModel.includeModels.push(id); dSourceModel.includePModelId = pid; this.changeNodeZIndexDeep(dSourceModel, dragContainerModel, stage); } if (dragParentActiveIds.indexOf(pid) == -1) { dragParentActiveIds.push(pid); } } } (_a2 = dmodel.pModel) == null ? void 0 : _a2.resortModelByZIndex(); }); updateCallActivityView(stage, model.layer, dragParentActiveIds); } editor.bus.push("refresh-shape"); editor.bus.executeAll(); this.dragModels = null; if (((_g = data2.models) == null ? void 0 : _g.length) > 0) { let data1 = ddeiEditor.clone(data2); data1.model = data2.models[0]; changeSettingButtonPos(operateType, data1, ddInstance); } let toolBoxs = document.getElementsByClassName("ddei-core-panel-toolbox-simple"); for (let i = 0; i < toolBoxs.length; i++) { toolBoxs[i].style.display = ""; } let topMenus = document.getElementsByClassName("ddei-core-panel-topmenu-simple"); for (let i = 0; i < topMenus.length; i++) { topMenus[i].style.display = ""; } } } /** * 鼠标操作时、隐藏临时按钮 */ hiddenTempElements(operateType, data2, ddInstance, evt) { if (ddInstance && ddInstance["AC_DESIGN_EDIT"]) { let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); if (operateType == "DRAG" || operateType == "SCROLL_WORKING" || operateType == "CHANGE_RATIO" || operateType == "CHANGE_WPV" || operateType == "CHANGE_BOUNDS" || operateType == "CHANGE_ROTATE") { ddeiEditor.DDeiEditorUtil.hiddenDialog(editor, "ddei-flow-setting-button-dialog"); ddeiEditor.DDeiEditorUtil.hiddenDialog(editor, "ddei-flow-element-setting-dialog"); } } } mouseOperating(operateType, data2, ddInstance, evt) { return this.hiddenTempElements(operateType, data2, ddInstance, evt); } static configuration(options) { if (options && Object.keys(options).length !== 0) { let lcs = new _DDeiFlowLifeCycle(options); return lcs; } return _DDeiFlowLifeCycle; } static modify(fn) { return _DDeiFlowLifeCycle.defaultIns.modify(fn); } mouseMoveInControl(operate, data2, ddInstance, evt) { var _a, _b; let models = data2 == null ? void 0 : data2.models; if ((models == null ? void 0 : models.length) > 0) { let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); if (editor.tempChooseCallActivity) { if (models[0] != editor.tempChooseCallActivity && editor.tempCallActivity != models[0]) { if (models[0].id != editor.tempChooseCallActivity.id && (models[0].bpmnBaseType == "Activity" || models[0].bpmnBaseType == "Event")) { (_b = (_a = editor.tempCallActivity) == null ? void 0 : _a.render) == null ? void 0 : _b.clearCachedValue(); editor.tempCallActivity = models[0]; models[0].render.setCachedValue("border.color", "blue"); editor.bus.push("refresh-shape"); editor.bus.executeAll(); } } } else { for (let i = 0; i < models.length; i++) { if (models[i]) { let data1 = ddeiEditor.clone(data2); data1.model = models[i]; let rs = showSettingButton(operate, data1, ddInstance); if (rs && (rs.state == 2 || rs.state == -2)) { break; } } } } } } mouseMoveInLayer(operate, data2, ddInstance, evt) { var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m; let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); if (editor) { if (editor.tempCallActivity) { editor.tempCallActivity.render.clearCachedValue(); delete editor.tempCallActivity; } if (((_a = editor.ddInstance.stage.selectedModels) == null ? void 0 : _a.size) > 0) { return; } let settingBtnEle = document.getElementById(editor.id + "_ddei-flow-setting-button-dialog"); let settingDialogEle = document.getElementById(editor.id + "_ddei-flow-element-setting-dialog"); if (settingBtnEle && !settingDialogEle && !(evt.target == settingBtnEle || ((_b = evt.target) == null ? void 0 : _b.parentElement) == settingBtnEle || ((_c = evt.target.parentElement) == null ? void 0 : _c.parentElement) == settingBtnEle || ((_e = (_d = evt.target.parentElement) == null ? void 0 : _d.parentElement) == null ? void 0 : _e.parentElement) == settingBtnEle)) { ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-setting-button-dialog"); } else if (settingDialogEle && !settingBtnEle && !(evt.target == settingDialogEle || ((_f = evt.target) == null ? void 0 : _f.parentElement) == settingDialogEle || ((_g = evt.target.parentElement) == null ? void 0 : _g.parentElement) == settingDialogEle)) { ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-element-setting-dialog"); } else if (settingBtnEle && settingDialogEle && !(evt.target == settingBtnEle || ((_h = evt.target) == null ? void 0 : _h.parentElement) == settingBtnEle || ((_i = evt.target.parentElement) == null ? void 0 : _i.parentElement) == settingBtnEle || ((_k = (_j = evt.target.parentElement) == null ? void 0 : _j.parentElement) == null ? void 0 : _k.parentElement) == settingBtnEle) && !(evt.target == settingDialogEle || ((_l = evt.target) == null ? void 0 : _l.parentElement) == settingDialogEle || ((_m = evt.target.parentElement) == null ? void 0 : _m.parentElement) == settingDialogEle)) { ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-setting-button-dialog"); ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-element-setting-dialog"); } } } controlDelAfter(operateType, data2, ddInstance, evt) { let result = new ddeiEditor.DDeiFuncCallResult(); result.state = 1; let models = data2.models; let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); let stage = ddInstance.stage; models.forEach((model) => { let includeModels = getIncludeModels(model); includeModels.forEach((lms) => { stage.removeModel(lms, true); }); }); ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-setting-button-dialog"); ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-element-setting-dialog"); return result; } controlSelectBefore(operateType, data2, ddInstance, evt) { var _a, _b; let result = new ddeiEditor.DDeiFuncCallResult(); result.state = 1; let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); if (editor.tempChooseCallActivity) { if (editor.tempCallActivity) { editor.tempChooseCallActivity.activityId = editor.tempCallActivity.id; editor.tempChooseCallActivity.destroyRender(); editor.tempChooseCallActivity.initRender(); } (_b = (_a = editor.tempCallActivity) == null ? void 0 : _a.render) == null ? void 0 : _b.clearCachedValue(); delete editor.tempCallActivity; delete editor.tempChooseCallActivity; editor.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); editor.bus.executeAll(); result.state = -1; } return result; } }; /** * 缺省实例 */ __publicField(_DDeiFlowLifeCycle, "defaultIns", new _DDeiFlowLifeCycle()); let DDeiFlowLifeCycle = _DDeiFlowLifeCycle; const _DDeiFlowLifeCycles = class _DDeiFlowLifeCycles extends ddeiEditor.DDeiPluginBase { constructor() { super(...arguments); __publicField(this, "type", "package"); __publicField(this, "lifecycles", DDeiFlowLifeCycle); } getLifeCyclies(editor) { if (ddeiEditor.DDeiPluginBase.isSubclass(this.lifecycles, ddeiEditor.DDeiPluginBase)) { return this.lifecycles.defaultIns.getLifeCyclies(editor); } else if (this.lifecycles instanceof ddeiEditor.DDeiPluginBase) { return this.lifecycles.getLifeCyclies(editor); } } static modify(fn) { return _DDeiFlowLifeCycles.defaultIns.modify(fn); } static configuration(options) { let core = new _DDeiFlowLifeCycles(options); core.lifecycles = core.lifecycles.configuration(options); return core; } }; /** * 缺省实例 */ __publicField(_DDeiFlowLifeCycles, "defaultIns", new DDeiFlowLifeCycle(null)); let DDeiFlowLifeCycles = _DDeiFlowLifeCycles; const DialogBase = { props: { editor: { type: ddeiEditor.DDeiEditor, default: null } }, data: function() { return { forceRefresh: false }; }, methods: { forceRefreshView: function() { this.forceRefresh = false; this.$nextTick(() => { this.forceRefresh = true; if (this.refreshData) { this.refreshData(); } }); } }, mounted() { this.editor.dialogs[this.dialogId].viewer = this; } }; const _sfc_main$1 = { name: "ddei-flow-element-setting-dialog", mixins: [DialogBase], props: { //外部传入的插件扩展参数 options: { type: Object, default: null } }, data() { return { dialogId: "ddei-flow-element-setting-dialog", model: null, bpmnSubTypeDataSource: null, bpmnSubTypeIndex: -1, startPointTypeDataSource: null, startPointTypeIndex: -1, endPointTypeDataSource: null, endPointTypeIndex: -1, lineTypeDataSource: null, lineTypeIndex: -1, timeTypeIndex: -1, timeTypeDataSource: [ { text: "ddei.flow.property.ds.timedate", value: "timeDate" }, { text: "ddei.flow.property.ds.timeduration", value: "timeDuration" }, { text: "ddei.flow.property.ds.timecron", value: "CRON" } ], dataTypeDataSource: null, dataTypeIndex: -1 }; }, computed: {}, components: {}, watch: {}, created() { }, mounted() { this.editor.dialogs[this.dialogId].viewer = this; this.refreshData(); }, methods: { modelChangeProperty(model, property) { var _a, _b; if (!model || !property) { return; } let mds = [model]; if (this.editBefore && !this.editBefore( ddeiEditor.DDeiEnumOperateType.EDIT, mds, (_a = this.attrDefine) == null ? void 0 : _a.code, this.editor.ddInstance, null )) { return; } let paths = [property]; this.editor.bus.push( ddeiEditor.DDeiEnumBusCommandType.ModelChangeValue, { mids: [model.id], paths, value: model[property] }, null, true ); this.editor.bus.push(ddeiEditor.DDeiEditorEnumBusCommandType.RefreshEditorParts, { parts: ["topmenu"] }); this.editor.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); this.editor.bus.executeAll(); ddeiEditor.DDeiUtil.invokeCallbackFunc("EVENT_CONTROL_EDIT_AFTER", ddeiEditor.DDeiEnumOperateType.EDIT, { models: mds, propName: (_b = this.attrDefine) == null ? void 0 : _b.code }, this.editor.ddInstance, null); }, validItemCondition(item) { if (!item.condition) { return true; } else { let func = new Function("model", "item", "editor", "component", "return " + item.condition); let rs = func(this.model, item, this.editor, this); return rs; } }, forceRefreshView: function() { this.forceRefresh = false; this.$nextTick(() => { this.forceRefresh = true; if (this.refreshData) { this.refreshData(); } }); }, refreshData() { var _a, _b, _c, _d; if (this.editor.tempPopData) { this.model = (_a = this.editor.tempPopData[this.dialogId]) == null ? void 0 : _a.model; if (this.model) { let controlDefine = ddeiEditor.DDeiEditorUtil.getControlDefine(this.model); { let ds = (_b = controlDefine.attrDefineMap.get("bpmnSubType")) == null ? void 0 : _b.dataSource; if ((ds == null ? void 0 : ds.length) > 0) { for (let i = 0; i < ds.length; i++) { if (ds[i].value == this.model.bpmnSubType) { this.bpmnSubTypeIndex = i; break; } } } this.bpmnSubTypeDataSource = ds; } { let ds = (_c = controlDefine.attrDefineMap.get("dataType")) == null ? void 0 : _c.dataSource; if ((ds == null ? void 0 : ds.length) > 0) { for (let i = 0; i < ds.length; i++) { if (ds[i].value == this.model.dataType) { this.dataTypeIndex = i; break; } } } this.dataTypeDataSource = ds; } this.refreshPointType(); { let ds = (_d = controlDefine.attrDefineMap.get("type")) == null ? void 0 : _d.dataSource; if ((ds == null ? void 0 : ds.length) > 0) { let value = this.model.type ? this.model.type : 1; for (let i = 0; i < ds.length; i++) { if (ds[i].value == value) { this.lineTypeIndex = i; break; } } } this.lineTypeDataSource = ds; } { let ds = this.timeTypeDataSource; if ((ds == null ? void 0 : ds.length) > 0) { let value = this.model.timeType ? this.model.timeType : "timeDate"; for (let i = 0; i < ds.length; i++) { if (ds[i].value == value) { this.timeTypeIndex = i; break; } } } } } } }, refreshPointType() { var _a, _b, _c, _d; let controlDefine = ddeiEditor.DDeiEditorUtil.getControlDefine(this.model); { let ds = (_a = controlDefine.attrDefineMap.get("sp.type")) == null ? void 0 : _a.dataSource; if ((ds == null ? void 0 : ds.length) > 0) { let value = ((_b = this.model.sp) == null ? void 0 : _b.type) ? this.model.sp.type : -1; for (let i = 0; i < ds.length; i++) { if (ds[i].value == value) { this.startPointTypeIndex = i; break; } } } this.startPointTypeDataSource = ds; } { let ds = (_c = controlDefine.attrDefineMap.get("ep.type")) == null ? void 0 : _c.dataSource; if ((ds == null ? void 0 : ds.length) > 0) { let value = ((_d = this.model.ep) == null ? void 0 : _d.type) ? this.model.ep.type : -1; for (let i = 0; i < ds.length; i++) { if (ds[i].value == value) { this.endPointTypeIndex = i; break; } } } this.endPointTypeDataSource = ds; } }, /** * 切换BPMN类型 */ changeBpmnSubType(delta) { let editor = this.editor; let ds = this.bpmnSubTypeDataSource; this.bpmnSubTypeIndex += delta; if (this.bpmnSubTypeIndex >= ds.length) { this.model.bpmnSubType = ds[0].value; this.bpmnSubTypeIndex = 0; } else if (this.bpmnSubTypeIndex == -1) { this.model.bpmnSubType = ds[ds.length - 1].value; this.bpmnSubTypeIndex = ds.length - 1; } else { this.model.bpmnSubType = ds[this.bpmnSubTypeIndex].value; } if (this.model.bpmnBaseType == "Sequence") { this.changeLineBySubType(); } this.model.render.clearCachedValue(); this.model.initPVS(); this.model.render.enableRefreshShape(); editor.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); editor.bus.executeAll(); ddeiEditor.DDeiUtil.invokeCallbackFunc("EVENT_CONTENT_CHANGE_AFTER", "CHANGE", null, this.editor.ddInstance); }, /** * 切换数据类型 */ changeDataType(delta) { let ds = this.dataTypeDataSource; this.dataTypeIndex += delta; if (this.dataTypeIndex >= ds.length) { this.model.dataType = ds[0].value; this.dataTypeIndex = 0; } else if (this.dataTypeIndex == -1) { this.model.dataType = ds[ds.length - 1].value; this.dataTypeIndex = ds.length - 1; } else { this.model.dataType = ds[this.dataTypeIndex].value; } ddeiEditor.DDeiUtil.invokeCallbackFunc("EVENT_CONTENT_CHANGE_AFTER", "CHANGE", null, this.editor.ddInstance); }, /** * 切换时间类型 */ changeTimeType(delta) { let ds = this.timeTypeDataSource; this.timeTypeIndex += delta; if (this.timeTypeIndex >= ds.length) { this.model.timeType = ds[0].value; this.timeTypeIndex = 0; } else if (this.timeTypeIndex == -1) { this.model.timeType = ds[ds.length - 1].value; this.timeTypeIndex = ds.length - 1; } else { this.model.timeType = ds[this.timeTypeIndex].value; } ddeiEditor.DDeiUtil.invokeCallbackFunc("EVENT_CONTENT_CHANGE_AFTER", "CHANGE", null, this.editor.ddInstance); }, /** * 根据线段的bpmnSubType修改线的样式以及部分选项的范围值 */ changeLineBySubType() { let subType = this.model.bpmnSubType ? this.model.bpmnSubType : 1; delete this.model.sp; delete this.model.ep; delete this.model.dash; switch (subType) { case 1: { this.model.ep = { type: 51 }; break; } case 2: { this.model.sp = { type: 4 }; this.model.ep = { type: 51 }; break; } case 3: { this.model.ep = { type: 51 }; break; } case 4: { this.model.ep = { type: 5 }; this.model.sp = { type: 2 }; this.model.dash = [10, 5]; break; } case 5: { this.model.ep = { type: 0 }; this.model.sp = { type: 0 }; this.model.dash = [4, 4]; break; } } this.refreshPointType(); ddeiEditor.DDeiUtil.invokeCallbackFunc("EVENT_CONTENT_CHANGE_AFTER", "CHANGE", null, this.editor.ddInstance); }, /** * 切换连线类型 */ changeLineType(delta) { let editor = this.editor; let ds = this.lineTypeDataSource; this.lineTypeIndex += delta; if (this.lineTypeIndex >= ds.length) { this.model.type = ds[0].value; this.lineTypeIndex = 0; } else if (this.lineTypeIndex == -1) { this.model.type = ds[ds.length - 1].value; this.lineTypeIndex = ds.length - 1; } else { this.model.type = ds[this.lineTypeIndex].value; } this.model.render.clearCachedValue(); this.model.initPVS(); this.model.render.enableRefreshShape(); editor.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); editor.bus.executeAll(); ddeiEditor.DDeiUtil.invokeCallbackFunc("EVENT_CONTENT_CHANGE_AFTER", "CHANGE", null, this.editor.ddInstance); }, /** * 切换点的类型 */ changePointType(type, delta) { let editor = this.editor; if (type == 1) { let ds = this.startPointTypeDataSource; this.startPointTypeIndex += delta; if (!this.model.sp) { this.model.sp = {}; } if (this.startPointTypeIndex >= ds.length) { this.model.sp.type = ds[0].value; this.startPointTypeIndex = 0; } else if (this.startPointTypeIndex == -1) { this.model.sp.type = ds[ds.length - 1].value; this.startPointTypeIndex = ds.length - 1; } else { this.model.sp.type = ds[this.startPointTypeIndex].value; } } else if (type == 2) { let ds = this.endPointTypeDataSource; this.endPointTypeIndex += delta; if (!this.model.ep) { this.model.ep = {}; } if (this.endPointTypeIndex >= ds.length) { this.model.ep.type = ds[0].value; this.endPointTypeIndex = 0; } else if (this.endPointTypeIndex == -1) { this.model.ep.type = ds[ds.length - 1].value; this.endPointTypeIndex = ds.length - 1; } else { this.model.ep.type = ds[this.endPointTypeIndex].value; } } this.model.initPVS(); this.model.render.enableRefreshShape(); editor.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); editor.bus.executeAll(); ddeiEditor.DDeiUtil.invokeCallbackFunc("EVENT_CONTENT_CHANGE_AFTER", "CHANGE", null, this.editor.ddInstance); }, /** * 交换起点和终点 */ exchangePoints() { let editor = this.editor; this.model.exchangeStartAndEnd(); this.model.render.enableRefreshShape(); editor.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); editor.bus.executeAll(); ddeiEditor.DDeiUtil.invokeCallbackFunc("EVENT_CONTENT_CHANGE_AFTER", "CHANGE", null, this.editor.ddInstance); }, /** * 切换BPMN类型 */ changeBpmnLabel(label) { let editor = this.editor; if (!this.model[label]) { this.model[label] = 1; } else { this.model[label] = 0; } if (label == "displayView") { delete this.model.upActivityId; } this.model.render.clearCachedValue(); this.model.initPVS(); this.model.render.enableRefreshShape(); editor.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); editor.bus.executeAll(); ddeiEditor.DDeiUtil.invokeCallbackFunc("EVENT_CONTENT_CHANGE_AFTER", "CHANGE", null, this.editor.ddInstance); } } }; const ElementSettingDialog_vue_vue_type_style_index_0_scoped_2d6bc3f8_lang = ""; const _hoisted_1$1 = ["id"]; const _hoisted_2$1 = { class: "content" }; const _hoisted_3$1 = { style: { "display": "contents" } }; const _hoisted_4$1 = { key: 0, class: "row" }; const _hoisted_5 = { class: "change-bpmn-sub-type" }; const _hoisted_6 = { class: "change-bpmn-sub-type-text" }; const _hoisted_7 = { key: 1, class: "row" }; const _hoisted_8 = { class: "change-bpmn-sub-type" }; const _hoisted_9 = { class: "change-bpmn-sub-type-text" }; const _hoisted_10 = { key: 2, class: "row" }; const _hoisted_11 = ["title"]; const _hoisted_12 = { class: "change-property-text-title" }; const _hoisted_13 = { class: "change-property-text-input" }; const _hoisted_14 = ["placeholder"]; const _hoisted_15 = { key: 3, class: "row" }; const _hoisted_16 = { class: "change-bpmn-sub-type" }; const _hoisted_17 = { class: "change-bpmn-sub-type-text" }; const _hoisted_18 = { key: 4, class: "row" }; const _hoisted_19 = ["title"]; const _hoisted_20 = { class: "change-property-text-title" }; const _hoisted_21 = { class: "change-property-text-input" }; const _hoisted_22 = { key: 5, class: "row" }; const _hoisted_23 = ["title"]; const _hoisted_24 = { class: "change-property-text-title" }; const _hoisted_25 = { class: "change-property-text-input" }; const _hoisted_26 = { key: 6, class: "row" }; const _hoisted_27 = ["title"]; const _hoisted_28 = { class: "change-property-text-title" }; const _hoisted_29 = { class: "change-property-text-input" }; const _hoisted_30 = { key: 7, class: "row" }; const _hoisted_31 = ["title"]; const _hoisted_32 = { class: "change-property-text-title" }; const _hoisted_33 = { class: "change-property-text-input" }; const _hoisted_34 = ["placeholder"]; const _hoisted_35 = { key: 8, class: "row" }; const _hoisted_36 = ["title"]; const _hoisted_37 = { class: "change-property-text-title" }; const _hoisted_38 = { class: "change-property-text-input" }; const _hoisted_39 = ["placeholder"]; const _hoisted_40 = { key: 9, class: "row" }; const _hoisted_41 = ["title"]; const _hoisted_42 = { class: "change-property-text-title" }; const _hoisted_43 = { class: "change-property-text-input" }; const _hoisted_44 = ["placeholder"]; const _hoisted_45 = { key: 10, class: "row" }; const _hoisted_46 = ["title"]; const _hoisted_47 = { class: "change-property-text-title" }; const _hoisted_48 = { class: "change-property-text-input" }; const _hoisted_49 = ["placeholder"]; const _hoisted_50 = { key: 11, class: "row" }; const _hoisted_51 = ["title"]; const _hoisted_52 = { class: "change-property-text-title" }; const _hoisted_53 = { class: "change-property-text-input" }; const _hoisted_54 = ["placeholder"]; const _hoisted_55 = { key: 12, class: "row" }; const _hoisted_56 = { class: "change-bpmn-sub-type" }; const _hoisted_57 = { class: "change-bpmn-sub-type-text" }; const _hoisted_58 = { key: 13, class: "row" }; const _hoisted_59 = { class: "change-point-type" }; const _hoisted_60 = { class: "change-point-type-title" }; const _hoisted_61 = { class: "change-point-type-text" }; const _hoisted_62 = { key: 14, class: "row" }; const _hoisted_63 = { class: "quick-button-text" }; const _hoisted_64 = { key: 15, class: "row" }; const _hoisted_65 = { class: "change-point-type" }; const _hoisted_66 = { class: "change-point-type-title" }; const _hoisted_67 = { class: "change-point-type-text" }; const _hoisted_68 = { key: 16, class: "row" }; const _hoisted_69 = { key: 17, class: "row" }; const _hoisted_70 = { key: 18, class: "row" }; const _hoisted_71 = { key: 19, class: "row" }; const _hoisted_72 = { key: 20, class: "row" }; const _hoisted_73 = { key: 21, class: "row" }; const _hoisted_74 = ["title"]; const _hoisted_75 = { class: "change-property-text-title" }; const _hoisted_76 = { class: "change-property-text-input" }; const _hoisted_77 = ["placeholder"]; const _hoisted_78 = { key: 22, class: "row" }; const _hoisted_79 = { key: 23, class: "row" }; const _hoisted_80 = { key: 24, class: "row" }; const _hoisted_81 = { key: 25, class: "row" }; const _hoisted_82 = { key: 26, class: "row" }; const _hoisted_83 = { key: 27, class: "row" }; const _hoisted_84 = ["title"]; const _hoisted_85 = { class: "change-property-text-title" }; const _hoisted_86 = { class: "change-property-text-input" }; const _hoisted_87 = ["onUpdate:modelValue", "onChange", "placeholder"]; const _hoisted_88 = { key: 28, class: "row" }; const _hoisted_89 = ["title"]; const _hoisted_90 = { class: "change-property-textarea-title" }; const _hoisted_91 = { class: "change-property-textarea-input" }; const _hoisted_92 = ["onUpdate:modelValue", "onChange", "placeholder"]; function _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) { var _a, _b; return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", { key: 0, id: ((_a = _ctx.editor) == null ? void 0 : _a.id) + "_" + $data.dialogId, class: "ddei-flow-element-setting-dialog" }, [ vue.createElementVNode("div", _hoisted_2$1, [ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_b = $props.options) == null ? void 0 : _b.items, (item) => { var _a2, _b2, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L, _M, _N, _O, _P, _Q, _R; return vue.openBlock(), vue.createElementBlock("div", _hoisted_3$1, [ !item.viewer && item.id == "ddei-flow-change-bpmnsubtype" && $options.validItemCondition(item) && ((_a2 = $data.bpmnSubTypeDataSource) == null ? void 0 : _a2.length) > 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_4$1, [ vue.createElementVNode("div", _hoisted_5, [ (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[0] || (_cache[0] = ($event) => $options.changeBpmnSubType(-1)), style: { "width": "16px", "height": "16px" }, "aria-hidden": "true" }, _cache[33] || (_cache[33] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-left" }, null, -1) ]))), vue.createElementVNode("div", _hoisted_6, vue.toDisplayString(_ctx.editor.i18n($data.bpmnSubTypeDataSource[$data.bpmnSubTypeIndex].text)), 1), (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[1] || (_cache[1] = ($event) => $options.changeBpmnSubType(1)), style: { "width": "16px", "height": "16px" }, "aria-hidden": "true" }, _cache[34] || (_cache[34] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-right" }, null, -1) ]))) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-dataobject-setting" && $data.model.bpmnType == "DataObject" && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_7, [ vue.createElementVNode("div", _hoisted_8, [ (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[2] || (_cache[2] = ($event) => $options.changeDataType(-1)), style: { "width": "16px", "height": "16px" }, "aria-hidden": "true" }, _cache[35] || (_cache[35] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-left" }, null, -1) ]))), vue.createElementVNode("div", _hoisted_9, vue.toDisplayString(_ctx.editor.i18n($data.dataTypeDataSource[$data.dataTypeIndex].text)), 1), (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[3] || (_cache[3] = ($event) => $options.changeDataType(1)), style: { "width": "16px", "height": "16px" }, "aria-hidden": "true" }, _cache[36] || (_cache[36] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-right" }, null, -1) ]))) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-dataobject-setting" && $data.model.bpmnType == "DataObject" && $data.model.dataType == 8 && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_10, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_12, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.busicls")), 1), vue.createElementVNode("div", _hoisted_13, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => $data.model.customDataType = $event), placeholder: _ctx.editor.i18n("ddei.flow.busicls") }, null, 8, _hoisted_14), [ [vue.vModelText, $data.model.customDataType] ]) ]) ], 8, _hoisted_11) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-time-setting" && ($data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 3 || $data.model.bpmnType == "IntermediateCatchEvent" && ($data.model.bpmnSubType == 1 || !$data.model.bpmnSubType) || $data.model.bpmnType == "BoundaryEvent" && $data.model.bpmnSubType == 2) && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_15, [ vue.createElementVNode("div", _hoisted_16, [ (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[5] || (_cache[5] = ($event) => $options.changeTimeType(-1)), style: { "width": "16px", "height": "16px" }, "aria-hidden": "true" }, _cache[37] || (_cache[37] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-left" }, null, -1) ]))), vue.createElementVNode("div", _hoisted_17, vue.toDisplayString(_ctx.editor.i18n($data.timeTypeDataSource[$data.timeTypeIndex].text)), 1), (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[6] || (_cache[6] = ($event) => $options.changeTimeType(1)), style: { "width": "16px", "height": "16px" }, "aria-hidden": "true" }, _cache[38] || (_cache[38] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-right" }, null, -1) ]))) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-time-setting" && $data.model.timeType != "timeDuration" && $data.model.timeType != "CRON" && ($data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 3 || $data.model.bpmnType == "IntermediateCatchEvent" && ($data.model.bpmnSubType == 1 || !$data.model.bpmnSubType) || $data.model.bpmnType == "BoundaryEvent" && $data.model.bpmnSubType == 2) && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_18, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_20, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.time")), 1), vue.createElementVNode("div", _hoisted_21, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[7] || (_cache[7] = ($event) => $data.model.timeValue = $event), placeholder: "2011-03-11T12:13:14" }, null, 512), [ [vue.vModelText, $data.model.timeValue] ]) ]) ], 8, _hoisted_19) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-time-setting" && $data.model.timeType == "timeDuration" && ($data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 3 || $data.model.bpmnType == "IntermediateCatchEvent" && ($data.model.bpmnSubType == 1 || !$data.model.bpmnSubType) || $data.model.bpmnType == "BoundaryEvent" && $data.model.bpmnSubType == 2) && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_22, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_24, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.timeduration")), 1), vue.createElementVNode("div", _hoisted_25, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[8] || (_cache[8] = ($event) => $data.model.timeValue = $event), placeholder: "R3/PT10H/${EndDate}" }, null, 512), [ [vue.vModelText, $data.model.timeValue] ]) ]) ], 8, _hoisted_23) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-time-setting" && $data.model.timeType == "CRON" && ($data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 3 || $data.model.bpmnType == "IntermediateCatchEvent" && ($data.model.bpmnSubType == 1 || !$data.model.bpmnSubType) || $data.model.bpmnType == "BoundaryEvent" && $data.model.bpmnSubType == 2) && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_26, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_28, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.timecron")), 1), vue.createElementVNode("div", _hoisted_29, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[9] || (_cache[9] = ($event) => $data.model.timeValue = $event), placeholder: "0 0/5* * *?" }, null, 512), [ [vue.vModelText, $data.model.timeValue] ]) ]) ], 8, _hoisted_27) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-message-setting" && ($data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 2 || $data.model.bpmnType == "IntermediateCatchEvent" && $data.model.bpmnSubType == 2 || $data.model.bpmnType == "IntermediateThrowEvent" && $data.model.bpmnSubType == 2 || $data.model.bpmnType == "EndEvent" && $data.model.bpmnSubType == 2 || $data.model.bpmnType == "BoundaryEvent" && ($data.model.bpmnSubType == 1 || !$data.model.bpmnSubType)) && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_30, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_32, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.message")), 1), vue.createElementVNode("div", _hoisted_33, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[10] || (_cache[10] = ($event) => $data.model.messageName = $event), placeholder: _ctx.editor.i18n("ddei.flow.messagename") }, null, 8, _hoisted_34), [ [vue.vModelText, $data.model.messageName] ]) ]) ], 8, _hoisted_31) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-signal-setting" && ($data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 5 || $data.model.bpmnType == "IntermediateCatchEvent" && $data.model.bpmnSubType == 3 || $data.model.bpmnType == "IntermediateThrowEvent" && $data.model.bpmnSubType == 3 || $data.model.bpmnType == "EndEvent" && $data.model.bpmnSubType == 3 || $data.model.bpmnType == "BoundaryEvent" && $data.model.bpmnSubType == 3) && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_35, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_37, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.signal")), 1), vue.createElementVNode("div", _hoisted_38, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[11] || (_cache[11] = ($event) => $data.model.signalName = $event), placeholder: _ctx.editor.i18n("ddei.flow.signalname") }, null, 8, _hoisted_39), [ [vue.vModelText, $data.model.signalName] ]) ]) ], 8, _hoisted_36) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-escal-setting" && ($data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 8 || $data.model.bpmnType == "EndEvent" && $data.model.bpmnSubType == 5 || $data.model.bpmnType == "BoundaryEvent" && $data.model.bpmnSubType == 7 || $data.model.bpmnType == "IntermediateThrowEvent" && $data.model.bpmnSubType == 6) && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_40, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_42, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.escalation")), 1), vue.createElementVNode("div", _hoisted_43, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[12] || (_cache[12] = ($event) => $data.model.escalName = $event), placeholder: _ctx.editor.i18n("ddei.flow.escalname") }, null, 8, _hoisted_44), [ [vue.vModelText, $data.model.escalName] ]) ]) ], 8, _hoisted_41) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-error-setting" && ($data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 9 || $data.model.bpmnType == "IntermediateEvent" && $data.model.bpmnSubType == 27 || $data.model.bpmnType == "EndEvent" && $data.model.bpmnSubType == 6 || $data.model.bpmnType == "BoundaryEvent" && $data.model.bpmnSubType == 4) && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_45, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_47, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.errorcode")), 1), vue.createElementVNode("div", _hoisted_48, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[13] || (_cache[13] = ($event) => $data.model.errorCode = $event), placeholder: _ctx.editor.i18n("ddei.flow.errorcode") }, null, 8, _hoisted_49), [ [vue.vModelText, $data.model.errorCode] ]) ]) ], 8, _hoisted_46) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-condition-setting" && ($data.model.bpmnBaseType == "Sequence" && $data.model.bpmnSubType == 2 || $data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 4 || $data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 4) && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_50, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_52, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.condition")), 1), vue.createElementVNode("div", _hoisted_53, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[14] || (_cache[14] = ($event) => $data.model.condition = $event), placeholder: "${" + _ctx.editor.i18n("ddei.flow.conditionexpress") + "}" }, null, 8, _hoisted_54), [ [vue.vModelText, $data.model.condition] ]) ]) ], 8, _hoisted_51) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-linetype" && $options.validItemCondition(item) && ((_b2 = $data.lineTypeDataSource) == null ? void 0 : _b2.length) > 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_55, [ vue.createElementVNode("div", _hoisted_56, [ (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[15] || (_cache[15] = ($event) => $options.changeLineType(-1)), style: { "width": "16px", "height": "16px" }, "aria-hidden": "true" }, _cache[39] || (_cache[39] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-left" }, null, -1) ]))), vue.createElementVNode("div", _hoisted_57, vue.toDisplayString(_ctx.editor.i18n($data.lineTypeDataSource[$data.lineTypeIndex].text)), 1), (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[16] || (_cache[16] = ($event) => $options.changeLineType(1)), style: { "width": "16px", "height": "16px" }, "aria-hidden": "true" }, _cache[40] || (_cache[40] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-right" }, null, -1) ]))) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-linepointtype" && $options.validItemCondition(item) && ((_c = $data.model) == null ? void 0 : _c.bpmnSubType) == 5 && ((_d = $data.startPointTypeDataSource) == null ? void 0 : _d.length) > 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_58, [ vue.createElementVNode("div", _hoisted_59, [ vue.createElementVNode("div", _hoisted_60, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.startnode")), 1), (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[17] || (_cache[17] = ($event) => $options.changePointType(1, -1)), "aria-hidden": "true" }, _cache[41] || (_cache[41] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-left" }, null, -1) ]))), vue.createElementVNode("div", _hoisted_61, vue.toDisplayString(_ctx.editor.i18n($data.startPointTypeDataSource[$data.startPointTypeIndex].text)), 1), (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[18] || (_cache[18] = ($event) => $options.changePointType(1, 1)), "aria-hidden": "true" }, _cache[42] || (_cache[42] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-right" }, null, -1) ]))) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-linepointtype" && $options.validItemCondition(item) && ((_e = $data.model) == null ? void 0 : _e.bpmnBaseType) == "Sequence" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_62, [ vue.createElementVNode("div", { class: "quick-button", onClick: _cache[19] || (_cache[19] = ($event) => $options.exchangePoints()) }, [ vue.createElementVNode("div", _hoisted_63, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.exchange")), 1), _cache[43] || (_cache[43] = vue.createElementVNode("svg", { class: "icon", "aria-hidden": "true" }, [ vue.createElementVNode("use", { "xlink:href": "#icon-zhihuan" }) ], -1)) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-linepointtype" && $options.validItemCondition(item) && ((_f = $data.model) == null ? void 0 : _f.bpmnSubType) == 5 && ((_g = $data.endPointTypeDataSource) == null ? void 0 : _g.length) > 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_64, [ vue.createElementVNode("div", _hoisted_65, [ vue.createElementVNode("div", _hoisted_66, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.endnode")), 1), (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[20] || (_cache[20] = ($event) => $options.changePointType(2, -1)), "aria-hidden": "true" }, _cache[44] || (_cache[44] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-left" }, null, -1) ]))), vue.createElementVNode("div", _hoisted_67, vue.toDisplayString(_ctx.editor.i18n($data.endPointTypeDataSource[$data.endPointTypeIndex].text)), 1), (vue.openBlock(), vue.createElementBlock("svg", { class: "icon-ddei-flow", onClick: _cache[21] || (_cache[21] = ($event) => $options.changePointType(2, 1)), "aria-hidden": "true" }, _cache[45] || (_cache[45] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-right" }, null, -1) ]))) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-callactivity-review" && $options.validItemCondition(item) && ((_h = $data.model) == null ? void 0 : _h.bpmnType) == "CallActivityTask" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_68, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[22] || (_cache[22] = ($event) => $options.changeBpmnLabel("displayView")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_i = $data.model) == null ? void 0 : _i.displayView) != 1, "chk_state_checked": ((_j = $data.model) == null ? void 0 : _j.displayView) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_k = $data.model) == null ? void 0 : _k.displayView) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.overview")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && ((_l = $data.model) == null ? void 0 : _l.bpmnType) == "DataStore" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_69, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[23] || (_cache[23] = ($event) => $options.changeBpmnLabel("isUnlimited")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_m = $data.model) == null ? void 0 : _m.isUnlimited) != 1, "chk_state_checked": ((_n = $data.model) == null ? void 0 : _n.isUnlimited) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_o = $data.model) == null ? void 0 : _o.isUnlimited) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.unlimited")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && $data.model.bpmnType == "SubProcess" && $data.model.bpmnSubType == 4 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_70, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[24] || (_cache[24] = ($event) => $options.changeBpmnLabel("ordering")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_p = $data.model) == null ? void 0 : _p.ordering) != 1, "chk_state_checked": ((_q = $data.model) == null ? void 0 : _q.ordering) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_r = $data.model) == null ? void 0 : _r.ordering) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.ordering")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && ($data.model.bpmnType == "SubProcess" || $data.model.bpmnType == "ChoreographySubProcess") ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_71, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[25] || (_cache[25] = ($event) => $options.changeBpmnLabel("isLoop")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_s = $data.model) == null ? void 0 : _s.isLoop) != 1, "chk_state_checked": ((_t = $data.model) == null ? void 0 : _t.isLoop) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_u = $data.model) == null ? void 0 : _u.isLoop) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.loop")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && ((_v = $data.model) == null ? void 0 : _v.bpmnBaseType) == "Activity" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_72, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[26] || (_cache[26] = ($event) => $options.changeBpmnLabel("multiInstance")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_w = $data.model) == null ? void 0 : _w.multiInstance) != 1, "chk_state_checked": ((_x = $data.model) == null ? void 0 : _x.multiInstance) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_y = $data.model) == null ? void 0 : _y.multiInstance) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.multiins")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && ($data.model.multiInstance || $data.model.bpmnType == "StartEvent" && $data.model.bpmnSubType == 6 || $data.model.bpmnType == "BoundaryEvent" && $data.model.bpmnSubType == 9 || $data.model.bpmnType == "EndEvent" && $data.model.bpmnSubType == 4 || $data.model.bpmnType == "IntermediateCatchEvent" && $data.model.bpmnSubType == 6 || $data.model.bpmnType == "IntermediateThrowEvent" && $data.model.bpmnSubType == 5) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_73, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_75, vue.toDisplayString(_ctx.editor.i18n("ddei.flow.insnum")), 1), vue.createElementVNode("div", _hoisted_76, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": _cache[27] || (_cache[27] = ($event) => $data.model.loopCardinality = $event), placeholder: _ctx.editor.i18n("ddei.flow.insnum") }, null, 8, _hoisted_77), [ [vue.vModelText, $data.model.loopCardinality] ]) ]) ], 8, _hoisted_74) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && ((_z = $data.model) == null ? void 0 : _z.bpmnBaseType) == "Activity" && ((_A = $data.model) == null ? void 0 : _A.multiInstance) == 1 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_78, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[28] || (_cache[28] = ($event) => $options.changeBpmnLabel("isParallel")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_B = $data.model) == null ? void 0 : _B.isParallel) != 1, "chk_state_checked": ((_C = $data.model) == null ? void 0 : _C.isParallel) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_D = $data.model) == null ? void 0 : _D.isParallel) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.parallel")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && $data.model.bpmnType == "ChoreographySubProcess" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_79, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[29] || (_cache[29] = ($event) => $options.changeBpmnLabel("isAdHoc")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_E = $data.model) == null ? void 0 : _E.isAdHoc) != 1, "chk_state_checked": ((_F = $data.model) == null ? void 0 : _F.isAdHoc) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_G = $data.model) == null ? void 0 : _G.isAdHoc) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.property.custom")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && ($data.model.bpmnType == "BoundaryEvent" && ($data.model.bpmnSubType == 1 || !$data.model.bpmnSubType || $data.model.bpmnSubType == 2 || $data.model.bpmnSubType == 7 || $data.model.bpmnSubType == 8 || $data.model.bpmnSubType == 9) || ($data.model.bpmnType == "StartEvent" && ($data.model.bpmnSubType >= 2 && $data.model.bpmnSubType <= 8) || $data.model.bpmnSubType == 10)) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_80, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[30] || (_cache[30] = ($event) => $options.changeBpmnLabel("notInterrupting")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_H = $data.model) == null ? void 0 : _H.notInterrupting) != 1, "chk_state_checked": ((_I = $data.model) == null ? void 0 : _I.notInterrupting) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_J = $data.model) == null ? void 0 : _J.notInterrupting) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.notInterrupting")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && ((_K = $data.model) == null ? void 0 : _K.bpmnBaseType) == "Activity" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_81, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[31] || (_cache[31] = ($event) => $options.changeBpmnLabel("isCompensation")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_L = $data.model) == null ? void 0 : _L.isCompensation) != 1, "chk_state_checked": ((_M = $data.model) == null ? void 0 : _M.isCompensation) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_N = $data.model) == null ? void 0 : _N.isCompensation) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.compensation")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-change-activity-labels" && $options.validItemCondition(item) && ((_O = $data.model) == null ? void 0 : _O.bpmnType) == "DataObject" ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_82, [ vue.createElementVNode("div", { class: "change-bpmn-marker", onClick: _cache[32] || (_cache[32] = ($event) => $options.changeBpmnLabel("isCollection")) }, [ vue.createElementVNode("div", { class: vue.normalizeClass({ "chk_state": ((_P = $data.model) == null ? void 0 : _P.isCollection) != 1, "chk_state_checked": ((_Q = $data.model) == null ? void 0 : _Q.isCollection) == 1 }) }, [ vue.createElementVNode("span", null, vue.toDisplayString(((_R = $data.model) == null ? void 0 : _R.isCollection) == 1 ? "✓" : ""), 1) ], 2), vue.createTextVNode(" " + vue.toDisplayString(_ctx.editor.i18n("ddei.flow.datacoll")), 1) ]) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-property-editor-text" && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_83, [ vue.createElementVNode("div", { class: "change-property-text", title: item.desc }, [ vue.createElementVNode("div", _hoisted_85, vue.toDisplayString(_ctx.editor.i18n(item.label)), 1), vue.createElementVNode("div", _hoisted_86, [ vue.withDirectives(vue.createElementVNode("input", { "onUpdate:modelValue": ($event) => $data.model[item.property] = $event, onChange: ($event) => $options.modelChangeProperty($data.model, item.property), placeholder: _ctx.editor.i18n(item.desc) }, null, 40, _hoisted_87), [ [vue.vModelText, $data.model[item.property]] ]) ]) ], 8, _hoisted_84) ])) : vue.createCommentVNode("", true), !item.viewer && item.id == "ddei-flow-property-editor-textarea" && $options.validItemCondition(item) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_88, [ vue.createElementVNode("div", { class: "change-property-textarea", title: item.desc }, [ vue.createElementVNode("div", _hoisted_90, vue.toDisplayString(_ctx.editor.i18n(item.label)), 1), vue.createElementVNode("div", _hoisted_91, [ vue.withDirectives(vue.createElementVNode("textarea", { "onUpdate:modelValue": ($event) => $data.model[item.property] = $event, onChange: ($event) => $options.modelChangeProperty($data.model, item.property), placeholder: _ctx.editor.i18n(item.desc) }, null, 40, _hoisted_92), [ [vue.vModelText, $data.model[item.property]] ]) ]) ], 8, _hoisted_89) ])) : vue.createCommentVNode("", true), item.viewer && $options.validItemCondition(item) ? (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.viewer), vue.mergeProps({ key: 29, editor: _ctx.editor, options: $props.options, model: $data.model, ref_for: true }, item), null, 16, ["editor", "options", "model"])) : vue.createCommentVNode("", true) ]); }), 256)) ]) ], 8, _hoisted_1$1)) : vue.createCommentVNode("", true); } const ElementSettingDialog = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render$1], ["__scopeId", "data-v-2d6bc3f8"]]); const _DDeiFlowElementSettingDialog = class _DDeiFlowElementSettingDialog extends ddeiEditor.DDeiPluginBase { constructor() { super(...arguments); __publicField(this, "name", ElementSettingDialog.name); __publicField(this, "plugins", [ElementSettingDialog]); } getDialogs(editor) { return this.plugins; } static modify(fn) { return _DDeiFlowElementSettingDialog.defaultIns.modify(fn); } static configuration(options, fullConfig = false) { if (options) { let newOptions = {}; if (fullConfig) { if (fullConfig) { if (options[ElementSettingDialog.name]) { for (let i in options[ElementSettingDialog.name]) { newOptions[i] = options[ElementSettingDialog.name][i]; } } } } else { newOptions = options; } if (newOptions && Object.keys(newOptions).length !== 0) { let panels = new _DDeiFlowElementSettingDialog(newOptions); return panels; } } return _DDeiFlowElementSettingDialog.defaultIns; } }; /** * 缺省实例 */ __publicField(_DDeiFlowElementSettingDialog, "defaultIns", new _DDeiFlowElementSettingDialog({ items: [ { id: "ddei-flow-property-editor-text", label: "ddei.code", desc: "ddei.code", property: "code" }, { id: "ddei-flow-property-editor-text", label: "ddei.name", desc: "ddei.name", property: "name", condition: "model.bpmnBaseType != 'Event'" }, { id: "ddei-flow-property-editor-text", label: "ddei.flow.property.humanperformer", desc: "ddei.flow.user", property: "humanPerformer", condition: "model.bpmnType == 'UserTask'" }, { id: "ddei-flow-property-editor-text", label: "ddei.flow.property.potentialowner", desc: "ddei.flow.user", property: "potentialOwner", condition: "model.bpmnType == 'UserTask'" }, { id: "ddei-flow-property-editor-textarea", label: "ddei.flow.property.script", desc: `sum = 0 for ( i in inputArray ) { sum += i }`, property: "script", condition: "model.bpmnType == 'ScriptTask'" }, { id: "ddei-flow-property-editor-text", label: "ddei.flow.property.sender", desc: "上方参与人,用逗号隔开多个参与人", property: "topUser", condition: "model.bpmnType == 'ChoreographyTask' || model.bpmnType == 'ChoreographySubProcess'" }, { id: "ddei-flow-property-editor-text", label: "ddei.flow.property.receiver", desc: "下方参与人,用逗号隔开多个参与人", property: "bottomUser", condition: "model.bpmnType == 'ChoreographyTask' || model.bpmnType == 'ChoreographySubProcess'" }, { id: "ddei-flow-change-bpmnsubtype" }, { id: "ddei-flow-dataobject-setting" }, { id: "ddei-flow-time-setting" }, { id: "ddei-flow-message-setting" }, { id: "ddei-flow-signal-setting" }, { id: "ddei-flow-escal-setting" }, { id: "ddei-flow-error-setting" }, { id: "ddei-flow-condition-setting" }, { id: "ddei-flow-change-linetype" }, { id: "ddei-flow-change-linepointtype" }, // { // id: 'ddei-flow-callactivity-review' // }, { id: "ddei-flow-change-activity-labels" }, { id: "ddei-flow-property-editor-text", label: "ddei.flow.property.capacity", desc: "ddei.flow.property.capacity", property: "capacity", condition: "model.bpmnType == 'DataStore' && !model.isUnlimited" }, { id: "ddei-flow-property-editor-textarea", label: "ddei.desc", desc: "ddei.desc", property: "desc" } ] })); let DDeiFlowElementSettingDialog = _DDeiFlowElementSettingDialog; const _sfc_main = { name: "ddei-flow-setting-button-dialog", mixins: [DialogBase], props: { //外部传入的插件扩展参数 options: { type: Object, default: null } }, data() { return { dialogId: "ddei-flow-setting-button-dialog", model: null, stageRatio: 1, controlDefine: null, bpmnSubTypeDataSource: null }; }, computed: {}, components: {}, watch: {}, created() { }, mounted() { this.editor.dialogs[this.dialogId].viewer = this; this.refreshData(); }, methods: { validItemCondition(btn) { if (!this.editor.ddInstance["AC_DESIGN_EDIT"]) { return false; } if (!btn.condition) { return true; } else { let func = new Function("model", "btn", "editor", "component", "return " + btn.condition); let rs = func(this.model, btn, this.editor, this); return rs; } }, startChooseActivity(evt) { this.editor.tempChooseCallActivity = this.model; }, forceRefreshView: function() { this.forceRefresh = false; this.$nextTick(() => { this.forceRefresh = true; if (this.refreshData) { this.refreshData(); } }); }, refreshData() { var _a, _b; if (this.editor.tempPopData) { this.model = (_a = this.editor.tempPopData[this.dialogId]) == null ? void 0 : _a.model; if (this.model) { this.stageRatio = this.model.getStageRatio(); let controlDefine = ddeiEditor.DDeiEditorUtil.getControlDefine(this.model); let ds = (_b = controlDefine.attrDefineMap.get("bpmnSubType")) == null ? void 0 : _b.dataSource; if ((ds == null ? void 0 : ds.length) > 0) { for (let i = 0; i < ds.length; i++) { if (ds[i].value == this.model.bpmnSubType) { this.bpmnSubTypeIndex = i; break; } } } this.bpmnSubTypeDataSource = ds; this.controlDefine = controlDefine; } } }, settingMouseEnter(srcElement) { this.showSettingDialog(srcElement); }, settingMouseEnterLeave(srcElement) { delete this.editor.tempOperateModel; }, showSettingDialog(srcElement) { let editor = this.editor; if (editor.tempOperateModel) { let model = editor.tempOperateModel; if (model) { let left, top; if (this.model.bpmnBaseType == "Event") { left = srcElement.offsetLeft + -5.5 * (this.stageRatio - 1); top = srcElement.offsetTop + srcElement.clientHeight + 5.5 * (this.stageRatio - 1); } else { left = srcElement.offsetLeft + srcElement.clientWidth + 5.5 * (this.stageRatio - 1); top = srcElement.offsetTop + -5.5 * (this.stageRatio - 1); } ddeiEditor.DDeiEditorUtil.showDialog(editor, "ddei-flow-element-setting-dialog", { group: "ddei-flow-element-setting", model }, { type: 99, left, top, hiddenMask: true }, null, true, true); } } }, expandOrNotSubProcess() { let model = this.model; let stage = model.stage; let layer = model.layer; let ddInstance = stage.ddInstance; let editor = ddeiEditor.DDeiEditorUtil.getEditorInsByDDei(ddInstance); if (editor) { let scaleX = 1, scaleY = 1; let targetWidth, targetHeight; let includeModels = getIncludeModels(model); if (!model.isExpand) { targetWidth = model.otherWidth ? model.otherWidth : 300; targetHeight = model.otherHeight ? model.otherHeight : 200; model.otherWidth = model.width; model.otherHeight = model.height; model.isExpand = 1; let subLinks = stage.getSourceModelLinks(model.id); subLinks == null ? void 0 : subLinks.forEach((subLink) => { if (subLink.oldMid && subLink.oldSmpath) { let subModel = layer.getModelById(subLink.oldMid); if (subModel) { let subModelLinks = stage.getSourceModelLinks(subModel.id); subModelLinks.forEach((subModelLink) => { if (subModelLink.smpath == subLink.oldSmpath) { subModelLink.disabled = false; let sourcePV = subModelLink.getSourcePV(); let distPV = subModelLink.getDistPV(); distPV.x = sourcePV.x; distPV.y = sourcePV.y; } }); } stage.removeLink(subLink); subModel == null ? void 0 : subModel.updateLinkModels(); } }); model.updateLinkModels(); } else { targetWidth = model.otherWidth; targetHeight = model.otherHeight; model.otherWidth = model.width; model.otherHeight = model.height; model.isExpand = 0; let lines = []; includeModels.forEach((ims) => { if (ims.attachPModel != model.id) { let sublinks = stage.getSourceModelLinks(ims.id); sublinks == null ? void 0 : sublinks.forEach((slink) => { if (!slink.disabled && slink.dm) { if (lines.indexOf(slink.dm) == -1) { lines.push(slink.dm); } else { lines.splice(lines.indexOf(slink.dm), 1); } } }); } }); for (let ln = lines.length - 1; ln >= 0; ln--) { let line = lines[ln]; let sourceLinks = stage.getDistModelLinks(line.id); let finded = false; let inLink; for (let sl = 0; sl < sourceLinks.length; sl++) { if (!sourceLinks[sl].disabled) { if (sourceLinks[sl].sm == model) { finded = true; break; } if (includeModels.indexOf(sourceLinks[sl].sm) != -1) { inLink = sourceLinks[sl]; } } } if (finded) { lines.splice(ln, 1); } else if (inLink) { let distPV = inLink.getDistPV(); inLink.disabled = true; let crossPoint; let pvs = inLink.dm.pvs; let projPoint; if (inLink.dmpath == "startPoint") { for (let li = 0; li < pvs.length - 1; li++) { let p1 = pvs[li]; let p2 = pvs[li + 1]; for (let pi = 0; pi < model.operatePVS.length; pi++) { let p3 = model.operatePVS[pi]; let p4 = model.operatePVS[pi + 1]; if (pi == model.operatePVS.length - 1) { p3 = model.operatePVS[0]; p4 = model.operatePVS[pi]; } crossPoint = ddeiEditor.DDeiUtil.getLineCorssPoint(p1, p2, p3, p4); if (crossPoint) { break; } if (crossPoint) { break; } } } } else { for (let li = pvs.length - 1; li > 0; li--) { let p1 = pvs[li]; let p2 = pvs[li - 1]; for (let pi = 0; pi < model.operatePVS.length; pi++) { let p3 = model.operatePVS[pi]; let p4 = model.operatePVS[pi + 1]; if (pi == model.operatePVS.length - 1) { p3 = model.operatePVS[0]; p4 = model.operatePVS[pi]; } crossPoint = ddeiEditor.DDeiUtil.getLineCorssPoint(p1, p2, p3, p4); if (crossPoint) { break; } } if (crossPoint) { break; } } } if (crossPoint) { projPoint = model.getProjPoint({ x: crossPoint.x, y: crossPoint.y }); } if (!projPoint) { let proPoints; if (inLink.dmpath == "startPoint") { proPoints = ddeiEditor.DDeiAbstractShape.getProjPointDists(model.operatePVS, inLink.dm.startPoint.x, inLink.dm.startPoint.y, true, 1); } else { proPoints = ddeiEditor.DDeiAbstractShape.getProjPointDists(model.operatePVS, inLink.dm.endPoint.x, inLink.dm.endPoint.y, true, 1); } projPoint = proPoints[0]; } let id = "_" + ddeiEditor.DDeiUtil.getUniqueCode(); model.exPvs[id] = new ddeiEditor.Vector3(projPoint.x, projPoint.y, 1); model.exPvs[id].rate = projPoint.rate; model.exPvs[id].sita = projPoint.sita; model.exPvs[id].index = projPoint.index; model.exPvs[id].id = id; distPV.x = projPoint.x; distPV.y = projPoint.y; let link = new ddeiEditor.DDeiLink({ sm: model, dm: inLink.dm, smpath: "exPvs." + id, dmpath: inLink.dmpath, stage }); link.oldSmpath = inLink.smpath; link.oldMid = inLink.sm.id; stage.addLink(link); } } } scaleX = targetWidth / model.otherWidth; scaleY = targetHeight / model.otherHeight; if (scaleX != 1 || scaleY != 1) { let m1 = new ddeiEditor.Matrix3(); let move1Matrix = new ddeiEditor.Matrix3( 1, 0, -model.cpv.x, 0, 1, -model.cpv.y, 0, 0, 1 ); m1.premultiply(move1Matrix); if (model.rotate) { let angle = ddeiEditor.DDeiUtil.preciseTimes(model.rotate, ddeiEditor.DDeiConfig.ROTATE_UNIT); let rotateMatrix = new ddeiEditor.Matrix3( Math.cos(angle), Math.sin(angle), 0, -Math.sin(angle), Math.cos(angle), 0, 0, 0, 1 ); m1.premultiply(rotateMatrix); } let scaleMatrix = new ddeiEditor.Matrix3( scaleX, 0, 0, 0, scaleY, 0, 0, 0, 1 ); m1.premultiply(scaleMatrix); if (model.rotate) { let angle = ddeiEditor.DDeiUtil.preciseTimes(-model.rotate, ddeiEditor.DDeiConfig.ROTATE_UNIT); let rotateMatrix = new ddeiEditor.Matrix3( Math.cos(angle), Math.sin(angle), 0, -Math.sin(angle), Math.cos(angle), 0, 0, 0, 1 ); m1.premultiply(rotateMatrix); } let move2Matrix = new ddeiEditor.Matrix3( 1, 0, model.cpv.x, 0, 1, model.cpv.y, 0, 0, 1 ); m1.premultiply(move2Matrix); model.transVectors(m1); includeModels == null ? void 0 : includeModels.forEach((im) => { im.transVectors(m1); im.updateLinkModels(); }); if (model.isExpand == 1) { let deltaWidth = (targetWidth - model.otherWidth) / 2; let deltaHeight = (targetHeight - model.otherHeight) / 2; this.extParentBounds(model, deltaWidth, deltaHeight); } includeModels == null ? void 0 : includeModels.forEach((im) => { im.updateLinkModels(); }); model.updateLinkModels(); } editor.notifyChange(); ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-setting-button-dialog"); ddeiEditor.DDeiEditorUtil.closeDialog(editor, "ddei-flow-element-setting-dialog"); } }, //扩展上级控件大小以及位置 extParentBounds(model, deltaWidth, deltaHeight) { let stage = model.stage; let layer = model.layer; let curLevelModels = []; let parentSubProcess; if (model.includePModelId) { parentSubProcess = stage.getModelById(model.includePModelId); parentSubProcess == null ? void 0 : parentSubProcess.includeModels.forEach((includeModelid) => { if (includeModelid != model.id) { let subModel = stage.getModelById(includeModelid); if (subModel && subModel.baseModelType != "DDeiLine") { curLevelModels.push(subModel); } } }); } else { let layerModels = layer.getSubModels(); layerModels.forEach((lm) => { if (lm && lm.baseModelType != "DDeiLine" && !lm.includePModelId && lm.id != model.id) { curLevelModels.push(lm); } }); } let modelRect = ddeiEditor.DDeiAbstractShape.getOutRectByPV([model]); let needExt = false; for (let c = 0; c < curLevelModels.length; c++) { let rect = ddeiEditor.DDeiAbstractShape.getOutRectByPV([curLevelModels[c]]); if (ddeiEditor.DDeiUtil.isRectCross(modelRect, rect)) { needExt = true; break; } } if (needExt) { curLevelModels.forEach((subModel) => { if (subModel.baseModelType != "DDeiLine" && subModel.attachPModel != model.id) { let moveX = 0, moveY = 0; if (subModel.cpv.x > model.cpv.x) { moveX = deltaWidth; } else if (subModel.cpv.x < model.cpv.x) { moveX = -deltaWidth; } if (subModel.cpv.y > model.cpv.y) { moveY = deltaHeight; } else if (subModel.cpv.y < model.cpv.y) { moveY = -deltaHeight; } if (moveX || moveY) { let m2 = new ddeiEditor.Matrix3( 1, 0, moveX, 0, 1, moveY, 0, 0, 1 ); subModel.transVectors(m2); if (subModel.allowIncludeModel) { let includeModels1 = getIncludeModels(subModel); includeModels1.forEach((lms) => { lms.transVectors(m2); lms.updateLinkModels(); }); } } } subModel.updateLinkModels(); }); } if (parentSubProcess) { let parentRect = ddeiEditor.DDeiAbstractShape.getOutRectByPV([parentSubProcess]); let rect = ddeiEditor.DDeiAbstractShape.getOutRectByPV([...curLevelModels, model]); if (!(parentRect.x + 20 <= rect.x && parentRect.x1 - 20 >= rect.x1 && parentRect.y + 20 <= rect.y && parentRect.y1 - 20 >= rect.y1)) { let parentScaleX = (rect.width + 40) / parentRect.width; let parentScaleY = (rect.height + 40) / parentRect.height; let m1 = new ddeiEditor.Matrix3(); let move1Matrix = new ddeiEditor.Matrix3( 1, 0, -parentSubProcess.cpv.x, 0, 1, -parentSubProcess.cpv.y, 0, 0, 1 ); m1.premultiply(move1Matrix); if (parentSubProcess.rotate) { let angle = ddeiEditor.DDeiUtil.preciseTimes(parentSubProcess.rotate, ddeiEditor.DDeiConfig.ROTATE_UNIT); let rotateMatrix = new ddeiEditor.Matrix3( Math.cos(angle), Math.sin(angle), 0, -Math.sin(angle), Math.cos(angle), 0, 0, 0, 1 ); m1.premultiply(rotateMatrix); } let scaleMatrix = new ddeiEditor.Matrix3( parentScaleX, 0, 0, 0, parentScaleY, 0, 0, 0, 1 ); m1.premultiply(scaleMatrix); if (parentSubProcess.rotate) { let angle = ddeiEditor.DDeiUtil.preciseTimes(-parentSubProcess.rotate, ddeiEditor.DDeiConfig.ROTATE_UNIT); let rotateMatrix = new ddeiEditor.Matrix3( Math.cos(angle), Math.sin(angle), 0, -Math.sin(angle), Math.cos(angle), 0, 0, 0, 1 ); m1.premultiply(rotateMatrix); } let move2Matrix = new ddeiEditor.Matrix3( 1, 0, parentSubProcess.cpv.x + (rect.x + rect.width / 2 - parentRect.x - parentRect.width / 2), 0, 1, parentSubProcess.cpv.y + (rect.y + rect.height / 2 - parentRect.y - parentRect.height / 2), 0, 0, 1 ); m1.premultiply(move2Matrix); parentSubProcess.transVectors(m1); this.extParentBounds(parentSubProcess, rect.width + 40 - parentRect.width, rect.height + 40 - parentRect.height); parentSubProcess.updateLinkModels(); } } }, subProcessUnLock() { delete this.model.lock; }, subProcessLock() { this.model.lock = 1; }, deleteElement() { let stage = this.model.stage; stage.removeModel(this.model, true); } } }; const SettingButtonDialog_vue_vue_type_style_index_0_scoped_09abda49_lang = ""; const _hoisted_1 = ["id"]; const _hoisted_2 = { style: { "display": "contents" } }; const _hoisted_3 = { key: 0, "xlink:href": "#icon-ddei-flow-sub-process-marker" }; const _hoisted_4 = { key: 1, "xlink:href": "#icon-ddei-flow-sub-process-expand-marker" }; function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { var _a, _b, _c; return _ctx.forceRefresh ? (vue.openBlock(), vue.createElementBlock("div", { key: 0, id: ((_a = _ctx.editor) == null ? void 0 : _a.id) + "_" + $data.dialogId, style: vue.normalizeStyle({ transform: "scale(" + $data.stageRatio + ")" }), class: "ddei-flow-setting-button-dialog" }, [ vue.createElementVNode("div", { class: "content", style: vue.normalizeStyle({ "flex-direction": ((_b = $data.model) == null ? void 0 : _b.bpmnBaseType) != "Event" ? "column" : "" }) }, [ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList((_c = $props.options) == null ? void 0 : _c.buttons, (btn) => { var _a2, _b2, _c2, _d, _e, _f, _g; return vue.openBlock(), vue.createElementBlock("div", _hoisted_2, [ btn.viewer ? (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(btn.viewer), vue.mergeProps({ key: 0, editor: _ctx.editor, options: $props.options, model: $data.model, ref_for: true }, btn), null, 16, ["editor", "options", "model"])) : vue.createCommentVNode("", true), !btn.viewer && btn.id == "ddei-flow-edit-property" && $options.validItemCondition(btn) && ((_a2 = $data.controlDefine) == null ? void 0 : _a2.subject) == "bpmn" ? (vue.openBlock(), vue.createElementBlock("svg", { key: 1, class: "icon-ddei-flow", onMouseenter: _cache[0] || (_cache[0] = ($event) => $options.settingMouseEnter(_ctx.$el)), onMouseleave: _cache[1] || (_cache[1] = ($event) => $options.settingMouseEnterLeave(_ctx.$el)), "aria-hidden": "true" }, _cache[7] || (_cache[7] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-setting" }, null, -1) ]), 32)) : vue.createCommentVNode("", true), !btn.viewer && btn.id == "ddei-flow-choose-activity" && $options.validItemCondition(btn) && ((_b2 = $data.model) == null ? void 0 : _b2.bpmnType) == "CallActivityTask" ? (vue.openBlock(), vue.createElementBlock("svg", { key: 2, class: "icon-ddei-flow", onMousedown: _cache[2] || (_cache[2] = ($event) => $options.startChooseActivity(_ctx.$el)), "aria-hidden": "true" }, _cache[8] || (_cache[8] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-link" }, null, -1) ]), 32)) : vue.createCommentVNode("", true), !btn.viewer && btn.id == "ddei-flow-expand-or-not" && $options.validItemCondition(btn) && ((_c2 = $data.model) == null ? void 0 : _c2.allowIncludeModel) ? (vue.openBlock(), vue.createElementBlock("svg", { key: 3, class: "icon-ddei-flow", onClick: _cache[3] || (_cache[3] = ($event) => $options.expandOrNotSubProcess()), "aria-hidden": "true" }, [ !((_d = $data.model) == null ? void 0 : _d.isExpand) ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_3)) : vue.createCommentVNode("", true), ((_e = $data.model) == null ? void 0 : _e.isExpand) ? (vue.openBlock(), vue.createElementBlock("use", _hoisted_4)) : vue.createCommentVNode("", true) ])) : vue.createCommentVNode("", true), !btn.viewer && btn.id == "ddei-flow-lock-or-unlock" && $options.validItemCondition(btn) && ((_f = $data.model) == null ? void 0 : _f.allowIncludeModel) && $data.model.isExpand == 1 && !$data.model.lock ? (vue.openBlock(), vue.createElementBlock("svg", { key: 4, class: "icon-ddei-flow", onClick: _cache[4] || (_cache[4] = ($event) => $options.subProcessLock()), "aria-hidden": "true" }, _cache[9] || (_cache[9] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-lock" }, null, -1) ]))) : vue.createCommentVNode("", true), !btn.viewer && btn.id == "ddei-flow-lock-or-unlock" && $options.validItemCondition(btn) && ((_g = $data.model) == null ? void 0 : _g.allowIncludeModel) && $data.model.isExpand == 1 && $data.model.lock ? (vue.openBlock(), vue.createElementBlock("svg", { key: 5, class: "icon-ddei-flow", onClick: _cache[5] || (_cache[5] = ($event) => $options.subProcessUnLock()), "aria-hidden": "true" }, _cache[10] || (_cache[10] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-unlock" }, null, -1) ]))) : vue.createCommentVNode("", true), !btn.viewer && btn.id == "ddei-flow-remove-control" && $options.validItemCondition(btn) ? (vue.openBlock(), vue.createElementBlock("svg", { key: 6, class: "icon-ddei-flow", onClick: _cache[6] || (_cache[6] = ($event) => $options.deleteElement(_ctx.$el)), "aria-hidden": "true" }, _cache[11] || (_cache[11] = [ vue.createElementVNode("use", { "xlink:href": "#icon-ddei-flow-trash" }, null, -1) ]))) : vue.createCommentVNode("", true) ]); }), 256)) ], 4) ], 12, _hoisted_1)) : vue.createCommentVNode("", true); } const SettingButtonDialog = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-09abda49"]]); const _DDeiFlowSettingButtonDialog = class _DDeiFlowSettingButtonDialog extends ddeiEditor.DDeiPluginBase { constructor() { super(...arguments); __publicField(this, "name", SettingButtonDialog.name); __publicField(this, "plugins", [SettingButtonDialog]); } getDialogs(editor) { return this.plugins; } static modify(fn) { return _DDeiFlowSettingButtonDialog.defaultIns.modify(fn); } static configuration(options, fullConfig = false) { if (options) { let newOptions = {}; if (fullConfig) { if (fullConfig) { if (options[SettingButtonDialog.name]) { for (let i in options[SettingButtonDialog.name]) { newOptions[i] = options[SettingButtonDialog.name][i]; } } } } else { newOptions = options; } if (newOptions && Object.keys(newOptions).length !== 0) { let panels = new _DDeiFlowSettingButtonDialog(newOptions); return panels; } } return _DDeiFlowSettingButtonDialog; } }; /** * 缺省实例 */ __publicField(_DDeiFlowSettingButtonDialog, "defaultIns", new _DDeiFlowSettingButtonDialog({ buttons: [ { id: "ddei-flow-edit-property" }, { id: "ddei-flow-choose-activity" }, { id: "ddei-flow-expand-or-not" }, { id: "ddei-flow-lock-or-unlock" }, { id: "ddei-flow-remove-control" } ] })); let DDeiFlowSettingButtonDialog = _DDeiFlowSettingButtonDialog; const _DDeiFlowDialogs = class _DDeiFlowDialogs extends ddeiEditor.DDeiPluginBase { constructor() { super(...arguments); __publicField(this, "type", "package"); __publicField(this, "plugins", [DDeiFlowElementSettingDialog, DDeiFlowSettingButtonDialog]); } getDialogs(editor) { var _a; let dialogs = []; (_a = this.plugins) == null ? void 0 : _a.forEach((plugin) => { let ls; if (ddeiEditor.DDeiPluginBase.isSubclass(plugin, ddeiEditor.DDeiPluginBase)) { ls = plugin.defaultIns.getDialogs(editor); } else if (plugin instanceof ddeiEditor.DDeiPluginBase) { ls = plugin.getDialogs(editor); } if ((ls == null ? void 0 : ls.length) > 0) { dialogs = dialogs.concat(ls); } }); return dialogs; } static modify(fn) { return _DDeiFlowDialogs.defaultIns.modify(fn); } static configuration(options) { var _a; if (options) { let dialogs = new _DDeiFlowDialogs(options); for (let i = 0; i < ((_a = dialogs.plugins) == null ? void 0 : _a.length); i++) { dialogs.plugins[i] = dialogs.plugins[i].configuration(options, true); } return dialogs; } return _DDeiFlowDialogs; } }; /** * 缺省实例 */ __publicField(_DDeiFlowDialogs, "defaultIns", new _DDeiFlowDialogs(null)); let DDeiFlowDialogs = _DDeiFlowDialogs; const _DDeiKeyActionCancelChooseActivity = class _DDeiKeyActionCancelChooseActivity extends ddeiEditor.DDeiKeyAction { constructor() { super(...arguments); __publicField(this, "name", "ddei-core-keyaction-cancel-choose-activity"); __publicField(this, "defaultOptions", { "keys": [ { keys: "27" } ] }); } getHotKeys(editor) { return [this]; } static configuration(options, fullConfig = false) { if (options) { let newOptions = {}; if (fullConfig) { if (fullConfig) { if (options[_DDeiKeyActionCancelChooseActivity.defaultIns.name]) { for (let i in options[_DDeiKeyActionCancelChooseActivity.defaultIns.name]) { newOptions[i] = options[_DDeiKeyActionCancelChooseActivity.defaultIns.name][i]; } } } } else { newOptions = options; } if (newOptions && Object.keys(newOptions).length !== 0) { let panels = new _DDeiKeyActionCancelChooseActivity(newOptions); return panels; } } return _DDeiKeyActionCancelChooseActivity; } static modify(fn) { return _DDeiKeyActionCancelChooseActivity.defaultIns.modify(fn); } // ============================ 方法 =============================== action(evt, ddInstance, editor) { var _a, _b; (_b = (_a = editor.tempCallActivity) == null ? void 0 : _a.render) == null ? void 0 : _b.clearCachedValue(); delete editor.tempCallActivity; delete editor.tempChooseCallActivity; } }; /** * 缺省实例 */ __publicField(_DDeiKeyActionCancelChooseActivity, "defaultIns", new _DDeiKeyActionCancelChooseActivity()); let DDeiKeyActionCancelChooseActivity = _DDeiKeyActionCancelChooseActivity; const _DDeiFlowHotkeys = class _DDeiFlowHotkeys extends ddeiEditor.DDeiPluginBase { constructor() { super(...arguments); __publicField(this, "type", "package"); __publicField(this, "plugins", [ DDeiKeyActionCancelChooseActivity ]); } getHotKeys(editor) { var _a; let hotkeys = []; (_a = this.plugins) == null ? void 0 : _a.forEach((plugin) => { let ls; if (ddeiEditor.DDeiPluginBase.isSubclass(plugin, ddeiEditor.DDeiPluginBase)) { ls = plugin.defaultIns.getHotKeys(editor); } else if (plugin instanceof ddeiEditor.DDeiPluginBase) { ls = plugin.getHotKeys(editor); } if ((ls == null ? void 0 : ls.length) > 0) { hotkeys = hotkeys.concat(ls); } }); return hotkeys; } static modify(fn) { return _DDeiFlowHotkeys.defaultIns.modify(fn); } static configuration(options) { var _a; let hotkeys = new _DDeiFlowHotkeys(options); for (let i = 0; i < ((_a = hotkeys.plugins) == null ? void 0 : _a.length); i++) { hotkeys.plugins[i] = hotkeys.plugins[i].configuration(options, true); } return hotkeys; } }; /** * 缺省实例 */ __publicField(_DDeiFlowHotkeys, "defaultIns", new _DDeiFlowHotkeys(null)); let DDeiFlowHotkeys = _DDeiFlowHotkeys; class DDeiFlowFile { constructor(props) { /** * 所属API */ __publicField(this, "api"); /** * id */ __publicField(this, "id"); /** * 名称 */ __publicField(this, "name"); /** * 文件包含的所有流程图 */ __publicField(this, "graphics", []); for (let i in props) { this[i] = props[i]; } } toJSON() { var _a; let returnData = {}; for (let i in this) { if (this[i] || this[i] === 0) { returnData[i] = this[i]; } } if (((_a = returnData.graphics) == null ? void 0 : _a.length) > 0) { let gs = []; returnData.graphics.forEach((graph) => { gs.push(graph.toJSON()); }); returnData.graphics = gs; } else { delete returnData.graphics; } delete returnData.api; return returnData; } } class DDeiFlowGraph { constructor(props) { /** * 所属API */ __publicField(this, "api"); /** * 所属文件 */ __publicField(this, "file"); /** * id */ __publicField(this, "id"); /** * 名称 */ __publicField(this, "name"); /** * 所有节点 */ __publicField(this, "nodes", /* @__PURE__ */ new Map()); /** * 所有分组 */ __publicField(this, "groups"); /** * 开始节点 */ __publicField(this, "startNodes", []); /** * 结束节点 */ __publicField(this, "endNodes", []); /** * 孤立节点 */ __publicField(this, "isolatedNodes", []); for (let i in props) { this[i] = props[i]; } } /** * 获取流程节点 * @param key key字段 */ getFlowNode(key) { let nodes = Array.from(this.nodes.values()); for (let i = 0; i < nodes.length; i++) { let node = nodes[i]; if (node[this.api.jsonKeyField] == key) { return node; } } } /** * 批量设置节点属性 * @param data 属性对象 * @param nodify 立即刷新 */ setNodesData(nodes, nodify = true) { if (nodes) { let nodesModels2 = []; for (let nodeId in nodes) { let nodeData = nodes[nodeId]; let node = this.getFlowNode(nodeId); if (node && nodeData) { nodesModels2.push(node.shapeModel); node.setData(nodeData, false); } } } if (nodify && nodesModels.length > 0) { let ddInstance = nodesModels[0].stage.ddInstance; nodesModels.forEach((shapeModel) => { shapeModel.render.clearCachedValue(); shapeModel.render.enableRefreshShape(); }); ddInstance.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); ddInstance.bus.executeAll(); } } /** * 设置属性到图形对象中,并根据 * @param data 属性对象 * @param nodify 立即刷新 */ setData(data2, nodify = true) { if (data2) { ddeiEditor.merge(this.shapeModel, data2); ddeiEditor.merge(this, data2); } if (nodify) { let ddInstance = this.shapeModel.stage.ddInstance; this.shapeModel.render.clearCachedValue(); this.shapeModel.render.enableRefreshShape(); ddInstance.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); ddInstance.bus.executeAll(); } } toJSON() { var _a, _b, _c, _d, _e, _f; let returnData = ddeiEditor.clone(this); delete returnData.shapeModel; delete returnData.file; let startNodes = []; (_a = returnData.startNodes) == null ? void 0 : _a.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; startNodes.push(key); }); if (startNodes.length > 0) { returnData.startNodes = startNodes; } else { delete returnData.startNodes; } let endNodes = []; (_b = returnData.endNodes) == null ? void 0 : _b.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; endNodes.push(key); }); if (endNodes.length > 0) { returnData.endNodes = endNodes; } else { delete returnData.endNodes; } let isolatedNodes = []; (_c = returnData.isolatedNodes) == null ? void 0 : _c.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; isolatedNodes.push(key); }); if (isolatedNodes.length > 0) { returnData.isolatedNodes = isolatedNodes; } else { delete returnData.isolatedNodes; } let groups = []; (_d = returnData.groups) == null ? void 0 : _d.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; groups.push(key); }); if (groups.length > 0) { returnData.groups = groups; } else { delete returnData.groups; } if (((_e = returnData.nodes) == null ? void 0 : _e.size) > 0) { let nodes = {}; (_f = returnData.nodes) == null ? void 0 : _f.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; nodes[key] = node.toJSON(); }); returnData.nodes = nodes; } else { delete returnData.nodes; } delete returnData.api; return returnData; } } class DDeiFlowNode { constructor(props) { /** * 所属API */ __publicField(this, "api"); /** * 所属图形 */ __publicField(this, "graph"); /** * id */ __publicField(this, "id"); /** * code */ __publicField(this, "code"); /** * 名称 */ __publicField(this, "name"); /** * 备注 */ __publicField(this, "desc"); /** * 直接前置节点 */ __publicField(this, "prevNodes", []); /** * 直接后续节点 */ __publicField(this, "nextNodes", []); /** * 附着节点 */ __publicField(this, "attachNodes", []); /** * 所有层级子流程,按照最外层到最里层的顺序排序 */ __publicField(this, "subProcesses"); for (let i in props) { this[i] = props[i]; } } /** * 设置属性到图形对象中,并根据 * @param data 属性对象 * @param nodify 立即刷新 */ setData(data2, nodify = true) { if (data2) { ddeiEditor.merge(this.shapeModel, data2); ddeiEditor.merge(this, data2); } if (nodify) { let ddInstance = this.shapeModel.stage.ddInstance; this.shapeModel.render.clearCachedValue(); this.shapeModel.render.enableRefreshShape(); ddInstance.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); ddInstance.bus.executeAll(); } } toJSON() { var _a, _b, _c, _d; let returnData = {}; for (let i in this) { if (this[i] || this[i] === 0) { returnData[i] = this[i]; } } delete returnData.shapeModel; delete returnData.graph; delete returnData.essBounds; let prevNodes = []; (_a = returnData.prevNodes) == null ? void 0 : _a.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; prevNodes.push(key); }); if (prevNodes.length > 0) { returnData.prevNodes = prevNodes; } else { delete returnData.prevNodes; } let nextNodes = []; (_b = returnData.nextNodes) == null ? void 0 : _b.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; nextNodes.push(key); }); if (nextNodes.length > 0) { returnData.nextNodes = nextNodes; } else { delete returnData.nextNodes; } let subProcesses = []; (_c = returnData.subProcesses) == null ? void 0 : _c.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; subProcesses.push(key); }); if (subProcesses.length > 0) { returnData.subProcesses = subProcesses; } else { delete returnData.subProcesses; } let attachNodes = []; (_d = returnData.attachNodes) == null ? void 0 : _d.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; attachNodes.push(key); }); if (attachNodes.length > 0) { returnData.attachNodes = attachNodes; } else { delete returnData.attachNodes; } if (returnData.attachPNode) { let key = returnData.attachPNode[this.api.jsonKeyField] ? returnData.attachPNode[this.api.jsonKeyField] : returnData.attachPNode.id; returnData.attachPNode = key; } else { delete returnData.attachPNode; } delete returnData.api; return returnData; } } class DDeiFlowGroup { constructor(props) { /** * 所属API */ __publicField(this, "api"); /** * 分组ID */ __publicField(this, "id"); /** * 分组名称 */ __publicField(this, "name"); /** * 分组备注 */ __publicField(this, "desc"); /** * 分组中的所有节点引用 */ __publicField(this, "nodes", /* @__PURE__ */ new Map()); for (let i in props) { this[i] = props[i]; } } /** * 设置属性到图形对象中,并根据 * @param data 属性对象 * @param nodify 立即刷新 */ setData(data2, nodify = true) { if (data2) { ddeiEditor.merge(this.shapeModel, data2); ddeiEditor.merge(this, data2); } if (nodify) { let ddInstance = this.shapeModel.stage.ddInstance; this.shapeModel.render.clearCachedValue(); this.shapeModel.render.enableRefreshShape(); ddInstance.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); ddInstance.bus.executeAll(); } } /** * 设置属性到图形对象中,并根据 * @param data 属性对象 * @param nodify 立即刷新 */ setNodesData(nodes, nodify = true) { if (nodes) { for (let nodeId in nodes) { let nodeData = nodes[nodeId]; if (nodeData) { ddeiEditor.merge(this.shapeModel, data); ddeiEditor.merge(this, data); } } } if (nodify) { let ddInstance = this.shapeModel.stage.ddInstance; this.shapeModel.render.clearCachedValue(); this.shapeModel.render.enableRefreshShape(); ddInstance.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); ddInstance.bus.executeAll(); } } toJSON() { var _a, _b; let returnData = {}; for (let i in this) { if (this[i] || this[i] === 0) { returnData[i] = this[i]; } } delete returnData.shapeModel; delete returnData.graph; delete returnData.essBounds; if (((_a = returnData.nodes) == null ? void 0 : _a.size) > 0) { let nodes = []; (_b = returnData.nodes) == null ? void 0 : _b.forEach((node) => { let key = node[this.api.jsonKeyField] ? node[this.api.jsonKeyField] : node.id; nodes.push(key); }); returnData.nodes = nodes; } else { delete returnData.nodes; } delete returnData.api; return returnData; } } class DDeiFlowSequence { constructor(props) { /** * 所属API */ __publicField(this, "api"); /** * 所属图形 */ __publicField(this, "graph"); /** * 条件,默认无条件 */ __publicField(this, "condition", null); /** * 是否默认 */ __publicField(this, "default", false); /** * id */ __publicField(this, "id"); /** * code */ __publicField(this, "code"); /** * 名称 */ __publicField(this, "name"); /** * 备注 */ __publicField(this, "desc"); /** * 文本 */ __publicField(this, "text"); /** * 直接前置节点 */ __publicField(this, "prevNode"); /** * 直接后续节点 */ __publicField(this, "nextNode"); for (let i in props) { this[i] = props[i]; } } /** * 设置属性到图形对象中,并根据 * @param data 属性对象 * @param nodify 立即刷新 */ setData(data2, nodify = true) { if (data2) { ddeiEditor.merge(this.shapeModel, data2); ddeiEditor.merge(this, data2); } if (nodify) { let ddInstance = this.shapeModel.stage.ddInstance; this.shapeModel.render.clearCachedValue(); this.shapeModel.render.enableRefreshShape(); ddInstance.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); ddInstance.bus.executeAll(); } } toJSON() { let returnData = {}; for (let i in this) { if (this[i] || this[i] === 0) { returnData[i] = this[i]; } } delete returnData.shapeModel; delete returnData.graph; if (returnData.prevNode) { let key = returnData.prevNode[this.api.jsonKeyField] ? returnData.prevNode[this.api.jsonKeyField] : returnData.prevNode.id; returnData.prevNode = key; } else { delete returnData.prevNode; } if (returnData.nextNode) { let key = returnData.nextNode[this.api.jsonKeyField] ? returnData.nextNode[this.api.jsonKeyField] : returnData.nextNode.id; returnData.nextNode = key; } else { delete returnData.nextNode; } delete returnData.api; return returnData; } } class DDeiFlowSubProcess extends DDeiFlowNode { constructor() { super(...arguments); /** * 子流程所有节点 */ __publicField(this, "nodes", /* @__PURE__ */ new Map()); /** * 子流程开始节点 */ __publicField(this, "startNodes", []); /** * 子流程结束节点 */ __publicField(this, "endNodes", []); /** * 子流程孤立节点 */ __publicField(this, "isolatedNodes", []); } /** * 设置属性到图形对象中,并根据 * @param data 属性对象 * @param nodify 立即刷新 */ setData(data2, nodify = true) { if (data2) { ddeiEditor.merge(this.shapeModel, data2); ddeiEditor.merge(this, data2); } if (nodify) { let ddInstance = this.shapeModel.stage.ddInstance; this.shapeModel.render.clearCachedValue(); this.shapeModel.render.enableRefreshShape(); ddInstance.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); ddInstance.bus.executeAll(); } } toJSON() { var _a, _b, _c, _d, _e; let api = this.api; let returnData = super.toJSON(); let startNodes = []; (_a = returnData.startNodes) == null ? void 0 : _a.forEach((node) => { let key = node[api.jsonKeyField] ? node[api.jsonKeyField] : node.id; startNodes.push(key); }); if (startNodes.length > 0) { returnData.startNodes = startNodes; } else { delete returnData.startNodes; } let endNodes = []; (_b = returnData.endNodes) == null ? void 0 : _b.forEach((node) => { let key = node[api.jsonKeyField] ? node[api.jsonKeyField] : node.id; endNodes.push(key); }); if (endNodes.length > 0) { returnData.endNodes = endNodes; } else { delete returnData.endNodes; } let isolatedNodes = []; (_c = returnData.isolatedNodes) == null ? void 0 : _c.forEach((node) => { let key = node[api.jsonKeyField] ? node[api.jsonKeyField] : node.id; isolatedNodes.push(key); }); if (isolatedNodes.length > 0) { returnData.isolatedNodes = isolatedNodes; } else { delete returnData.isolatedNodes; } if (((_d = returnData.nodes) == null ? void 0 : _d.size) > 0) { let nodes = {}; (_e = returnData.nodes) == null ? void 0 : _e.forEach((node) => { let key = node[api.jsonKeyField] ? node[api.jsonKeyField] : node.id; nodes[key] = node.toJSON(); }); returnData.nodes = nodes; } else { delete returnData.nodes; } delete returnData.api; return returnData; } } class DDeiFlowBpmnXmlNode { constructor(contentStr, defineStr, processStr, currentProcessStr, rootStr = null) { /** * 追加在当前位置 */ __publicField(this, "contentStr", null); /** * 追加在define这一级,用于新增名称空间或者引用 */ __publicField(this, "rootStr", null); /** * 追加在定义级,与当前流程process节点平级 */ __publicField(this, "defineStr", null); /** * 追加当前最外层流程 */ __publicField(this, "processStr", null); /** * 追加当前子流程内部 */ __publicField(this, "currentProcessStr", null); this.contentStr = contentStr; this.defineStr = defineStr; this.processStr = processStr; this.currentProcessStr = currentProcessStr; this.rootStr = rootStr; } } function bind(fn, thisArg) { return function wrap() { return fn.apply(thisArg, arguments); }; } const { toString } = Object.prototype; const { getPrototypeOf } = Object; const kindOf = ((cache) => (thing) => { const str = toString.call(thing); return cache[str] || (cache[str] = str.slice(8, -1).toLowerCase()); })(/* @__PURE__ */ Object.create(null)); const kindOfTest = (type) => { type = type.toLowerCase(); return (thing) => kindOf(thing) === type; }; const typeOfTest = (type) => (thing) => typeof thing === type; const { isArray } = Array; const isUndefined = typeOfTest("undefined"); function isBuffer(val) { return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor) && isFunction(val.constructor.isBuffer) && val.constructor.isBuffer(val); } const isArrayBuffer = kindOfTest("ArrayBuffer"); function isArrayBufferView(val) { let result; if (typeof ArrayBuffer !== "undefined" && ArrayBuffer.isView) { result = ArrayBuffer.isView(val); } else { result = val && val.buffer && isArrayBuffer(val.buffer); } return result; } const isString = typeOfTest("string"); const isFunction = typeOfTest("function"); const isNumber = typeOfTest("number"); const isObject = (thing) => thing !== null && typeof thing === "object"; const isBoolean = (thing) => thing === true || thing === false; const isPlainObject = (val) => { if (kindOf(val) !== "object") { return false; } const prototype2 = getPrototypeOf(val); return (prototype2 === null || prototype2 === Object.prototype || Object.getPrototypeOf(prototype2) === null) && !(Symbol.toStringTag in val) && !(Symbol.iterator in val); }; const isDate = kindOfTest("Date"); const isFile = kindOfTest("File"); const isBlob = kindOfTest("Blob"); const isFileList = kindOfTest("FileList"); const isStream = (val) => isObject(val) && isFunction(val.pipe); const isFormData = (thing) => { let kind; return thing && (typeof FormData === "function" && thing instanceof FormData || isFunction(thing.append) && ((kind = kindOf(thing)) === "formdata" || // detect form-data instance kind === "object" && isFunction(thing.toString) && thing.toString() === "[object FormData]")); }; const isURLSearchParams = kindOfTest("URLSearchParams"); const [isReadableStream, isRequest, isResponse, isHeaders] = ["ReadableStream", "Request", "Response", "Headers"].map(kindOfTest); const trim = (str) => str.trim ? str.trim() : str.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, ""); function forEach(obj, fn, { allOwnKeys = false } = {}) { if (obj === null || typeof obj === "undefined") { return; } let i; let l; if (typeof obj !== "object") { obj = [obj]; } if (isArray(obj)) { for (i = 0, l = obj.length; i < l; i++) { fn.call(null, obj[i], i, obj); } } else { const keys = allOwnKeys ? Object.getOwnPropertyNames(obj) : Object.keys(obj); const len = keys.length; let key; for (i = 0; i < len; i++) { key = keys[i]; fn.call(null, obj[key], key, obj); } } } function findKey(obj, key) { key = key.toLowerCase(); const keys = Object.keys(obj); let i = keys.length; let _key; while (i-- > 0) { _key = keys[i]; if (key === _key.toLowerCase()) { return _key; } } return null; } const _global = (() => { if (typeof globalThis !== "undefined") return globalThis; return typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : global; })(); const isContextDefined = (context) => !isUndefined(context) && context !== _global; function merge() { const { caseless } = isContextDefined(this) && this || {}; const result = {}; const assignValue = (val, key) => { const targetKey = caseless && findKey(result, key) || key; if (isPlainObject(result[targetKey]) && isPlainObject(val)) { result[targetKey] = merge(result[targetKey], val); } else if (isPlainObject(val)) { result[targetKey] = merge({}, val); } else if (isArray(val)) { result[targetKey] = val.slice(); } else { result[targetKey] = val; } }; for (let i = 0, l = arguments.length; i < l; i++) { arguments[i] && forEach(arguments[i], assignValue); } return result; } const extend = (a, b, thisArg, { allOwnKeys } = {}) => { forEach(b, (val, key) => { if (thisArg && isFunction(val)) { a[key] = bind(val, thisArg); } else { a[key] = val; } }, { allOwnKeys }); return a; }; const stripBOM = (content) => { if (content.charCodeAt(0) === 65279) { content = content.slice(1); } return content; }; const inherits = (constructor, superConstructor, props, descriptors2) => { constructor.prototype = Object.create(superConstructor.prototype, descriptors2); constructor.prototype.constructor = constructor; Object.defineProperty(constructor, "super", { value: superConstructor.prototype }); props && Object.assign(constructor.prototype, props); }; const toFlatObject = (sourceObj, destObj, filter, propFilter) => { let props; let i; let prop; const merged = {}; destObj = destObj || {}; if (sourceObj == null) return destObj; do { props = Object.getOwnPropertyNames(sourceObj); i = props.length; while (i-- > 0) { prop = props[i]; if ((!propFilter || propFilter(prop, sourceObj, destObj)) && !merged[prop]) { destObj[prop] = sourceObj[prop]; merged[prop] = true; } } sourceObj = filter !== false && getPrototypeOf(sourceObj); } while (sourceObj && (!filter || filter(sourceObj, destObj)) && sourceObj !== Object.prototype); return destObj; }; const endsWith = (str, searchString, position) => { str = String(str); if (position === void 0 || position > str.length) { position = str.length; } position -= searchString.length; const lastIndex = str.indexOf(searchString, position); return lastIndex !== -1 && lastIndex === position; }; const toArray = (thing) => { if (!thing) return null; if (isArray(thing)) return thing; let i = thing.length; if (!isNumber(i)) return null; const arr = new Array(i); while (i-- > 0) { arr[i] = thing[i]; } return arr; }; const isTypedArray = ((TypedArray) => { return (thing) => { return TypedArray && thing instanceof TypedArray; }; })(typeof Uint8Array !== "undefined" && getPrototypeOf(Uint8Array)); const forEachEntry = (obj, fn) => { const generator = obj && obj[Symbol.iterator]; const iterator = generator.call(obj); let result; while ((result = iterator.next()) && !result.done) { const pair = result.value; fn.call(obj, pair[0], pair[1]); } }; const matchAll = (regExp, str) => { let matches; const arr = []; while ((matches = regExp.exec(str)) !== null) { arr.push(matches); } return arr; }; const isHTMLForm = kindOfTest("HTMLFormElement"); const toCamelCase = (str) => { return str.toLowerCase().replace( /[-_\s]([a-z\d])(\w*)/g, function replacer(m, p1, p2) { return p1.toUpperCase() + p2; } ); }; const hasOwnProperty = (({ hasOwnProperty: hasOwnProperty2 }) => (obj, prop) => hasOwnProperty2.call(obj, prop))(Object.prototype); const isRegExp = kindOfTest("RegExp"); const reduceDescriptors = (obj, reducer) => { const descriptors2 = Object.getOwnPropertyDescriptors(obj); const reducedDescriptors = {}; forEach(descriptors2, (descriptor, name) => { let ret; if ((ret = reducer(descriptor, name, obj)) !== false) { reducedDescriptors[name] = ret || descriptor; } }); Object.defineProperties(obj, reducedDescriptors); }; const freezeMethods = (obj) => { reduceDescriptors(obj, (descriptor, name) => { if (isFunction(obj) && ["arguments", "caller", "callee"].indexOf(name) !== -1) { return false; } const value = obj[name]; if (!isFunction(value)) return; descriptor.enumerable = false; if ("writable" in descriptor) { descriptor.writable = false; return; } if (!descriptor.set) { descriptor.set = () => { throw Error("Can not rewrite read-only method '" + name + "'"); }; } }); }; const toObjectSet = (arrayOrString, delimiter) => { const obj = {}; const define2 = (arr) => { arr.forEach((value) => { obj[value] = true; }); }; isArray(arrayOrString) ? define2(arrayOrString) : define2(String(arrayOrString).split(delimiter)); return obj; }; const noop = () => { }; const toFiniteNumber = (value, defaultValue) => { return value != null && Number.isFinite(value = +value) ? value : defaultValue; }; const ALPHA = "abcdefghijklmnopqrstuvwxyz"; const DIGIT = "0123456789"; const ALPHABET = { DIGIT, ALPHA, ALPHA_DIGIT: ALPHA + ALPHA.toUpperCase() + DIGIT }; const generateString = (size = 16, alphabet = ALPHABET.ALPHA_DIGIT) => { let str = ""; const { length } = alphabet; while (size--) { str += alphabet[Math.random() * length | 0]; } return str; }; function isSpecCompliantForm(thing) { return !!(thing && isFunction(thing.append) && thing[Symbol.toStringTag] === "FormData" && thing[Symbol.iterator]); } const toJSONObject = (obj) => { const stack = new Array(10); const visit = (source, i) => { if (isObject(source)) { if (stack.indexOf(source) >= 0) { return; } if (!("toJSON" in source)) { stack[i] = source; const target = isArray(source) ? [] : {}; forEach(source, (value, key) => { const reducedValue = visit(value, i + 1); !isUndefined(reducedValue) && (target[key] = reducedValue); }); stack[i] = void 0; return target; } } return source; }; return visit(obj, 0); }; const isAsyncFn = kindOfTest("AsyncFunction"); const isThenable = (thing) => thing && (isObject(thing) || isFunction(thing)) && isFunction(thing.then) && isFunction(thing.catch); const _setImmediate = ((setImmediateSupported, postMessageSupported) => { if (setImmediateSupported) { return setImmediate; } return postMessageSupported ? ((token, callbacks) => { _global.addEventListener("message", ({ source, data: data2 }) => { if (source === _global && data2 === token) { callbacks.length && callbacks.shift()(); } }, false); return (cb) => { callbacks.push(cb); _global.postMessage(token, "*"); }; })(`axios@${Math.random()}`, []) : (cb) => setTimeout(cb); })( typeof setImmediate === "function", isFunction(_global.postMessage) ); const asap = typeof queueMicrotask !== "undefined" ? queueMicrotask.bind(_global) : typeof process !== "undefined" && process.nextTick || _setImmediate; const utils$1 = { isArray, isArrayBuffer, isBuffer, isFormData, isArrayBufferView, isString, isNumber, isBoolean, isObject, isPlainObject, isReadableStream, isRequest, isResponse, isHeaders, isUndefined, isDate, isFile, isBlob, isRegExp, isFunction, isStream, isURLSearchParams, isTypedArray, isFileList, forEach, merge, extend, trim, stripBOM, inherits, toFlatObject, kindOf, kindOfTest, endsWith, toArray, forEachEntry, matchAll, isHTMLForm, hasOwnProperty, hasOwnProp: hasOwnProperty, // an alias to avoid ESLint no-prototype-builtins detection reduceDescriptors, freezeMethods, toObjectSet, toCamelCase, noop, toFiniteNumber, findKey, global: _global, isContextDefined, ALPHABET, generateString, isSpecCompliantForm, toJSONObject, isAsyncFn, isThenable, setImmediate: _setImmediate, asap }; function AxiosError(message2, code, config, request, response) { Error.call(this); if (Error.captureStackTrace) { Error.captureStackTrace(this, this.constructor); } else { this.stack = new Error().stack; } this.message = message2; this.name = "AxiosError"; code && (this.code = code); config && (this.config = config); request && (this.request = request); if (response) { this.response = response; this.status = response.status ? response.status : null; } } utils$1.inherits(AxiosError, Error, { toJSON: function toJSON() { return { // Standard message: this.message, name: this.name, // Microsoft description: this.description, number: this.number, // Mozilla fileName: this.fileName, lineNumber: this.lineNumber, columnNumber: this.columnNumber, stack: this.stack, // Axios config: utils$1.toJSONObject(this.config), code: this.code, status: this.status }; } }); const prototype$1 = AxiosError.prototype; const descriptors = {}; [ "ERR_BAD_OPTION_VALUE", "ERR_BAD_OPTION", "ECONNABORTED", "ETIMEDOUT", "ERR_NETWORK", "ERR_FR_TOO_MANY_REDIRECTS", "ERR_DEPRECATED", "ERR_BAD_RESPONSE", "ERR_BAD_REQUEST", "ERR_CANCELED", "ERR_NOT_SUPPORT", "ERR_INVALID_URL" // eslint-disable-next-line func-names ].forEach((code) => { descriptors[code] = { value: code }; }); Object.defineProperties(AxiosError, descriptors); Object.defineProperty(prototype$1, "isAxiosError", { value: true }); AxiosError.from = (error, code, config, request, response, customProps) => { const axiosError = Object.create(prototype$1); utils$1.toFlatObject(error, axiosError, function filter(obj) { return obj !== Error.prototype; }, (prop) => { return prop !== "isAxiosError"; }); AxiosError.call(axiosError, error.message, code, config, request, response); axiosError.cause = error; axiosError.name = error.name; customProps && Object.assign(axiosError, customProps); return axiosError; }; const httpAdapter = null; function isVisitable(thing) { return utils$1.isPlainObject(thing) || utils$1.isArray(thing); } function removeBrackets(key) { return utils$1.endsWith(key, "[]") ? key.slice(0, -2) : key; } function renderKey(path, key, dots) { if (!path) return key; return path.concat(key).map(function each(token, i) { token = removeBrackets(token); return !dots && i ? "[" + token + "]" : token; }).join(dots ? "." : ""); } function isFlatArray(arr) { return utils$1.isArray(arr) && !arr.some(isVisitable); } const predicates = utils$1.toFlatObject(utils$1, {}, null, function filter(prop) { return /^is[A-Z]/.test(prop); }); function toFormData(obj, formData, options) { if (!utils$1.isObject(obj)) { throw new TypeError("target must be an object"); } formData = formData || new FormData(); options = utils$1.toFlatObject(options, { metaTokens: true, dots: false, indexes: false }, false, function defined(option, source) { return !utils$1.isUndefined(source[option]); }); const metaTokens = options.metaTokens; const visitor = options.visitor || defaultVisitor; const dots = options.dots; const indexes = options.indexes; const _Blob = options.Blob || typeof Blob !== "undefined" && Blob; const useBlob = _Blob && utils$1.isSpecCompliantForm(formData); if (!utils$1.isFunction(visitor)) { throw new TypeError("visitor must be a function"); } function convertValue(value) { if (value === null) return ""; if (utils$1.isDate(value)) { return value.toISOString(); } if (!useBlob && utils$1.isBlob(value)) { throw new AxiosError("Blob is not supported. Use a Buffer instead."); } if (utils$1.isArrayBuffer(value) || utils$1.isTypedArray(value)) { return useBlob && typeof Blob === "function" ? new Blob([value]) : Buffer.from(value); } return value; } function defaultVisitor(value, key, path) { let arr = value; if (value && !path && typeof value === "object") { if (utils$1.endsWith(key, "{}")) { key = metaTokens ? key : key.slice(0, -2); value = JSON.stringify(value); } else if (utils$1.isArray(value) && isFlatArray(value) || (utils$1.isFileList(value) || utils$1.endsWith(key, "[]")) && (arr = utils$1.toArray(value))) { key = removeBrackets(key); arr.forEach(function each(el, index) { !(utils$1.isUndefined(el) || el === null) && formData.append( // eslint-disable-next-line no-nested-ternary indexes === true ? renderKey([key], index, dots) : indexes === null ? key : key + "[]", convertValue(el) ); }); return false; } } if (isVisitable(value)) { return true; } formData.append(renderKey(path, key, dots), convertValue(value)); return false; } const stack = []; const exposedHelpers = Object.assign(predicates, { defaultVisitor, convertValue, isVisitable }); function build(value, path) { if (utils$1.isUndefined(value)) return; if (stack.indexOf(value) !== -1) { throw Error("Circular reference detected in " + path.join(".")); } stack.push(value); utils$1.forEach(value, function each(el, key) { const result = !(utils$1.isUndefined(el) || el === null) && visitor.call( formData, el, utils$1.isString(key) ? key.trim() : key, path, exposedHelpers ); if (result === true) { build(el, path ? path.concat(key) : [key]); } }); stack.pop(); } if (!utils$1.isObject(obj)) { throw new TypeError("data must be an object"); } build(obj); return formData; } function encode$1(str) { const charMap = { "!": "%21", "'": "%27", "(": "%28", ")": "%29", "~": "%7E", "%20": "+", "%00": "\0" }; return encodeURIComponent(str).replace(/[!'()~]|%20|%00/g, function replacer(match) { return charMap[match]; }); } function AxiosURLSearchParams(params, options) { this._pairs = []; params && toFormData(params, this, options); } const prototype = AxiosURLSearchParams.prototype; prototype.append = function append(name, value) { this._pairs.push([name, value]); }; prototype.toString = function toString2(encoder) { const _encode = encoder ? function(value) { return encoder.call(this, value, encode$1); } : encode$1; return this._pairs.map(function each(pair) { return _encode(pair[0]) + "=" + _encode(pair[1]); }, "").join("&"); }; function encode(val) { return encodeURIComponent(val).replace(/%3A/gi, ":").replace(/%24/g, "$").replace(/%2C/gi, ",").replace(/%20/g, "+").replace(/%5B/gi, "[").replace(/%5D/gi, "]"); } function buildURL(url, params, options) { if (!params) { return url; } const _encode = options && options.encode || encode; if (utils$1.isFunction(options)) { options = { serialize: options }; } const serializeFn = options && options.serialize; let serializedParams; if (serializeFn) { serializedParams = serializeFn(params, options); } else { serializedParams = utils$1.isURLSearchParams(params) ? params.toString() : new AxiosURLSearchParams(params, options).toString(_encode); } if (serializedParams) { const hashmarkIndex = url.indexOf("#"); if (hashmarkIndex !== -1) { url = url.slice(0, hashmarkIndex); } url += (url.indexOf("?") === -1 ? "?" : "&") + serializedParams; } return url; } class InterceptorManager { constructor() { this.handlers = []; } /** * Add a new interceptor to the stack * * @param {Function} fulfilled The function to handle `then` for a `Promise` * @param {Function} rejected The function to handle `reject` for a `Promise` * * @return {Number} An ID used to remove interceptor later */ use(fulfilled, rejected, options) { this.handlers.push({ fulfilled, rejected, synchronous: options ? options.synchronous : false, runWhen: options ? options.runWhen : null }); return this.handlers.length - 1; } /** * Remove an interceptor from the stack * * @param {Number} id The ID that was returned by `use` * * @returns {Boolean} `true` if the interceptor was removed, `false` otherwise */ eject(id) { if (this.handlers[id]) { this.handlers[id] = null; } } /** * Clear all interceptors from the stack * * @returns {void} */ clear() { if (this.handlers) { this.handlers = []; } } /** * Iterate over all the registered interceptors * * This method is particularly useful for skipping over any * interceptors that may have become `null` calling `eject`. * * @param {Function} fn The function to call for each interceptor * * @returns {void} */ forEach(fn) { utils$1.forEach(this.handlers, function forEachHandler(h) { if (h !== null) { fn(h); } }); } } const InterceptorManager$1 = InterceptorManager; const transitionalDefaults = { silentJSONParsing: true, forcedJSONParsing: true, clarifyTimeoutError: false }; const URLSearchParams$1 = typeof URLSearchParams !== "undefined" ? URLSearchParams : AxiosURLSearchParams; const FormData$1 = typeof FormData !== "undefined" ? FormData : null; const Blob$1 = typeof Blob !== "undefined" ? Blob : null; const platform$1 = { isBrowser: true, classes: { URLSearchParams: URLSearchParams$1, FormData: FormData$1, Blob: Blob$1 }, protocols: ["http", "https", "file", "blob", "url", "data"] }; const hasBrowserEnv = typeof window !== "undefined" && typeof document !== "undefined"; const _navigator = typeof navigator === "object" && navigator || void 0; const hasStandardBrowserEnv = hasBrowserEnv && (!_navigator || ["ReactNative", "NativeScript", "NS"].indexOf(_navigator.product) < 0); const hasStandardBrowserWebWorkerEnv = (() => { return typeof WorkerGlobalScope !== "undefined" && // eslint-disable-next-line no-undef self instanceof WorkerGlobalScope && typeof self.importScripts === "function"; })(); const origin = hasBrowserEnv && window.location.href || "http://localhost"; const utils = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ __proto__: null, hasBrowserEnv, hasStandardBrowserEnv, hasStandardBrowserWebWorkerEnv, navigator: _navigator, origin }, Symbol.toStringTag, { value: "Module" })); const platform = { ...utils, ...platform$1 }; function toURLEncodedForm(data2, options) { return toFormData(data2, new platform.classes.URLSearchParams(), Object.assign({ visitor: function(value, key, path, helpers) { if (platform.isNode && utils$1.isBuffer(value)) { this.append(key, value.toString("base64")); return false; } return helpers.defaultVisitor.apply(this, arguments); } }, options)); } function parsePropPath(name) { return utils$1.matchAll(/\w+|\[(\w*)]/g, name).map((match) => { return match[0] === "[]" ? "" : match[1] || match[0]; }); } function arrayToObject(arr) { const obj = {}; const keys = Object.keys(arr); let i; const len = keys.length; let key; for (i = 0; i < len; i++) { key = keys[i]; obj[key] = arr[key]; } return obj; } function formDataToJSON(formData) { function buildPath(path, value, target, index) { let name = path[index++]; if (name === "__proto__") return true; const isNumericKey = Number.isFinite(+name); const isLast = index >= path.length; name = !name && utils$1.isArray(target) ? target.length : name; if (isLast) { if (utils$1.hasOwnProp(target, name)) { target[name] = [target[name], value]; } else { target[name] = value; } return !isNumericKey; } if (!target[name] || !utils$1.isObject(target[name])) { target[name] = []; } const result = buildPath(path, value, target[name], index); if (result && utils$1.isArray(target[name])) { target[name] = arrayToObject(target[name]); } return !isNumericKey; } if (utils$1.isFormData(formData) && utils$1.isFunction(formData.entries)) { const obj = {}; utils$1.forEachEntry(formData, (name, value) => { buildPath(parsePropPath(name), value, obj, 0); }); return obj; } return null; } function stringifySafely(rawValue, parser, encoder) { if (utils$1.isString(rawValue)) { try { (parser || JSON.parse)(rawValue); return utils$1.trim(rawValue); } catch (e) { if (e.name !== "SyntaxError") { throw e; } } } return (encoder || JSON.stringify)(rawValue); } const defaults = { transitional: transitionalDefaults, adapter: ["xhr", "http", "fetch"], transformRequest: [function transformRequest(data2, headers) { const contentType = headers.getContentType() || ""; const hasJSONContentType = contentType.indexOf("application/json") > -1; const isObjectPayload = utils$1.isObject(data2); if (isObjectPayload && utils$1.isHTMLForm(data2)) { data2 = new FormData(data2); } const isFormData2 = utils$1.isFormData(data2); if (isFormData2) { return hasJSONContentType ? JSON.stringify(formDataToJSON(data2)) : data2; } if (utils$1.isArrayBuffer(data2) || utils$1.isBuffer(data2) || utils$1.isStream(data2) || utils$1.isFile(data2) || utils$1.isBlob(data2) || utils$1.isReadableStream(data2)) { return data2; } if (utils$1.isArrayBufferView(data2)) { return data2.buffer; } if (utils$1.isURLSearchParams(data2)) { headers.setContentType("application/x-www-form-urlencoded;charset=utf-8", false); return data2.toString(); } let isFileList2; if (isObjectPayload) { if (contentType.indexOf("application/x-www-form-urlencoded") > -1) { return toURLEncodedForm(data2, this.formSerializer).toString(); } if ((isFileList2 = utils$1.isFileList(data2)) || contentType.indexOf("multipart/form-data") > -1) { const _FormData = this.env && this.env.FormData; return toFormData( isFileList2 ? { "files[]": data2 } : data2, _FormData && new _FormData(), this.formSerializer ); } } if (isObjectPayload || hasJSONContentType) { headers.setContentType("application/json", false); return stringifySafely(data2); } return data2; }], transformResponse: [function transformResponse(data2) { const transitional = this.transitional || defaults.transitional; const forcedJSONParsing = transitional && transitional.forcedJSONParsing; const JSONRequested = this.responseType === "json"; if (utils$1.isResponse(data2) || utils$1.isReadableStream(data2)) { return data2; } if (data2 && utils$1.isString(data2) && (forcedJSONParsing && !this.responseType || JSONRequested)) { const silentJSONParsing = transitional && transitional.silentJSONParsing; const strictJSONParsing = !silentJSONParsing && JSONRequested; try { return JSON.parse(data2); } catch (e) { if (strictJSONParsing) { if (e.name === "SyntaxError") { throw AxiosError.from(e, AxiosError.ERR_BAD_RESPONSE, this, null, this.response); } throw e; } } } return data2; }], /** * A timeout in milliseconds to abort a request. If set to 0 (default) a * timeout is not created. */ timeout: 0, xsrfCookieName: "XSRF-TOKEN", xsrfHeaderName: "X-XSRF-TOKEN", maxContentLength: -1, maxBodyLength: -1, env: { FormData: platform.classes.FormData, Blob: platform.classes.Blob }, validateStatus: function validateStatus(status) { return status >= 200 && status < 300; }, headers: { common: { "Accept": "application/json, text/plain, */*", "Content-Type": void 0 } } }; utils$1.forEach(["delete", "get", "head", "post", "put", "patch"], (method) => { defaults.headers[method] = {}; }); const defaults$1 = defaults; const ignoreDuplicateOf = utils$1.toObjectSet([ "age", "authorization", "content-length", "content-type", "etag", "expires", "from", "host", "if-modified-since", "if-unmodified-since", "last-modified", "location", "max-forwards", "proxy-authorization", "referer", "retry-after", "user-agent" ]); const parseHeaders = (rawHeaders) => { const parsed = {}; let key; let val; let i; rawHeaders && rawHeaders.split("\n").forEach(function parser(line) { i = line.indexOf(":"); key = line.substring(0, i).trim().toLowerCase(); val = line.substring(i + 1).trim(); if (!key || parsed[key] && ignoreDuplicateOf[key]) { return; } if (key === "set-cookie") { if (parsed[key]) { parsed[key].push(val); } else { parsed[key] = [val]; } } else { parsed[key] = parsed[key] ? parsed[key] + ", " + val : val; } }); return parsed; }; const $internals = Symbol("internals"); function normalizeHeader(header) { return header && String(header).trim().toLowerCase(); } function normalizeValue(value) { if (value === false || value == null) { return value; } return utils$1.isArray(value) ? value.map(normalizeValue) : String(value); } function parseTokens(str) { const tokens = /* @__PURE__ */ Object.create(null); const tokensRE = /([^\s,;=]+)\s*(?:=\s*([^,;]+))?/g; let match; while (match = tokensRE.exec(str)) { tokens[match[1]] = match[2]; } return tokens; } const isValidHeaderName = (str) => /^[-_a-zA-Z0-9^`|~,!#$%&'*+.]+$/.test(str.trim()); function matchHeaderValue(context, value, header, filter, isHeaderNameFilter) { if (utils$1.isFunction(filter)) { return filter.call(this, value, header); } if (isHeaderNameFilter) { value = header; } if (!utils$1.isString(value)) return; if (utils$1.isString(filter)) { return value.indexOf(filter) !== -1; } if (utils$1.isRegExp(filter)) { return filter.test(value); } } function formatHeader(header) { return header.trim().toLowerCase().replace(/([a-z\d])(\w*)/g, (w, char, str) => { return char.toUpperCase() + str; }); } function buildAccessors(obj, header) { const accessorName = utils$1.toCamelCase(" " + header); ["get", "set", "has"].forEach((methodName) => { Object.defineProperty(obj, methodName + accessorName, { value: function(arg1, arg2, arg3) { return this[methodName].call(this, header, arg1, arg2, arg3); }, configurable: true }); }); } class AxiosHeaders { constructor(headers) { headers && this.set(headers); } set(header, valueOrRewrite, rewrite) { const self2 = this; function setHeader(_value, _header, _rewrite) { const lHeader = normalizeHeader(_header); if (!lHeader) { throw new Error("header name must be a non-empty string"); } const key = utils$1.findKey(self2, lHeader); if (!key || self2[key] === void 0 || _rewrite === true || _rewrite === void 0 && self2[key] !== false) { self2[key || _header] = normalizeValue(_value); } } const setHeaders = (headers, _rewrite) => utils$1.forEach(headers, (_value, _header) => setHeader(_value, _header, _rewrite)); if (utils$1.isPlainObject(header) || header instanceof this.constructor) { setHeaders(header, valueOrRewrite); } else if (utils$1.isString(header) && (header = header.trim()) && !isValidHeaderName(header)) { setHeaders(parseHeaders(header), valueOrRewrite); } else if (utils$1.isHeaders(header)) { for (const [key, value] of header.entries()) { setHeader(value, key, rewrite); } } else { header != null && setHeader(valueOrRewrite, header, rewrite); } return this; } get(header, parser) { header = normalizeHeader(header); if (header) { const key = utils$1.findKey(this, header); if (key) { const value = this[key]; if (!parser) { return value; } if (parser === true) { return parseTokens(value); } if (utils$1.isFunction(parser)) { return parser.call(this, value, key); } if (utils$1.isRegExp(parser)) { return parser.exec(value); } throw new TypeError("parser must be boolean|regexp|function"); } } } has(header, matcher) { header = normalizeHeader(header); if (header) { const key = utils$1.findKey(this, header); return !!(key && this[key] !== void 0 && (!matcher || matchHeaderValue(this, this[key], key, matcher))); } return false; } delete(header, matcher) { const self2 = this; let deleted = false; function deleteHeader(_header) { _header = normalizeHeader(_header); if (_header) { const key = utils$1.findKey(self2, _header); if (key && (!matcher || matchHeaderValue(self2, self2[key], key, matcher))) { delete self2[key]; deleted = true; } } } if (utils$1.isArray(header)) { header.forEach(deleteHeader); } else { deleteHeader(header); } return deleted; } clear(matcher) { const keys = Object.keys(this); let i = keys.length; let deleted = false; while (i--) { const key = keys[i]; if (!matcher || matchHeaderValue(this, this[key], key, matcher, true)) { delete this[key]; deleted = true; } } return deleted; } normalize(format) { const self2 = this; const headers = {}; utils$1.forEach(this, (value, header) => { const key = utils$1.findKey(headers, header); if (key) { self2[key] = normalizeValue(value); delete self2[header]; return; } const normalized = format ? formatHeader(header) : String(header).trim(); if (normalized !== header) { delete self2[header]; } self2[normalized] = normalizeValue(value); headers[normalized] = true; }); return this; } concat(...targets) { return this.constructor.concat(this, ...targets); } toJSON(asStrings) { const obj = /* @__PURE__ */ Object.create(null); utils$1.forEach(this, (value, header) => { value != null && value !== false && (obj[header] = asStrings && utils$1.isArray(value) ? value.join(", ") : value); }); return obj; } [Symbol.iterator]() { return Object.entries(this.toJSON())[Symbol.iterator](); } toString() { return Object.entries(this.toJSON()).map(([header, value]) => header + ": " + value).join("\n"); } get [Symbol.toStringTag]() { return "AxiosHeaders"; } static from(thing) { return thing instanceof this ? thing : new this(thing); } static concat(first, ...targets) { const computed = new this(first); targets.forEach((target) => computed.set(target)); return computed; } static accessor(header) { const internals = this[$internals] = this[$internals] = { accessors: {} }; const accessors = internals.accessors; const prototype2 = this.prototype; function defineAccessor(_header) { const lHeader = normalizeHeader(_header); if (!accessors[lHeader]) { buildAccessors(prototype2, _header); accessors[lHeader] = true; } } utils$1.isArray(header) ? header.forEach(defineAccessor) : defineAccessor(header); return this; } } AxiosHeaders.accessor(["Content-Type", "Content-Length", "Accept", "Accept-Encoding", "User-Agent", "Authorization"]); utils$1.reduceDescriptors(AxiosHeaders.prototype, ({ value }, key) => { let mapped = key[0].toUpperCase() + key.slice(1); return { get: () => value, set(headerValue) { this[mapped] = headerValue; } }; }); utils$1.freezeMethods(AxiosHeaders); const AxiosHeaders$1 = AxiosHeaders; function transformData(fns, response) { const config = this || defaults$1; const context = response || config; const headers = AxiosHeaders$1.from(context.headers); let data2 = context.data; utils$1.forEach(fns, function transform(fn) { data2 = fn.call(config, data2, headers.normalize(), response ? response.status : void 0); }); headers.normalize(); return data2; } function isCancel(value) { return !!(value && value.__CANCEL__); } function CanceledError(message2, config, request) { AxiosError.call(this, message2 == null ? "canceled" : message2, AxiosError.ERR_CANCELED, config, request); this.name = "CanceledError"; } utils$1.inherits(CanceledError, AxiosError, { __CANCEL__: true }); function settle(resolve, reject, response) { const validateStatus = response.config.validateStatus; if (!response.status || !validateStatus || validateStatus(response.status)) { resolve(response); } else { reject(new AxiosError( "Request failed with status code " + response.status, [AxiosError.ERR_BAD_REQUEST, AxiosError.ERR_BAD_RESPONSE][Math.floor(response.status / 100) - 4], response.config, response.request, response )); } } function parseProtocol(url) { const match = /^([-+\w]{1,25})(:?\/\/|:)/.exec(url); return match && match[1] || ""; } function speedometer(samplesCount, min) { samplesCount = samplesCount || 10; const bytes = new Array(samplesCount); const timestamps = new Array(samplesCount); let head = 0; let tail = 0; let firstSampleTS; min = min !== void 0 ? min : 1e3; return function push(chunkLength) { const now = Date.now(); const startedAt = timestamps[tail]; if (!firstSampleTS) { firstSampleTS = now; } bytes[head] = chunkLength; timestamps[head] = now; let i = tail; let bytesCount = 0; while (i !== head) { bytesCount += bytes[i++]; i = i % samplesCount; } head = (head + 1) % samplesCount; if (head === tail) { tail = (tail + 1) % samplesCount; } if (now - firstSampleTS < min) { return; } const passed = startedAt && now - startedAt; return passed ? Math.round(bytesCount * 1e3 / passed) : void 0; }; } function throttle(fn, freq) { let timestamp = 0; let threshold = 1e3 / freq; let lastArgs; let timer; const invoke = (args, now = Date.now()) => { timestamp = now; lastArgs = null; if (timer) { clearTimeout(timer); timer = null; } fn.apply(null, args); }; const throttled = (...args) => { const now = Date.now(); const passed = now - timestamp; if (passed >= threshold) { invoke(args, now); } else { lastArgs = args; if (!timer) { timer = setTimeout(() => { timer = null; invoke(lastArgs); }, threshold - passed); } } }; const flush = () => lastArgs && invoke(lastArgs); return [throttled, flush]; } const progressEventReducer = (listener, isDownloadStream, freq = 3) => { let bytesNotified = 0; const _speedometer = speedometer(50, 250); return throttle((e) => { const loaded = e.loaded; const total = e.lengthComputable ? e.total : void 0; const progressBytes = loaded - bytesNotified; const rate = _speedometer(progressBytes); const inRange = loaded <= total; bytesNotified = loaded; const data2 = { loaded, total, progress: total ? loaded / total : void 0, bytes: progressBytes, rate: rate ? rate : void 0, estimated: rate && total && inRange ? (total - loaded) / rate : void 0, event: e, lengthComputable: total != null, [isDownloadStream ? "download" : "upload"]: true }; listener(data2); }, freq); }; const progressEventDecorator = (total, throttled) => { const lengthComputable = total != null; return [(loaded) => throttled[0]({ lengthComputable, total, loaded }), throttled[1]]; }; const asyncDecorator = (fn) => (...args) => utils$1.asap(() => fn(...args)); const isURLSameOrigin = platform.hasStandardBrowserEnv ? ((origin2, isMSIE) => (url) => { url = new URL(url, platform.origin); return origin2.protocol === url.protocol && origin2.host === url.host && (isMSIE || origin2.port === url.port); })( new URL(platform.origin), platform.navigator && /(msie|trident)/i.test(platform.navigator.userAgent) ) : () => true; const cookies = platform.hasStandardBrowserEnv ? ( // Standard browser envs support document.cookie { write(name, value, expires, path, domain, secure) { const cookie = [name + "=" + encodeURIComponent(value)]; utils$1.isNumber(expires) && cookie.push("expires=" + new Date(expires).toGMTString()); utils$1.isString(path) && cookie.push("path=" + path); utils$1.isString(domain) && cookie.push("domain=" + domain); secure === true && cookie.push("secure"); document.cookie = cookie.join("; "); }, read(name) { const match = document.cookie.match(new RegExp("(^|;\\s*)(" + name + ")=([^;]*)")); return match ? decodeURIComponent(match[3]) : null; }, remove(name) { this.write(name, "", Date.now() - 864e5); } } ) : ( // Non-standard browser env (web workers, react-native) lack needed support. { write() { }, read() { return null; }, remove() { } } ); function isAbsoluteURL(url) { return /^([a-z][a-z\d+\-.]*:)?\/\//i.test(url); } function combineURLs(baseURL2, relativeURL) { return relativeURL ? baseURL2.replace(/\/?\/$/, "") + "/" + relativeURL.replace(/^\/+/, "") : baseURL2; } function buildFullPath(baseURL2, requestedURL) { if (baseURL2 && !isAbsoluteURL(requestedURL)) { return combineURLs(baseURL2, requestedURL); } return requestedURL; } const headersToObject = (thing) => thing instanceof AxiosHeaders$1 ? { ...thing } : thing; function mergeConfig(config1, config2) { config2 = config2 || {}; const config = {}; function getMergedValue(target, source, prop, caseless) { if (utils$1.isPlainObject(target) && utils$1.isPlainObject(source)) { return utils$1.merge.call({ caseless }, target, source); } else if (utils$1.isPlainObject(source)) { return utils$1.merge({}, source); } else if (utils$1.isArray(source)) { return source.slice(); } return source; } function mergeDeepProperties(a, b, prop, caseless) { if (!utils$1.isUndefined(b)) { return getMergedValue(a, b, prop, caseless); } else if (!utils$1.isUndefined(a)) { return getMergedValue(void 0, a, prop, caseless); } } function valueFromConfig2(a, b) { if (!utils$1.isUndefined(b)) { return getMergedValue(void 0, b); } } function defaultToConfig2(a, b) { if (!utils$1.isUndefined(b)) { return getMergedValue(void 0, b); } else if (!utils$1.isUndefined(a)) { return getMergedValue(void 0, a); } } function mergeDirectKeys(a, b, prop) { if (prop in config2) { return getMergedValue(a, b); } else if (prop in config1) { return getMergedValue(void 0, a); } } const mergeMap = { url: valueFromConfig2, method: valueFromConfig2, data: valueFromConfig2, baseURL: defaultToConfig2, transformRequest: defaultToConfig2, transformResponse: defaultToConfig2, paramsSerializer: defaultToConfig2, timeout: defaultToConfig2, timeoutMessage: defaultToConfig2, withCredentials: defaultToConfig2, withXSRFToken: defaultToConfig2, adapter: defaultToConfig2, responseType: defaultToConfig2, xsrfCookieName: defaultToConfig2, xsrfHeaderName: defaultToConfig2, onUploadProgress: defaultToConfig2, onDownloadProgress: defaultToConfig2, decompress: defaultToConfig2, maxContentLength: defaultToConfig2, maxBodyLength: defaultToConfig2, beforeRedirect: defaultToConfig2, transport: defaultToConfig2, httpAgent: defaultToConfig2, httpsAgent: defaultToConfig2, cancelToken: defaultToConfig2, socketPath: defaultToConfig2, responseEncoding: defaultToConfig2, validateStatus: mergeDirectKeys, headers: (a, b, prop) => mergeDeepProperties(headersToObject(a), headersToObject(b), prop, true) }; utils$1.forEach(Object.keys(Object.assign({}, config1, config2)), function computeConfigValue(prop) { const merge2 = mergeMap[prop] || mergeDeepProperties; const configValue = merge2(config1[prop], config2[prop], prop); utils$1.isUndefined(configValue) && merge2 !== mergeDirectKeys || (config[prop] = configValue); }); return config; } const resolveConfig = (config) => { const newConfig = mergeConfig({}, config); let { data: data2, withXSRFToken, xsrfHeaderName, xsrfCookieName, headers, auth } = newConfig; newConfig.headers = headers = AxiosHeaders$1.from(headers); newConfig.url = buildURL(buildFullPath(newConfig.baseURL, newConfig.url), config.params, config.paramsSerializer); if (auth) { headers.set( "Authorization", "Basic " + btoa((auth.username || "") + ":" + (auth.password ? unescape(encodeURIComponent(auth.password)) : "")) ); } let contentType; if (utils$1.isFormData(data2)) { if (platform.hasStandardBrowserEnv || platform.hasStandardBrowserWebWorkerEnv) { headers.setContentType(void 0); } else if ((contentType = headers.getContentType()) !== false) { const [type, ...tokens] = contentType ? contentType.split(";").map((token) => token.trim()).filter(Boolean) : []; headers.setContentType([type || "multipart/form-data", ...tokens].join("; ")); } } if (platform.hasStandardBrowserEnv) { withXSRFToken && utils$1.isFunction(withXSRFToken) && (withXSRFToken = withXSRFToken(newConfig)); if (withXSRFToken || withXSRFToken !== false && isURLSameOrigin(newConfig.url)) { const xsrfValue = xsrfHeaderName && xsrfCookieName && cookies.read(xsrfCookieName); if (xsrfValue) { headers.set(xsrfHeaderName, xsrfValue); } } } return newConfig; }; const isXHRAdapterSupported = typeof XMLHttpRequest !== "undefined"; const xhrAdapter = isXHRAdapterSupported && function(config) { return new Promise(function dispatchXhrRequest(resolve, reject) { const _config = resolveConfig(config); let requestData = _config.data; const requestHeaders = AxiosHeaders$1.from(_config.headers).normalize(); let { responseType, onUploadProgress, onDownloadProgress } = _config; let onCanceled; let uploadThrottled, downloadThrottled; let flushUpload, flushDownload; function done() { flushUpload && flushUpload(); flushDownload && flushDownload(); _config.cancelToken && _config.cancelToken.unsubscribe(onCanceled); _config.signal && _config.signal.removeEventListener("abort", onCanceled); } let request = new XMLHttpRequest(); request.open(_config.method.toUpperCase(), _config.url, true); request.timeout = _config.timeout; function onloadend() { if (!request) { return; } const responseHeaders = AxiosHeaders$1.from( "getAllResponseHeaders" in request && request.getAllResponseHeaders() ); const responseData = !responseType || responseType === "text" || responseType === "json" ? request.responseText : request.response; const response = { data: responseData, status: request.status, statusText: request.statusText, headers: responseHeaders, config, request }; settle(function _resolve(value) { resolve(value); done(); }, function _reject(err) { reject(err); done(); }, response); request = null; } if ("onloadend" in request) { request.onloadend = onloadend; } else { request.onreadystatechange = function handleLoad() { if (!request || request.readyState !== 4) { return; } if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf("file:") === 0)) { return; } setTimeout(onloadend); }; } request.onabort = function handleAbort() { if (!request) { return; } reject(new AxiosError("Request aborted", AxiosError.ECONNABORTED, config, request)); request = null; }; request.onerror = function handleError() { reject(new AxiosError("Network Error", AxiosError.ERR_NETWORK, config, request)); request = null; }; request.ontimeout = function handleTimeout() { let timeoutErrorMessage = _config.timeout ? "timeout of " + _config.timeout + "ms exceeded" : "timeout exceeded"; const transitional = _config.transitional || transitionalDefaults; if (_config.timeoutErrorMessage) { timeoutErrorMessage = _config.timeoutErrorMessage; } reject(new AxiosError( timeoutErrorMessage, transitional.clarifyTimeoutError ? AxiosError.ETIMEDOUT : AxiosError.ECONNABORTED, config, request )); request = null; }; requestData === void 0 && requestHeaders.setContentType(null); if ("setRequestHeader" in request) { utils$1.forEach(requestHeaders.toJSON(), function setRequestHeader(val, key) { request.setRequestHeader(key, val); }); } if (!utils$1.isUndefined(_config.withCredentials)) { request.withCredentials = !!_config.withCredentials; } if (responseType && responseType !== "json") { request.responseType = _config.responseType; } if (onDownloadProgress) { [downloadThrottled, flushDownload] = progressEventReducer(onDownloadProgress, true); request.addEventListener("progress", downloadThrottled); } if (onUploadProgress && request.upload) { [uploadThrottled, flushUpload] = progressEventReducer(onUploadProgress); request.upload.addEventListener("progress", uploadThrottled); request.upload.addEventListener("loadend", flushUpload); } if (_config.cancelToken || _config.signal) { onCanceled = (cancel) => { if (!request) { return; } reject(!cancel || cancel.type ? new CanceledError(null, config, request) : cancel); request.abort(); request = null; }; _config.cancelToken && _config.cancelToken.subscribe(onCanceled); if (_config.signal) { _config.signal.aborted ? onCanceled() : _config.signal.addEventListener("abort", onCanceled); } } const protocol = parseProtocol(_config.url); if (protocol && platform.protocols.indexOf(protocol) === -1) { reject(new AxiosError("Unsupported protocol " + protocol + ":", AxiosError.ERR_BAD_REQUEST, config)); return; } request.send(requestData || null); }); }; const composeSignals = (signals, timeout) => { const { length } = signals = signals ? signals.filter(Boolean) : []; if (timeout || length) { let controller = new AbortController(); let aborted; const onabort = function(reason) { if (!aborted) { aborted = true; unsubscribe(); const err = reason instanceof Error ? reason : this.reason; controller.abort(err instanceof AxiosError ? err : new CanceledError(err instanceof Error ? err.message : err)); } }; let timer = timeout && setTimeout(() => { timer = null; onabort(new AxiosError(`timeout ${timeout} of ms exceeded`, AxiosError.ETIMEDOUT)); }, timeout); const unsubscribe = () => { if (signals) { timer && clearTimeout(timer); timer = null; signals.forEach((signal2) => { signal2.unsubscribe ? signal2.unsubscribe(onabort) : signal2.removeEventListener("abort", onabort); }); signals = null; } }; signals.forEach((signal2) => signal2.addEventListener("abort", onabort)); const { signal } = controller; signal.unsubscribe = () => utils$1.asap(unsubscribe); return signal; } }; const composeSignals$1 = composeSignals; const streamChunk = function* (chunk, chunkSize) { let len = chunk.byteLength; if (!chunkSize || len < chunkSize) { yield chunk; return; } let pos = 0; let end; while (pos < len) { end = pos + chunkSize; yield chunk.slice(pos, end); pos = end; } }; const readBytes = async function* (iterable, chunkSize) { for await (const chunk of readStream(iterable)) { yield* streamChunk(chunk, chunkSize); } }; const readStream = async function* (stream) { if (stream[Symbol.asyncIterator]) { yield* stream; return; } const reader = stream.getReader(); try { for (; ; ) { const { done, value } = await reader.read(); if (done) { break; } yield value; } } finally { await reader.cancel(); } }; const trackStream = (stream, chunkSize, onProgress, onFinish) => { const iterator = readBytes(stream, chunkSize); let bytes = 0; let done; let _onFinish = (e) => { if (!done) { done = true; onFinish && onFinish(e); } }; return new ReadableStream({ async pull(controller) { try { const { done: done2, value } = await iterator.next(); if (done2) { _onFinish(); controller.close(); return; } let len = value.byteLength; if (onProgress) { let loadedBytes = bytes += len; onProgress(loadedBytes); } controller.enqueue(new Uint8Array(value)); } catch (err) { _onFinish(err); throw err; } }, cancel(reason) { _onFinish(reason); return iterator.return(); } }, { highWaterMark: 2 }); }; const isFetchSupported = typeof fetch === "function" && typeof Request === "function" && typeof Response === "function"; const isReadableStreamSupported = isFetchSupported && typeof ReadableStream === "function"; const encodeText = isFetchSupported && (typeof TextEncoder === "function" ? ((encoder) => (str) => encoder.encode(str))(new TextEncoder()) : async (str) => new Uint8Array(await new Response(str).arrayBuffer())); const test = (fn, ...args) => { try { return !!fn(...args); } catch (e) { return false; } }; const supportsRequestStream = isReadableStreamSupported && test(() => { let duplexAccessed = false; const hasContentType = new Request(platform.origin, { body: new ReadableStream(), method: "POST", get duplex() { duplexAccessed = true; return "half"; } }).headers.has("Content-Type"); return duplexAccessed && !hasContentType; }); const DEFAULT_CHUNK_SIZE = 64 * 1024; const supportsResponseStream = isReadableStreamSupported && test(() => utils$1.isReadableStream(new Response("").body)); const resolvers = { stream: supportsResponseStream && ((res2) => res2.body) }; isFetchSupported && ((res2) => { ["text", "arrayBuffer", "blob", "formData", "stream"].forEach((type) => { !resolvers[type] && (resolvers[type] = utils$1.isFunction(res2[type]) ? (res3) => res3[type]() : (_, config) => { throw new AxiosError(`Response type '${type}' is not supported`, AxiosError.ERR_NOT_SUPPORT, config); }); }); })(new Response()); const getBodyLength = async (body) => { if (body == null) { return 0; } if (utils$1.isBlob(body)) { return body.size; } if (utils$1.isSpecCompliantForm(body)) { const _request = new Request(platform.origin, { method: "POST", body }); return (await _request.arrayBuffer()).byteLength; } if (utils$1.isArrayBufferView(body) || utils$1.isArrayBuffer(body)) { return body.byteLength; } if (utils$1.isURLSearchParams(body)) { body = body + ""; } if (utils$1.isString(body)) { return (await encodeText(body)).byteLength; } }; const resolveBodyLength = async (headers, body) => { const length = utils$1.toFiniteNumber(headers.getContentLength()); return length == null ? getBodyLength(body) : length; }; const fetchAdapter = isFetchSupported && (async (config) => { let { url, method, data: data2, signal, cancelToken, timeout, onDownloadProgress, onUploadProgress, responseType, headers, withCredentials = "same-origin", fetchOptions } = resolveConfig(config); responseType = responseType ? (responseType + "").toLowerCase() : "text"; let composedSignal = composeSignals$1([signal, cancelToken && cancelToken.toAbortSignal()], timeout); let request; const unsubscribe = composedSignal && composedSignal.unsubscribe && (() => { composedSignal.unsubscribe(); }); let requestContentLength; try { if (onUploadProgress && supportsRequestStream && method !== "get" && method !== "head" && (requestContentLength = await resolveBodyLength(headers, data2)) !== 0) { let _request = new Request(url, { method: "POST", body: data2, duplex: "half" }); let contentTypeHeader; if (utils$1.isFormData(data2) && (contentTypeHeader = _request.headers.get("content-type"))) { headers.setContentType(contentTypeHeader); } if (_request.body) { const [onProgress, flush] = progressEventDecorator( requestContentLength, progressEventReducer(asyncDecorator(onUploadProgress)) ); data2 = trackStream(_request.body, DEFAULT_CHUNK_SIZE, onProgress, flush); } } if (!utils$1.isString(withCredentials)) { withCredentials = withCredentials ? "include" : "omit"; } const isCredentialsSupported = "credentials" in Request.prototype; request = new Request(url, { ...fetchOptions, signal: composedSignal, method: method.toUpperCase(), headers: headers.normalize().toJSON(), body: data2, duplex: "half", credentials: isCredentialsSupported ? withCredentials : void 0 }); let response = await fetch(request); const isStreamResponse = supportsResponseStream && (responseType === "stream" || responseType === "response"); if (supportsResponseStream && (onDownloadProgress || isStreamResponse && unsubscribe)) { const options = {}; ["status", "statusText", "headers"].forEach((prop) => { options[prop] = response[prop]; }); const responseContentLength = utils$1.toFiniteNumber(response.headers.get("content-length")); const [onProgress, flush] = onDownloadProgress && progressEventDecorator( responseContentLength, progressEventReducer(asyncDecorator(onDownloadProgress), true) ) || []; response = new Response( trackStream(response.body, DEFAULT_CHUNK_SIZE, onProgress, () => { flush && flush(); unsubscribe && unsubscribe(); }), options ); } responseType = responseType || "text"; let responseData = await resolvers[utils$1.findKey(resolvers, responseType) || "text"](response, config); !isStreamResponse && unsubscribe && unsubscribe(); return await new Promise((resolve, reject) => { settle(resolve, reject, { data: responseData, headers: AxiosHeaders$1.from(response.headers), status: response.status, statusText: response.statusText, config, request }); }); } catch (err) { unsubscribe && unsubscribe(); if (err && err.name === "TypeError" && /fetch/i.test(err.message)) { throw Object.assign( new AxiosError("Network Error", AxiosError.ERR_NETWORK, config, request), { cause: err.cause || err } ); } throw AxiosError.from(err, err && err.code, config, request); } }); const knownAdapters = { http: httpAdapter, xhr: xhrAdapter, fetch: fetchAdapter }; utils$1.forEach(knownAdapters, (fn, value) => { if (fn) { try { Object.defineProperty(fn, "name", { value }); } catch (e) { } Object.defineProperty(fn, "adapterName", { value }); } }); const renderReason = (reason) => `- ${reason}`; const isResolvedHandle = (adapter) => utils$1.isFunction(adapter) || adapter === null || adapter === false; const adapters = { getAdapter: (adapters2) => { adapters2 = utils$1.isArray(adapters2) ? adapters2 : [adapters2]; const { length } = adapters2; let nameOrAdapter; let adapter; const rejectedReasons = {}; for (let i = 0; i < length; i++) { nameOrAdapter = adapters2[i]; let id; adapter = nameOrAdapter; if (!isResolvedHandle(nameOrAdapter)) { adapter = knownAdapters[(id = String(nameOrAdapter)).toLowerCase()]; if (adapter === void 0) { throw new AxiosError(`Unknown adapter '${id}'`); } } if (adapter) { break; } rejectedReasons[id || "#" + i] = adapter; } if (!adapter) { const reasons = Object.entries(rejectedReasons).map( ([id, state]) => `adapter ${id} ` + (state === false ? "is not supported by the environment" : "is not available in the build") ); let s = length ? reasons.length > 1 ? "since :\n" + reasons.map(renderReason).join("\n") : " " + renderReason(reasons[0]) : "as no adapter specified"; throw new AxiosError( `There is no suitable adapter to dispatch the request ` + s, "ERR_NOT_SUPPORT" ); } return adapter; }, adapters: knownAdapters }; function throwIfCancellationRequested(config) { if (config.cancelToken) { config.cancelToken.throwIfRequested(); } if (config.signal && config.signal.aborted) { throw new CanceledError(null, config); } } function dispatchRequest(config) { throwIfCancellationRequested(config); config.headers = AxiosHeaders$1.from(config.headers); config.data = transformData.call( config, config.transformRequest ); if (["post", "put", "patch"].indexOf(config.method) !== -1) { config.headers.setContentType("application/x-www-form-urlencoded", false); } const adapter = adapters.getAdapter(config.adapter || defaults$1.adapter); return adapter(config).then(function onAdapterResolution(response) { throwIfCancellationRequested(config); response.data = transformData.call( config, config.transformResponse, response ); response.headers = AxiosHeaders$1.from(response.headers); return response; }, function onAdapterRejection(reason) { if (!isCancel(reason)) { throwIfCancellationRequested(config); if (reason && reason.response) { reason.response.data = transformData.call( config, config.transformResponse, reason.response ); reason.response.headers = AxiosHeaders$1.from(reason.response.headers); } } return Promise.reject(reason); }); } const VERSION = "1.7.8"; const validators$1 = {}; ["object", "boolean", "number", "function", "string", "symbol"].forEach((type, i) => { validators$1[type] = function validator2(thing) { return typeof thing === type || "a" + (i < 1 ? "n " : " ") + type; }; }); const deprecatedWarnings = {}; validators$1.transitional = function transitional(validator2, version, message2) { function formatMessage(opt, desc) { return "[Axios v" + VERSION + "] Transitional option '" + opt + "'" + desc + (message2 ? ". " + message2 : ""); } return (value, opt, opts) => { if (validator2 === false) { throw new AxiosError( formatMessage(opt, " has been removed" + (version ? " in " + version : "")), AxiosError.ERR_DEPRECATED ); } if (version && !deprecatedWarnings[opt]) { deprecatedWarnings[opt] = true; console.warn( formatMessage( opt, " has been deprecated since v" + version + " and will be removed in the near future" ) ); } return validator2 ? validator2(value, opt, opts) : true; }; }; validators$1.spelling = function spelling(correctSpelling) { return (value, opt) => { console.warn(`${opt} is likely a misspelling of ${correctSpelling}`); return true; }; }; function assertOptions(options, schema, allowUnknown) { if (typeof options !== "object") { throw new AxiosError("options must be an object", AxiosError.ERR_BAD_OPTION_VALUE); } const keys = Object.keys(options); let i = keys.length; while (i-- > 0) { const opt = keys[i]; const validator2 = schema[opt]; if (validator2) { const value = options[opt]; const result = value === void 0 || validator2(value, opt, options); if (result !== true) { throw new AxiosError("option " + opt + " must be " + result, AxiosError.ERR_BAD_OPTION_VALUE); } continue; } if (allowUnknown !== true) { throw new AxiosError("Unknown option " + opt, AxiosError.ERR_BAD_OPTION); } } } const validator = { assertOptions, validators: validators$1 }; const validators = validator.validators; class Axios { constructor(instanceConfig) { this.defaults = instanceConfig; this.interceptors = { request: new InterceptorManager$1(), response: new InterceptorManager$1() }; } /** * Dispatch a request * * @param {String|Object} configOrUrl The config specific for this request (merged with this.defaults) * @param {?Object} config * * @returns {Promise} The Promise to be fulfilled */ async request(configOrUrl, config) { try { return await this._request(configOrUrl, config); } catch (err) { if (err instanceof Error) { let dummy = {}; Error.captureStackTrace ? Error.captureStackTrace(dummy) : dummy = new Error(); const stack = dummy.stack ? dummy.stack.replace(/^.+\n/, "") : ""; try { if (!err.stack) { err.stack = stack; } else if (stack && !String(err.stack).endsWith(stack.replace(/^.+\n.+\n/, ""))) { err.stack += "\n" + stack; } } catch (e) { } } throw err; } } _request(configOrUrl, config) { if (typeof configOrUrl === "string") { config = config || {}; config.url = configOrUrl; } else { config = configOrUrl || {}; } config = mergeConfig(this.defaults, config); const { transitional, paramsSerializer, headers } = config; if (transitional !== void 0) { validator.assertOptions(transitional, { silentJSONParsing: validators.transitional(validators.boolean), forcedJSONParsing: validators.transitional(validators.boolean), clarifyTimeoutError: validators.transitional(validators.boolean) }, false); } if (paramsSerializer != null) { if (utils$1.isFunction(paramsSerializer)) { config.paramsSerializer = { serialize: paramsSerializer }; } else { validator.assertOptions(paramsSerializer, { encode: validators.function, serialize: validators.function }, true); } } validator.assertOptions(config, { baseUrl: validators.spelling("baseURL"), withXsrfToken: validators.spelling("withXSRFToken") }, true); config.method = (config.method || this.defaults.method || "get").toLowerCase(); let contextHeaders = headers && utils$1.merge( headers.common, headers[config.method] ); headers && utils$1.forEach( ["delete", "get", "head", "post", "put", "patch", "common"], (method) => { delete headers[method]; } ); config.headers = AxiosHeaders$1.concat(contextHeaders, headers); const requestInterceptorChain = []; let synchronousRequestInterceptors = true; this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) { if (typeof interceptor.runWhen === "function" && interceptor.runWhen(config) === false) { return; } synchronousRequestInterceptors = synchronousRequestInterceptors && interceptor.synchronous; requestInterceptorChain.unshift(interceptor.fulfilled, interceptor.rejected); }); const responseInterceptorChain = []; this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) { responseInterceptorChain.push(interceptor.fulfilled, interceptor.rejected); }); let promise; let i = 0; let len; if (!synchronousRequestInterceptors) { const chain = [dispatchRequest.bind(this), void 0]; chain.unshift.apply(chain, requestInterceptorChain); chain.push.apply(chain, responseInterceptorChain); len = chain.length; promise = Promise.resolve(config); while (i < len) { promise = promise.then(chain[i++], chain[i++]); } return promise; } len = requestInterceptorChain.length; let newConfig = config; i = 0; while (i < len) { const onFulfilled = requestInterceptorChain[i++]; const onRejected = requestInterceptorChain[i++]; try { newConfig = onFulfilled(newConfig); } catch (error) { onRejected.call(this, error); break; } } try { promise = dispatchRequest.call(this, newConfig); } catch (error) { return Promise.reject(error); } i = 0; len = responseInterceptorChain.length; while (i < len) { promise = promise.then(responseInterceptorChain[i++], responseInterceptorChain[i++]); } return promise; } getUri(config) { config = mergeConfig(this.defaults, config); const fullPath = buildFullPath(config.baseURL, config.url); return buildURL(fullPath, config.params, config.paramsSerializer); } } utils$1.forEach(["delete", "get", "head", "options"], function forEachMethodNoData(method) { Axios.prototype[method] = function(url, config) { return this.request(mergeConfig(config || {}, { method, url, data: (config || {}).data })); }; }); utils$1.forEach(["post", "put", "patch"], function forEachMethodWithData(method) { function generateHTTPMethod(isForm) { return function httpMethod(url, data2, config) { return this.request(mergeConfig(config || {}, { method, headers: isForm ? { "Content-Type": "multipart/form-data" } : {}, url, data: data2 })); }; } Axios.prototype[method] = generateHTTPMethod(); Axios.prototype[method + "Form"] = generateHTTPMethod(true); }); const Axios$1 = Axios; class CancelToken { constructor(executor) { if (typeof executor !== "function") { throw new TypeError("executor must be a function."); } let resolvePromise; this.promise = new Promise(function promiseExecutor(resolve) { resolvePromise = resolve; }); const token = this; this.promise.then((cancel) => { if (!token._listeners) return; let i = token._listeners.length; while (i-- > 0) { token._listeners[i](cancel); } token._listeners = null; }); this.promise.then = (onfulfilled) => { let _resolve; const promise = new Promise((resolve) => { token.subscribe(resolve); _resolve = resolve; }).then(onfulfilled); promise.cancel = function reject() { token.unsubscribe(_resolve); }; return promise; }; executor(function cancel(message2, config, request) { if (token.reason) { return; } token.reason = new CanceledError(message2, config, request); resolvePromise(token.reason); }); } /** * Throws a `CanceledError` if cancellation has been requested. */ throwIfRequested() { if (this.reason) { throw this.reason; } } /** * Subscribe to the cancel signal */ subscribe(listener) { if (this.reason) { listener(this.reason); return; } if (this._listeners) { this._listeners.push(listener); } else { this._listeners = [listener]; } } /** * Unsubscribe from the cancel signal */ unsubscribe(listener) { if (!this._listeners) { return; } const index = this._listeners.indexOf(listener); if (index !== -1) { this._listeners.splice(index, 1); } } toAbortSignal() { const controller = new AbortController(); const abort = (err) => { controller.abort(err); }; this.subscribe(abort); controller.signal.unsubscribe = () => this.unsubscribe(abort); return controller.signal; } /** * Returns an object that contains a new `CancelToken` and a function that, when called, * cancels the `CancelToken`. */ static source() { let cancel; const token = new CancelToken(function executor(c) { cancel = c; }); return { token, cancel }; } } const CancelToken$1 = CancelToken; function spread(callback) { return function wrap(arr) { return callback.apply(null, arr); }; } function isAxiosError(payload) { return utils$1.isObject(payload) && payload.isAxiosError === true; } const HttpStatusCode = { Continue: 100, SwitchingProtocols: 101, Processing: 102, EarlyHints: 103, Ok: 200, Created: 201, Accepted: 202, NonAuthoritativeInformation: 203, NoContent: 204, ResetContent: 205, PartialContent: 206, MultiStatus: 207, AlreadyReported: 208, ImUsed: 226, MultipleChoices: 300, MovedPermanently: 301, Found: 302, SeeOther: 303, NotModified: 304, UseProxy: 305, Unused: 306, TemporaryRedirect: 307, PermanentRedirect: 308, BadRequest: 400, Unauthorized: 401, PaymentRequired: 402, Forbidden: 403, NotFound: 404, MethodNotAllowed: 405, NotAcceptable: 406, ProxyAuthenticationRequired: 407, RequestTimeout: 408, Conflict: 409, Gone: 410, LengthRequired: 411, PreconditionFailed: 412, PayloadTooLarge: 413, UriTooLong: 414, UnsupportedMediaType: 415, RangeNotSatisfiable: 416, ExpectationFailed: 417, ImATeapot: 418, MisdirectedRequest: 421, UnprocessableEntity: 422, Locked: 423, FailedDependency: 424, TooEarly: 425, UpgradeRequired: 426, PreconditionRequired: 428, TooManyRequests: 429, RequestHeaderFieldsTooLarge: 431, UnavailableForLegalReasons: 451, InternalServerError: 500, NotImplemented: 501, BadGateway: 502, ServiceUnavailable: 503, GatewayTimeout: 504, HttpVersionNotSupported: 505, VariantAlsoNegotiates: 506, InsufficientStorage: 507, LoopDetected: 508, NotExtended: 510, NetworkAuthenticationRequired: 511 }; Object.entries(HttpStatusCode).forEach(([key, value]) => { HttpStatusCode[value] = key; }); const HttpStatusCode$1 = HttpStatusCode; function createInstance(defaultConfig) { const context = new Axios$1(defaultConfig); const instance = bind(Axios$1.prototype.request, context); utils$1.extend(instance, Axios$1.prototype, context, { allOwnKeys: true }); utils$1.extend(instance, context, null, { allOwnKeys: true }); instance.create = function create(instanceConfig) { return createInstance(mergeConfig(defaultConfig, instanceConfig)); }; return instance; } const axios = createInstance(defaults$1); axios.Axios = Axios$1; axios.CanceledError = CanceledError; axios.CancelToken = CancelToken$1; axios.isCancel = isCancel; axios.VERSION = VERSION; axios.toFormData = toFormData; axios.AxiosError = AxiosError; axios.Cancel = axios.CanceledError; axios.all = function all(promises) { return Promise.all(promises); }; axios.spread = spread; axios.isAxiosError = isAxiosError; axios.mergeConfig = mergeConfig; axios.AxiosHeaders = AxiosHeaders$1; axios.formToJSON = (thing) => formDataToJSON(utils$1.isHTMLForm(thing) ? new FormData(thing) : thing); axios.getAdapter = adapters.getAdapter; axios.HttpStatusCode = HttpStatusCode$1; axios.default = axios; const axios$1 = axios; const baseURL = "https://www.ddei.top/dflow/api"; const post = function(api, data2, successFn, errorFn) { let config = { method: "post", url: baseURL + api, headers: { "Content-Type": "text/plain" // 指定内容类型为JSON }, data: data2 }; axios$1(config).then((response) => { if (successFn) { successFn(response); } }).catch((error) => { if (errorFn) { errorFn(error); } }); }; const xml2graph = function(xml2, fn) { post("/bpmn/xml2graph", xml2, fn); }; class DDeiFlowAPI { constructor(editor) { __publicField(this, "editor"); /** * 配置的属性 */ __publicField(this, "jsonField", ["id", "name", "code", "text", "ep", "sp", "desc", "isUnlimited", "capacity", "condition", "default", "bpmnType", "bpmnSubType", "scriptFormat", "dataType", "customDataType", "isCollection", "loopCardinality", "script", "bpmnBaseType", "ordering", "activityId", "errorCode", "timeType", "timeValue", "potentialOwner", "humanPerformer", "notInterrupting", "escalName", "messageName", "signalName", "isLoop", "isLoop", "isTransaction", "multiInstance", "isParallel", "isCompensation", "essBounds"]); /** * json中以哪个字段作为key,默认为id,可以指定为code或其他字段 */ __publicField(this, "jsonKeyField", "id"); /** * 模型缓存 */ __publicField(this, "modelsCache", {}); /** * 转换为bpmn时的回调函数,每个元素转换为bpmn前都会调用此方法,用于接管bpmn元素的生成,如果返回false会触发原来的逻辑,返回其他值将不会调用原有的逻辑。 */ __publicField(this, "bpmnProcessorFN", null); /** * 转换为bpmn时的回调函数,每个元素转换为bpmn后都会调用此方法,用于接管bpmn元素的生成。 */ __publicField(this, "bpmnAfterProcessorFN", null); /** * 转换为bpmndi时的回调函数,每个元素转换为bpmndi前都会调用此方法,用于接管bpmn元素的生成,如果返回false会触发原来的逻辑,返回其他值将不会调用原有的逻辑。 */ __publicField(this, "bpmndiProcessorFN", null); this.editor = editor; } /** * 设置键字段 * @param field 字段名称 */ setJsonKeyField(field) { if (field) { this.jsonKeyField = field; } } /** * 配置返回的json数据字段 * @param fn 外部方法,用来修改jsonField */ configJsonField(fn) { fn(this.jsonField); } /** * 将模型转换为图片 并返回base64 * @param models */ toImage(models, skipMark = false) { return new Promise((resolve, reject) => { let imageMap = {}; let allModels = []; models.forEach((model) => { allModels.push(model); if (model.allowIncludeModel) { let subModels = getIncludeModels(model); subModels.forEach((sm) => { if (!ddeiEditor.DDeiUtil.isModelHidden(sm)) { allModels.push(sm); } }); } }); let ddInstance = this.editor.ddInstance; let rat1 = ddInstance == null ? void 0 : ddInstance.render.ratio; let stage = ddInstance.stage; let lines = []; let doubleLines = []; allModels.forEach((ims) => { let sublinks = stage.getSourceModelLinks(ims.id); sublinks == null ? void 0 : sublinks.forEach((slink) => { if (!slink.disabled && slink.dm) { if (lines.indexOf(slink.dm) == -1) { lines.push(slink.dm); } else { doubleLines.push(slink.dm); } } }); }); lines = doubleLines; let promiseArr = []; allModels.push(...lines); allModels.forEach((model) => { promiseArr.push(new Promise((resolve2, reject2) => { let loadImage = false; if (model.render.viewer) { loadImage = true; } else if (model.render.tempCanvas) { imageMap[model.id] = new Image(); imageMap[model.id].src = model.render.tempCanvas.toDataURL("image/png"); imageMap[model.id].onload = () => { resolve2(); }; loadImage = true; } if (!loadImage) { resolve2(); } })); }); let canvas = document.createElement("canvas"); let outRect = ddeiEditor.DDeiAbstractShape.getOutRectByPV(allModels); let width = outRect.width * rat1; let height = outRect.height * rat1; canvas.setAttribute("width", width); canvas.setAttribute("height", height); canvas.setAttribute("style", "pointer-events:none;z-index:100;position:absolute;-webkit-font-smoothing:antialiased;-moz-transform-origin:left top;-moz-transform:scale(" + 1 / rat1 + ");display:block;zoom:" + 1 / rat1); let ctx = canvas.getContext("2d", { willReadFrequently: true }); ctx.translate(-outRect.x * rat1, -outRect.y * rat1); Promise.all(promiseArr).then((all) => { for (let i = 0; i < allModels.length; i++) { let model = allModels[i]; let modelImage = imageMap[model.id]; if (modelImage) { let outRect2 = ddeiEditor.DDeiAbstractShape.getOutRectByPV([model]); if (model.baseModelType == "DDeiLine") { ctx == null ? void 0 : ctx.drawImage(modelImage, ((outRect2.x + outRect2.x1) / 2 - model.render.tempCanvas.offsetWidth / 2 / rat1) * rat1, ((outRect2.y + outRect2.y1) / 2 - model.render.tempCanvas.offsetHeight / 2 / rat1) * rat1); } else { ctx == null ? void 0 : ctx.drawImage(modelImage, outRect2.x * rat1, outRect2.y * rat1); } } } resolve(canvas.toDataURL()); }); }); } toSimpleSvg(dom) { let useElements = dom.querySelectorAll("use"); let arr = [...useElements]; let cloneElements = []; arr.forEach((useElement) => { let href = useElement.getAttribute("xlink:href"); if (href && href.startsWith("#")) { let id = href.substring(1); let paths = document.getElementById(id).querySelectorAll("path"); let svgWidth = useElement.parentNode.width; let svgHeight = useElement.parentNode.height; let totalBBox = { x: Infinity, y: Infinity, width: 0, height: 0 }; paths.forEach(function(path) { let bbox = path.getBBox(); totalBBox.x = Math.min(totalBBox.x, bbox.x); totalBBox.y = Math.min(totalBBox.y, bbox.y); totalBBox.width = Math.max(totalBBox.width, bbox.x + bbox.width); totalBBox.height = Math.max(totalBBox.height, bbox.y + bbox.height); }); if (svgWidth.baseVal) { svgWidth = svgWidth.baseVal.value; } if (svgHeight.baseVal) { svgHeight = svgHeight.baseVal.value; } let scaleX = svgWidth / totalBBox.width; let scaleY = svgHeight / totalBBox.height; let scale = Math.min(scaleX, scaleY); let translateX = (svgWidth - totalBBox.width * scale) / 2 - totalBBox.x * scale; let translateY = (svgHeight - totalBBox.height * scale) / 2 - totalBBox.y * scale; paths.forEach((path) => { let transform = "scale(" + scale + ") translate(" + translateX + "," + translateY + ")"; let clonedElement = path.cloneNode(true); clonedElement.setAttribute("transform", transform); cloneElements.push(clonedElement); useElement.parentNode.appendChild(clonedElement); }); } }); return cloneElements; } settingSubModelsData(model, dataJson2) { let key = model[this.jsonKeyField] ? model[this.jsonKeyField] : model.id; if (dataJson2[key]) { ddeiEditor.merge(model, dataJson2[key]); } if (model.models) { for (let id in model.models) { let subModel = model.models[id]; this.settingSubModelsData(subModel, dataJson2); } } } /** * 通过BpmnXML加载并刷新流程图 * @param designJson 设计器json * @param dataJson 数据json */ loadFromBpmnXML(xml, dataJson = null, ratio = 1) { if (xml) { xml2graph(xml, (res) => { var _a, _b, _c, _d, _e; if (res.status == 200) { try { let data = eval(res.data); if (data.state == "success" && data.graphs.length > 0) { let graph = data.graphs[0]; if (dataJson) { dataJson = typeof dataJson == "string" ? JSON.parse(dataJson) : dataJson; (_a = graph.controls) == null ? void 0 : _a.forEach((control) => { let key = control[this.jsonKeyField] ? control[this.jsonKeyField] : control.id; if (dataJson[key]) { ddeiEditor.merge(control, dataJson[key]); } }); (_b = graph.lines) == null ? void 0 : _b.forEach((control) => { let key = control[this.jsonKeyField] ? control[this.jsonKeyField] : control.id; if (dataJson[key]) { ddeiEditor.merge(control, dataJson[key]); } }); } let ddInstance = this.editor.ddInstance; (_c = ddInstance.stage) == null ? void 0 : _c.destroyRender(); let file = this.editor.files[this.editor.currentFileIndex]; let sheet = file.sheets[file.currentSheetIndex]; sheet.name = graph.name; sheet.desc = graph.desc; let stage = ddeiEditor.DDeiStage.initByJSON({ id: graph.id, ratio }, { currentDdInstance: ddInstance }); sheet.stage = stage; ddInstance.stage = stage; stage.initRender(); graph.controls.forEach((control) => { if (!control[this.jsonKeyField]) { control[this.jsonKeyField] = control.id; } }); this.editor.addControls(graph.controls, true, false); this.editor.addLines(graph.lines); this.editor.changeState(ddeiEditor.DDeiEditorState.DESIGNING); ddInstance.bus.push( ddeiEditor.DDeiEditorEnumBusCommandType.ClearTemplateUI ); ddInstance.bus.push( ddeiEditor.DDeiEditorEnumBusCommandType.RefreshEditorParts ); (_d = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _d.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); (_e = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _e.executeAll(); ddeiEditor.DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_FILE_AFTER", "LOAD_FILE", { file }, this.editor.ddInstance); } } catch (e) { console.error(e); } } }); } } /** * 加载并刷新流程图 * @param designJson 设计器json * @param dataJson 数据json */ loadData(designJson, dataJson2 = null) { var _a, _b, _c, _d; let resultJSON = typeof designJson == "string" ? JSON.parse(designJson) : designJson; if (dataJson2) { dataJson2 = typeof dataJson2 == "string" ? JSON.parse(dataJson2) : dataJson2; resultJSON.sheets.forEach((sheet) => { sheet.stage.layers.forEach((layer) => { this.settingSubModelsData(layer, dataJson2); }); }); } let ddInstance = this.editor.ddInstance; let file = ddeiEditor.DDeiFile.loadFromJSON(resultJSON, { currentDdInstance: ddInstance }); let openedFiles = this.editor.files; let openedFileIndex = -1; if (!file.id) { file.id = ddeiEditor.DDeiUtil.getUniqueCode(); } for (let fi = 0; fi < openedFiles.length; fi++) { if (openedFiles[fi].id && openedFiles[fi].id == file.id) { openedFileIndex = fi; break; } } ddInstance.stage.destroyRender(); if (openedFileIndex == -1) { this.editor.addFile(file); for (let x = 0; x < this.editor.files.length; x++) { this.editor.files[x].active = ddeiEditor.DDeiActiveType.NONE; } this.editor.currentFileIndex = this.editor.files.length - 1; file.state = ddeiEditor.DDeiFileState.NONE; file.active = ddeiEditor.DDeiActiveType.ACTIVE; let sheets = file == null ? void 0 : file.sheets; if (file && sheets && ddInstance) { file.changeSheet(file.currentSheetIndex); let stage = sheets[file.currentSheetIndex].stage; stage.ddInstance = ddInstance; ddInstance.disabled = false; file.initHistroy(); file.histroy[0].isNew = true; ddInstance.stage = stage; stage.initRender(); if (!stage.wpv) { stage.wpv = { x: -(stage.width - ddInstance.render.container.clientWidth) / 2, y: -(stage.height - ddInstance.render.container.clientHeight) / 2, z: 0 }; } this.editor.changeState(ddeiEditor.DDeiEditorState.DESIGNING); ddInstance.bus.push( ddeiEditor.DDeiEditorEnumBusCommandType.ClearTemplateUI ); ddInstance.bus.push( ddeiEditor.DDeiEditorEnumBusCommandType.RefreshEditorParts ); (_a = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _a.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); (_b = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _b.executeAll(); } } else { file = this.editor.files[openedFileIndex]; if (file && ddInstance) { for (let x = 0; x < this.editor.files.length; x++) { this.editor.files[x].active = ddeiEditor.DDeiActiveType.NONE; } file.active = ddeiEditor.DDeiActiveType.ACTIVE; this.editor.currentFileIndex = openedFileIndex; let stage = file.sheets[file.currentSheetIndex].stage; stage.ddInstance = ddInstance; ddInstance.stage = stage; ddInstance.disabled = false; stage.initRender(); this.editor.changeState(ddeiEditor.DDeiEditorState.DESIGNING); ddInstance.bus.push( ddeiEditor.DDeiEditorEnumBusCommandType.ClearTemplateUI ); ddInstance.bus.push( ddeiEditor.DDeiEditorEnumBusCommandType.RefreshEditorParts ); (_c = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _c.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); (_d = ddInstance == null ? void 0 : ddInstance.bus) == null ? void 0 : _d.executeAll(); } } ddeiEditor.DDeiEditorUtil.invokeCallbackFunc("EVENT_ADD_FILE_AFTER", "LOAD_FILE", { file }, this.editor.ddInstance); } /** * 刷新视图 */ refresh() { var _a, _b; let ddInstance = this.editor.ddInstance; for (let i in this.modelsCache) { let shapeModel = this.modelsCache[i]; (_a = shapeModel == null ? void 0 : shapeModel.render) == null ? void 0 : _a.clearCachedValue(); (_b = shapeModel == null ? void 0 : shapeModel.render) == null ? void 0 : _b.enableRefreshShape(); } ddInstance.bus.push(ddeiEditor.DDeiEnumBusCommandType.RefreshShape); ddInstance.bus.executeAll(); } /** * 获取当前的流程图 */ getFlowGraphs() { let file = this.editor.files[this.editor.currentFileIndex]; if (file) { let sheet = file.sheets[file.currentSheetIndex]; let graphics = this.stage2FlowGraphs(sheet.stage); return graphics; } return null; } /** * 将当前文档转换为易于识别和解析的json对象 */ toFlowObject(fileObj = false, allSheets = false) { let file = this.editor.files[this.editor.currentFileIndex]; if (file) { let returnFile = new DDeiFlowFile({ id: file.id, name: file.name }); let sheets = file.sheets; let sheetLen = sheets.length; let i = 0; if (!allSheets) { i = file.currentSheetIndex; sheetLen = i + 1; } for (; i < sheetLen; i++) { let sheet = sheets[i]; let graphics = this.stage2FlowGraphs(sheet.stage, fileObj); if (!fileObj) { return graphics[0]; } graphics == null ? void 0 : graphics.forEach((graph) => { graph.file = returnFile; returnFile.graphics.push(graph); }); } return returnFile; } else { return null; } } /** * 将舞台对象转换为易于解析和遍历的json对象 * @param stage 舞台对象 * @returns json对象 */ stage2FlowGraphs(stage, allLayers = true) { if (stage) { let layers = stage.layers; if (!((layers == null ? void 0 : layers.length) > 0)) { return null; } let layerLen = layers.length; let i = 0; let singleLayer = false; if (!allLayers) { i = stage.layerIndex; layerLen = i + 1; } if (!allLayers || layerLen == 1) { singleLayer = true; } let returnArray = []; this.modelsCache = {}; for (; i < layerLen; i++) { let layer = layers[i]; let graph = new DDeiFlowGraph({ id: singleLayer ? stage.id : stage.id + "_" + layer.id, name: stage.name, shapeModel: stage, api: this }); let models = stage.getLayerModels(); models.forEach((model) => { this.modelsCache[model.id] = model; let node = this.parseModelToFlowNode(model); if (node) { node.graph = graph; graph.nodes.set(node[this.jsonKeyField] ? node[this.jsonKeyField] : node.id, node); } }); let deletedNodes = []; graph.nodes.forEach((node) => { let model = this.modelsCache[node.id]; if (model.includePModelId) { let subProcessNode = this.getSubProcessNode(model.includePModelId, graph); if (subProcessNode) { let subProcesses = this.getSubProcessNodes(subProcessNode.id, graph); node.graph = subProcessNode; node.subProcesses = subProcesses; subProcessNode.nodes.set(node[this.jsonKeyField] ? node[this.jsonKeyField] : node.id, node); deletedNodes.push(node.id); } } }); graph.nodes.forEach((node) => { var _a; let model = this.modelsCache[node.id]; let attachNodes = []; (_a = model.attachModels) == null ? void 0 : _a.forEach((amid) => { let attachModel = this.modelsCache[amid]; if (attachModel) { let attachNode = graph.nodes.get(attachModel[this.jsonKeyField] ? attachModel[this.jsonKeyField] : attachModel.id); attachNode.attachPNode = node; attachNodes.push(attachNode); } }); if (attachNodes.length > 0) { node.attachNodes = attachNodes; } }); let isolatedNodes = []; let groups = []; graph.nodes.forEach((node) => { var _a; if (node instanceof DDeiFlowSequence) { let lineModel = this.modelsCache[node.id]; let lineSequenceNode = node; let lineLinks = stage.getDistModelLinks(lineSequenceNode.id); let lineNode1, lineNode2; if ((lineLinks == null ? void 0 : lineLinks.length) > 0) { let lineLink = lineLinks[0]; if (lineLink.sm) { let distPV = lineLink.getDistPV(); lineNode1 = graph.nodes.get(lineLink.sm[this.jsonKeyField] ? lineLink.sm[this.jsonKeyField] : lineLink.sm.id); let lineNodeModel = this.modelsCache[lineNode1.id]; this.getSubProcessNode(lineNodeModel.includePModelId, graph); if (distPV == lineModel.startPoint) { lineSequenceNode.prevNode = lineNode1; } else if (distPV == lineModel.endPoint) { lineSequenceNode.nextNode = lineNode1; } } } if ((lineLinks == null ? void 0 : lineLinks.length) > 0) { let lineLink = lineLinks[1]; if (lineLink.sm) { let distPV = lineLink.getDistPV(); lineNode2 = graph.nodes.get(lineLink.sm[this.jsonKeyField] ? lineLink.sm[this.jsonKeyField] : lineLink.sm.id); let lineNodeModel = this.modelsCache[lineNode2.id]; this.getSubProcessNode(lineNodeModel.includePModelId, graph); if (distPV == lineModel.startPoint) { lineSequenceNode.prevNode = lineNode2; } else if (distPV == lineModel.endPoint) { lineSequenceNode.nextNode = lineNode2; } } } } else if (node instanceof DDeiFlowGroup) { groups.push(node); let model = this.modelsCache[node.id]; (_a = model.includeModels) == null ? void 0 : _a.forEach((im) => { let md = this.modelsCache[im]; let key = md[this.jsonKeyField] ? md[this.jsonKeyField] : md.id; node.nodes.set(key, graph.nodes.get(key)); }); } else { let nodeLinks = stage.getSourceModelLinks(node.id); nodeLinks == null ? void 0 : nodeLinks.forEach((link) => { let linePV = link.getDistPV(); let key = link.dm[this.jsonKeyField] ? link.dm[this.jsonKeyField] : link.dm.id; let lineSequenceNode = graph.nodes.get(key); if (linePV == link.dm.startPoint) { node.nextNodes.push(lineSequenceNode); } else if (linePV == link.dm.endPoint) { node.prevNodes.push(lineSequenceNode); } }); } }); graph.groups = groups; graph.nodes.forEach((node) => { let model = this.modelsCache[node.id]; if (node.bpmnType == "StartEvent") { if (!node.attachPNode) { if (!model.includePModelId) { graph.startNodes.push(node); } else { let subProcessNode = this.getSubProcessNode(model.includePModelId, graph); if (subProcessNode) { subProcessNode.startNodes.push(node); } else { graph.startNodes.push(node); } } } } else if (node.bpmnType == "EndEvent") { if (!model.includePModelId) { graph.endNodes.push(node); } else { let subProcessNode = this.getSubProcessNode(model.includePModelId, graph); if (subProcessNode) { subProcessNode.endNodes.push(node); } else { graph.endNodes.push(node); } } } }); graph.nodes.forEach((node) => { var _a, _b, _c; if (node instanceof DDeiFlowSequence) { if (!node.prevNode && !node.nextNode) { isolatedNodes.push(node); } } else if (!node.attachPNode && ((_a = node.prevNodes) == null ? void 0 : _a.length) == 0 && node.bpmnType != "StartEvent" && node.bpmnType != "Group" && node.bpmnType != "Comment") { if (node.bpmnType != "SubProcess") { isolatedNodes.push(node); } else { let isolated = true; graph.nodes.forEach((n1) => { if (n1.subProcesses && n1.subProcesses.indexOf(node) != -1) { isolated = false; } }); if (isolated) { isolatedNodes.push(node); } } } else if (!node.attachPNode && ((_b = node.prevNodes) == null ? void 0 : _b.length) == 0 && ((_c = node.nextNodes) == null ? void 0 : _c.length) == 0) { if (node.bpmnType != "SubProcess") { isolatedNodes.push(node); } else { let isolated = true; graph.nodes.forEach((n1) => { if (n1.subProcesses && n1.subProcesses.indexOf(node) != -1) { isolated = false; } }); if (isolated) { isolatedNodes.push(node); } } } }); graph.isolatedNodes = isolatedNodes; deletedNodes.forEach((id) => { graph.nodes.delete(id); }); returnArray.push(graph); } return returnArray; } else { return null; } } getSubProcessNodes(includePModelId, graph) { let returnNodes = []; while (includePModelId) { let subProcessesNode = this.getSubProcessNode(includePModelId, graph); if (subProcessesNode) { returnNodes.splice(0, 0, subProcessesNode); let subProcessModel = this.modelsCache[subProcessesNode.id]; includePModelId = subProcessModel == null ? void 0 : subProcessModel.includePModelId; } else { break; } } return returnNodes; } getSubProcessNode(includePModelId, graph) { let pNodeModel = this.modelsCache[includePModelId]; if (pNodeModel) { let pNode = graph.nodes.get(pNodeModel[this.jsonKeyField] ? pNodeModel[this.jsonKeyField] : pNodeModel.id); if (pNode) { if (pNode.bpmnType == "SubProcess") { return pNode; } else if (pNode.bpmnType == "Group" && pNodeModel.includePModelId) { return this.getSubProcessNode(pNodeModel.includePModelId, graph); } } } return null; } /** * 转换model为node * @param model model * @returns node */ parseModelToFlowNode(model) { let returnNode = null; let modelJson = {}; this.jsonField.forEach((field) => { if (model[field] != void 0 && model[field] != null) { modelJson[field] = model[field]; } }); modelJson.shapeModel = model; modelJson.api = this; switch (model.bpmnBaseType) { case "Event": { returnNode = new DDeiFlowNode(modelJson); } break; case "Activity": { if (model.bpmnType == "SubProcess") { returnNode = new DDeiFlowSubProcess(modelJson); } else { returnNode = new DDeiFlowNode(modelJson); } } break; case "Group": { returnNode = new DDeiFlowGroup(modelJson); } break; case "Sequence": { returnNode = new DDeiFlowSequence(modelJson); } break; case "Comment": { returnNode = new DDeiFlowNode(modelJson); } break; } if (!returnNode) { returnNode = new DDeiFlowNode(modelJson); } return returnNode; } /** * 将当前文档转换为符合bpmn规范的xml文档 * @param allSheets 输出所有sheet,默认false * @param diagram 输出bpmndi图形定义 */ toBPMNXML(allSheets = false, diagram = false) { let flowObject = this.toFlowObject(true, allSheets); let returnStr; if (this.bpmnProcessorFN) { let fnResult = this.bpmnProcessorFN(flowObject, 0); if (fnResult !== false) { returnStr = fnResult; } } if (!returnStr) { if (!flowObject.id) { flowObject.id = ddeiEditor.DDeiUtil.getUniqueCode(); } returnStr = ` `; let contentStr = ""; let defineStr = ""; for (let gi = 0; gi < flowObject.graphics.length; gi++) { let flowGraph2 = flowObject.graphics[gi]; let processResult = this.flowGraph2BPMNXML(flowGraph2); if (processResult == null ? void 0 : processResult.contentStr) { contentStr += processResult.contentStr + "\n"; } if (processResult == null ? void 0 : processResult.defineStr) { defineStr += processResult.defineStr; } } returnStr += defineStr; returnStr += contentStr; if (diagram) { let skip = false; if (this.bpmndiProcessorFN) { let fnResult = this.bpmndiProcessorFN(flowGraph, 2); if (fnResult !== false) { returnStr += fnResult + "\n"; skip = true; } } if (!skip) { returnStr += ' \n'; for (let gi = 0; gi < flowObject.graphics.length; gi++) { let flowGraph2 = flowObject.graphics[gi]; let bpmndiXML = this.flowGraph2BPMNDIXML(flowGraph2); if (bpmndiXML) { returnStr += bpmndiXML + "\n"; } } returnStr += " \n"; } } returnStr += ""; } return returnStr; } /** * 将舞台对象转换为bpmn规范的xml字符串 * @param stage 舞台对象 * @returns xml字符串 */ flowGraph2BPMNXML(graph) { let returnData; let contentStr = ""; let defineStr = ""; let skip = false; if (this.bpmnProcessorFN) { let fnResult = this.bpmnProcessorFN(graph, 0); if (fnResult !== false) { returnData = fnResult; skip = true; } } if (!skip) { if (graph) { contentStr += ' \n'; let innerStr = ""; let processStr = ""; graph.nodes.forEach((node) => { let nodeResult = this.node2BPMNXML(node, 3); if (nodeResult) { if (nodeResult.contentStr) { innerStr += nodeResult.contentStr; } if (nodeResult.defineStr) { defineStr += nodeResult.defineStr; } if (nodeResult.processStr) { processStr += nodeResult.processStr; } } }); contentStr += processStr; contentStr += innerStr; contentStr += " \n"; } returnData = new DDeiFlowBpmnXmlNode(contentStr, defineStr, null, null); } if (this.bpmnAfterProcessorFN) { returnData = this.bpmnAfterProcessorFN(graph, 0, returnData); } return returnData; } node2BPMNXML(node, tabLevel = 0) { if (node) { if (node instanceof DDeiFlowSequence) { return this.sequence2BPMNXML(node, 3); } else if (node instanceof DDeiFlowNode) { if (node.bpmnType == "StartEvent") { return this.startEvent2BPMNXML(node, tabLevel); } else if (node.bpmnType == "BoundaryEvent") { return this.boundaryEvent2BPMNXML(node, tabLevel); } else if (node.bpmnType == "IntermediateCatchEvent") { return this.intermediaCatchEvent2BPMNXML(node, tabLevel); } else if (node.bpmnType == "IntermediateThrowEvent") { return this.intermediaThrowEvent2BPMNXML(node, tabLevel); } else if (node.bpmnType == "EndEvent") { return this.endEvent2BPMNXML(node, tabLevel); } else if (node.bpmnType == "SubProcess") { return this.subProcess2BPMNXML(node, tabLevel); } else if (node.bpmnBaseType == "Gateway") { return this.gateway2BPMNXML(node, tabLevel); } else if (node.bpmnType == "Comment") { return this.comment2BPMNXML(node, tabLevel); } else if (node.bpmnBaseType == "Other") { return this.other2BPMNXML(node, tabLevel); } else { return this.task2BPMNXML(node, tabLevel); } } else ; } return null; } /** * 将对象转换为bpmn规范的xml字符串 * @param node 对象 * @returns xml字符串 */ startEvent2BPMNXML(node, tabLevel = 0) { var _a, _b; let returnData; let contentStr = ""; let defineStr = ""; let processStr = ""; let currentProcessStr = ""; let skip = false; if (this.bpmnProcessorFN) { let fnResult = this.bpmnProcessorFN(node, tabLevel); if (fnResult !== false) { returnData = fnResult; skip = true; } } if (!skip) { let tabStr = ""; for (let i = 0; i < tabLevel; i++) { tabStr += " "; } if (node) { contentStr += tabStr + ' 0 && ((_b = node.subProcesses[0]) == null ? void 0 : _b.bpmnSubType) == 2) { contentStr += ' isInterrupting="false"'; } } let childXML = ""; if (node.bpmnSubType == 2) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 3) { childXML += tabStr + " \n"; if (node.timeType == "timeDuration") { childXML += tabStr + " " + (node.timeValue ? node.timeValue : "") + "\n"; } else if (node.timeType == "CRON") { childXML += tabStr + " " + (node.timeValue ? node.timeValue : "") + "\n"; } else { childXML += tabStr + " " + (node.timeValue ? node.timeValue : "") + "\n"; } childXML += tabStr + " \n"; } else if (node.bpmnSubType == 4) { childXML += tabStr + " \n"; childXML += tabStr + ' '; childXML += tabStr + " \n"; childXML += tabStr + " \n"; childXML += tabStr + " \n"; } else if (node.bpmnSubType == 5) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 9) { if (node.errorCode) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else { childXML += tabStr + " \n"; } } else if (node.bpmnSubType == 10) { childXML += tabStr + " \n"; } else if (node.bpmnSubType == 8) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 7) { contentStr += ' parallelMultiple="true"'; } else if (node.bpmnSubType == 6) { childXML += tabStr + ' \n'; if (node.loopCardinality) { childXML += tabStr + ' '; childXML += tabStr + " \n"; childXML += tabStr + " \n"; } childXML += tabStr + " \n"; } if (node.notInterrupting) { childXML += tabStr + "true\n"; } if (childXML) { contentStr += ">\n" + childXML + tabStr + "\n"; } else { contentStr += "/>\n"; } } returnData = new DDeiFlowBpmnXmlNode(contentStr, defineStr, processStr, currentProcessStr); } if (this.bpmnAfterProcessorFN) { returnData = this.bpmnAfterProcessorFN(node, tabLevel, returnData); } return returnData; } /** * 将对象转换为bpmn规范的xml字符串 * @param node 对象 * @returns xml字符串 */ boundaryEvent2BPMNXML(node, tabLevel = 0) { let returnData; let contentStr = ""; let defineStr = ""; let processStr = ""; let currentProcessStr = ""; let skip = false; if (this.bpmnProcessorFN) { let fnResult = this.bpmnProcessorFN(node, tabLevel); if (fnResult !== false) { returnData = fnResult; skip = true; } } if (!skip) { let tabStr = ""; for (let i = 0; i < tabLevel; i++) { tabStr += " "; } if (node) { contentStr += tabStr + '\n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 2) { childXML += tabStr + " \n"; if (node.timeType == "timeDuration") { childXML += tabStr + " " + (node.timeValue ? node.timeValue : "") + "\n"; } else if (node.timeType == "CRON") { childXML += tabStr + " " + (node.timeValue ? node.timeValue : "") + "\n"; } else { childXML += tabStr + " " + (node.timeValue ? node.timeValue : "") + "\n"; } childXML += tabStr + " \n"; } else if (node.bpmnSubType == 3) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 4) { if (node.errorCode) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else { childXML += tabStr + " \n"; } } else if (node.bpmnSubType == 6) { childXML += tabStr + " \n"; } else if (node.bpmnSubType == 5) { childXML += tabStr + " \n"; } else if (node.bpmnSubType == 8) { contentStr += ' parallelMultiple="true"'; } else if (node.bpmnSubType == 9) { childXML += tabStr + ' \n'; if (node.loopCardinality) { childXML += tabStr + ' '; childXML += tabStr + " \n"; childXML += tabStr + " \n"; } childXML += tabStr + " \n"; } else if (node.bpmnSubType == 7) { defineStr += ' \n'; childXML += tabStr + ' \n'; } if (node.notInterrupting) { childXML += tabStr + "true\n"; } if (childXML) { contentStr += ">\n" + childXML + tabStr + "\n"; } else { contentStr += "/>\n"; } } returnData = new DDeiFlowBpmnXmlNode(contentStr, defineStr, processStr, currentProcessStr); } if (this.bpmnAfterProcessorFN) { returnData = this.bpmnAfterProcessorFN(node, tabLevel, returnData); } return returnData; } /** * 将对象转换为bpmn规范的xml字符串 * @param node 对象 * @returns xml字符串 */ intermediaCatchEvent2BPMNXML(node, tabLevel = 0) { let returnData; let contentStr = ""; let defineStr = ""; let processStr = ""; let currentProcessStr = ""; let skip = false; if (this.bpmnProcessorFN) { let fnResult = this.bpmnProcessorFN(node, tabLevel); if (fnResult !== false) { returnData = fnResult; skip = true; } } if (!skip) { let tabStr = ""; for (let i = 0; i < tabLevel; i++) { tabStr += " "; } if (node) { contentStr += tabStr + '\n'; childXML += tabStr + ' \n'; } else if (!node.bpmnSubType || node.bpmnSubType == 1) { childXML += tabStr + " \n"; if (node.timeType == "timeDuration") { childXML += tabStr + " " + (node.timeValue ? node.timeValue : "") + "\n"; } else if (node.timeType == "CRON") { childXML += tabStr + " " + (node.timeValue ? node.timeValue : "") + "\n"; } else { childXML += tabStr + " " + (node.timeValue ? node.timeValue : "") + "\n"; } childXML += tabStr + " \n"; } else if (node.bpmnSubType == 3) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 5) { contentStr += ' parallelMultiple="true"'; } if (node.bpmnSubType == 4) { childXML += tabStr + "\n"; } else if (node.bpmnSubType == 6) { childXML += tabStr + ' \n'; if (node.loopCardinality) { childXML += tabStr + ' '; childXML += tabStr + " \n"; childXML += tabStr + " \n"; } childXML += tabStr + " \n"; } if (childXML) { contentStr += ">\n" + childXML + tabStr + "\n"; } else { contentStr += "/>\n"; } } returnData = new DDeiFlowBpmnXmlNode(contentStr, defineStr, processStr, currentProcessStr); } if (this.bpmnAfterProcessorFN) { returnData = this.bpmnAfterProcessorFN(node, tabLevel, returnData); } return returnData; } /** * 将对象转换为bpmn规范的xml字符串 * @param node 对象 * @returns xml字符串 */ intermediaThrowEvent2BPMNXML(node, tabLevel = 0) { let returnData; let contentStr = ""; let defineStr = ""; let processStr = ""; let currentProcessStr = ""; let skip = false; if (this.bpmnProcessorFN) { let fnResult = this.bpmnProcessorFN(node, tabLevel); if (fnResult !== false) { returnData = fnResult; skip = true; } } if (!skip) { let tabStr = ""; for (let i = 0; i < tabLevel; i++) { tabStr += " "; } if (node) { contentStr += tabStr + '\n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 3) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 4) { childXML += tabStr + " \n"; } if (node.notInterrupting) { childXML += tabStr + "true\n"; } if (node.bpmnSubType == 7) { childXML += tabStr + "\n"; } else if (node.bpmnSubType == 6) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 5) { childXML += tabStr + ' \n'; if (node.loopCardinality) { childXML += tabStr + ' '; childXML += tabStr + " \n"; childXML += tabStr + " \n"; } childXML += tabStr + " \n"; } if (childXML) { contentStr += ">\n" + childXML + tabStr + "\n"; } else { contentStr += "/>\n"; } } returnData = new DDeiFlowBpmnXmlNode(contentStr, defineStr, processStr, currentProcessStr); } if (this.bpmnAfterProcessorFN) { returnData = this.bpmnAfterProcessorFN(node, tabLevel, returnData); } return returnData; } /** * 将对象转换为bpmn规范的xml字符串 * @param node 对象 * @returns xml字符串 */ endEvent2BPMNXML(node, tabLevel = 0) { let returnData; let contentStr = ""; let defineStr = ""; let processStr = ""; let currentProcessStr = ""; let skip = false; if (this.bpmnProcessorFN) { let fnResult = this.bpmnProcessorFN(node, tabLevel); if (fnResult !== false) { returnData = fnResult; skip = true; } } if (!skip) { let tabStr = ""; for (let i = 0; i < tabLevel; i++) { tabStr += " "; } if (node) { contentStr += tabStr + '\n'; childXML += tabStr + ' \n'; } else { childXML += tabStr + " \n"; } } else if (node.bpmnSubType == 9) { childXML += tabStr + " \n"; } else if (node.bpmnSubType == 8) { childXML += tabStr + " \n"; } else if (node.bpmnSubType == 3) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 7) { childXML += tabStr + " \n"; } else if (node.bpmnSubType == 2) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 5) { defineStr += ' \n'; childXML += tabStr + ' \n'; } else if (node.bpmnSubType == 4) { childXML += tabStr + ' \n'; if (node.loopCardinality) { childXML += tabStr + ' '; childXML += tabStr + " \n"; childXML += tabStr + " \n"; } childXML += tabStr + " \n"; } if (node.notInterrupting) { childXML += tabStr + "true\n"; } if (childXML) { contentStr += ">\n" + childXML + tabStr + "\n"; } else { contentStr += "/>\n"; } } returnData = new DDeiFlowBpmnXmlNode(contentStr, defineStr, processStr, currentProcessStr); } if (this.bpmnAfterProcessorFN) { returnData = this.bpmnAfterProcessorFN(node, tabLevel, returnData); } return returnData; } /** * 将对象转换为bpmn规范的xml字符串 * @param node 对象 * @returns xml字符串 */ task2BPMNXML(node, tabLevel = 0) { let returnData; let contentStr = ""; let defineStr = ""; let processStr = ""; let currentProcessStr = ""; let skip = false; if (this.bpmnProcessorFN) { let fnResult = this.bpmnProcessorFN(node, tabLevel); if (fnResult !== false) { returnData = fnResult; skip = true; } } if (!skip) { let tabStr = ""; for (let i = 0; i < tabLevel; i++) { tabStr += " "; } if (node) { let childXML = ""; let nodeTag = "bpmn:task"; if (node.bpmnType == "UserTask") { nodeTag = "bpmn:userTask"; } else if (node.bpmnType == "ServiceTask") { nodeTag = "bpmn:serviceTask"; } else if (node.bpmnType == "SendTask") { nodeTag = "bpmn:sendTask"; } else if (node.bpmnType == "ScriptTask") { nodeTag = "bpmn:scriptTask"; } else if (node.bpmnType == "ManualTask") { nodeTag = "bpmn:manualTask"; } else if (node.bpmnType == "ReceiveTask") { nodeTag = "bpmn:receiveTask"; } else if (node.bpmnType == "CallActivityTask") { nodeTag = "bpmn:callActivity"; } else if (node.bpmnType == "ChoreographyTask") { nodeTag = "bpmn:choreography"; } else if (node.bpmnType == "BusinessTask") { nodeTag = "bpmn:businessRuleTask"; } contentStr += tabStr + "<" + nodeTag + ' id="' + (node[this.jsonKeyField] ? node[this.jsonKeyField] : node.id) + '"'; if (node.name) { contentStr += ' name="' + node.name + '"'; } if (node.isCompensation) { contentStr += ' isForCompensation="true"'; } if (node.bpmnType == "ScriptTask") { nodeTag = "bpmn:scriptTask"; if (node.scriptFormat) { contentStr += ' scriptFormat="' + node.scriptFormat + '"'; } else if (node.script) { contentStr += ' scriptFormat="groovy"'; } if (node.script) { let scriptArr = node.script.split("\n"); childXML += tabStr + "