diff --git a/.github/workflows/preview.yml b/.github/workflows/preview.yml index af4a1b7..bb7565b 100644 --- a/.github/workflows/preview.yml +++ b/.github/workflows/preview.yml @@ -69,7 +69,11 @@ jobs: - name: Build site if: github.event.action != 'closed' - run: hugo --minify --baseURL "${{ steps.gh_pages_url.outputs.url }}" + run: | + chmod +x setup-dev.sh + ./setup-dev.sh + docker run --rm -v $(pwd)/structurizr:/usr/local/structurizr -v $(pwd)/static/diagrammen:/out structurizr/cli export --workspace workspace.dsl --format static --output /out + hugo --minify --baseURL "${{ steps.gh_pages_url.outputs.url }}" - name: Override robots.txt (disallow indexing) if: github.event.action != 'closed' diff --git a/.gitignore b/.gitignore index 1f2127e..241abf6 100644 --- a/.gitignore +++ b/.gitignore @@ -3,6 +3,11 @@ public resources tmp .hugo_build.lock +.generated + +# Structurizr +structurizr/diagrammen/ +static/diagrammen/ # Editors .vscode/* diff --git a/Containerfile b/Containerfile index 44012d0..b5b0a90 100644 --- a/Containerfile +++ b/Containerfile @@ -1,8 +1,15 @@ +FROM structurizr/cli:latest AS structurizr-export + +WORKDIR /usr/local/structurizr +COPY structurizr/ ./ + +RUN /usr/local/structurizr-cli/structurizr.sh export --workspace workspace.dsl --format static --output /out/diagrammen + FROM alpine:3.21 AS builder ARG HUGO_VERSION=0.154.4 -RUN apk add --no-cache wget \ +RUN apk add --no-cache wget bash dos2unix \ && wget -O hugo.tar.gz https://github.com/gohugoio/hugo/releases/download/v${HUGO_VERSION}/hugo_${HUGO_VERSION}_linux-amd64.tar.gz \ && tar -xzf hugo.tar.gz -C /usr/local/bin \ && rm hugo.tar.gz @@ -10,6 +17,12 @@ RUN apk add --no-cache wget \ WORKDIR /app COPY . . +RUN dos2unix setup-dev.sh \ + && chmod +x setup-dev.sh \ + && ./setup-dev.sh + +COPY --from=structurizr-export /out/diagrammen /app/static/diagrammen + ARG BASE_URL RUN if [ -n "$BASE_URL" ]; then \ hugo --minify --baseURL "$BASE_URL"; \ diff --git a/README.md b/README.md index 86d1f2a..d12cefe 100644 --- a/README.md +++ b/README.md @@ -18,18 +18,28 @@ Of volg de installatie-instructies voor [Hugo](https://gohugo.io/installation/) ### Development server starten -```bash +``` just up ``` Of direct met Hugo: - -```bash -hugo server +``` +bash +./setup-dev.sh && hugo server ``` De site is dan beschikbaar op [http://localhost:1313/](http://localhost:1313/) (of de host zoals vermeld in de terminal). + +#### Diagrammen +Om C4 diagrammen in te laden en te gebruiken binnen dit project run het volgende commando: +``` +docker run -it --rm -v $PWD/structurizr:/usr/local/structurizr structurizr/cli export --workspace workspace.dsl --format static --output ./diagrammen +mkdir -p static/diagrammen/ && cp -r structurizr/diagrammen/* ./static/diagrammen/ +``` +Vervolgens kan je +`./setup-dev.sh && hugo server` weer draaien. + ## Content toevoegen ### Weekly diff --git a/assets/css/base.css b/assets/css/base.css index c32e052..9ded5ef 100644 --- a/assets/css/base.css +++ b/assets/css/base.css @@ -181,3 +181,12 @@ nav a { text-decoration: underline; } } + +.docs { + table { + float: left; + text-align: left; + padding-bottom: 2rem; + min-width: 100%; + } +} diff --git a/assets/css/components/card-grid.css b/assets/css/components/card-grid.css index 9043d99..0b267d6 100644 --- a/assets/css/components/card-grid.css +++ b/assets/css/components/card-grid.css @@ -24,6 +24,7 @@ img { height: 2.5rem; object-fit: contain; + width: 2.5rem; } h2 { diff --git a/assets/css/layout.css b/assets/css/layout.css index a16c1a5..b9e5c89 100644 --- a/assets/css/layout.css +++ b/assets/css/layout.css @@ -38,6 +38,7 @@ main > .content { max-width: var(--content-max-width); margin-left: auto; margin-right: auto; + width: 100%; } main > section, @@ -47,10 +48,35 @@ main > .content { padding-top: 0; } +main .content img { + max-width: 100%; + height: auto; +} + +#main-content section img { + max-width: 100%; + height: auto; +} + main > article { + width: 100%; > * { max-width: var(--article-max-width); } + + > .content { + max-width: 100%; + + > * { + max-width: var(--article-max-width); + margin-left: auto; + margin-right: auto; + } + + > :is(iframe, img) { + max-width: 100%; + } + } } /* Sidebar layout - grid met hoofdcontent en zijbalk */ @@ -82,10 +108,6 @@ body:has(main > .article-layout) .breadcrumb { /* Artikel met inhoudsopgave (TOC) */ main:has(.toc) { - .toc { - display: none; - } - @media (min-width: 950px) { max-width: var(--content-max-width); display: grid; @@ -96,7 +118,6 @@ main:has(.toc) { margin: 0 auto; .toc { - display: block; position: sticky; top: 1rem; align-self: start; diff --git a/content/documentatie/_index.md b/content/documentatie/_index.md new file mode 100644 index 0000000..5ef6b63 --- /dev/null +++ b/content/documentatie/_index.md @@ -0,0 +1,3 @@ +--- +title: "Documentatie" +--- diff --git a/content/documentatie/beslissingen/_index.md b/content/documentatie/beslissingen/_index.md new file mode 100644 index 0000000..3c05632 --- /dev/null +++ b/content/documentatie/beslissingen/_index.md @@ -0,0 +1,3 @@ +--- +title: "Beslissingen" +--- diff --git a/content/documentatie/diagrammen/_index.md b/content/documentatie/diagrammen/_index.md new file mode 100644 index 0000000..f325220 --- /dev/null +++ b/content/documentatie/diagrammen/_index.md @@ -0,0 +1,6 @@ +--- +title: "Diagrammen" +--- +Hieron ziet u de structuur van alle system in C4, u kunt op een diagram klikken om meer informatie te krijgen. +{{< diagram "SysteemLandschap" >}} + diff --git a/hugo.yaml b/hugo.yaml index 41397be..1a47c4a 100644 --- a/hugo.yaml +++ b/hugo.yaml @@ -1,6 +1,19 @@ title: MijnOverheid Zakelijk defaultContentLanguage: nl +module: + mounts: + - source: content + target: content + - source: .generated + target: content + - source: static + target: static + - source: assets + target: assets + - source: layouts + target: layouts + params: description: Bij MijnOverheid Zakelijk staan ondernemers centraal. Elk uur minder aan gedoe, is een uur meer ondernemen. We zorgen voor overzicht en makkelijk zaken doen. Met elkaar bouwen we zo aan nieuwe digitale snelwegen. @@ -38,9 +51,12 @@ menus: - name: Onderwerpen pageRef: /onderwerpen weight: 4 + - name: Documentatie + pageRef: /documentatie + weight: 5 - name: Contact pageRef: /contact - weight: 5 + weight: 6 footer: - name: Privacy diff --git a/justfile b/justfile index 22649b4..c9ac768 100644 --- a/justfile +++ b/justfile @@ -7,14 +7,23 @@ default: # Start development server up: + ./setup-dev.sh + docker run -it --rm -v $PWD/structurizr:/usr/local/structurizr structurizr/cli export --workspace workspace.dsl --format static --output ./diagrammen + mkdir -p static/diagrammen/ && cp -r structurizr/diagrammen/* ./static/diagrammen/ hugo server # Bouw de site build: + ./setup-dev.sh + docker run -it --rm -v $PWD/structurizr:/usr/local/structurizr structurizr/cli export --workspace workspace.dsl --format static --output ./diagrammen + mkdir -p static/diagrammen/ && cp -r structurizr/diagrammen/* ./static/diagrammen/ rm -rf public && hugo --minify --gc --logLevel warn # Controleer op broken links check: + ./setup-dev.sh + docker run -it --rm -v $PWD/structurizr:/usr/local/structurizr structurizr/cli export --workspace workspace.dsl --format static --output ./diagrammen + mkdir -p static/diagrammen/ && cp -r structurizr/diagrammen/* ./static/diagrammen/ rm -rf .htmltest && hugo --minify --quiet --destination .htmltest/public && htmltest && rm -rf .htmltest # Voer pre-commit checks uit diff --git a/layouts/_default/_markup/render-image.html b/layouts/_default/_markup/render-image.html new file mode 100644 index 0000000..3380aa5 --- /dev/null +++ b/layouts/_default/_markup/render-image.html @@ -0,0 +1,2 @@ +{{- $url := .Destination -}} +{{ .Text }} diff --git a/layouts/documentatie/IAM/list.html b/layouts/documentatie/IAM/list.html new file mode 100644 index 0000000..9a85fd3 --- /dev/null +++ b/layouts/documentatie/IAM/list.html @@ -0,0 +1,25 @@ +{{ define "main" }} +
+ {{ if .Title }} +

{{ .Title | strings.FirstUpper }}

+ {{ end }} + +
{{ .Content }}
+ +
+{{- $toc := .TableOfContents -}} +{{ if and $toc (ne .Params.toc false) (gt (len (findRE "
  • " $toc)) 0) }} + + {{ end }} + {{ end }} + + {{ define "scripts" }} + {{- $toc := .TableOfContents -}} + {{ if and $toc (ne .Params.toc false) (gt (len (findRE "
  • " $toc)) 0) }} + {{ $tocScript := resources.Get "js/toc.js" | fingerprint "md5" }} + + {{ end }} +{{ end }} diff --git a/layouts/documentatie/beslissingen/list.html b/layouts/documentatie/beslissingen/list.html new file mode 100644 index 0000000..5c044e3 --- /dev/null +++ b/layouts/documentatie/beslissingen/list.html @@ -0,0 +1,31 @@ +{{ define "main" }} +
    +
    +

    {{.Title}}

    +
    + + + + + + + + + + + {{ range .Pages.Reverse }} + {{ $content := .RawContent }} + {{ $title := index (findRE "(?m)^# .*" $content 1) 0 | replaceRE "^# " "" }} + {{ $date := index (findRE "(?m)^Date: .*" $content 1) 0 | replaceRE "^Date: " "" }} + {{ $status := index (findRE "(?s)## Status\\s+\\w+" $content 1) 0 | replaceRE "(?s)## Status\\s+" "" }} + + + + + + {{ end }} + +
    BeslissingDatumStatus
    {{ $title + }}{{ $date }}{{ $status }}
    +
    +{{ end }} diff --git a/layouts/documentatie/list.html b/layouts/documentatie/list.html new file mode 100644 index 0000000..545a265 --- /dev/null +++ b/layouts/documentatie/list.html @@ -0,0 +1,17 @@ +{{ define "main" }} +
    + {{ if .Title }} +

    {{ .Title | strings.FirstUpper }}

    + {{ end }} +
    {{ .Content }}
    + {{ with .Pages.ByWeight }} + + {{ end }} + + +
    + {{ end }} diff --git a/layouts/documentatie/notificatieservice/list.html b/layouts/documentatie/notificatieservice/list.html new file mode 100644 index 0000000..9a85fd3 --- /dev/null +++ b/layouts/documentatie/notificatieservice/list.html @@ -0,0 +1,25 @@ +{{ define "main" }} +
    + {{ if .Title }} +

    {{ .Title | strings.FirstUpper }}

    + {{ end }} + +
    {{ .Content }}
    + +
    +{{- $toc := .TableOfContents -}} +{{ if and $toc (ne .Params.toc false) (gt (len (findRE "
  • " $toc)) 0) }} + + {{ end }} + {{ end }} + + {{ define "scripts" }} + {{- $toc := .TableOfContents -}} + {{ if and $toc (ne .Params.toc false) (gt (len (findRE "
  • " $toc)) 0) }} + {{ $tocScript := resources.Get "js/toc.js" | fingerprint "md5" }} + + {{ end }} +{{ end }} diff --git a/layouts/documentatie/portaal/list.html b/layouts/documentatie/portaal/list.html new file mode 100644 index 0000000..9a85fd3 --- /dev/null +++ b/layouts/documentatie/portaal/list.html @@ -0,0 +1,25 @@ +{{ define "main" }} +
    + {{ if .Title }} +

    {{ .Title | strings.FirstUpper }}

    + {{ end }} + +
    {{ .Content }}
    + +
    +{{- $toc := .TableOfContents -}} +{{ if and $toc (ne .Params.toc false) (gt (len (findRE "
  • " $toc)) 0) }} + + {{ end }} + {{ end }} + + {{ define "scripts" }} + {{- $toc := .TableOfContents -}} + {{ if and $toc (ne .Params.toc false) (gt (len (findRE "
  • " $toc)) 0) }} + {{ $tocScript := resources.Get "js/toc.js" | fingerprint "md5" }} + + {{ end }} +{{ end }} diff --git a/layouts/documentatie/profielservice/list.html b/layouts/documentatie/profielservice/list.html new file mode 100644 index 0000000..9a85fd3 --- /dev/null +++ b/layouts/documentatie/profielservice/list.html @@ -0,0 +1,25 @@ +{{ define "main" }} +
    + {{ if .Title }} +

    {{ .Title | strings.FirstUpper }}

    + {{ end }} + +
    {{ .Content }}
    + +
    +{{- $toc := .TableOfContents -}} +{{ if and $toc (ne .Params.toc false) (gt (len (findRE "
  • " $toc)) 0) }} + + {{ end }} + {{ end }} + + {{ define "scripts" }} + {{- $toc := .TableOfContents -}} + {{ if and $toc (ne .Params.toc false) (gt (len (findRE "
  • " $toc)) 0) }} + {{ $tocScript := resources.Get "js/toc.js" | fingerprint "md5" }} + + {{ end }} +{{ end }} diff --git a/layouts/page.html b/layouts/page.html index 552a886..238e3de 100644 --- a/layouts/page.html +++ b/layouts/page.html @@ -1,7 +1,9 @@ {{ define "main" }}
    + {{ if .Title }}

    {{ .Title }}

    - {{ .Content }} + {{ end }} +
    {{ .Content }}
    {{- $toc := .TableOfContents -}} {{ if and $toc (ne .Params.toc false) (gt (len (findRE "
  • " $toc)) 0) }} diff --git a/layouts/shortcodes/diagram.html b/layouts/shortcodes/diagram.html new file mode 100644 index 0000000..26475e0 --- /dev/null +++ b/layouts/shortcodes/diagram.html @@ -0,0 +1 @@ + diff --git a/setup-dev.sh b/setup-dev.sh new file mode 100755 index 0000000..53547fe --- /dev/null +++ b/setup-dev.sh @@ -0,0 +1,67 @@ +#!/bin/bash + +# Ensure we are in the project root +ROOT_DIR=$(pwd) +GEN_DIR=".generated" + +# Configuration: source_folder:target_folder +DOCS_MAPPING=( + "IAM" + "profielservice" + "portaal" + "notificatieservice" +) + +# Clean and recreate generated directory +rm -rf "$GEN_DIR" +mkdir -p "$GEN_DIR/documentatie/beslissingen/" + +# 1. Copy decisions to .generated/documentatie/beslissingen/ as Page Bundles +echo "Copying decisions to $GEN_DIR..." + +for f in structurizr/decisions/*.md; do + if [ -f "$f" ]; then + filename=$(basename "$f" .md) + # Convert to lowercase and replace spaces with hyphens to match Hugo's default URL behavior + dirname=$(echo "$filename" | tr '[:upper:]' '[:lower:]' | tr ' ' '-') + + BUNDLE_DIR="$GEN_DIR/documentatie/beslissingen/$dirname" + mkdir -p "$BUNDLE_DIR/images" + + # Copy markdown as index.md to create a leaf bundle + cp -v "$f" "$BUNDLE_DIR/index.md" + + # Copy images to the bundle's images folder + cp -v structurizr/decisions/images/* "$BUNDLE_DIR/images/" 2>/dev/null + fi +done + +# Copy images to a central folder as well (optional, but keeps compatibility) +mkdir -p "$GEN_DIR/documentatie/beslissingen/images" +cp -v structurizr/decisions/images/* "$GEN_DIR/documentatie/beslissingen/images/" 2>/dev/null || echo "No decision images found." + +# 2. Copy documentation folders +for folder in "${DOCS_MAPPING[@]}"; do + echo "Processing $folder to $GEN_DIR/documentatie/$folder..." + + TARGET_PATH="$GEN_DIR/documentatie/$folder" + mkdir -p "$TARGET_PATH" + + if [ -d "structurizr/$folder" ]; then + echo "---" > "$TARGET_PATH/_index.md" + echo "title: \"$folder\"" >> "$TARGET_PATH/_index.md" + echo "---" >> "$TARGET_PATH/_index.md" + echo "" >> "$TARGET_PATH/_index.md" + find "structurizr/$folder" -type f -name "*.md" ! -name "_*" | sort -V | xargs cat >> "$TARGET_PATH/_index.md" + mkdir -p "$TARGET_PATH/images" + find "structurizr/$folder" -type f \( -name "*.png" -o -name "*.jpg" -o -name "*.jpeg" -o -name "*.svg" -o -name "*.gif" \) -exec cp -v {} "$TARGET_PATH/images/" \; + else + echo "Warning: Source structurizr/$folder not found." + fi +done + +# 3. Apply sed replacements for structurizr diagrams in the generated folder +echo "Updating diagram embeds in $GEN_DIR..." +find "$GEN_DIR" -type f -name "*.md" -exec sed -i 's|!\[.*\](embed:\(.*\))|{{< diagram "\1" >}}|g' {} + + +echo "Done! You can now run 'hugo server'." diff --git a/structurizr/.adr-dir b/structurizr/.adr-dir new file mode 100644 index 0000000..d9ac890 --- /dev/null +++ b/structurizr/.adr-dir @@ -0,0 +1 @@ +decisions diff --git a/structurizr/.structurizr/1/images/BDContainer-thumbnail-dark.png b/structurizr/.structurizr/1/images/BDContainer-thumbnail-dark.png new file mode 100644 index 0000000..282bcc3 Binary files /dev/null and b/structurizr/.structurizr/1/images/BDContainer-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/MOZAContainer-thumbnail-dark.png b/structurizr/.structurizr/1/images/MOZAContainer-thumbnail-dark.png new file mode 100644 index 0000000..c0740a5 Binary files /dev/null and b/structurizr/.structurizr/1/images/MOZAContainer-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/MOZAContext-thumbnail-dark.png b/structurizr/.structurizr/1/images/MOZAContext-thumbnail-dark.png new file mode 100644 index 0000000..846151a Binary files /dev/null and b/structurizr/.structurizr/1/images/MOZAContext-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/NotificatieServiceContainer-thumbnail-dark.png b/structurizr/.structurizr/1/images/NotificatieServiceContainer-thumbnail-dark.png new file mode 100644 index 0000000..b7b46f7 Binary files /dev/null and b/structurizr/.structurizr/1/images/NotificatieServiceContainer-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/NotificatieServiceContext-thumbnail-dark.png b/structurizr/.structurizr/1/images/NotificatieServiceContext-thumbnail-dark.png new file mode 100644 index 0000000..3214912 Binary files /dev/null and b/structurizr/.structurizr/1/images/NotificatieServiceContext-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/Ontwikkelomgeving-thumbnail-dark.png b/structurizr/.structurizr/1/images/Ontwikkelomgeving-thumbnail-dark.png new file mode 100644 index 0000000..bfd613a Binary files /dev/null and b/structurizr/.structurizr/1/images/Ontwikkelomgeving-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/ProfielServiceContainer-thumbnail-dark.png b/structurizr/.structurizr/1/images/ProfielServiceContainer-thumbnail-dark.png new file mode 100644 index 0000000..4d0b1c9 Binary files /dev/null and b/structurizr/.structurizr/1/images/ProfielServiceContainer-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/RVOContainer-thumbnail-dark.png b/structurizr/.structurizr/1/images/RVOContainer-thumbnail-dark.png new file mode 100644 index 0000000..3988cb1 Binary files /dev/null and b/structurizr/.structurizr/1/images/RVOContainer-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/SysteemLandschap-thumbnail-dark.png b/structurizr/.structurizr/1/images/SysteemLandschap-thumbnail-dark.png new file mode 100644 index 0000000..34140b7 Binary files /dev/null and b/structurizr/.structurizr/1/images/SysteemLandschap-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/UWVContainer-thumbnail-dark.png b/structurizr/.structurizr/1/images/UWVContainer-thumbnail-dark.png new file mode 100644 index 0000000..13300ac Binary files /dev/null and b/structurizr/.structurizr/1/images/UWVContainer-thumbnail-dark.png differ diff --git a/structurizr/.structurizr/1/images/thumbnail-dark.png b/structurizr/.structurizr/1/images/thumbnail-dark.png new file mode 100644 index 0000000..34140b7 Binary files /dev/null and b/structurizr/.structurizr/1/images/thumbnail-dark.png differ diff --git a/structurizr/.structurizr/index/_1.cfe b/structurizr/.structurizr/index/_1.cfe new file mode 100644 index 0000000..a95e262 Binary files /dev/null and b/structurizr/.structurizr/index/_1.cfe differ diff --git a/structurizr/.structurizr/index/_1.cfs b/structurizr/.structurizr/index/_1.cfs new file mode 100644 index 0000000..c5bba6e Binary files /dev/null and b/structurizr/.structurizr/index/_1.cfs differ diff --git a/structurizr/.structurizr/index/_1.si b/structurizr/.structurizr/index/_1.si new file mode 100644 index 0000000..29b5b74 Binary files /dev/null and b/structurizr/.structurizr/index/_1.si differ diff --git a/structurizr/.structurizr/index/segments_2 b/structurizr/.structurizr/index/segments_2 new file mode 100644 index 0000000..a957317 Binary files /dev/null and b/structurizr/.structurizr/index/segments_2 differ diff --git a/structurizr/.structurizr/index/write.lock b/structurizr/.structurizr/index/write.lock new file mode 100644 index 0000000..e69de29 diff --git a/structurizr/IAM/01-context.md b/structurizr/IAM/01-context.md new file mode 100644 index 0000000..3342348 --- /dev/null +++ b/structurizr/IAM/01-context.md @@ -0,0 +1,18 @@ +## Context + +De Identity en Access Management (IAM) is gerealiseerd met Keycloak; een open source Identity en Access Management systeem voor moderne applicaties en services. Deze wordt gebruikt om gebruikers en services binnen MOZA te identificeren en te autoriseren. Keycloak is een Identity Broker waar diverse Identity Providers op kunnen worden aangesloten middels Open ID Connect koppelingen + +Via Keycloak wordt toegang verleend aan bedrijven middels: + +1. DigiD + DigiD voor ZZP-ers +2. eHerkenning voor bedrijven + Bedrijven kunnen via eHerkenning inloggen. Deze koppeling wordt gerealiseerd middels Open ID Connect. +3. EIDAS + Voor europese bedrijven of Wallets... + +Meer informatie over Keycloak zelf is te vinden: [https://www.keycloak.org](https://www.keycloak.org/) + +> NOTE: Documentatie moet nog verder worden uitgewerkt + +![](embed:IAMContext) diff --git a/structurizr/IAM/02-functioneel-overzicht.md b/structurizr/IAM/02-functioneel-overzicht.md new file mode 100644 index 0000000..8d79f47 --- /dev/null +++ b/structurizr/IAM/02-functioneel-overzicht.md @@ -0,0 +1,7 @@ +## Functioneel Overzicht + +Tussen de MOZA en Keycloak is een Open ID Connect verbinding opgezet, waarmee gebruikers kunnen inloggen op basis van hun e-mail adres en wachtwoord. Binnen Keycloak is het mogelijk om een koppeling te maken met andere Identity Providers, waardoor het voor het MOZ systeem eenvoudiger wordt om aan te haken op bijvoorbeeld eHerkenning etc. + +Zie de afbeelding hieronder voor de mogelijkheden: + +![Identity Providers](images/keycloak-ips.png) diff --git a/structurizr/IAM/06-software-architectuur.md b/structurizr/IAM/06-software-architectuur.md new file mode 100644 index 0000000..e1e73a1 --- /dev/null +++ b/structurizr/IAM/06-software-architectuur.md @@ -0,0 +1,32 @@ +## Software architectuur + +### KvK BSN API-integratie + +Om ondernemers op een betrouwbare manier te kunnen identificeren, maakt het systeem gebruik van de KvK-BSN API. +Deze integratie stelt de service in staat organisaties op te vragen waarin een natuurlijk persoon één of meerdere functies vervult. + +#### Interactie-overzicht + +De endpoint **POST `/mijnoverheid/mijnorganisaties`** ontvangt het BSN van de betreffende persoon. +De KvK-API verwerkt dit verzoek en retourneert een lijst met 0, 1 of meerdere organisaties die aan deze persoon zijn gekoppeld. +De interactie volgt een eenvoudige request–response-flow, zoals weergegeven in het sequentiediagram. + +![Sequentiediagram KvK BSN Api](./images/SeqKvKBSN.png "Sequentiediagram KvK BSN Api") + +| **#** | **Omschrijving** | **Toelichting** | +| ----- | ----------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------ | +| 1 | POST /mijnoverheid/mijnorganisaties | De service doet een verzoek naar de KVK-API en stuurt hierbij het **BSN van de natuurlijk persoon** mee. | +| 2 | Lijst met organisaties | De KVK-API verwerkt het verzoek en retourneert een **lijst met 0, 1 of meerdere organisaties** waarin de natuurlijk persoon een functie vervult. | + +
    + Zie mermaid code + + sequenceDiagram + participant Service + + Service-->>KvK API: POST /mijnoverheid/mijnorganisaties + activate KvK API + KvK API-->>Service: Lijst met 0, 1, of meer organisaties + deactivate KvK API + +
    diff --git a/structurizr/IAM/images/SeqKvKBSN.png b/structurizr/IAM/images/SeqKvKBSN.png new file mode 100644 index 0000000..fed8c13 Binary files /dev/null and b/structurizr/IAM/images/SeqKvKBSN.png differ diff --git a/structurizr/IAM/images/eherkenning.excalidraw b/structurizr/IAM/images/eherkenning.excalidraw new file mode 100644 index 0000000..407d266 --- /dev/null +++ b/structurizr/IAM/images/eherkenning.excalidraw @@ -0,0 +1,26467 @@ +{ + "type": "excalidraw", + "version": 2, + "source": "https://excalidraw.com", + "elements": [ + { + "id": "EtEwKTDCQtPgYt3r3fwVB", + "type": "rectangle", + "x": -700, + "y": -26660, + "width": 2344.534567445122, + "height": 1403.174796678658, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#ebfbee", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "YzA", + "roundness": null, + "seed": 1256824699, + "version": 1857, + "versionNonce": 1810418465, + "isDeleted": false, + "boundElements": [ + { + "id": "upeK8VWE9GciZSkIVsesX", + "type": "arrow" + } + ], + "updated": 1762252916538, + "link": null, + "locked": false + }, + { + "id": "bVEI9mF_I-D7-r952tSmf", + "type": "rectangle", + "x": -700, + "y": -27120, + "width": 2344.534567445122, + "height": 468.2660426363876, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "YzB", + "roundness": null, + "seed": 1879818967, + "version": 1698, + "versionNonce": 262418735, + "isDeleted": false, + "boundElements": [ + { + "id": "swA5vVBmSI7fGuJ_rw1hv", + "type": "arrow" + }, + { + "id": "jEtESAk-FWvTx7MxH8YQh", + "type": "arrow" + }, + { + "id": "qFMoo3YNqpx2NG_78dYib", + "type": "arrow" + }, + { + "id": "110qgmWaZ5RbVS1oTZ_FB", + "type": "arrow" + } + ], + "updated": 1762347952819, + "link": null, + "locked": false + }, + { + "id": "9naZyC1mLqSfJLvL7z97l", + "type": "arrow", + "x": -594.5110962415547, + "y": -26340, + "width": 0, + "height": 800, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "YzH", + "roundness": null, + "seed": 911686901, + "version": 441, + "versionNonce": 1496844373, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 800 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": "arrow", + "endArrowhead": "arrow", + "elbowed": false, + "fixedSegments": null, + "startIsSpecial": null, + "endIsSpecial": null + }, + { + "id": "rgPfTnbekIvjMRHeKoMU0", + "type": "rectangle", + "x": -698.3582846701547, + "y": -24984.158734152443, + "width": 2339.132061323902, + "height": 645.2245620313968, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "YzJ", + "roundness": null, + "seed": 1269423875, + "version": 1131, + "versionNonce": 149277615, + "isDeleted": false, + "boundElements": [], + "updated": 1762251455280, + "link": null, + "locked": false + }, + { + "id": "cjEsErzJnGGvUei7tzjxG", + "type": "rectangle", + "x": 120.00000000000045, + "y": -29320, + "width": 700, + "height": 859.9999999999999, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fcc2d7", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 60, + "groupIds": [], + "frameId": null, + "index": "YzL", + "roundness": { + "type": 3 + }, + "seed": 1580336227, + "version": 411, + "versionNonce": 1265318573, + "isDeleted": false, + "boundElements": [], + "updated": 1751032031638, + "link": null, + "locked": false + }, + { + "id": "tOijGb-6c41VoTDdHtkAX", + "type": "rectangle", + "x": -580, + "y": -29320, + "width": 700, + "height": 855.9999999999998, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#a5d8ff", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 60, + "groupIds": [], + "frameId": null, + "index": "YzM", + "roundness": { + "type": 3 + }, + "seed": 1623639213, + "version": 413, + "versionNonce": 1252014403, + "isDeleted": false, + "boundElements": [ + { + "id": "56YigtKXiSVpA6wLjk2zQ", + "type": "arrow" + }, + { + "id": "Oq_WiMNnMo-lwjbssoats", + "type": "arrow" + }, + { + "id": "dEu-ew9Q1Ts1k1xtFavi5", + "type": "arrow" + }, + { + "id": "0fgVSOe5L7MIUYNbQuxQx", + "type": "arrow" + } + ], + "updated": 1751032021544, + "link": null, + "locked": false + }, + { + "id": "YrNzF9iRKSSC8ec30eioo", + "type": "rectangle", + "x": 820.0000000000005, + "y": -29320, + "width": 700, + "height": 859.9999999999999, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#f783ac", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 60, + "groupIds": [], + "frameId": null, + "index": "YzN", + "roundness": { + "type": 3 + }, + "seed": 1169560973, + "version": 427, + "versionNonce": 1976561293, + "isDeleted": false, + "boundElements": [], + "updated": 1751032039701, + "link": null, + "locked": false + }, + { + "id": "yIO_UcEGUuiyXd__09eY8", + "type": "rectangle", + "x": -579.9999999999995, + "y": -29820, + "width": 700, + "height": 500, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 60, + "groupIds": [], + "frameId": null, + "index": "YzP", + "roundness": { + "type": 3 + }, + "seed": 2057852653, + "version": 300, + "versionNonce": 205088195, + "isDeleted": false, + "boundElements": [], + "updated": 1751032009794, + "link": null, + "locked": false + }, + { + "id": "67vzgpQjwq5jL1d5N6t4l", + "type": "rectangle", + "x": 220, + "y": -29620, + "width": 700, + "height": 500.00000000000006, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#fcc2d7", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 60, + "groupIds": [], + "frameId": null, + "index": "YzQ", + "roundness": { + "type": 3 + }, + "seed": 45674829, + "version": 296, + "versionNonce": 1881933115, + "isDeleted": false, + "boundElements": [ + { + "id": "dcD6UOyhBM-Qz1H7VnTHP", + "type": "arrow" + } + ], + "updated": 1762179514709, + "link": null, + "locked": false + }, + { + "id": "4d2o838TsHJF3nX0DxOir", + "type": "rectangle", + "x": 820, + "y": -29820, + "width": 700, + "height": 500, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#f783ac", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 60, + "groupIds": [], + "frameId": null, + "index": "YzS", + "roundness": { + "type": 3 + }, + "seed": 1183268781, + "version": 325, + "versionNonce": 679743971, + "isDeleted": false, + "boundElements": [], + "updated": 1751032001139, + "link": null, + "locked": false + }, + { + "id": "LDxuZDxITDM8lsVm9GxPi", + "type": "rectangle", + "x": -143.5196324034601, + "y": -31714.02493644096, + "width": 195.41048250461327, + "height": 172.1406090042678, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#e9ecef", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "Yzw", + "roundness": null, + "seed": 587448237, + "version": 1124, + "versionNonce": 1229697133, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false + }, + { + "id": "RQQpxDCizq8Txs_1zpPjK", + "type": "rectangle", + "x": -55.42920282404708, + "y": -31634.46154205329, + "width": 1073.952897175974, + "height": 1141.5274614926639, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#e9ecef", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "Yzx", + "roundness": null, + "seed": 937710957, + "version": 931, + "versionNonce": 1293691939, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "7TI31OgMzliuqxSEZ4omN", + "type": "rectangle", + "x": -69.93892447139393, + "y": -31650.508826294146, + "width": 1073.952897175974, + "height": 1142.1717381416713, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "Yzy", + "roundness": null, + "seed": 499455597, + "version": 825, + "versionNonce": 293173155, + "isDeleted": false, + "boundElements": [ + { + "id": "VYHPtZ8svvUv0STCTQs3K", + "type": "arrow" + }, + { + "id": "VVJCM4FaC3Hov2qMh8V7g", + "type": "arrow" + } + ], + "updated": 1751031114004, + "link": null, + "locked": false + }, + { + "id": "d2No4WS5ByWBFftUnrFni", + "type": "rectangle", + "x": -700, + "y": -31795.818354974374, + "width": 2343.4006972296675, + "height": 1518.2231286650635, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "Z2", + "roundness": null, + "seed": 1501238765, + "version": 723, + "versionNonce": 1798945091, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false + }, + { + "id": "AVUYE-h49vrZDcdqyQI29", + "type": "text", + "x": -1020, + "y": -32140, + "width": 4340.456143897681, + "height": 20.89287891610926, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bM6", + "roundness": null, + "seed": 987108428, + "version": 229, + "versionNonce": 1553772227, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "{\"type\":\"excalidraw/clipboard\",\"elements\":[{\"id\":\"IE0INQknEsFlI5Jf3YLBT\",\"type\":\"rectangle\",\"x\":503.498016,\"y\":-30733.184584844712,\"width\":1839.9999999999998,\"height\":1133,\"angle\":0,\"strokeColor\":\"#1e1e1e\",\"backgroundColor\":\"transparent\",\"fillStyle\":\"solid\",\"strokeWidth\":2,\"strokeStyle\":\"solid\",\"roughness\":0,\"opacity\":100,\"groupIds\":[],\"frameId\":null,\"index\":\"bM3\",\"roundness\":{\"type\":3},\"seed\":496448588,\"version\":52,\"versionNonce\":1997475572,\"isDeleted\":false,\"boundElements\":null,\"updated\":1746999590670,\"link\":null,\"locked\":false}],\"files\":{}}", + "fontSize": 16.71430313288741, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "{\"type\":\"excalidraw/clipboard\",\"elements\":[{\"id\":\"IE0INQknEsFlI5Jf3YLBT\",\"type\":\"rectangle\",\"x\":503.498016,\"y\":-30733.184584844712,\"width\":1839.9999999999998,\"height\":1133,\"angle\":0,\"strokeColor\":\"#1e1e1e\",\"backgroundColor\":\"transparent\",\"fillStyle\":\"solid\",\"strokeWidth\":2,\"strokeStyle\":\"solid\",\"roughness\":0,\"opacity\":100,\"groupIds\":[],\"frameId\":null,\"index\":\"bM3\",\"roundness\":{\"type\":3},\"seed\":496448588,\"version\":52,\"versionNonce\":1997475572,\"isDeleted\":false,\"boundElements\":null,\"updated\":1746999590670,\"link\":null,\"locked\":false}],\"files\":{}}", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "DlmPEor6TnqI0-xdLAUF3", + "type": "rectangle", + "x": 338.09356611283374, + "y": -31250.04674138722, + "width": 523.4469188778107, + "height": 677.8118967059494, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff4e6", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bQz", + "roundness": null, + "seed": 174657763, + "version": 880, + "versionNonce": 736541603, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "EcPQ2WDzeE1qVQdIovKCw", + "type": "text", + "x": 632.1056301065946, + "y": -30992.70032359864, + "width": 199.19963289391708, + "height": 40.689103923869546, + "angle": 0, + "strokeColor": "#6741d9", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bR2", + "roundness": null, + "seed": 506501443, + "version": 896, + "versionNonce": 2007925773, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "OneWelcome", + "fontSize": 35.381829499017, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "OneWelcome", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "l0frjmGgZvrtNPj4RaW56", + "type": "rectangle", + "x": 79.36936711663833, + "y": -31329.44817745428, + "width": 513.1584019348139, + "height": 677.8118967059494, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bR4", + "roundness": null, + "seed": 1597727971, + "version": 1014, + "versionNonce": 58019651, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "Unl2gO_t763FH5oTI3aTX", + "type": "rectangle", + "x": 338.093566183029, + "y": -31250.046741153226, + "width": 254.4342012830005, + "height": 598.4104606272086, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#f3f0ff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRA", + "roundness": null, + "seed": 397649859, + "version": 793, + "versionNonce": 347896429, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "-fBoHrz5Qwj3IeSztzq7Z", + "type": "rectangle", + "x": 18.776864657799194, + "y": -31353.420936996845, + "width": 217.21763433660468, + "height": 47.94551906172546, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "nfeSIxVlQgWuB0r-PmzqY" + ], + "frameId": null, + "index": "bRFV", + "roundness": null, + "seed": 305437325, + "version": 859, + "versionNonce": 2133880547, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "xD3dC1N9zFrs3N-Seup44", + "type": "text", + "x": 46.80949159743517, + "y": -31346.647677156365, + "width": 161.15238171726878, + "height": 34.399000901822085, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "nfeSIxVlQgWuB0r-PmzqY" + ], + "frameId": null, + "index": "bRG", + "roundness": null, + "seed": 583545923, + "version": 885, + "versionNonce": 494707917, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "Leveranciers", + "fontSize": 27.519200721457665, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Leveranciers", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "8-KTMbadi7lwwCJhR1jhP", + "type": "rectangle", + "x": 707.5743353054468, + "y": -30596.207604598287, + "width": 217.21763433660468, + "height": 47.94551906172546, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "ZcpTK5mTe5tvNyAciPajL" + ], + "frameId": null, + "index": "bRGV", + "roundness": null, + "seed": 244415971, + "version": 901, + "versionNonce": 27695747, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "XbDxun1SE1v-oy6uIzM8b", + "type": "text", + "x": 750.9076386260454, + "y": -30589.434344757803, + "width": 130.55102895534333, + "height": 34.399000901822085, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "ZcpTK5mTe5tvNyAciPajL" + ], + "frameId": null, + "index": "bRH", + "roundness": null, + "seed": 1074645379, + "version": 933, + "versionNonce": 1166574381, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "Makelaars", + "fontSize": 27.519200721457665, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Makelaars", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "dOGCUM0JXI4CR9T6Q7JbE", + "type": "image", + "x": 632.1056305968955, + "y": -30824.540748297328, + "width": 192.86728568210606, + "height": 104.87158658964518, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#f3f0ff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRK", + "roundness": null, + "seed": 811293667, + "version": 761, + "versionNonce": 395727395, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "83a74977708d75361f44dabc8f179b40205d7422", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "EBMgUZxmIwBgazx3CKond", + "type": "image", + "x": 661.6154034165879, + "y": -31132.880408080542, + "width": 140.18008477624613, + "height": 140.18008477624613, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#f3f0ff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRL", + "roundness": null, + "seed": 1006619555, + "version": 725, + "versionNonce": 290035085, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "4875a3ba63a03226b397f189b1625e43248d09d2", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "SOwOhw1WnkocRSU4jt8bf", + "type": "image", + "x": 350.1166635662976, + "y": -31159.088128090178, + "width": 228.28256318872263, + "height": 69.59447586100642, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#f3f0ff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRM", + "roundness": null, + "seed": 1942332493, + "version": 716, + "versionNonce": 837686723, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "a290e5bf6303127ae129b00af21ec58726257300", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "Zlb4wH4wHKscEPcdFU4RO", + "type": "image", + "x": 350.11666349607276, + "y": -31017.71205317591, + "width": 233.84172095209263, + "height": 129.4248969436235, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#f3f0ff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRN", + "roundness": null, + "seed": 1346182925, + "version": 758, + "versionNonce": 1006197741, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "67f00ba8d75e950dd6aae04f858d0c81baea1681", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "aY6owZ8WLkr1kyf0_Xib2", + "type": "image", + "x": 375.78154604705105, + "y": -30792.688006207765, + "width": 176.9527985133238, + "height": 41.16610243191908, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#f3f0ff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRO", + "roundness": null, + "seed": 1227944707, + "version": 736, + "versionNonce": 533488995, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "f6c358754b9f1ab00bf1a7add91e70d20d080960", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "OHscIdFkWA1vXjSXkZp7E", + "type": "image", + "x": 98.85465562393159, + "y": -31225.196939982587, + "width": 216.30947914252445, + "height": 54.01245097436386, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#f3f0ff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRP", + "roundness": null, + "seed": 16304333, + "version": 728, + "versionNonce": 1570854477, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "926b2fb3670f767cbce8054d47de2eb62fe9fcd4", + "scale": [ + 1, + 1 + ], + "crop": null, + "initialWidth": 8.019982000000027, + "initialHeight": 2.0025885426170533 + }, + { + "id": "Bzwiy2lPx3XDD_4L0Pgqa", + "type": "image", + "x": 107.76867119031198, + "y": -31036.845412074486, + "width": 183.28771393634426, + "height": 63.50125522204054, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRQ", + "roundness": null, + "seed": 1534891917, + "version": 698, + "versionNonce": 1216332035, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "b51e50c7cb906dd0d7108fdfb919139ea0bb955c", + "scale": [ + 1, + 1 + ], + "crop": null, + "initialWidth": 8.019982000000027, + "initialHeight": 2.7785764409448914 + }, + { + "id": "y-Gn3scAGbKQiWMhOLLGA", + "type": "image", + "x": 99.70524693389774, + "y": -30838.29923493775, + "width": 208.5281312673467, + "height": 68.20607626869464, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRR", + "roundness": null, + "seed": 553881315, + "version": 681, + "versionNonce": 1360725165, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "de05584155117ae20f48c6b11cfef05b28c66ac8", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "3ylwj8XVq2qoj1pSVnY1n", + "type": "rectangle", + "x": 1062.8351124345436, + "y": -31253.229115580227, + "width": 466.9885069742715, + "height": 667.947715633972, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRW", + "roundness": null, + "seed": 1830001635, + "version": 867, + "versionNonce": 1263212456, + "isDeleted": false, + "boundElements": [ + { + "id": "VYHPtZ8svvUv0STCTQs3K", + "type": "arrow" + }, + { + "id": "VVJCM4FaC3Hov2qMh8V7g", + "type": "arrow" + }, + { + "id": "w84_K_hWpv_SeV-ZvF9ku", + "type": "arrow" + } + ], + "updated": 1760105831124, + "link": null, + "locked": false + }, + { + "id": "6zJVVH4iaXBDKvZj6CNuB", + "type": "rectangle", + "x": 362.84678833063026, + "y": -31501.495977152146, + "width": 295.5008363054892, + "height": 98.28285971949167, + "angle": 4.7123889803846275, + "strokeColor": "#228be6", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "8odC-9dm5ZqjAjw1xPx6C" + ], + "frameId": null, + "index": "bRtG", + "roundness": null, + "seed": 1359943341, + "version": 1741, + "versionNonce": 1008320333, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "UMq2X33BEiMq7b1tiUG2b", + "type": "rectangle", + "x": 353.90980512466194, + "y": -31492.261313978237, + "width": 295.5008363054892, + "height": 98.28285971949167, + "angle": 4.7123889803846275, + "strokeColor": "#228be6", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "8odC-9dm5ZqjAjw1xPx6C" + ], + "frameId": null, + "index": "bRtV", + "roundness": null, + "seed": 1510137549, + "version": 1718, + "versionNonce": 1790176355, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "I6WbaaqIbwZpZq1DPWpzO", + "type": "rectangle", + "x": 345.62989978149153, + "y": -31483.33661524054, + "width": 295.5008363054892, + "height": 98.28285971949167, + "angle": 4.7123889803846275, + "strokeColor": "#228be6", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "8odC-9dm5ZqjAjw1xPx6C" + ], + "frameId": null, + "index": "bRtl", + "roundness": null, + "seed": 1291548771, + "version": 1663, + "versionNonce": 1713168109, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "CLNMlYRfZhMqyh6IccSj7" + } + ], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "CLNMlYRfZhMqyh6IccSj7", + "type": "text", + "x": 361.6762316305252, + "y": -31451.394685831703, + "width": 263.4081726074219, + "height": 34.39900090182208, + "angle": 4.7123889803846275, + "strokeColor": "#228be6", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "8odC-9dm5ZqjAjw1xPx6C" + ], + "frameId": null, + "index": "bRu", + "roundness": null, + "seed": 1146385411, + "version": 1756, + "versionNonce": 1037472355, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "Machtigingenregister", + "fontSize": 27.519200721457665, + "fontFamily": 6, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "I6WbaaqIbwZpZq1DPWpzO", + "originalText": "Machtigingenregister", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "type": "line", + "version": 7156, + "versionNonce": 2089786435, + "isDeleted": false, + "id": "b_RY3ROLILqTeqc2fI3Es", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 540.1636071323037, + "y": -31320.132786599457, + "strokeColor": "#1971c2", + "backgroundColor": "#a5d8ff", + "width": 36.86158427001497, + "height": 47.57572655827629, + "seed": 1047391309, + "groupIds": [ + "_Y4V_ccxQMFP9_tgpMfyj", + "hsoVqgyGvbuESCNB0Zd3v", + "GCArz55RPxGGE5tD0htyx", + "8odC-9dm5ZqjAjw1xPx6C" + ], + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 0.12155057485494992, + 35.957476268733615 + ], + [ + 0.0056882815586784055, + 40.05107879797992 + ], + [ + 1.898453114704463, + 41.81987383074428 + ], + [ + 8.489912203292034, + 43.31684716459825 + ], + [ + 19.631345208859994, + 43.78298229843207 + ], + [ + 30.27624768295255, + 43.03872927617655 + ], + [ + 35.93196274414161, + 41.258861634271554 + ], + [ + 36.729624822253406, + 39.75841454068687 + ], + [ + 36.84165357356136, + 36.462684996393165 + ], + [ + 36.75372403038364, + 3.016631559376741 + ], + [ + 36.55550261576305, + -0.14340424544510566 + ], + [ + 34.18861703514054, + -1.9095690441511632 + ], + [ + 29.20446111643721, + -2.932438240035564 + ], + [ + 17.846243199492154, + -3.792744259844222 + ], + [ + 8.739833080950557, + -3.279741843089235 + ], + [ + 1.577703367623307, + -1.5397002395695303 + ], + [ + -0.019930696453615324, + -0.02160554489511206 + ], + [ + 0, + 0 + ] + ], + "index": "bRuV", + "frameId": null, + "roundness": { + "type": 2 + }, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "polygon": false + }, + { + "type": "ellipse", + "version": 7874, + "versionNonce": 184122733, + "isDeleted": false, + "id": "wGk9GsdXUNoh0rL_IpJ2t", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 540.2942902099121, + "y": -31324.43412030924, + "strokeColor": "#1971c2", + "backgroundColor": "#a5d8ff", + "width": 36.625148031698494, + "height": 7.407160647108594, + "seed": 1474615981, + "groupIds": [ + "_Y4V_ccxQMFP9_tgpMfyj", + "hsoVqgyGvbuESCNB0Zd3v", + "GCArz55RPxGGE5tD0htyx", + "8odC-9dm5ZqjAjw1xPx6C" + ], + "index": "bRv", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "wRCsqsZuvxmIbXHr9PPyq", + "type": "image", + "x": 412.1288766176749, + "y": -31646.16562675134, + "width": 64.22002275424242, + "height": 64.22002275424242, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "8odC-9dm5ZqjAjw1xPx6C" + ], + "frameId": null, + "index": "bRw", + "roundness": null, + "seed": 1216539277, + "version": 1266, + "versionNonce": 629581987, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "9451b2424c9252d8fc74839a946f6dc4c466acda", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "diJ-Os7TYVh2k3FfjUNxw", + "type": "text", + "x": 1148.8451695935455, + "y": -31214.25087373112, + "width": 363.2533055542084, + "height": 343.99000901822086, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "dotted", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bRz", + "roundness": null, + "seed": 2071588771, + "version": 952, + "versionNonce": 509376845, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "Overheid:\n- Belastingdienst\n- UWV\n- RVO\n- Gemeenten\n- Pronvicies\n- Waterschappen\n- Kadaster\n- MijnOverheid Zakelijk?\n- Etc.", + "fontSize": 27.519200721457665, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Overheid:\n- Belastingdienst\n- UWV\n- RVO\n- Gemeenten\n- Pronvicies\n- Waterschappen\n- Kadaster\n- MijnOverheid Zakelijk?\n- Etc.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Kl7begI_nhBxMNvJoT3iT", + "type": "text", + "x": 1148.845169266936, + "y": -30856.090661017202, + "width": 257.3044247675643, + "height": 171.99500450911043, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "dotted", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bS0", + "roundness": null, + "seed": 32279821, + "version": 786, + "versionNonce": 1589399043, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "Private\n- Pensioenfondsen\n- Verzekeraars\n- Banken\n- Etc.", + "fontSize": 27.519200721457665, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Private\n- Pensioenfondsen\n- Verzekeraars\n- Banken\n- Etc.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "6wb38QwzxTKj9jwkbgH05", + "type": "rectangle", + "x": -586.4229209257837, + "y": -31248.314972594253, + "width": 466.9885069742715, + "height": 667.9477151908628, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bS1", + "roundness": null, + "seed": 2005845571, + "version": 873, + "versionNonce": 1873908184, + "isDeleted": false, + "boundElements": [ + { + "id": "w84_K_hWpv_SeV-ZvF9ku", + "type": "arrow" + } + ], + "updated": 1760105831124, + "link": null, + "locked": false + }, + { + "id": "avScmPedDcn6PJtTuwfMZ", + "type": "text", + "x": -526.7418394004658, + "y": -31188.411487131027, + "width": 227.03331597138026, + "height": 137.59600360728834, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "dotted", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bS4", + "roundness": null, + "seed": 1458514211, + "version": 1241, + "versionNonce": 1051301283, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "- Bedrijven\n- Organisaties\n- Intermediairs\n- Eenmanszaken", + "fontSize": 27.519200721457665, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "- Bedrijven\n- Organisaties\n- Intermediairs\n- Eenmanszaken", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "SLjPalSS36w9FgPTnjoBQ", + "type": "rectangle", + "x": -489.51756258467276, + "y": -31280.108909287566, + "width": 228.8777658338809, + "height": 47.94551906172546, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "-8VY8CEnDtMfirIiDMWTX" + ], + "frameId": null, + "index": "bS6", + "roundness": null, + "seed": 109919811, + "version": 921, + "versionNonce": 178145805, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "dKKDdTpJWhvuEb-vs2qrR", + "type": "text", + "x": -475.9745409520342, + "y": -31273.335650429923, + "width": 205.6784343276324, + "height": 34.399000901822085, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "-8VY8CEnDtMfirIiDMWTX" + ], + "frameId": null, + "index": "bS7", + "roundness": null, + "seed": 1467121123, + "version": 957, + "versionNonce": 751626563, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "Dienstafnemers", + "fontSize": 27.519200721457665, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Dienstafnemers", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "lk1Y7NP-td-JrqaAhE7iU", + "type": "rectangle", + "x": 1181.923817135591, + "y": -31288.164590324435, + "width": 233.8237142226032, + "height": 47.94551906172546, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bS8", + "roundness": null, + "seed": 554952163, + "version": 962, + "versionNonce": 29589613, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "PsOjV1sJF4S6ud8ukWfsE", + "type": "text", + "x": 1197.8902762020377, + "y": -31281.391331466788, + "width": 204.59173583984375, + "height": 34.39900090182208, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bS9", + "roundness": null, + "seed": 637743491, + "version": 1007, + "versionNonce": 243583203, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "Dienstverleners", + "fontSize": 27.519200721457665, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Dienstverleners", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "w84_K_hWpv_SeV-ZvF9ku", + "type": "arrow", + "x": -385.5648225891342, + "y": -30575.45311441741, + "width": 1780.939007981298, + "height": 240.36725696027133, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSC", + "roundness": null, + "seed": 1928501443, + "version": 2510, + "versionNonce": 1086281384, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "KBf-0YIME2fHZlOrVI5im" + } + ], + "updated": 1760105909576, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 235.4531144174107 + ], + [ + 1780.939007981298, + 235.4531144174107 + ], + [ + 1780.939007981298, + -4.914142542860645 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "6wb38QwzxTKj9jwkbgH05", + "focus": 0.13977284092896408, + "gap": 5.000000000003638, + "fixedPoint": [ + 0.4301135795355145, + 1.0073570773194036 + ] + }, + "endBinding": { + "elementId": "3ylwj8XVq2qoj1pSVnY1n", + "focus": -0.42418525505999033, + "gap": 5.000000000007276, + "fixedPoint": [ + 0.7120926275299987, + 1.0073570773145286 + ] + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": true, + "fixedSegments": [ + { + "index": 2, + "start": [ + 0, + 235.4531144174107 + ], + "end": [ + 1780.939007981298, + 235.4531144174107 + ] + } + ], + "startIsSpecial": false, + "endIsSpecial": false + }, + { + "id": "KBf-0YIME2fHZlOrVI5im", + "type": "text", + "x": 464.9267761280772, + "y": -30352.285357464938, + "width": 79.955810546875, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#e9ecef", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSCV", + "roundness": null, + "seed": 2008500067, + "version": 338, + "versionNonce": 97541592, + "isDeleted": false, + "boundElements": [], + "updated": 1760105902344, + "link": null, + "locked": false, + "text": "Inloggen", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "w84_K_hWpv_SeV-ZvF9ku", + "originalText": "Inloggen", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "FQ9N_zz7NGXK5Z6OYg5Td", + "type": "text", + "x": 766.5399526068118, + "y": -31610.751334798148, + "width": 192.68936822782695, + "height": 81.37820784773909, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSG", + "roundness": null, + "seed": 938562829, + "version": 780, + "versionNonce": 1963329837, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "eHerkenning\nNetwerk", + "fontSize": 35.381829499017, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "eHerkenning\nNetwerk", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "VYHPtZ8svvUv0STCTQs3K", + "type": "arrow", + "x": 1320.559489184398, + "y": -30580.36725696027, + "width": 915.8558746154636, + "height": 182.45590416045525, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#e9ecef", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSH", + "roundness": null, + "seed": 1526461923, + "version": 2547, + "versionNonce": 1567578280, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "E8CbPnX6pO1OpwqmHud96" + } + ], + "updated": 1760105831127, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 182.45590416045525 + ], + [ + -915.8558746154636, + 182.45590416045525 + ], + [ + -915.8558746154636, + 76.85027557447756 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "3ylwj8XVq2qoj1pSVnY1n", + "focus": -0.10377181836748411, + "gap": 5.000000000007276, + "fixedPoint": [ + 0.5518859091837429, + 1.0073570773145286 + ] + }, + "endBinding": { + "elementId": "7TI31OgMzliuqxSEZ4omN", + "focus": 0.11608313495231991, + "gap": 15.151031875026092, + "fixedPoint": [ + 0.44195843252383826, + 1.0042201243523348 + ] + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": true, + "fixedSegments": [ + { + "index": 2, + "start": [ + 0, + 182.45590416045525 + ], + "end": [ + -915.8558746154636, + 182.45590416045525 + ] + } + ], + "startIsSpecial": false, + "endIsSpecial": false + }, + { + "id": "E8CbPnX6pO1OpwqmHud96", + "type": "text", + "x": 661.3469754606506, + "y": -30410.196710264754, + "width": 402.56915283203125, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#e9ecef", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSHV", + "roundness": null, + "seed": 303776291, + "version": 327, + "versionNonce": 1153978189, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114012, + "link": null, + "locked": false, + "text": "Redirect voor authenticatie & autorisatie", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "VYHPtZ8svvUv0STCTQs3K", + "originalText": "Redirect voor authenticatie & autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "VVJCM4FaC3Hov2qMh8V7g", + "type": "arrow", + "x": 530.8937396280271, + "y": -30503.516981385794, + "width": 718.4711192941438, + "height": 127.41505717674954, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#e9ecef", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSI", + "roundness": null, + "seed": 1048544259, + "version": 2589, + "versionNonce": 1246626728, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "LsVrPt5roH1Wl_6xeX63T" + } + ], + "updated": 1760105831128, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 50.56478160227198 + ], + [ + 718.4711192941438, + 50.56478160227198 + ], + [ + 718.4711192941438, + -76.85027557447756 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "7TI31OgMzliuqxSEZ4omN", + "focus": -0.11891809348314361, + "gap": 15.151031875026092, + "fixedPoint": [ + 0.5594590467415731, + 1.0042201243523348 + ] + }, + "endBinding": { + "elementId": "3ylwj8XVq2qoj1pSVnY1n", + "focus": 0.2011377423560251, + "gap": 5.000000000007276, + "fixedPoint": [ + 0.3994311288219866, + 1.0073570773145286 + ] + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": true, + "fixedSegments": [ + { + "index": 2, + "start": [ + 0, + 50.56478160227198 + ], + "end": [ + 718.4711192941438, + 50.56478160227198 + ] + } + ], + "startIsSpecial": false, + "endIsSpecial": false + }, + { + "id": "LsVrPt5roH1Wl_6xeX63T", + "type": "text", + "x": 743.0688286940443, + "y": -30465.23755724846, + "width": 294.1209411621094, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#e9ecef", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSJ", + "roundness": null, + "seed": 1826805005, + "version": 488, + "versionNonce": 78238083, + "isDeleted": false, + "boundElements": [], + "updated": 1751033654576, + "link": null, + "locked": false, + "text": "Redirect autorisatie bevestigd", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "VVJCM4FaC3Hov2qMh8V7g", + "originalText": "Redirect autorisatie bevestigd", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "lIeN9ba6hljYnJTl0eDYP", + "type": "ellipse", + "x": 1228.9915126330834, + "y": -30529.69768729541, + "width": 40.74669079986492, + "height": 42, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSL", + "roundness": { + "type": 2 + }, + "seed": 1069668685, + "version": 1473, + "versionNonce": 903600899, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "m4mWpGx3rZiw-iNRmZFrg" + } + ], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "m4mWpGx3rZiw-iNRmZFrg", + "type": "text", + "x": 1244.679850086967, + "y": -30518.375215672277, + "width": 9.557754516601562, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#ffcf66", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSM", + "roundness": null, + "seed": 1110648749, + "version": 1197, + "versionNonce": 178621101, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "3", + "fontSize": 15.725257555118667, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "lIeN9ba6hljYnJTl0eDYP", + "originalText": "3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "VpwhWKA6vj2vi1aubmw0b", + "type": "ellipse", + "x": 1300.1861435622386, + "y": -30475.39669843994, + "width": 40.74669079986492, + "height": 42, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSN", + "roundness": { + "type": 2 + }, + "seed": 761035523, + "version": 1464, + "versionNonce": 72319651, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "rCriIvDv2z_g5PqLiSkrU" + } + ], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "rCriIvDv2z_g5PqLiSkrU", + "type": "text", + "x": 1315.1513593730558, + "y": -30464.074226816807, + "width": 11.003997802734375, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#ffcf66", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSO", + "roundness": null, + "seed": 45884067, + "version": 1189, + "versionNonce": 1280945421, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "2", + "fontSize": 15.725257555118667, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "VpwhWKA6vj2vi1aubmw0b", + "originalText": "2", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "BHo5VYEJk7TxTjwPiBH7k", + "type": "ellipse", + "x": 1375.0008401093137, + "y": -30406.986595074522, + "width": 40.74669079986492, + "height": 42, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSP", + "roundness": { + "type": 2 + }, + "seed": 1080142893, + "version": 1492, + "versionNonce": 19740227, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "l2ZOV-9Z5VxRHxcz4S_Zr" + } + ], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "l2ZOV-9Z5VxRHxcz4S_Zr", + "type": "text", + "x": 1392.111838390834, + "y": -30395.664123451388, + "width": 6.712432861328125, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#ffcf66", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSQ", + "roundness": null, + "seed": 152411789, + "version": 1217, + "versionNonce": 1545241453, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "1", + "fontSize": 15.725257555118667, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "BHo5VYEJk7TxTjwPiBH7k", + "originalText": "1", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "type": "line", + "version": 1638, + "versionNonce": 1800631779, + "isDeleted": false, + "id": "8SjKV7AVAet4x31Cu-Woy", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -192.13022970850358, + "y": -30971.81000443734, + "strokeColor": "#000000", + "backgroundColor": "#e3fafc", + "width": 226.6916959840848, + "height": 183.60820019616847, + "seed": 329494755, + "groupIds": [], + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + -6.983417202341376e-15, + 91.80410009808422 + ], + [ + 136.0150175904509, + 91.80410009808423 + ], + [ + 136.0150175904509, + 137.70615014712635 + ], + [ + 226.6916959840848, + 45.902050049042124 + ], + [ + 136.0150175904509, + -45.9020500490421 + ], + [ + 136.0150175904509, + 0 + ], + [ + 0, + 0 + ] + ], + "index": "bSU", + "frameId": null, + "roundness": null, + "polygon": true + }, + { + "type": "line", + "version": 1655, + "versionNonce": 1043434957, + "isDeleted": false, + "id": "Ok-WR-A3p-UPHVeT63CXP", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1126.9553996622344, + "y": -30971.810004022012, + "strokeColor": "#000000", + "backgroundColor": "#e3fafc", + "width": 226.6916959840848, + "height": 183.60820019616847, + "seed": 542901571, + "groupIds": [], + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 6.983417202341376e-15, + 91.80410009808422 + ], + [ + -136.0150175904509, + 91.80410009808423 + ], + [ + -136.0150175904509, + 137.70615014712635 + ], + [ + -226.6916959840848, + 45.902050049042124 + ], + [ + -136.0150175904509, + -45.9020500490421 + ], + [ + -136.0150175904509, + 0 + ], + [ + 0, + 0 + ] + ], + "index": "bSV", + "frameId": null, + "roundness": null, + "polygon": true + }, + { + "id": "HaPUaR3cxTiPqx2CJjlEw", + "type": "text", + "x": 1055.5960440484696, + "y": -31685.610448013795, + "width": 14.958637452274322, + "height": 24.570714929872917, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSa", + "roundness": null, + "seed": 1933015971, + "version": 599, + "versionNonce": 834161709, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "B", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "B", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Tws1GPeOLInTjpR-9TS84", + "type": "text", + "x": -48.96175159912042, + "y": -31911.051707523307, + "width": 53.839319361047096, + "height": 24.570714929872917, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bSd", + "roundness": null, + "seed": 885504333, + "version": 264, + "versionNonce": 501455139, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "ttest", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "ttest", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "xAsJ7Y61oCNwNROf59nnJ", + "type": "rectangle", + "x": -158.12790138739916, + "y": -31727.34140971256, + "width": 192.68936777384462, + "height": 171.99868065230118, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "U52M-_LtbmgvKlOSjG1J1" + ], + "frameId": null, + "index": "bSl", + "roundness": null, + "seed": 1608120301, + "version": 1363, + "versionNonce": 1452818061, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "FDgAulmMW3-4fSIRg4jAb", + "type": "rectangle", + "x": -122.41322715565599, + "y": -31761.939488092703, + "width": 123.9262721106583, + "height": 47.94551906172546, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "U52M-_LtbmgvKlOSjG1J1" + ], + "frameId": null, + "index": "bSm", + "roundness": null, + "seed": 1921294509, + "version": 1363, + "versionNonce": 754613443, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "y8kYWfV1O3PDqTVR3Mycc", + "type": "text", + "x": -104.63649135495285, + "y": -31755.166229235056, + "width": 92.2168145034368, + "height": 34.399000901822085, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "U52M-_LtbmgvKlOSjG1J1" + ], + "frameId": null, + "index": "bSn", + "roundness": null, + "seed": 1407582989, + "version": 1389, + "versionNonce": 327869677, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "Beheer", + "fontSize": 27.519200721457665, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Beheer", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "m8l0UrsEPboa86MIpJ_zc", + "type": "image", + "x": -126.87188203531883, + "y": -31687.24344474413, + "width": 132.84358297706902, + "height": 101.36803133475418, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "U52M-_LtbmgvKlOSjG1J1" + ], + "frameId": null, + "index": "bSo", + "roundness": null, + "seed": 1953989987, + "version": 1591, + "versionNonce": 567329155, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "status": "saved", + "fileId": "6f678ec65c6911ad61b1e68da56b44fb3b275748", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "type": "ellipse", + "version": 3140, + "versionNonce": 1501109219, + "isDeleted": false, + "id": "3JHqF_u792IQeTMuwSmXE", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 253.88118835857352, + "y": -31639.37568481391, + "strokeColor": "#228be6", + "backgroundColor": "#228be6", + "width": 45.392609833217996, + "height": 43.591239138158315, + "seed": 278992749, + "groupIds": [ + "JRtS0djLXU5o9eaFRVlQv", + "HLSWQA2VJRowQxjOyWLTI", + "AcZeunAFWkgs4nNtmpeLf" + ], + "roundness": { + "type": 2 + }, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "index": "bSr", + "frameId": null + }, + { + "type": "ellipse", + "version": 1821, + "versionNonce": 1797343181, + "isDeleted": false, + "id": "UnhPq3AJ_Mw5VTIpx-4F6", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 259.63275603586993, + "y": -31625.64566630641, + "strokeColor": "#ffffff", + "backgroundColor": "#ffffff", + "width": 16.919592191929425, + "height": 17.101772682887415, + "seed": 1288020429, + "groupIds": [ + "JRtS0djLXU5o9eaFRVlQv", + "HLSWQA2VJRowQxjOyWLTI", + "AcZeunAFWkgs4nNtmpeLf" + ], + "roundness": { + "type": 2 + }, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "index": "bSs", + "frameId": null + }, + { + "type": "ellipse", + "version": 1478, + "versionNonce": 1213310851, + "isDeleted": false, + "id": "0ye1uD0ppNCdiMs4gmdC2", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 262.0005733106331, + "y": -31619.544574421812, + "strokeColor": "#228be6", + "backgroundColor": "#228be6", + "width": 4.353208009438352, + "height": 5.5775400428144035, + "seed": 2091507757, + "groupIds": [ + "JRtS0djLXU5o9eaFRVlQv", + "HLSWQA2VJRowQxjOyWLTI", + "AcZeunAFWkgs4nNtmpeLf" + ], + "roundness": null, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "index": "bSt", + "frameId": null + }, + { + "type": "rectangle", + "version": 1717, + "versionNonce": 1554040365, + "isDeleted": false, + "id": "JghVfb2vsqqeLOL69CPrP", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 274.96525652454693, + "y": -31619.88468996157, + "strokeColor": "#ffffff", + "backgroundColor": "#ffffff", + "width": 19.267289740848426, + "height": 4.986724495512072, + "seed": 1983337101, + "groupIds": [ + "GppLry0Npja85AtTb2bbn", + "JRtS0djLXU5o9eaFRVlQv", + "HLSWQA2VJRowQxjOyWLTI", + "AcZeunAFWkgs4nNtmpeLf" + ], + "roundness": { + "type": 3 + }, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "index": "bSu", + "frameId": null + }, + { + "type": "line", + "version": 1604, + "versionNonce": 1331150627, + "isDeleted": false, + "id": "BcTmwbOBotmAbLQFrfxFo", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 279.7877771218614, + "y": -31615.583455050448, + "strokeColor": "#ffffff", + "backgroundColor": "#ffffff", + "width": 5.159719122355257, + "height": 2.5885942582105925, + "seed": 371685613, + "groupIds": [ + "GppLry0Npja85AtTb2bbn", + "JRtS0djLXU5o9eaFRVlQv", + "HLSWQA2VJRowQxjOyWLTI", + "AcZeunAFWkgs4nNtmpeLf" + ], + "roundness": null, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 2.535429432620667, + 2.5055167733368187 + ], + [ + 5.159719122355257, + -0.08307748487377367 + ] + ], + "index": "bSv", + "frameId": null, + "polygon": false + }, + { + "type": "line", + "version": 1667, + "versionNonce": 1113684109, + "isDeleted": false, + "id": "YuAWgZuvO3Ogv6IJD4edY", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 284.41327643942077, + "y": -31615.9833334736, + "strokeColor": "#ffffff", + "backgroundColor": "#ffffff", + "width": 5.159719122355257, + "height": 2.457060632121706, + "seed": 1711526733, + "groupIds": [ + "GppLry0Npja85AtTb2bbn", + "JRtS0djLXU5o9eaFRVlQv", + "HLSWQA2VJRowQxjOyWLTI", + "AcZeunAFWkgs4nNtmpeLf" + ], + "roundness": null, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 2.8423451294630375, + 2.373983147247932 + ], + [ + 5.159719122355257, + -0.08307748487377367 + ] + ], + "index": "bSw", + "frameId": null, + "polygon": false + }, + { + "type": "line", + "version": 1905, + "versionNonce": 687465155, + "isDeleted": false, + "id": "5979Jm7y_bqjkvjuseXUT", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 289.62224596996475, + "y": -31615.13940055564, + "strokeColor": "#ffffff", + "backgroundColor": "#ffffff", + "width": 4.326668921157341, + "height": 1.4767007289260639, + "seed": 36037037, + "groupIds": [ + "GppLry0Npja85AtTb2bbn", + "JRtS0djLXU5o9eaFRVlQv", + "HLSWQA2VJRowQxjOyWLTI", + "AcZeunAFWkgs4nNtmpeLf" + ], + "roundness": null, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 2.8125434341684117, + 1.4767007289260639 + ], + [ + 4.326668921157341, + 0.12039197094796673 + ] + ], + "index": "bSx", + "frameId": null, + "polygon": false + }, + { + "id": "nYELzlOUG8mf45MJi7Qhy", + "type": "rectangle", + "x": 194.21244559819655, + "y": -31501.267952878814, + "width": 295.5008363054892, + "height": 98.28285971949167, + "angle": 4.7123889803846275, + "strokeColor": "#228be6", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "AcZeunAFWkgs4nNtmpeLf" + ], + "frameId": null, + "index": "bSy", + "roundness": null, + "seed": 1798099459, + "version": 1592, + "versionNonce": 2061395971, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "yd61gOxpslmChhwfL6K44", + "type": "rectangle", + "x": 184.2926337950334, + "y": -31492.03328970491, + "width": 295.5008363054892, + "height": 98.28285971949167, + "angle": 4.7123889803846275, + "strokeColor": "#228be6", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "AcZeunAFWkgs4nNtmpeLf" + ], + "frameId": null, + "index": "bSz", + "roundness": null, + "seed": 1919523235, + "version": 1570, + "versionNonce": 1990086061, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "-2FwFkfZVkOClWJiPztHP", + "type": "rectangle", + "x": 176.01272845186298, + "y": -31483.108590967207, + "width": 295.5008363054892, + "height": 98.28285971949167, + "angle": 4.7123889803846275, + "strokeColor": "#228be6", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "AcZeunAFWkgs4nNtmpeLf" + ], + "frameId": null, + "index": "bT0", + "roundness": null, + "seed": 1911319875, + "version": 1515, + "versionNonce": 58224547, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "A4L7edT0H-b_DkS-WqYTx" + } + ], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "A4L7edT0H-b_DkS-WqYTx", + "type": "text", + "x": 202.14148827941227, + "y": -31451.16666155837, + "width": 243.24331665039062, + "height": 34.39900090182208, + "angle": 4.7123889803846275, + "strokeColor": "#228be6", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "AcZeunAFWkgs4nNtmpeLf" + ], + "frameId": null, + "index": "bT1", + "roundness": null, + "seed": 219401443, + "version": 1635, + "versionNonce": 1648496653, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "text": "Authenticatiedienst", + "fontSize": 27.519200721457665, + "fontFamily": 6, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "-2FwFkfZVkOClWJiPztHP", + "originalText": "Authenticatiedienst", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "type": "line", + "version": 6954, + "versionNonce": 1722843971, + "isDeleted": false, + "id": "-O0I8CcMOQX8OJlsSpp8u", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 367.3839636547659, + "y": -31319.90476232613, + "strokeColor": "#1971c2", + "backgroundColor": "#a5d8ff", + "width": 36.861584270014966, + "height": 47.57572655827629, + "seed": 2003712131, + "groupIds": [ + "j7K42yJwSrw2TqILIXFTL", + "nt4o7I-p25e95_zrIsH0G", + "3FQ0aaKLsvSodeW5ObU8M", + "AcZeunAFWkgs4nNtmpeLf" + ], + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 0.1215505748549499, + 35.957476268733615 + ], + [ + 0.005688281558678405, + 40.05107879797992 + ], + [ + 1.8984531147044625, + 41.81987383074428 + ], + [ + 8.489912203292032, + 43.31684716459825 + ], + [ + 19.63134520885999, + 43.78298229843207 + ], + [ + 30.276247682952544, + 43.03872927617655 + ], + [ + 35.9319627441416, + 41.258861634271554 + ], + [ + 36.7296248222534, + 39.75841454068687 + ], + [ + 36.84165357356135, + 36.462684996393165 + ], + [ + 36.75372403038363, + 3.016631559376741 + ], + [ + 36.55550261576304, + -0.14340424544510566 + ], + [ + 34.18861703514053, + -1.9095690441511632 + ], + [ + 29.2044611164372, + -2.932438240035564 + ], + [ + 17.84624319949215, + -3.792744259844222 + ], + [ + 8.739833080950556, + -3.279741843089235 + ], + [ + 1.5777033676233065, + -1.5397002395695303 + ], + [ + -0.01993069645361532, + -0.02160554489511206 + ], + [ + 0, + 0 + ] + ], + "index": "bT2", + "frameId": null, + "roundness": { + "type": 2 + }, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false, + "polygon": false + }, + { + "type": "ellipse", + "version": 7676, + "versionNonce": 2097055341, + "isDeleted": false, + "id": "1l6ZOJbTVDoxqBiYUw4hc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 367.5146467323748, + "y": -31324.20609603591, + "strokeColor": "#1971c2", + "backgroundColor": "#a5d8ff", + "width": 36.625148031698494, + "height": 7.407160647108594, + "seed": 1857695779, + "groupIds": [ + "j7K42yJwSrw2TqILIXFTL", + "nt4o7I-p25e95_zrIsH0G", + "3FQ0aaKLsvSodeW5ObU8M", + "AcZeunAFWkgs4nNtmpeLf" + ], + "index": "bT3", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114000, + "link": null, + "locked": false + }, + { + "id": "DPHwfogZkkoJAkzdamb-j", + "type": "text", + "x": -699.9999998372273, + "y": -31920, + "width": 562.3283086412837, + "height": 118.74362970865101, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bbu", + "roundness": null, + "seed": 222046093, + "version": 390, + "versionNonce": 114792675, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "text": "eHerkenning", + "fontSize": 103.25533018143568, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "eHerkenning", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "sV8Ug5hbPdYcuqqEmg0Ko", + "type": "text", + "x": 1680, + "y": -28129, + "width": 1255.8309326171875, + "height": 1513.5560396801714, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bdp", + "roundness": null, + "seed": 683180387, + "version": 4497, + "versionNonce": 1545509473, + "isDeleted": false, + "boundElements": [], + "updated": 1762272560723, + "link": null, + "locked": false, + "text": "Machtigingen\n----------------\n\n- Een machtiging is de autorisatie die een specifieke gebruiker het recht \n geeft om namens een organisatie in te loggen bij een specifieke dienst.\n - Een machtiging verleent dus toegang tot een dienst, maar regelt NIET\n de rechten binnen die dienst zelf.\n\n- Wettelijk vertegenwoordigers kunnen machtigingen toekennen.\n\n- Ook aangewezen machtigingenbeheerders kunnen machtigingen toekennen.\n\n- Machtigingen worden vastgelegd in het Machtigingenregister.\n - Iedere leverancier beheert zijn eigen Machtigingenregister. (Federatief)\n - Leveranciers bieden de mogelijkheid om machtigingen te beheren via\n een eigen beheermodule.\n\n- Ketenmachtiging is een digitale toestemming die een organisatie geeft aan\n een andere organisatie (intermediair), zodat die namens hen kan inloggen bij\n een dienst. \n - Wordt vastgelegd in het Machtigingenregister.\n - Een intermediair met een eHerkenning ketenmachtiging kan een beheerder\n aanstellen die medewerkers machtigt om namens de machtiginggevende\n organisatie specifieke diensten te gebruiken.\n\n- Vestigingsgebonden machtiging is beperkt tot één specifieke vestiging.\n Deze machtiging kan alleen toegang krijgen tot diensten die expliciet\n vestigingsgebonden machtigingen accepteren.\n\n- Een BSN-gerechtigde dienst ontvangt bij het inloggen van een gebuiker een\n Versleutelde Identiteit (VI). Met specifiek sleutelmateriaal kan de dienst\n de VI ontsleutelen en zo het oorspronkelijke BSN van de gebruiker achterhalen.\n - Een aanvraag om BSN-gemachtigd te zijn kan worden ingediend door organisaties\n die voor hun publieke taken het BSN nodig hebben.\n - De Rijksdienst voor Identiteitsgegevens (RvIG) beoordeelt namens BZK of\n een organisatie daarvoor in aanmerking komt.\n\n- Een dienst zonder BSN-recht ontvangt bij het inloggen van een gebruiker een\n PseudoID (ipv een BSN). Dit is een uniek, niet-herleidbaar pseudoniem dat\n specifiek is voor de combinatie van gebruiker (BSN) en dienstverlener.\n Het PseudoID — ook wel Persistent Pseudoniem genoemd — blijft altijd hetzelfde\n voor dezelfde gebruiker bij dezelfde dienstverlener.\n\n", + "fontSize": 27.519200721457665, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtigingen\n----------------\n\n- Een machtiging is de autorisatie die een specifieke gebruiker het recht \n geeft om namens een organisatie in te loggen bij een specifieke dienst.\n - Een machtiging verleent dus toegang tot een dienst, maar regelt NIET\n de rechten binnen die dienst zelf.\n\n- Wettelijk vertegenwoordigers kunnen machtigingen toekennen.\n\n- Ook aangewezen machtigingenbeheerders kunnen machtigingen toekennen.\n\n- Machtigingen worden vastgelegd in het Machtigingenregister.\n - Iedere leverancier beheert zijn eigen Machtigingenregister. (Federatief)\n - Leveranciers bieden de mogelijkheid om machtigingen te beheren via\n een eigen beheermodule.\n\n- Ketenmachtiging is een digitale toestemming die een organisatie geeft aan\n een andere organisatie (intermediair), zodat die namens hen kan inloggen bij\n een dienst. \n - Wordt vastgelegd in het Machtigingenregister.\n - Een intermediair met een eHerkenning ketenmachtiging kan een beheerder\n aanstellen die medewerkers machtigt om namens de machtiginggevende\n organisatie specifieke diensten te gebruiken.\n\n- Vestigingsgebonden machtiging is beperkt tot één specifieke vestiging.\n Deze machtiging kan alleen toegang krijgen tot diensten die expliciet\n vestigingsgebonden machtigingen accepteren.\n\n- Een BSN-gerechtigde dienst ontvangt bij het inloggen van een gebuiker een\n Versleutelde Identiteit (VI). Met specifiek sleutelmateriaal kan de dienst\n de VI ontsleutelen en zo het oorspronkelijke BSN van de gebruiker achterhalen.\n - Een aanvraag om BSN-gemachtigd te zijn kan worden ingediend door organisaties\n die voor hun publieke taken het BSN nodig hebben.\n - De Rijksdienst voor Identiteitsgegevens (RvIG) beoordeelt namens BZK of\n een organisatie daarvoor in aanmerking komt.\n\n- Een dienst zonder BSN-recht ontvangt bij het inloggen van een gebruiker een\n PseudoID (ipv een BSN). Dit is een uniek, niet-herleidbaar pseudoniem dat\n specifiek is voor de combinatie van gebruiker (BSN) en dienstverlener.\n Het PseudoID — ook wel Persistent Pseudoniem genoemd — blijft altijd hetzelfde\n voor dezelfde gebruiker bij dezelfde dienstverlener.\n\n", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "VUa0rHHH2hTEutBWEMCYN", + "type": "text", + "x": 1680, + "y": -31849.85029197907, + "width": 1149.91748046875, + "height": 1582.3540414838155, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bdu", + "roundness": null, + "seed": 78115917, + "version": 4217, + "versionNonce": 1947769217, + "isDeleted": false, + "boundElements": [], + "updated": 1762246231518, + "link": null, + "locked": false, + "text": "eHerkenning\n----------------\n\n- Federatieve inlogsysteem (SAML 2.0/OIDC) voor bedrijven. \n \"Login with Google/Facebook/Etc.\", maar dan voor de overheid.\n\n- Single Sign-On (SSO) wordt ondersteund, met uitzondering van\n diensten waarvoor het betrouwbaarheidsniveau EH4 vereist is.\n\n- Afspraken en specificaties vastgelegd in Afsprakenstelsel eTD.\n\n- Erkende leveranciers van eHerkenning (de ID Providers).\n - Digidentity\n - KPN\n - QuoVadis\n - Reconi\n - We-ID\n - ZLogin\n\n- Een gebruiker vraagt eHerkeningsmiddel aan bij een leverancier.\n - Een digitale sleutel voor toegang tot aangesloten diensten.\n - Persoonsgebonden.\n - LoA eHerkenningsmiddel:\n - EH2+: 2FA usr/pwd + sms-code of pincode via een token.\n - EH3: 2FA usr/pwd + sms-code of pincode via een token\n of met QR-code.\n - EH4: Via PKI-certificaat\n\n- Een dienstverlener sluit zijn dienst(en) aan via een eHerkenningsmakelaar.\n - Registratie dienst in Dienstencatalogus.\n - Dienstverlener naam\n - Dienst naam\n - Dienstomschrijving\n - Betrouwbaarheidsniveau (LoA)\n - URL\n - Dienst technisch koppelen aan het eHerkenning-netwerk.\n - SSO-ondersteuning?\n - Accepteert de dienst alleen algemeen (kvk-nummergebonden)\n machtigingen, alleen vestigingsgebonden machtigingen, of beide?\n - Erkende eHerkenningsmakelaars:\n - Digidentity\n - KPN\n - OneWelcome\n - Reconi\n - Signicat\n ", + "fontSize": 27.519200721457665, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "eHerkenning\n----------------\n\n- Federatieve inlogsysteem (SAML 2.0/OIDC) voor bedrijven. \n \"Login with Google/Facebook/Etc.\", maar dan voor de overheid.\n\n- Single Sign-On (SSO) wordt ondersteund, met uitzondering van\n diensten waarvoor het betrouwbaarheidsniveau EH4 vereist is.\n\n- Afspraken en specificaties vastgelegd in Afsprakenstelsel eTD.\n\n- Erkende leveranciers van eHerkenning (de ID Providers).\n - Digidentity\n - KPN\n - QuoVadis\n - Reconi\n - We-ID\n - ZLogin\n\n- Een gebruiker vraagt eHerkeningsmiddel aan bij een leverancier.\n - Een digitale sleutel voor toegang tot aangesloten diensten.\n - Persoonsgebonden.\n - LoA eHerkenningsmiddel:\n - EH2+: 2FA usr/pwd + sms-code of pincode via een token.\n - EH3: 2FA usr/pwd + sms-code of pincode via een token\n of met QR-code.\n - EH4: Via PKI-certificaat\n\n- Een dienstverlener sluit zijn dienst(en) aan via een eHerkenningsmakelaar.\n - Registratie dienst in Dienstencatalogus.\n - Dienstverlener naam\n - Dienst naam\n - Dienstomschrijving\n - Betrouwbaarheidsniveau (LoA)\n - URL\n - Dienst technisch koppelen aan het eHerkenning-netwerk.\n - SSO-ondersteuning?\n - Accepteert de dienst alleen algemeen (kvk-nummergebonden)\n machtigingen, alleen vestigingsgebonden machtigingen, of beide?\n - Erkende eHerkenningsmakelaars:\n - Digidentity\n - KPN\n - OneWelcome\n - Reconi\n - Signicat\n ", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "ON56_ROLcfhSmHcDC_K_x", + "type": "rectangle", + "x": 642.8601318669525, + "y": -31484.579204559705, + "width": 246.40573919838207, + "height": 196.41461410517866, + "angle": 0, + "strokeColor": "#228be6", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "Yc92WvwU-EUve7626nf4D" + ], + "frameId": null, + "index": "be3", + "roundness": null, + "seed": 223661891, + "version": 514, + "versionNonce": 897427149, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false + }, + { + "id": "HU3iWXQgQjCgzOc0CA82u", + "type": "text", + "x": 657.8116527197985, + "y": -31329.6394806531, + "width": 217.45660088746126, + "height": 31.647080829676312, + "angle": 0, + "strokeColor": "#228be6", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "Yc92WvwU-EUve7626nf4D" + ], + "frameId": null, + "index": "be4", + "roundness": null, + "seed": 1157580739, + "version": 522, + "versionNonce": 1771574883, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "text": "Dienstencatalogus", + "fontSize": 27.51920072145767, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Dienstencatalogus", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "type": "rectangle", + "version": 1131, + "versionNonce": 744830285, + "isDeleted": false, + "id": "wltsCBJNs2OaeDUzGznsu", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 712.6119077045155, + "y": -31466.58907545726, + "strokeColor": "#228be6", + "backgroundColor": "#868e96", + "width": 62.201432804304126, + "height": 93.30214920645618, + "seed": 913697283, + "groupIds": [ + "2-834BePUgs376h-QqgyR", + "Yc92WvwU-EUve7626nf4D" + ], + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "index": "be5", + "frameId": null, + "roundness": null + }, + { + "type": "line", + "version": 1330, + "versionNonce": 531452419, + "isDeleted": false, + "id": "bp-sVCejX-eFMseXFi-m0", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 728.1622659055915, + "y": -31373.286926250803, + "strokeColor": "#228be6", + "backgroundColor": "#868e96", + "width": 62.20143280430413, + "height": 93.30214920645622, + "seed": 617591203, + "groupIds": [ + "2-834BePUgs376h-QqgyR", + "Yc92WvwU-EUve7626nf4D" + ], + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 15.55035820107603 + ], + [ + 62.20143280430413, + 15.550358201076058 + ], + [ + 62.20143280430413, + -77.75179100538016 + ], + [ + 46.65107460322809, + -77.75179100538017 + ], + [ + 46.6510746032281, + 0 + ], + [ + 0, + 0 + ] + ], + "index": "be6", + "frameId": null, + "roundness": null, + "polygon": false + }, + { + "type": "line", + "version": 1330, + "versionNonce": 2047542189, + "isDeleted": false, + "id": "kd4MpcQXfFmiziL9BTnBO", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 743.7126241066676, + "y": -31357.736568049728, + "strokeColor": "#228be6", + "backgroundColor": "#868e96", + "width": 62.20143280430413, + "height": 93.30214920645622, + "seed": 533693763, + "groupIds": [ + "2-834BePUgs376h-QqgyR", + "Yc92WvwU-EUve7626nf4D" + ], + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 15.55035820107603 + ], + [ + 62.20143280430413, + 15.550358201076058 + ], + [ + 62.20143280430413, + -77.75179100538016 + ], + [ + 46.65107460322809, + -77.75179100538017 + ], + [ + 46.6510746032281, + 0 + ], + [ + 0, + 0 + ] + ], + "index": "be7", + "frameId": null, + "roundness": null, + "polygon": false + }, + { + "type": "line", + "version": 1148, + "versionNonce": 1121589667, + "isDeleted": false, + "id": "_m7aCa8MRiJ0md6FHPdPO", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 728.1622659055915, + "y": -31451.038717256186, + "strokeColor": "#228be6", + "backgroundColor": "#868e96", + "width": 31.100716402152063, + "height": 0, + "seed": 1054074083, + "groupIds": [ + "2-834BePUgs376h-QqgyR", + "Yc92WvwU-EUve7626nf4D" + ], + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 31.100716402152063, + 0 + ] + ], + "index": "be8", + "frameId": null, + "roundness": null, + "polygon": false + }, + { + "type": "line", + "version": 1174, + "versionNonce": 44566029, + "isDeleted": false, + "id": "JfN908CMyySXLvKq-wAD7", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 728.1622659055915, + "y": -31419.938000854036, + "strokeColor": "#228be6", + "backgroundColor": "#868e96", + "width": 31.100716402152063, + "height": 0, + "seed": 694898819, + "groupIds": [ + "2-834BePUgs376h-QqgyR", + "Yc92WvwU-EUve7626nf4D" + ], + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 31.100716402152063, + 0 + ] + ], + "index": "be9", + "frameId": null, + "roundness": null, + "polygon": false + }, + { + "type": "line", + "version": 1158, + "versionNonce": 1615654211, + "isDeleted": false, + "id": "e3QmAnbKOMWM3_XjPRou_", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 728.1622659055915, + "y": -31435.48835905511, + "strokeColor": "#228be6", + "backgroundColor": "#868e96", + "width": 31.100716402152063, + "height": 0, + "seed": 290736163, + "groupIds": [ + "2-834BePUgs376h-QqgyR", + "Yc92WvwU-EUve7626nf4D" + ], + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 31.100716402152063, + 0 + ] + ], + "index": "beA", + "frameId": null, + "roundness": null, + "polygon": false + }, + { + "type": "line", + "version": 1184, + "versionNonce": 1228258413, + "isDeleted": false, + "id": "o3ssRcy-BpyqP-dHhHyl9", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 728.1622659055915, + "y": -31404.387642652957, + "strokeColor": "#228be6", + "backgroundColor": "#868e96", + "width": 31.100716402152063, + "height": 0, + "seed": 1820150723, + "groupIds": [ + "2-834BePUgs376h-QqgyR", + "Yc92WvwU-EUve7626nf4D" + ], + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 31.100716402152063, + 0 + ] + ], + "index": "beB", + "frameId": null, + "roundness": null, + "polygon": false + }, + { + "type": "line", + "version": 1239, + "versionNonce": 1533299939, + "isDeleted": false, + "id": "wGSoUi9A6UfOyeq0a-q5v", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 728.1622659055915, + "y": -31388.837284451878, + "strokeColor": "#228be6", + "backgroundColor": "#868e96", + "width": 15.550358201076032, + "height": 0, + "seed": 1862589283, + "groupIds": [ + "2-834BePUgs376h-QqgyR", + "Yc92WvwU-EUve7626nf4D" + ], + "boundElements": [], + "updated": 1751031114001, + "link": null, + "locked": false, + "startBinding": null, + "endBinding": null, + "lastCommittedPoint": null, + "startArrowhead": null, + "endArrowhead": null, + "points": [ + [ + 0, + 0 + ], + [ + 15.550358201076032, + 0 + ] + ], + "index": "beC", + "frameId": null, + "roundness": null, + "polygon": false + }, + { + "id": "lGArtdDfWh2cSeKIHojrx", + "type": "rectangle", + "x": -640, + "y": -24700, + "width": 1083.4163914174037, + "height": 299.9999999999996, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "pjqPGqJUDdhapuFIxx5Nx" + ], + "frameId": null, + "index": "beLG", + "roundness": { + "type": 3 + }, + "seed": 1989182733, + "version": 1005, + "versionNonce": 2099599343, + "isDeleted": false, + "boundElements": [], + "updated": 1762261485198, + "link": null, + "locked": false + }, + { + "id": "rcqPBa4rAw2wDvYwqEdVa", + "type": "rectangle", + "x": -580, + "y": -24740, + "width": 435.5307805125512, + "height": 80, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "31_fMEiYc3nRdl51ZjjN1", + "pjqPGqJUDdhapuFIxx5Nx" + ], + "frameId": null, + "index": "beLV", + "roundness": { + "type": 3 + }, + "seed": 2134335043, + "version": 589, + "versionNonce": 632455695, + "isDeleted": false, + "boundElements": [], + "updated": 1762261485198, + "link": null, + "locked": false + }, + { + "id": "7fJAPIDxdsp2pIOD7EBs1", + "type": "text", + "x": -560, + "y": -24720, + "width": 389.17999267578125, + "height": 44.22728687377125, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "31_fMEiYc3nRdl51ZjjN1", + "pjqPGqJUDdhapuFIxx5Nx" + ], + "frameId": null, + "index": "beM", + "roundness": { + "type": 2 + }, + "seed": 926557389, + "version": 900, + "versionNonce": 861235247, + "isDeleted": false, + "boundElements": [], + "updated": 1762261485198, + "link": null, + "locked": false, + "text": "Algemene autorisatie", + "fontSize": 35.381829499017, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Algemene autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "mCmmcSHcmOWCfNDkt4xGS", + "type": "text", + "x": -621.7132547576703, + "y": -24625.94802718876, + "width": 1028.87353515625, + "height": 171.99500450911043, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "pjqPGqJUDdhapuFIxx5Nx" + ], + "frameId": null, + "index": "beN", + "roundness": { + "type": 2 + }, + "seed": 1207825891, + "version": 1574, + "versionNonce": 1945537103, + "isDeleted": false, + "boundElements": [], + "updated": 1762261485198, + "link": null, + "locked": false, + "text": "- Gebruiker logt in met reguliere eHerkenning machtiging, eventueel\n via een ketenmachtiging.\n\n- Gebruiker ziet notificaties met een KVK-nummer dat overeenkomt met\n dat van de vertegenwoordigde dienstafnemer.", + "fontSize": 27.51920072145767, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "- Gebruiker logt in met reguliere eHerkenning machtiging, eventueel\n via een ketenmachtiging.\n\n- Gebruiker ziet notificaties met een KVK-nummer dat overeenkomt met\n dat van de vertegenwoordigde dienstafnemer.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "2arorfRdHYR_TRrcRfzjA", + "type": "text", + "x": -690.4480959728558, + "y": -25110.43897826205, + "width": 1538.1151123046875, + "height": 118.74362970865103, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "beW", + "roundness": null, + "seed": 388703043, + "version": 803, + "versionNonce": 14440847, + "isDeleted": false, + "boundElements": [], + "updated": 1762251483358, + "link": null, + "locked": false, + "text": "MOZa autorisatie via eHerkenning", + "fontSize": 103.25533018143568, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "MOZa autorisatie via eHerkenning", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "PAy9tsNfULwvhPQqsq66V", + "type": "text", + "x": -621.1531612227852, + "y": -24913.62463905725, + "width": 1451.7321058106645, + "height": 103.19700270546623, + "angle": 0, + "strokeColor": "#228be6", + "backgroundColor": "#ffffff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "yBkp3rvqcr87yWd8sHl9r" + ], + "frameId": null, + "index": "beZ", + "roundness": null, + "seed": 1841519459, + "version": 2612, + "versionNonce": 2002780303, + "isDeleted": false, + "boundElements": [], + "updated": 1762261002400, + "link": null, + "locked": false, + "text": "- De gebruikersgegevens via eHerkenning bieden beperkte autorisatiemogelijkheden voor MOZa.\n\n- Twee af te leiden autorisatievormen: algemeen en vestigingsgebonden.", + "fontSize": 27.519200721457665, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "- De gebruikersgegevens via eHerkenning bieden beperkte autorisatiemogelijkheden voor MOZa.\n\n- Twee af te leiden autorisatievormen: algemeen en vestigingsgebonden.", + "autoResize": false, + "lineHeight": 1.25 + }, + { + "id": "64PVZQ-y2df3aEWcH6PJU", + "type": "rectangle", + "x": -339.99999999999955, + "y": -29660, + "width": 182.01759766038205, + "height": 158.92029120482397, + "angle": 0, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "frameId": null, + "index": "bj5", + "roundness": { + "type": 3 + }, + "seed": 2012681827, + "version": 1707, + "versionNonce": 545091309, + "isDeleted": false, + "boundElements": [ + { + "id": "62h3q2H1TdZ82PLmbL3B7", + "type": "arrow" + }, + { + "id": "Yewwjmm-QsQMr3u58TEUv", + "type": "arrow" + }, + { + "id": "QOCOmZsoaGmzDWZLzfzLv", + "type": "arrow" + }, + { + "id": "DSHAdWP2SjiLrwrwx_zWT", + "type": "arrow" + }, + { + "id": "FUv1pzBpzhymLrfWXCQ5D", + "type": "arrow" + }, + { + "id": "dcD6UOyhBM-Qz1H7VnTHP", + "type": "arrow" + } + ], + "updated": 1751031114004, + "link": null, + "locked": false + }, + { + "type": "ellipse", + "version": 1686, + "versionNonce": 1457011331, + "isDeleted": false, + "id": "YeAuzX1KnyHdAJNjBdtvz", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -286.99999999999955, + "y": -29620, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 75.67780198400858, + "height": 73.71214478961875, + "seed": 91822499, + "groupIds": [ + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bj7", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1626, + "versionNonce": 1304486701, + "isDeleted": false, + "id": "W0h45Fq5leLt9V9RHEwdm", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -273.24039963927044, + "y": -29612.137371222438, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1997270339, + "groupIds": [ + "6Qzdi5uR72Nct8akkEJfd", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bj8", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1598, + "versionNonce": 362017315, + "isDeleted": false, + "id": "tSoilguSwzsXheajpzUhs", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -268.3262566532958, + "y": -29607.223228236464, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1111706851, + "groupIds": [ + "6Qzdi5uR72Nct8akkEJfd", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bj9", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1600, + "versionNonce": 863368589, + "isDeleted": false, + "id": "360W_4g3U6VfMJrK1bgRT", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -268.81767095189343, + "y": -29598.869185160314, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1521334403, + "groupIds": [ + "6Qzdi5uR72Nct8akkEJfd", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjA", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1609, + "versionNonce": 1597486531, + "isDeleted": false, + "id": "01Z3Aa4cPDB6DP1gBi3II", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -268.81767095189343, + "y": -29589.040899188367, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1040822307, + "groupIds": [ + "6Qzdi5uR72Nct8akkEJfd", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjB", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1678, + "versionNonce": 429505517, + "isDeleted": false, + "id": "aeLu9-LUio0wGG8fC0UmZ", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -263.9035279659188, + "y": -29601.3262566533, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 776319939, + "groupIds": [ + "jZAkTWeh-dHFJ2oxTxFcE", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjC", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1652, + "versionNonce": 853673315, + "isDeleted": false, + "id": "PdJphWJEKqC_-CiEtBCt5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -258.98938497994413, + "y": -29596.412113667328, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 729826147, + "groupIds": [ + "jZAkTWeh-dHFJ2oxTxFcE", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjD", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1654, + "versionNonce": 1748350541, + "isDeleted": false, + "id": "ZiKJxPMngTbI4mql6X1mQ", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -259.4807992785418, + "y": -29588.058070591163, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 772267779, + "groupIds": [ + "jZAkTWeh-dHFJ2oxTxFcE", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjE", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1663, + "versionNonce": 669081859, + "isDeleted": false, + "id": "p4tk-HySGwHB3buoXP7hO", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -259.4807992785418, + "y": -29578.229784619216, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 542836387, + "groupIds": [ + "jZAkTWeh-dHFJ2oxTxFcE", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjF", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1666, + "versionNonce": 1243833517, + "isDeleted": false, + "id": "V0I3OzCXHCxlS2ZOY951G", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -253.09241339677465, + "y": -29594.446456472935, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 422066755, + "groupIds": [ + "YCs7Da5Jh-07fsmXxOpUV", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1636, + "versionNonce": 1739868323, + "isDeleted": false, + "id": "FYm-YpfUA1EhmixnVuEPE", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -248.1782704108, + "y": -29589.53231348696, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1431173603, + "groupIds": [ + "YCs7Da5Jh-07fsmXxOpUV", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjH", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1638, + "versionNonce": 1393313549, + "isDeleted": false, + "id": "TW0V7iNZJjvtt0z7bxfPA", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -248.66968470939764, + "y": -29581.178270410797, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1910162819, + "groupIds": [ + "YCs7Da5Jh-07fsmXxOpUV", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjI", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1647, + "versionNonce": 1745435715, + "isDeleted": false, + "id": "PvQ_OXlkJuHq_G57nBFQD", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -248.66968470939764, + "y": -29571.34998443885, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1712135459, + "groupIds": [ + "YCs7Da5Jh-07fsmXxOpUV", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjJ", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1681, + "versionNonce": 1701436781, + "isDeleted": false, + "id": "-u8cqu8JkVAXJzpBB5JLc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -245.22978461921548, + "y": -29585.600999098177, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1028882627, + "groupIds": [ + "-duKUz1cIMdgOZ40nEhGM", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjK", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1654, + "versionNonce": 1690221539, + "isDeleted": false, + "id": "nhnSnbjcQeqlWU0stSJKK", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -240.31564163324083, + "y": -29580.686856112203, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 290222179, + "groupIds": [ + "-duKUz1cIMdgOZ40nEhGM", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjL", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1655, + "versionNonce": 1485154253, + "isDeleted": false, + "id": "iEboe3tNp9WoMo7vvMSi9", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -240.80705593183848, + "y": -29572.332813036053, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1137077251, + "groupIds": [ + "-duKUz1cIMdgOZ40nEhGM", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjM", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1667, + "versionNonce": 434325379, + "isDeleted": false, + "id": "GK0UFm7fRypjz9ur4RZxi", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -240.80705593183848, + "y": -29562.5045270641, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 2025845667, + "groupIds": [ + "-duKUz1cIMdgOZ40nEhGM", + "1SvZwpUgnOCTqwL50KVT2", + "w50kvQ9dPkIjENpERmhWQ", + "TTQbD9INZ-yfQqaB3w808", + "L5VZixsflKMbJLLxUnQc3" + ], + "index": "bjN", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "iWGjdG5lnOZhAaY8nE77o", + "type": "rectangle", + "x": -220.50703582762617, + "y": -29514.510351824036, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iiJAZFwZv8AbtWiTEJvLt", + "g_gTvSvZtwWokix8E8BQy", + "vxhJ2NAbRVD-hTVr84lgr", + "L5VZixsflKMbJLLxUnQc3" + ], + "frameId": null, + "index": "bjO", + "roundness": { + "type": 3 + }, + "seed": 1348962115, + "version": 1011, + "versionNonce": 1584997933, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "8Gkb-RrW0xKieH30Lsf_2", + "type": "rectangle", + "x": -179.037301268806, + "y": -29514.510352122343, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iiJAZFwZv8AbtWiTEJvLt", + "g_gTvSvZtwWokix8E8BQy", + "vxhJ2NAbRVD-hTVr84lgr", + "L5VZixsflKMbJLLxUnQc3" + ], + "frameId": null, + "index": "bjP", + "roundness": null, + "seed": 1629202147, + "version": 1103, + "versionNonce": 1035296547, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "iNYr8ptj7H0sC3ikcZ3mf", + "type": "text", + "x": -200.91233949237676, + "y": -29514.57066760509, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iiJAZFwZv8AbtWiTEJvLt", + "g_gTvSvZtwWokix8E8BQy", + "vxhJ2NAbRVD-hTVr84lgr", + "L5VZixsflKMbJLLxUnQc3" + ], + "frameId": null, + "index": "bjQ", + "roundness": null, + "seed": 1902826115, + "version": 836, + "versionNonce": 707647629, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "3CLf7KwB4hw_uNedNEsT3", + "type": "text", + "x": -212.1157806777328, + "y": -29514.570667737506, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iiJAZFwZv8AbtWiTEJvLt", + "g_gTvSvZtwWokix8E8BQy", + "vxhJ2NAbRVD-hTVr84lgr", + "L5VZixsflKMbJLLxUnQc3" + ], + "frameId": null, + "index": "bjR", + "roundness": null, + "seed": 1913883171, + "version": 858, + "versionNonce": 983794371, + "isDeleted": false, + "boundElements": [ + { + "id": "62h3q2H1TdZ82PLmbL3B7", + "type": "arrow" + } + ], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "EezGwqvGylHEYCEpntzNf", + "type": "rectangle", + "x": -180.73838829313263, + "y": -29515.59400663401, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iiJAZFwZv8AbtWiTEJvLt", + "g_gTvSvZtwWokix8E8BQy", + "vxhJ2NAbRVD-hTVr84lgr", + "L5VZixsflKMbJLLxUnQc3" + ], + "frameId": null, + "index": "bjS", + "roundness": null, + "seed": 939806147, + "version": 1152, + "versionNonce": 1432174317, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "xa4rnwT_VbHPpejk5m_0h", + "type": "rectangle", + "x": -146.02950599503947, + "y": -29514.323080729315, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iiJAZFwZv8AbtWiTEJvLt", + "g_gTvSvZtwWokix8E8BQy", + "vxhJ2NAbRVD-hTVr84lgr", + "L5VZixsflKMbJLLxUnQc3" + ], + "frameId": null, + "index": "bjT", + "roundness": null, + "seed": 1985715555, + "version": 1069, + "versionNonce": 692859491, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "PyjcDiv6poLHWAGDwc_2h", + "type": "text", + "x": -173.22233228854247, + "y": -29515.780121744043, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "BuZYWdHqCpXIwYfV3DeTq", + "g_gTvSvZtwWokix8E8BQy", + "vxhJ2NAbRVD-hTVr84lgr", + "L5VZixsflKMbJLLxUnQc3" + ], + "frameId": null, + "index": "bjU", + "roundness": null, + "seed": 2020079875, + "version": 1051, + "versionNonce": 110156109, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "EzVzRhnEEexv5bdXTLJSO", + "type": "rectangle", + "x": 373.00000000000045, + "y": -29660, + "width": 182.01759766038205, + "height": 158.92029120482397, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "frameId": null, + "index": "bjU4", + "roundness": { + "type": 3 + }, + "seed": 1034512781, + "version": 1699, + "versionNonce": 887012867, + "isDeleted": false, + "boundElements": [ + { + "id": "Yewwjmm-QsQMr3u58TEUv", + "type": "arrow" + }, + { + "id": "5l5jDt_z-U3-44bLZ8jJJ", + "type": "arrow" + }, + { + "id": "LqRsDI8WRF03IYiZHy31j", + "type": "arrow" + }, + { + "id": "OsoysEpb_WO840idPv-92", + "type": "arrow" + }, + { + "id": "dcD6UOyhBM-Qz1H7VnTHP", + "type": "arrow" + }, + { + "id": "62h3q2H1TdZ82PLmbL3B7", + "type": "arrow" + }, + { + "id": "DSHAdWP2SjiLrwrwx_zWT", + "type": "arrow" + }, + { + "id": "FUv1pzBpzhymLrfWXCQ5D", + "type": "arrow" + }, + { + "id": "4xmlYocPLH_MusCQLGUoe", + "type": "arrow" + }, + { + "id": "N7HYjBNHx4q6nmMHDk6O1", + "type": "arrow" + } + ], + "updated": 1751031114004, + "link": null, + "locked": false + }, + { + "type": "ellipse", + "version": 1693, + "versionNonce": 1461856173, + "isDeleted": false, + "id": "YCLQ1yAeCh0u71lpFJpxR", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 426.00000000000045, + "y": -29620, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 75.67780198400858, + "height": 73.71214478961875, + "seed": 1797007949, + "groupIds": [ + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjUG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1631, + "versionNonce": 1094137251, + "isDeleted": false, + "id": "4QBw2YoS-DIiJX3qBfyCB", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 439.75960036072956, + "y": -29612.137371222438, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 270227629, + "groupIds": [ + "I478faxFEtTtMA3yzi9DZ", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjUO", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1602, + "versionNonce": 2033887757, + "isDeleted": false, + "id": "cxo2Ceq8LMmolzlhOfuzL", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 444.67374334670427, + "y": -29607.223228236464, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 2112207629, + "groupIds": [ + "I478faxFEtTtMA3yzi9DZ", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjUV", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1604, + "versionNonce": 1285982531, + "isDeleted": false, + "id": "S0EZV9ZC7uy64DuV4VGs1", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 444.1823290481071, + "y": -29598.869185160307, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1559548269, + "groupIds": [ + "I478faxFEtTtMA3yzi9DZ", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjUZ", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1613, + "versionNonce": 500424813, + "isDeleted": false, + "id": "EzpRfQwYtfFIg_mIRCrPd", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 444.1823290481071, + "y": -29589.04089918836, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 177347533, + "groupIds": [ + "I478faxFEtTtMA3yzi9DZ", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjUd", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1682, + "versionNonce": 1110075619, + "isDeleted": false, + "id": "RQqUTHTPasWfQUP1zyL23", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 449.0964720340817, + "y": -29601.326256653294, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 2128026157, + "groupIds": [ + "wi3_tAkLZYVzhiZiWsVgt", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjUl", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1656, + "versionNonce": 448219853, + "isDeleted": false, + "id": "YY3tG6sAutD-3oYfRcnTp", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 454.0106150200559, + "y": -29596.41211366732, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1923959949, + "groupIds": [ + "wi3_tAkLZYVzhiZiWsVgt", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjUt", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1658, + "versionNonce": 122770563, + "isDeleted": false, + "id": "C6DoDhJhcA9RhN43e0Z7X", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 453.51920072145873, + "y": -29588.058070591163, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1171141357, + "groupIds": [ + "wi3_tAkLZYVzhiZiWsVgt", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjV", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1667, + "versionNonce": 1350461741, + "isDeleted": false, + "id": "8X43BvmBoRcUWxcy4hEkG", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 453.51920072145873, + "y": -29578.229784619216, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 616779085, + "groupIds": [ + "wi3_tAkLZYVzhiZiWsVgt", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjV8", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1666, + "versionNonce": 1272564771, + "isDeleted": false, + "id": "fvs4JeU-u38PERkNepty6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 459.9075866032254, + "y": -29594.446456472935, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1860574125, + "groupIds": [ + "5sb3EsSe-7ns0QFEeOhbQ", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjVG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1640, + "versionNonce": 1351793549, + "isDeleted": false, + "id": "At65z_Q5bKAm0WRQgA7ee", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 464.82172958920006, + "y": -29589.53231348696, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1549803021, + "groupIds": [ + "5sb3EsSe-7ns0QFEeOhbQ", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjVV", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1642, + "versionNonce": 1135759299, + "isDeleted": false, + "id": "aAbBtq5hb6QyNNb5089Wb", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 464.33031529060287, + "y": -29581.178270410797, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1680528493, + "groupIds": [ + "5sb3EsSe-7ns0QFEeOhbQ", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjVl", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1651, + "versionNonce": 1127072237, + "isDeleted": false, + "id": "mrw-c8NOaD9GEcUO1vrAd", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 464.33031529060287, + "y": -29571.34998443885, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1645199053, + "groupIds": [ + "5sb3EsSe-7ns0QFEeOhbQ", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjW", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1683, + "versionNonce": 553213795, + "isDeleted": false, + "id": "5xZBNVTRhO_wS7qpgWM1D", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 467.77021538078503, + "y": -29585.600999098177, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 2091408685, + "groupIds": [ + "c-ko8aI4BFfTEUqifrrw8", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjWG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1658, + "versionNonce": 223935565, + "isDeleted": false, + "id": "T5rY8-D6qTR4CgO2aw6NQ", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 472.6843583667597, + "y": -29580.686856112203, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1264463757, + "groupIds": [ + "c-ko8aI4BFfTEUqifrrw8", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjWV", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1659, + "versionNonce": 1308457731, + "isDeleted": false, + "id": "xuzzb_IYGMp9BhkJl1Muz", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 472.19294406816203, + "y": -29572.332813036046, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1013626349, + "groupIds": [ + "c-ko8aI4BFfTEUqifrrw8", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjX", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1668, + "versionNonce": 921561773, + "isDeleted": false, + "id": "FWgYAPmeNtFpLiflERhtJ", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 472.19294406816203, + "y": -29562.50452706409, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 987197517, + "groupIds": [ + "c-ko8aI4BFfTEUqifrrw8", + "5DueEnzqlxPlguwRybvAP", + "po8ApKN6C4j8GCHtGDXFq", + "5YFOrwqGiWNDq2fhbIwgn", + "HWRMK9Q45bjXhqhnzzYXm" + ], + "index": "bjY", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "FUv1pzBpzhymLrfWXCQ5D", + "type": "arrow", + "x": -150.48358107117002, + "y": -29600.332096632377, + "width": 518.0292101869624, + "height": 0.33485129784821765, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fcc2d7", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkc", + "roundness": { + "type": 2 + }, + "seed": 1449851107, + "version": 1053, + "versionNonce": 758103341, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "JuVC-h5WkkmSgYTbQEy32" + } + ], + "updated": 1751031114070, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 518.0292101869624, + 0.33485129784821765 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "64PVZQ-y2df3aEWcH6PJU", + "focus": -0.24970037000999137, + "gap": 10.017145835123614 + }, + "endBinding": { + "elementId": "EzVzRhnEEexv5bdXTLJSO", + "focus": 0.24390452846232313, + "gap": 7.274584773994491 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "JuVC-h5WkkmSgYTbQEy32", + "type": "text", + "x": 2.8401776273576047, + "y": -29612.664445355957, + "width": 212.07980346679688, + "height": 25, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkcV", + "roundness": null, + "seed": 359656195, + "version": 68, + "versionNonce": 1170611309, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114015, + "link": null, + "locked": false, + "text": "Leverancier selecteren", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "FUv1pzBpzhymLrfWXCQ5D", + "originalText": "Leverancier selecteren", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Yewwjmm-QsQMr3u58TEUv", + "type": "arrow", + "x": 360, + "y": -29560, + "width": 520, + "height": 0, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fcc2d7", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkd", + "roundness": { + "type": 2 + }, + "seed": 80595235, + "version": 1058, + "versionNonce": 1444130723, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "ezUzkAA4Zsc72sXZHJnS5" + } + ], + "updated": 1751031325265, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -520, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "EzVzRhnEEexv5bdXTLJSO", + "focus": -0.2584925341108807, + "gap": 13.000000000000455 + }, + "endBinding": { + "elementId": "64PVZQ-y2df3aEWcH6PJU", + "focus": 0.25849253411087114, + "gap": 2.0175976603825063 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "ezUzkAA4Zsc72sXZHJnS5", + "type": "text", + "x": 0.09739525488379286, + "y": -29572.499220356825, + "width": 211.1998291015625, + "height": 25, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkdV", + "roundness": null, + "seed": 1121579971, + "version": 84, + "versionNonce": 16910029, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114015, + "link": null, + "locked": false, + "text": "Autorisatie bevestigd", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "Yewwjmm-QsQMr3u58TEUv", + "originalText": "Autorisatie bevestigd", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "4xmlYocPLH_MusCQLGUoe", + "type": "arrow", + "x": 580, + "y": -29640, + "width": 476.212514822892, + "height": 59.921026018193515, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fcc2d7", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bke", + "roundness": { + "type": 2 + }, + "seed": 1738936355, + "version": 1602, + "versionNonce": 2065063523, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "2LT8CL7DA8fBY-i9AQWNY" + } + ], + "updated": 1751031822019, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 190.85412269636208, + -52.516290351624775 + ], + [ + 476.212514822892, + -59.921026018193515 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "EzVzRhnEEexv5bdXTLJSO", + "focus": -0.2635675417659752, + "gap": 25.86790219448174 + }, + "endBinding": { + "elementId": "AW1xqJdBCNEYZ_OYXCg3q", + "focus": 0.2738431650079038, + "gap": 4.557128009862026 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "2LT8CL7DA8fBY-i9AQWNY", + "type": "text", + "x": 704.674175796948, + "y": -29705.016290351625, + "width": 132.35989379882812, + "height": 25, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkeV", + "roundness": null, + "seed": 183260035, + "version": 96, + "versionNonce": 370255149, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114015, + "link": null, + "locked": false, + "text": "Authenticatie", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "4xmlYocPLH_MusCQLGUoe", + "originalText": "Authenticatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "5l5jDt_z-U3-44bLZ8jJJ", + "type": "arrow", + "x": 1043.6565222737477, + "y": -29680, + "width": 483.65652227374767, + "height": 61.09695668212589, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fcc2d7", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkh", + "roundness": { + "type": 2 + }, + "seed": 1463996067, + "version": 1284, + "versionNonce": 1587608771, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "NPvvOTKTKBpsD_l7Ec_l7" + } + ], + "updated": 1751031847574, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -203.65652227374767, + 60 + ], + [ + -483.65652227374767, + 61.09695668212589 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": { + "elementId": "EzVzRhnEEexv5bdXTLJSO", + "focus": -0.5291081692628878, + "gap": 4.982402339617465 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "NPvvOTKTKBpsD_l7Ec_l7", + "type": "text", + "x": 723.2800903320317, + "y": -29632.5, + "width": 233.4398193359375, + "height": 25, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkhV", + "roundness": null, + "seed": 53518115, + "version": 75, + "versionNonce": 2019456909, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114015, + "link": null, + "locked": false, + "text": "Authenticatie bevestigd", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "5l5jDt_z-U3-44bLZ8jJJ", + "originalText": "Authenticatie bevestigd", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "LqRsDI8WRF03IYiZHy31j", + "type": "arrow", + "x": 568.854106192287, + "y": -29561.013263073437, + "width": 480.11725322891084, + "height": 83.25610292872443, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fcc2d7", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bki", + "roundness": { + "type": 2 + }, + "seed": 1263583011, + "version": 1349, + "versionNonce": 804446477, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "LaDK85U_eRKbg6PEUhDHm" + } + ], + "updated": 1751031114078, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 231.1458938077135, + 21.013263073436974 + ], + [ + 480.11725322891084, + 83.25610292872443 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": { + "elementId": "srnsrgsNlqdR3RafOvO-B", + "focus": -0.14394053887468677, + "gap": 13.404804880332676 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "LaDK85U_eRKbg6PEUhDHm", + "type": "text", + "x": 744.9400482177739, + "y": -29552.5, + "width": 110.11990356445312, + "height": 25, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkiV", + "roundness": null, + "seed": 1215107683, + "version": 52, + "versionNonce": 1914830317, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114015, + "link": null, + "locked": false, + "text": "Autorisatie", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "LqRsDI8WRF03IYiZHy31j", + "originalText": "Autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "OsoysEpb_WO840idPv-92", + "type": "arrow", + "x": 1048.971359421198, + "y": -29467.31104476118, + "width": 475.38850536594714, + "height": 82.56685837790428, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fcc2d7", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkl", + "roundness": { + "type": 2 + }, + "seed": 998931683, + "version": 1453, + "versionNonce": 1584215917, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "iuSaFnukl7Oq3NNLnRBIt" + } + ], + "updated": 1751031114078, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -268.9713594211977, + 7.311044761179801 + ], + [ + -475.38850536594714, + -75.25581361672448 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "srnsrgsNlqdR3RafOvO-B", + "focus": 0.12519936874081533, + "gap": 13.404804880332449 + }, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "iuSaFnukl7Oq3NNLnRBIt", + "type": "text", + "x": 674.4000854492191, + "y": -29472.5, + "width": 211.1998291015625, + "height": 25, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bklV", + "roundness": null, + "seed": 422264653, + "version": 123, + "versionNonce": 1248180301, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114015, + "link": null, + "locked": false, + "text": "Autorisatie bevestigd", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "OsoysEpb_WO840idPv-92", + "originalText": "Autorisatie bevestigd", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "dcD6UOyhBM-Qz1H7VnTHP", + "type": "arrow", + "x": -236.17537167209167, + "y": -29668.869116408583, + "width": 656.1753716720916, + "height": 91.13088359141693, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bks", + "roundness": { + "type": 2 + }, + "seed": 713329411, + "version": 1050, + "versionNonce": 60071853, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "2MzlqydfR9-x0cJUGCIEG" + } + ], + "updated": 1751031354458, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 296.1753716720921, + -91.13088359141693 + ], + [ + 656.1753716720916, + -11.130883591416932 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "64PVZQ-y2df3aEWcH6PJU", + "focus": -0.7852567427096285, + "gap": 13.346065423109394 + }, + "endBinding": { + "elementId": "EzVzRhnEEexv5bdXTLJSO", + "focus": 0.8996440936944148, + "gap": 20 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "2MzlqydfR9-x0cJUGCIEG", + "type": "text", + "x": 22.360031127930142, + "y": -29772.5, + "width": 75.27993774414062, + "height": 25, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bksV", + "roundness": null, + "seed": 1673133507, + "version": 40, + "versionNonce": 721626797, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114015, + "link": null, + "locked": false, + "text": "redirect", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "dcD6UOyhBM-Qz1H7VnTHP", + "originalText": "redirect", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "N7HYjBNHx4q6nmMHDk6O1", + "type": "arrow", + "x": 480, + "y": -29680, + "width": 565.9040062020172, + "height": 80, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkt", + "roundness": { + "type": 2 + }, + "seed": 92349357, + "version": 1434, + "versionNonce": 1869111981, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "j92AP29R-v4wbmdHn8T7M" + } + ], + "updated": 1751031357331, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 260.00000000000045, + -80 + ], + [ + 565.9040062020172, + -51.63587477383044 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "EzVzRhnEEexv5bdXTLJSO", + "focus": -0.8797437759174198, + "gap": 20 + }, + "endBinding": { + "elementId": "AW1xqJdBCNEYZ_OYXCg3q", + "focus": 0.42532685172543766, + "gap": 17.201347667389037 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "j92AP29R-v4wbmdHn8T7M", + "type": "text", + "x": 702.3600311279301, + "y": -29772.5, + "width": 75.27993774414062, + "height": 25, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bktV", + "roundness": null, + "seed": 79856333, + "version": 39, + "versionNonce": 1185138957, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114016, + "link": null, + "locked": false, + "text": "redirect", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "N7HYjBNHx4q6nmMHDk6O1", + "originalText": "redirect", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "gioNpA3UMZFOjXWJfDh8x", + "type": "arrow", + "x": 1043.6565222737477, + "y": -29664.875363031657, + "width": 46.595195119668006, + "height": 173.66895652455423, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bku", + "roundness": { + "type": 2 + }, + "seed": 1525291661, + "version": 1216, + "versionNonce": 1360462659, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "VSVorIfXmtPuE5W6uQbXH" + } + ], + "updated": 1751031854200, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -43.65652227374767, + 84.87536303165689 + ], + [ + 2.938672845920337, + 173.66895652455423 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": { + "elementId": "srnsrgsNlqdR3RafOvO-B", + "focus": -0.6168952313515191, + "gap": 16.343477726252786 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "VSVorIfXmtPuE5W6uQbXH", + "type": "text", + "x": 942.3600311279301, + "y": -29592.5, + "width": 75.27993774414062, + "height": 25, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkuV", + "roundness": null, + "seed": 1857378211, + "version": 48, + "versionNonce": 1052843885, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114016, + "link": null, + "locked": false, + "text": "redirect", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "gioNpA3UMZFOjXWJfDh8x", + "originalText": "redirect", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "62h3q2H1TdZ82PLmbL3B7", + "type": "arrow", + "x": 1043.6565222737477, + "y": -29441.452371762138, + "width": 563.6565222737477, + "height": 80, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bkx", + "roundness": { + "type": 2 + }, + "seed": 657251651, + "version": 1416, + "versionNonce": 612497677, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "HHvvmtwf3BtaHOV33bb_9" + } + ], + "updated": 1751031340651, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -303.6565222737473, + 41.45237176213777 + ], + [ + -563.6565222737477, + -38.54762823786223 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": { + "elementId": "EzVzRhnEEexv5bdXTLJSO", + "focus": 0.889791050540123, + "gap": 21.079708795175975 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false, + "fixedSegments": null, + "startIsSpecial": null, + "endIsSpecial": null + }, + { + "id": "HHvvmtwf3BtaHOV33bb_9", + "type": "text", + "x": 702.36003112793, + "y": -29412.5, + "width": 75.27993774414062, + "height": 25, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bky", + "roundness": null, + "seed": 1607218925, + "version": 53, + "versionNonce": 1235528141, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114016, + "link": null, + "locked": false, + "text": "redirect", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "62h3q2H1TdZ82PLmbL3B7", + "originalText": "redirect", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "KK1ZPO28RXv5pqSN9c920", + "type": "ellipse", + "x": 900.0000000000005, + "y": -29720, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "IEM_abi09WaKLGBZvIkkZ" + ], + "frameId": null, + "index": "blHV", + "roundness": { + "type": 2 + }, + "seed": 1936097795, + "version": 272, + "versionNonce": 732271875, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "zevdPs5ThjDaGnoNQPcdD", + "type": "text", + "x": 915.0000000000005, + "y": -29712, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "IEM_abi09WaKLGBZvIkkZ" + ], + "frameId": null, + "index": "blI", + "roundness": null, + "seed": 176361197, + "version": 267, + "versionNonce": 2062315693, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "3", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "MHEl31rkydRC9LK25p-Ml", + "type": "ellipse", + "x": 620, + "y": -29631, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "mOlFwVmfAJshu4tI6v_Cd" + ], + "frameId": null, + "index": "blK", + "roundness": { + "type": 2 + }, + "seed": 529130573, + "version": 290, + "versionNonce": 451381549, + "isDeleted": false, + "boundElements": [], + "updated": 1751031838061, + "link": null, + "locked": false + }, + { + "id": "J9rzNryv-MCCrnLY1N7hS", + "type": "text", + "x": 635, + "y": -29623, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "mOlFwVmfAJshu4tI6v_Cd" + ], + "frameId": null, + "index": "blL", + "roundness": null, + "seed": 583127725, + "version": 286, + "versionNonce": 269659171, + "isDeleted": false, + "boundElements": [], + "updated": 1751031838061, + "link": null, + "locked": false, + "text": "4", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "4", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "xFj527UEjVJJLhDJRntvF", + "type": "ellipse", + "x": 260.00000000000045, + "y": -29620, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "i1ISEdUVGMYnsc8wFxMyg" + ], + "frameId": null, + "index": "blM", + "roundness": { + "type": 2 + }, + "seed": 2070384845, + "version": 330, + "versionNonce": 1196453955, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "YlZhTIwIProPc0t4WH8Kk", + "type": "text", + "x": 275.00000000000045, + "y": -29612, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "i1ISEdUVGMYnsc8wFxMyg" + ], + "frameId": null, + "index": "blN", + "roundness": null, + "seed": 2134241069, + "version": 325, + "versionNonce": 1751116141, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "2", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "2", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "46mfeC9nuxbNCGWpmDnDq", + "type": "ellipse", + "x": 920.0000000000005, + "y": -29529, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "XY0_sdcBOesMzM_vaYUMQ" + ], + "frameId": null, + "index": "blQ", + "roundness": { + "type": 2 + }, + "seed": 162689133, + "version": 356, + "versionNonce": 267221891, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "frP9ePCit8EhkowzbbkUA", + "type": "text", + "x": 935.0000000000005, + "y": -29521, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "XY0_sdcBOesMzM_vaYUMQ" + ], + "frameId": null, + "index": "blR", + "roundness": null, + "seed": 742644429, + "version": 353, + "versionNonce": 1281110573, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "5", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "5", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Twz-vsowKh8ZYE8V8hiXF", + "type": "ellipse", + "x": 623.0000000000005, + "y": -29530, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "y8oV951V8u3uuzfMGbGFO" + ], + "frameId": null, + "index": "blS", + "roundness": { + "type": 2 + }, + "seed": 1062457187, + "version": 283, + "versionNonce": 1549341475, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "Tz-MgljvZwUw4p_mzeRzD", + "type": "text", + "x": 638.0000000000005, + "y": -29522, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "y8oV951V8u3uuzfMGbGFO" + ], + "frameId": null, + "index": "blT", + "roundness": null, + "seed": 394914563, + "version": 282, + "versionNonce": 2144298125, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "6", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "6", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "YXIg2h-LICELAeYSAEjz0", + "type": "ellipse", + "x": -79.99999999999955, + "y": -29580, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "AJ2HIb3F2N5SC_ZdLE2sL" + ], + "frameId": null, + "index": "blU", + "roundness": { + "type": 2 + }, + "seed": 1993506253, + "version": 246, + "versionNonce": 850441923, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "tv0233y9I52J2G5Fk2FwE", + "type": "text", + "x": -64.99999999999955, + "y": -29572, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "AJ2HIb3F2N5SC_ZdLE2sL" + ], + "frameId": null, + "index": "blV", + "roundness": null, + "seed": 146488365, + "version": 243, + "versionNonce": 384649965, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "7", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "7", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "AW1xqJdBCNEYZ_OYXCg3q", + "type": "rectangle", + "x": 1060.0000000000005, + "y": -29760, + "width": 242.01759766038202, + "height": 158.92029120482397, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "frameId": null, + "index": "blh4", + "roundness": { + "type": 3 + }, + "seed": 1890387075, + "version": 1691, + "versionNonce": 469129133, + "isDeleted": false, + "boundElements": [ + { + "id": "5l5jDt_z-U3-44bLZ8jJJ", + "type": "arrow" + }, + { + "id": "gioNpA3UMZFOjXWJfDh8x", + "type": "arrow" + }, + { + "id": "4xmlYocPLH_MusCQLGUoe", + "type": "arrow" + }, + { + "id": "N7HYjBNHx4q6nmMHDk6O1", + "type": "arrow" + } + ], + "updated": 1751031114004, + "link": null, + "locked": false + }, + { + "type": "ellipse", + "version": 1708, + "versionNonce": 1249492291, + "isDeleted": false, + "id": "5H9FBvJ2PBiM_kgMn9_6X", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1144.0000000000005, + "y": -29737, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 75.67780198400858, + "height": 73.71214478961875, + "seed": 1849654307, + "groupIds": [ + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blh8", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1648, + "versionNonce": 16641133, + "isDeleted": false, + "id": "V-rrsesVzLORSE2ak5x3o", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1157.7596003607296, + "y": -29729.137371222438, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1843527619, + "groupIds": [ + "LSgan6FDcV_nIhQ3u2WaQ", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blhG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1619, + "versionNonce": 125246691, + "isDeleted": false, + "id": "FAUjwfbYTL-ouYUE0gVkO", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1162.6737433467042, + "y": -29724.223228236464, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1236471651, + "groupIds": [ + "LSgan6FDcV_nIhQ3u2WaQ", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blhO", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1621, + "versionNonce": 616552141, + "isDeleted": false, + "id": "55K2n8VWmaDIBoOz-7lWy", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1162.182329048107, + "y": -29715.869185160307, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 335620867, + "groupIds": [ + "LSgan6FDcV_nIhQ3u2WaQ", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blhV", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1630, + "versionNonce": 1760004227, + "isDeleted": false, + "id": "-6lMATujRg9BWQwgAdGBI", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1162.182329048107, + "y": -29706.04089918836, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 290116259, + "groupIds": [ + "LSgan6FDcV_nIhQ3u2WaQ", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blhZ", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1699, + "versionNonce": 563442989, + "isDeleted": false, + "id": "qnbrxTSHzpx497IXcxno_", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1167.0964720340817, + "y": -29718.326256653294, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1916700227, + "groupIds": [ + "hPpbxRIrLNELoEOAuYBUB", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blhd", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1673, + "versionNonce": 76120099, + "isDeleted": false, + "id": "dOZSmazFiRcs6vTohpDkP", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1172.0106150200559, + "y": -29713.41211366732, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1304085987, + "groupIds": [ + "hPpbxRIrLNELoEOAuYBUB", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blhl", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1675, + "versionNonce": 48777101, + "isDeleted": false, + "id": "dzWdOooNbEdjSm2bHh8zU", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1171.5192007214587, + "y": -29705.058070591163, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1523454339, + "groupIds": [ + "hPpbxRIrLNELoEOAuYBUB", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blht", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1684, + "versionNonce": 877364163, + "isDeleted": false, + "id": "aLEkKB0lLuWKKVNc4OruA", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1171.5192007214587, + "y": -29695.229784619216, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1790372131, + "groupIds": [ + "hPpbxRIrLNELoEOAuYBUB", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "bli", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1683, + "versionNonce": 720489965, + "isDeleted": false, + "id": "0_zKXphByLdTGT85ZI27X", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1177.9075866032254, + "y": -29711.446456472935, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 585354435, + "groupIds": [ + "NsrIOpeygX_TwHkKpsar8", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "bli8", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1657, + "versionNonce": 273421155, + "isDeleted": false, + "id": "Dyho_ULT_tHiu9AJEE65M", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1182.8217295892, + "y": -29706.53231348696, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1995652195, + "groupIds": [ + "NsrIOpeygX_TwHkKpsar8", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "bliG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1659, + "versionNonce": 2025556045, + "isDeleted": false, + "id": "iJcQWmUGe4xE7BsRRVnyV", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1182.3303152906028, + "y": -29698.178270410797, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1655945219, + "groupIds": [ + "NsrIOpeygX_TwHkKpsar8", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "bliV", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1668, + "versionNonce": 685354755, + "isDeleted": false, + "id": "KYpkfBwfXBgAbZeOPNp5L", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1182.3303152906028, + "y": -29688.34998443885, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1680064419, + "groupIds": [ + "NsrIOpeygX_TwHkKpsar8", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blil", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1700, + "versionNonce": 773781165, + "isDeleted": false, + "id": "dLqlYIS5_J7I6o5r4tlD6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1185.770215380785, + "y": -29702.600999098177, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 896652099, + "groupIds": [ + "u3DFZ-dE5k6y_J6q6vhAr", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blj", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1675, + "versionNonce": 7526051, + "isDeleted": false, + "id": "wPNKIsBaCTEzGV1Lxg76B", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1190.6843583667596, + "y": -29697.686856112203, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1190949603, + "groupIds": [ + "u3DFZ-dE5k6y_J6q6vhAr", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "bljG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1676, + "versionNonce": 365271309, + "isDeleted": false, + "id": "bT_7MCPPCr-1CmnENl0q0", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1190.192944068162, + "y": -29689.332813036046, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 2035424899, + "groupIds": [ + "u3DFZ-dE5k6y_J6q6vhAr", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "bljV", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1685, + "versionNonce": 1170606659, + "isDeleted": false, + "id": "eNH_P2va5A3AzYk3C89T8", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1190.192944068162, + "y": -29679.50452706409, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 389109283, + "groupIds": [ + "u3DFZ-dE5k6y_J6q6vhAr", + "bklVy1W0g1XtLcYRUjuew", + "bf761ZzNvTjMUBvXWZQ3T", + "b4Iwcxb3RCqu3gcAenbic", + "6GxjjxosFRo5fva0QlOkt" + ], + "index": "blk", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "A29IDB2pKSPytd95mOxTB", + "type": "text", + "x": 1074.0000000000005, + "y": -29641, + "width": 220.00000000000006, + "height": 26.536372124262762, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "ADHe-_oHn5N0nocoRfFFO", + "6GxjjxosFRo5fva0QlOkt" + ], + "frameId": null, + "index": "bll", + "roundness": null, + "seed": 957244429, + "version": 2014, + "versionNonce": 1764290413, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "Authenticatiedienst", + "fontSize": 21.22909769941021, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Authenticatiedienst", + "autoResize": false, + "lineHeight": 1.25 + }, + { + "id": "srnsrgsNlqdR3RafOvO-B", + "type": "rectangle", + "x": 1060.0000000000005, + "y": -29540, + "width": 242.01759766038202, + "height": 158.92029120482397, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "frameId": null, + "index": "bm1", + "roundness": { + "type": 3 + }, + "seed": 1156941, + "version": 1716, + "versionNonce": 1946737165, + "isDeleted": false, + "boundElements": [ + { + "id": "62h3q2H1TdZ82PLmbL3B7", + "type": "arrow" + }, + { + "id": "LqRsDI8WRF03IYiZHy31j", + "type": "arrow" + }, + { + "id": "OsoysEpb_WO840idPv-92", + "type": "arrow" + }, + { + "id": "gioNpA3UMZFOjXWJfDh8x", + "type": "arrow" + } + ], + "updated": 1751031114004, + "link": null, + "locked": false + }, + { + "type": "ellipse", + "version": 1731, + "versionNonce": 1989310925, + "isDeleted": false, + "id": "MGLhzTGdxVBXJ0nlpA39w", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1144.0000000000005, + "y": -29517, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 75.67780198400858, + "height": 73.71214478961875, + "seed": 1129919917, + "groupIds": [ + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bm2", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1671, + "versionNonce": 1296340355, + "isDeleted": false, + "id": "yajchrFt6_CjxHv9nnFgP", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1157.7596003607296, + "y": -29509.137371222438, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 660600845, + "groupIds": [ + "6_ZLylEfDex3xwAVnMbB-", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bm3", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1642, + "versionNonce": 119257133, + "isDeleted": false, + "id": "enRCA_ZXe-UQAZ-yHmI0A", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1162.6737433467042, + "y": -29504.223228236464, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 908029549, + "groupIds": [ + "6_ZLylEfDex3xwAVnMbB-", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bm4", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1644, + "versionNonce": 1404890403, + "isDeleted": false, + "id": "8lBanJ77WoZMINeHNnADM", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1162.182329048107, + "y": -29495.869185160307, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 2120292557, + "groupIds": [ + "6_ZLylEfDex3xwAVnMbB-", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bm5", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1653, + "versionNonce": 78523021, + "isDeleted": false, + "id": "46gIVYWjX7oIwA-Np3H4j", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1162.182329048107, + "y": -29486.04089918836, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 2042525485, + "groupIds": [ + "6_ZLylEfDex3xwAVnMbB-", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bm6", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1722, + "versionNonce": 76107971, + "isDeleted": false, + "id": "H_ChktZr_pYgnSY6aL54X", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1167.0964720340817, + "y": -29498.326256653294, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 849414541, + "groupIds": [ + "Y_eCDsvrr4Z-uGUmu2r2K", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bm7", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1696, + "versionNonce": 1610830061, + "isDeleted": false, + "id": "PAyJJQYfioR1PXG73xUN4", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1172.0106150200559, + "y": -29493.41211366732, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 708988909, + "groupIds": [ + "Y_eCDsvrr4Z-uGUmu2r2K", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bm8", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1698, + "versionNonce": 289947747, + "isDeleted": false, + "id": "tsq8PGEjtXSw_PolwdlfA", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1171.5192007214587, + "y": -29485.058070591163, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 2125187661, + "groupIds": [ + "Y_eCDsvrr4Z-uGUmu2r2K", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bm9", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1707, + "versionNonce": 916761421, + "isDeleted": false, + "id": "PqpnY0pmtxdZRwgW9PXDB", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1171.5192007214587, + "y": -29475.229784619216, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1354168493, + "groupIds": [ + "Y_eCDsvrr4Z-uGUmu2r2K", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bmA", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1706, + "versionNonce": 1942502403, + "isDeleted": false, + "id": "ctFgbo1idR5fbG3NW7k0U", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1177.9075866032254, + "y": -29491.446456472935, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1779260173, + "groupIds": [ + "OzmZleo1vw-7rdmG-xFVC", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bmB", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1680, + "versionNonce": 954972589, + "isDeleted": false, + "id": "cRlx0ILGVloAxxVsUv-he", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1182.8217295892, + "y": -29486.53231348696, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 589853037, + "groupIds": [ + "OzmZleo1vw-7rdmG-xFVC", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bmC", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1682, + "versionNonce": 1745339299, + "isDeleted": false, + "id": "0qknvrF7Ao0reL9oIIxbL", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1182.3303152906028, + "y": -29478.178270410797, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 156351437, + "groupIds": [ + "OzmZleo1vw-7rdmG-xFVC", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bmD", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1691, + "versionNonce": 1342307341, + "isDeleted": false, + "id": "9i8wIhTld_Ek1y1Gdl2l9", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1182.3303152906028, + "y": -29468.34998443885, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1151515181, + "groupIds": [ + "OzmZleo1vw-7rdmG-xFVC", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bmE", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1723, + "versionNonce": 641029955, + "isDeleted": false, + "id": "qjp9qi5G_9_u0wt5pnCtZ", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1185.770215380785, + "y": -29482.600999098177, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1040510093, + "groupIds": [ + "1qV603THwPDv6-eNwv8Qq", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bmF", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1698, + "versionNonce": 65073773, + "isDeleted": false, + "id": "CBK0dVZGTpS6Oo7FLx-QW", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1190.6843583667596, + "y": -29477.686856112203, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 87151341, + "groupIds": [ + "1qV603THwPDv6-eNwv8Qq", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bmG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1699, + "versionNonce": 1555003107, + "isDeleted": false, + "id": "o4qePXONetaYLC0yrpSG4", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1190.192944068162, + "y": -29469.332813036046, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1991437645, + "groupIds": [ + "1qV603THwPDv6-eNwv8Qq", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bmH", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1708, + "versionNonce": 559029453, + "isDeleted": false, + "id": "FzeDknrZzFavAqDuOhiyC", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1190.192944068162, + "y": -29459.50452706409, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 568441773, + "groupIds": [ + "1qV603THwPDv6-eNwv8Qq", + "lJE5ZQSn8HcgZoFyt-tOO", + "5jcBspdeKxKlkz1u2fkK3", + "nwlU5hOwYb06p5RTTDwx9", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "index": "bmI", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "iBjh7vSKviQAwcfOQT_an", + "type": "text", + "x": 1075.0000000000005, + "y": -29421, + "width": 220.00000000000006, + "height": 26.536372124262762, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "airdCSbaBJ0OcBxc-Qe24", + "CjwuhCTCOdL24I-jE6Ecw" + ], + "frameId": null, + "index": "bmJ", + "roundness": null, + "seed": 1860681229, + "version": 2049, + "versionNonce": 1778688643, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "Machtigingenregister", + "fontSize": 21.22909769941021, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtigingenregister", + "autoResize": false, + "lineHeight": 1.25 + }, + { + "id": "molmivznMzvOry9C-yTH-", + "type": "rectangle", + "x": 1074.0000000000005, + "y": -29343, + "width": 233.8237142226032, + "height": 47.94551906172546, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "Zs4VMpXS6mbSL2C6RQKEJ" + ], + "frameId": null, + "index": "bmN", + "roundness": null, + "seed": 653397197, + "version": 1103, + "versionNonce": 535755565, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "aDFuyKXJEXMaqfql0JqhI", + "type": "text", + "x": 1117.2156066894536, + "y": -29337, + "width": 146.1605224609375, + "height": 34.39900090182208, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "Zs4VMpXS6mbSL2C6RQKEJ" + ], + "frameId": null, + "index": "bmO", + "roundness": null, + "seed": 1838243427, + "version": 1155, + "versionNonce": 1458788899, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "Leverancier", + "fontSize": 27.519200721457665, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Leverancier", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "29Gq_q5b7EpkUNeCcEiEX", + "type": "rectangle", + "x": 360.00000000000045, + "y": -29344, + "width": 233.8237142226032, + "height": 47.94551906172546, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "WA9slcKAJC_Bsx5Kqr3YV" + ], + "frameId": null, + "index": "bmP", + "roundness": null, + "seed": 126816109, + "version": 1132, + "versionNonce": 1210125709, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "PAd_-I9n-fqxFAj5uFKsw", + "type": "text", + "x": 418.51115417480514, + "y": -29338, + "width": 115.56942749023438, + "height": 34.39900090182208, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "WA9slcKAJC_Bsx5Kqr3YV" + ], + "frameId": null, + "index": "bmQ", + "roundness": null, + "seed": 590649805, + "version": 1181, + "versionNonce": 275389891, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "Makelaar", + "fontSize": 27.519200721457665, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Makelaar", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "CCSRsGNS2aRqn35SfODj1", + "type": "rectangle", + "x": -379.99999999999955, + "y": -29343, + "width": 233.8237142226032, + "height": 47.94551906172546, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "k_jf1QnivMKY2T_VRCWKX" + ], + "frameId": null, + "index": "bmR", + "roundness": null, + "seed": 465840035, + "version": 1147, + "versionNonce": 421647341, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "bhAStWc-JB62hCBBRO9-A", + "type": "text", + "x": -358.53103637695267, + "y": -29337, + "width": 189.65380859375, + "height": 34.39900090182208, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "k_jf1QnivMKY2T_VRCWKX" + ], + "frameId": null, + "index": "bmS", + "roundness": null, + "seed": 1824865091, + "version": 1216, + "versionNonce": 1636265315, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "Dienstverlener", + "fontSize": 27.519200721457665, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Dienstverlener", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "tbiJzp8kJ5YIxUKGNDI0K", + "type": "image", + "x": 854.0000000000005, + "y": -29260, + "width": 640, + "height": 749.7648686030428, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#ffffff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bmT", + "roundness": { + "type": 3 + }, + "seed": 1810428195, + "version": 176, + "versionNonce": 1861930573, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "status": "saved", + "fileId": "3c0e98095226c9e3930b94a4c63579099ed01c84", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "56YigtKXiSVpA6wLjk2zQ", + "type": "arrow", + "x": 125, + "y": -28891.9144, + "width": 70.00000000000045, + "height": 1058.0355999999992, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bma", + "roundness": null, + "seed": 611677859, + "version": 505, + "versionNonce": 997404013, + "isDeleted": false, + "boundElements": [], + "updated": 1751032018065, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 70.00000000000045, + 0 + ], + [ + 70.00000000000045, + -1058.0355999999992 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "tOijGb-6c41VoTDdHtkAX", + "focus": 0.9507418397626128, + "gap": 6, + "fixedPoint": [ + 1.0071428571428571, + 0.5001 + ] + }, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": true, + "fixedSegments": null, + "startIsSpecial": null, + "endIsSpecial": null + }, + { + "id": "Oq_WiMNnMo-lwjbssoats", + "type": "arrow", + "x": 125, + "y": -28891.9144, + "width": 70.00000000000045, + "height": 458.03559999999925, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bmc", + "roundness": null, + "seed": 2026838061, + "version": 505, + "versionNonce": 1088747469, + "isDeleted": false, + "boundElements": [], + "updated": 1751032018065, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 70.00000000000045, + 0 + ], + [ + 70.00000000000045, + -458.03559999999925 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "tOijGb-6c41VoTDdHtkAX", + "focus": 0.8409448818897687, + "gap": 6, + "fixedPoint": [ + 1.0071428571428571, + 0.5001 + ] + }, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": true, + "fixedSegments": null, + "startIsSpecial": null, + "endIsSpecial": null + }, + { + "id": "dEu-ew9Q1Ts1k1xtFavi5", + "type": "arrow", + "x": 125, + "y": -28891.9144, + "width": 70.00000000000045, + "height": 141.96440000000075, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bme", + "roundness": null, + "seed": 1392434179, + "version": 509, + "versionNonce": 510555693, + "isDeleted": false, + "boundElements": [], + "updated": 1751032018066, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 70.00000000000045, + 0 + ], + [ + 70.00000000000045, + 141.96440000000075 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "tOijGb-6c41VoTDdHtkAX", + "focus": -0.840944881889766, + "gap": 6, + "fixedPoint": [ + 1.0071428571428571, + 0.5001 + ] + }, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": true, + "fixedSegments": null, + "startIsSpecial": null, + "endIsSpecial": null + }, + { + "id": "0fgVSOe5L7MIUYNbQuxQx", + "type": "arrow", + "x": 125, + "y": -28891.9144, + "width": 50.000000000000455, + "height": 4161.964400000001, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bmg", + "roundness": null, + "seed": 9534669, + "version": 464, + "versionNonce": 1593387149, + "isDeleted": false, + "boundElements": [], + "updated": 1751032018066, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 50.000000000000455, + 0 + ], + [ + 50.000000000000455, + 4161.964400000001 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "tOijGb-6c41VoTDdHtkAX", + "focus": -0.9507418397626134, + "gap": 6, + "fixedPoint": [ + 1.0071428571428571, + 0.5001 + ] + }, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": true, + "fixedSegments": null, + "startIsSpecial": null, + "endIsSpecial": null + }, + { + "id": "PgSXnt4tKSK0VyYG5LZej", + "type": "text", + "x": -331.99999999999955, + "y": -29540, + "width": 162.56989181607653, + "height": 26.536372124262762, + "angle": 0, + "strokeColor": "#9c36b5", + "backgroundColor": "#a5d8ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "6sJIfK4FJcNR6JZ6akX5t", + "OLwVXn11kDLcHLcvNd3H3" + ], + "frameId": null, + "index": "bmn", + "roundness": null, + "seed": 821591459, + "version": 1523, + "versionNonce": 1083316909, + "isDeleted": false, + "boundElements": [ + { + "id": "Yewwjmm-QsQMr3u58TEUv", + "type": "arrow" + }, + { + "id": "DSHAdWP2SjiLrwrwx_zWT", + "type": "arrow" + } + ], + "updated": 1751031114004, + "link": null, + "locked": false, + "text": "Dienst", + "fontSize": 21.22909769941021, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Dienst", + "autoResize": false, + "lineHeight": 1.25 + }, + { + "id": "BfV-xceaIfpOayFQSK2fC", + "type": "image", + "x": 140.00000000000045, + "y": -29260, + "width": 441.2996389891701, + "height": 640.0000000000006, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "b0ZlD-yvtZ6FSY_YgFbYB" + ], + "frameId": null, + "index": "bmo", + "roundness": { + "type": 3 + }, + "seed": 1366953965, + "version": 304, + "versionNonce": 843015501, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "status": "saved", + "fileId": "43a41e07b0cf2a1cbdc4fde7a2333cb21b1a7c9a", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "uXuJRVLDmrld2zKgWMlgF", + "type": "image", + "x": 365.00000000000045, + "y": -29120, + "width": 435.5, + "height": 627.8773913043478, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#f783ac", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "b0ZlD-yvtZ6FSY_YgFbYB" + ], + "frameId": null, + "index": "bmp", + "roundness": { + "type": 3 + }, + "seed": 1037982499, + "version": 181, + "versionNonce": 1814540163, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "status": "saved", + "fileId": "37084cd4e7ea7eacf139b20ffe8bf0ce3b4c48b3", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "zQVBuvX_LNWQLk8RvRibF", + "type": "rectangle", + "x": -699.9999999999995, + "y": -29900, + "width": 2339.132061323902, + "height": 1479.9999999999984, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bmq", + "roundness": null, + "seed": 35616451, + "version": 918, + "versionNonce": 252657197, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "MLgT9D93bdTR91gM63bha", + "type": "ellipse", + "x": -347.99999999999955, + "y": -30020, + "width": 182.2099863465829, + "height": 172.55647673726426, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "lzDBvrx3QxaukE4IUnp6f", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bmr", + "roundness": { + "type": 2 + }, + "seed": 1577608749, + "version": 1075, + "versionNonce": 526387203, + "isDeleted": false, + "boundElements": [ + { + "id": "QOCOmZsoaGmzDWZLzfzLv", + "type": "arrow" + } + ], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "duDZUHkMWzL-u2VlqbODe", + "type": "image", + "x": -298.5125481111186, + "y": -29994.91827731696, + "width": 79.55074823294485, + "height": 79.55074823294485, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "b_h1LudrlS-tmI2H_vEOg", + "lzDBvrx3QxaukE4IUnp6f", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bms", + "roundness": null, + "seed": 1976899725, + "version": 1418, + "versionNonce": 210152877, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "status": "saved", + "fileId": "89153ff21bce9db4c81e5ca2b799580617710770", + "scale": [ + 1, + 1 + ], + "crop": null, + "initialWidth": 1.2277712023808363, + "initialHeight": 1.2277712023808363 + }, + { + "id": "gireBODn0ZLdltumpQWCz", + "type": "text", + "x": -298.04865125606955, + "y": -29911, + "width": 89.56465148925781, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "2OrHIy0rfkzrNXTg1EEjQ", + "yYthoKl7jLEGPwYrCBKyp", + "b_h1LudrlS-tmI2H_vEOg", + "lzDBvrx3QxaukE4IUnp6f", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bmt", + "roundness": null, + "seed": 706510573, + "version": 1467, + "versionNonce": 1724256163, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "Gebruiker", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Gebruiker", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Zn6mCl6mGgiWpRLW9cPbq", + "type": "rectangle", + "x": -200.22968839162695, + "y": -29979.88890703622, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "RDLy83iUvadRxkKV26-05", + "tPJJhY60eT1MbXzANKeEA", + "pzXwfk6YzR90DbC_CLyGG", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bmu", + "roundness": { + "type": 3 + }, + "seed": 23599437, + "version": 1031, + "versionNonce": 1545498637, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "a_ZGZT-hQYGvwvfVOeCCN", + "type": "rectangle", + "x": -158.7599538328068, + "y": -29979.888907334534, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "RDLy83iUvadRxkKV26-05", + "tPJJhY60eT1MbXzANKeEA", + "pzXwfk6YzR90DbC_CLyGG", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bmv", + "roundness": null, + "seed": 1964074925, + "version": 1123, + "versionNonce": 1330258755, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "n1l5h-BSfie8GmIf0izcw", + "type": "text", + "x": -180.6349920563771, + "y": -29979.949222817275, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "RDLy83iUvadRxkKV26-05", + "tPJJhY60eT1MbXzANKeEA", + "pzXwfk6YzR90DbC_CLyGG", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bmw", + "roundness": null, + "seed": 390195725, + "version": 857, + "versionNonce": 1011803757, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "EkiN2RtsKalwL8VwEsUQc", + "type": "text", + "x": -191.83843324173358, + "y": -29979.949222949697, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "RDLy83iUvadRxkKV26-05", + "tPJJhY60eT1MbXzANKeEA", + "pzXwfk6YzR90DbC_CLyGG", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bmx", + "roundness": null, + "seed": 2029199469, + "version": 877, + "versionNonce": 558547683, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "iFWDGrRT83rN18mHgEGPS", + "type": "rectangle", + "x": -160.46104085713296, + "y": -29980.972561846203, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "RDLy83iUvadRxkKV26-05", + "tPJJhY60eT1MbXzANKeEA", + "pzXwfk6YzR90DbC_CLyGG", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bmy", + "roundness": null, + "seed": 1341033165, + "version": 1173, + "versionNonce": 2145489101, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "EqlwSgCCK88FQcZeIMR77", + "type": "rectangle", + "x": -125.75215855904025, + "y": -29979.701635941514, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "RDLy83iUvadRxkKV26-05", + "tPJJhY60eT1MbXzANKeEA", + "pzXwfk6YzR90DbC_CLyGG", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bmz", + "roundness": null, + "seed": 1556982061, + "version": 1097, + "versionNonce": 357985923, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "phaBJLZu4ZN_E67u6OHqy", + "type": "text", + "x": -152.94498485254326, + "y": -29981.158676956227, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "JXhDuF7nomSxEP0FI18UK", + "tPJJhY60eT1MbXzANKeEA", + "pzXwfk6YzR90DbC_CLyGG", + "uTpKsEJINV33STEEcC1Cm" + ], + "frameId": null, + "index": "bn0", + "roundness": null, + "seed": 284818317, + "version": 1071, + "versionNonce": 1685057325, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "4Pm_As7dF9_Pojfbqblvq", + "type": "text", + "x": 360, + "y": -30021, + "width": 1231.9788818359375, + "height": 118.74362970865103, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bn1", + "roundness": null, + "seed": 134724749, + "version": 627, + "versionNonce": 733830797, + "isDeleted": false, + "boundElements": [], + "updated": 1751031671182, + "link": null, + "locked": false, + "text": "Authenticatie en autorisatie", + "fontSize": 103.25533018143568, + "fontFamily": 7, + "textAlign": "right", + "verticalAlign": "top", + "containerId": null, + "originalText": "Authenticatie en autorisatie", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "QOCOmZsoaGmzDWZLzfzLv", + "type": "arrow", + "x": -260.3078918820672, + "y": -29839.97491206628, + "width": 0.3078918820693275, + "height": 166.6288466431688, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#a5d8ff", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bn2", + "roundness": { + "type": 2 + }, + "seed": 684610381, + "version": 346, + "versionNonce": 1178359512, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "_pA_K5ArnjQblyxraqQcY" + } + ], + "updated": 1760102028801, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0.30789188206767903, + 39.97491206627819 + ], + [ + 0.3078918820693275, + 166.6288466431688 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "_pA_K5ArnjQblyxraqQcY", + "type": "text", + "x": -281.4999847412105, + "y": -29812.5, + "width": 42.999969482421875, + "height": 25, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#a5d8ff", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bn3", + "roundness": null, + "seed": 1817361283, + "version": 43, + "versionNonce": 1072704680, + "isDeleted": false, + "boundElements": [], + "updated": 1760102027693, + "link": null, + "locked": false, + "text": "login", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "QOCOmZsoaGmzDWZLzfzLv", + "originalText": "login", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "ZC4E0rrQ_uDcz0aiJ1ys2", + "type": "ellipse", + "x": -279.99999999999955, + "y": -29760, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "toPGo1hBd7kGewt4RWUYf" + ], + "frameId": null, + "index": "bn4", + "roundness": { + "type": 2 + }, + "seed": 745016685, + "version": 303, + "versionNonce": 1023373283, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false + }, + { + "id": "C24Wfs_bBDJoHZLZ1LgvN", + "type": "text", + "x": -264.99999999999955, + "y": -29752, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "toPGo1hBd7kGewt4RWUYf" + ], + "frameId": null, + "index": "bn5", + "roundness": null, + "seed": 4052941, + "version": 299, + "versionNonce": 685388749, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "text": "1", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "1", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "y42Z5WhaO8fKX6VpiIfHc", + "type": "text", + "x": 380.00000000000045, + "y": -29540, + "width": 162.56989181607653, + "height": 26.536372124262762, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#a5d8ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "1-IuZFKI8ON8BNwdF8Apx", + "4QLaKEuur1ALOD1KSm63s" + ], + "frameId": null, + "index": "bn6", + "roundness": null, + "seed": 688016685, + "version": 1550, + "versionNonce": 1854819075, + "isDeleted": false, + "boundElements": [ + { + "id": "Yewwjmm-QsQMr3u58TEUv", + "type": "arrow" + }, + { + "id": "62h3q2H1TdZ82PLmbL3B7", + "type": "arrow" + }, + { + "id": "DSHAdWP2SjiLrwrwx_zWT", + "type": "arrow" + } + ], + "updated": 1751031114004, + "link": null, + "locked": false, + "text": "Makelaar", + "fontSize": 21.22909769941021, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Makelaar", + "autoResize": false, + "lineHeight": 1.25 + }, + { + "id": "DSHAdWP2SjiLrwrwx_zWT", + "type": "arrow", + "x": 420, + "y": -29480, + "width": 680, + "height": 80, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bn7", + "roundness": { + "type": 2 + }, + "seed": 2137652451, + "version": 1630, + "versionNonce": 921316163, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "KhhMbvJWeoZ3feuzOHQkH" + } + ], + "updated": 1751031363396, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -339.99999999999955, + 80 + ], + [ + -680, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "EzVzRhnEEexv5bdXTLJSO", + "focus": -0.8940347387174037, + "gap": 21.079708795175975 + }, + "endBinding": { + "elementId": "64PVZQ-y2df3aEWcH6PJU", + "focus": 1.022366316561648, + "gap": 21.079708795175975 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false, + "fixedSegments": null, + "startIsSpecial": null, + "endIsSpecial": null + }, + { + "id": "KhhMbvJWeoZ3feuzOHQkH", + "type": "text", + "x": 42.36003112793014, + "y": -29412.5, + "width": 75.27993774414062, + "height": 25, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bn8", + "roundness": null, + "seed": 528377987, + "version": 57, + "versionNonce": 2096388749, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114016, + "link": null, + "locked": false, + "text": "redirect", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "DSHAdWP2SjiLrwrwx_zWT", + "originalText": "redirect", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "J8nPDKLebTVNJmOcCDglr", + "type": "image", + "x": -559.9999999999995, + "y": -29260, + "width": 660.493421052634, + "height": 460.0000000000016, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#228be6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "X_NSpavNIOwQSReTx4EYx" + ], + "frameId": null, + "index": "bnA", + "roundness": { + "type": 3 + }, + "seed": 619334531, + "version": 255, + "versionNonce": 294839907, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "status": "saved", + "fileId": "c2fa720fbef5bb40038163ca3eb4fab673fe2244", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "t9_h_gAz_eOAxswZfhiMn", + "type": "image", + "x": -639.9999999999995, + "y": -28980, + "width": 130.61111111111072, + "height": 130.61111111111072, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "cross-hatch", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "X_NSpavNIOwQSReTx4EYx" + ], + "frameId": null, + "index": "bnB", + "roundness": null, + "seed": 38082541, + "version": 153, + "versionNonce": 55465475, + "isDeleted": false, + "boundElements": [], + "updated": 1751031114002, + "link": null, + "locked": false, + "status": "saved", + "fileId": "f5699aee6a55a10b506386b441837c15a9d838ce", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "ofsG9Zj_QOJjb4bFCDKrz", + "type": "rectangle", + "x": 523.0227531666646, + "y": -24703.384022334078, + "width": 1063.6770689104314, + "height": 299.9999999999996, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "lb2ratEdF09lRFq2DRUzN" + ], + "frameId": null, + "index": "bnF", + "roundness": { + "type": 3 + }, + "seed": 373927427, + "version": 1051, + "versionNonce": 1772066447, + "isDeleted": false, + "boundElements": [], + "updated": 1762251455280, + "link": null, + "locked": false + }, + { + "id": "KniQ_I6nhkCV7FNV4oW1n", + "type": "text", + "x": 555.1270241638749, + "y": -24631.279751336868, + "width": 968.3515625, + "height": 171.99500450911043, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "lb2ratEdF09lRFq2DRUzN" + ], + "frameId": null, + "index": "bnG", + "roundness": { + "type": 2 + }, + "seed": 1569387939, + "version": 1581, + "versionNonce": 296479919, + "isDeleted": false, + "boundElements": [], + "updated": 1762251455280, + "link": null, + "locked": false, + "text": "- Gebruiker logt in met vestigingsgebonden machtiging, eventueel\n via een ketenmachtiging.\n\n- Gebruiker ziet alleen notificaties die horen bij het \n vestigingsnummer in de machtiging.", + "fontSize": 27.51920072145767, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "- Gebruiker logt in met vestigingsgebonden machtiging, eventueel\n via een ketenmachtiging.\n\n- Gebruiker ziet alleen notificaties die horen bij het \n vestigingsnummer in de machtiging.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "mgq7uLylLa_CbdZ8zbsXd", + "type": "rectangle", + "x": 600.7881434229398, + "y": -24743.384022334078, + "width": 621.4525772646434, + "height": 80, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "1eWf4uVyvTHUzzlSTfrav", + "lb2ratEdF09lRFq2DRUzN" + ], + "frameId": null, + "index": "bnH", + "roundness": { + "type": 3 + }, + "seed": 679627075, + "version": 620, + "versionNonce": 1040744143, + "isDeleted": false, + "boundElements": [], + "updated": 1762251455280, + "link": null, + "locked": false + }, + { + "id": "IhEKyKqxu_f-HHSLQ3Nt4", + "type": "text", + "x": 620.7881434229398, + "y": -24723.384022334078, + "width": 583.77001953125, + "height": 44.22728687377125, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "1eWf4uVyvTHUzzlSTfrav", + "lb2ratEdF09lRFq2DRUzN" + ], + "frameId": null, + "index": "bnI", + "roundness": { + "type": 2 + }, + "seed": 747514083, + "version": 932, + "versionNonce": 1900924143, + "isDeleted": false, + "boundElements": [], + "updated": 1762251455280, + "link": null, + "locked": false, + "text": "Vestigingsgebonden autorisatie", + "fontSize": 35.381829499017, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Vestigingsgebonden autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "xwJGYAdIpxG130Z7Giivf", + "type": "text", + "x": 1680, + "y": -29953.133722638762, + "width": 1195.3089599609375, + "height": 859.975022545552, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dotted", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bnN", + "roundness": null, + "seed": 585650088, + "version": 5375, + "versionNonce": 397822081, + "isDeleted": false, + "boundElements": [], + "updated": 1762246235745, + "link": null, + "locked": false, + "text": "Authenticatie en autorisatie: de happy flow\n----------------\n\n1) De gebruiker logt in op de website van de dienst.\n\n2) De gebruiker wordt doorgestuurd naar de website van de makelaar waarmee\n de dienst is aangesloten op het eHerkenning-netwerk. Daar kan de gebruiker \n zijn leverancier selecteren.\n\n3) De gebruiker heeft zijn leverancier geselecteerd en wordt doorgestuurd naar\n de website van deze leverancier, waar hij zich kan authenticeren.\n\n4) Nadat de authenticatie is voltooid door de authenticatiedienst van de \n leverancier, wordt de gebruiker teruggeleid naar de makelaar.\n\n5) De gebruiker wordt automatisch teruggestuurd naar de leverancier om \n de autorisatie uit te voeren.\n\n6) Zodra verificaties in het Machtigingenregister zijn uitgevoerd en de \n autorisatie is afgerond, wordt de gebruiker teruggeleid naar de makelaar.\n\n7) De makelaar stuurt de gebruiker terug naar de website van de dienst en \n bevestigd de autorisatie met een authentication token.\n\n De gebruiker is nu ingelogd.", + "fontSize": 27.519200721457665, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Authenticatie en autorisatie: de happy flow\n----------------\n\n1) De gebruiker logt in op de website van de dienst.\n\n2) De gebruiker wordt doorgestuurd naar de website van de makelaar waarmee\n de dienst is aangesloten op het eHerkenning-netwerk. Daar kan de gebruiker \n zijn leverancier selecteren.\n\n3) De gebruiker heeft zijn leverancier geselecteerd en wordt doorgestuurd naar\n de website van deze leverancier, waar hij zich kan authenticeren.\n\n4) Nadat de authenticatie is voltooid door de authenticatiedienst van de \n leverancier, wordt de gebruiker teruggeleid naar de makelaar.\n\n5) De gebruiker wordt automatisch teruggestuurd naar de leverancier om \n de autorisatie uit te voeren.\n\n6) Zodra verificaties in het Machtigingenregister zijn uitgevoerd en de \n autorisatie is afgerond, wordt de gebruiker teruggeleid naar de makelaar.\n\n7) De makelaar stuurt de gebruiker terug naar de website van de dienst en \n bevestigd de autorisatie met een authentication token.\n\n De gebruiker is nu ingelogd.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "CuRSB_Ai-9iWU5AuCAajV", + "type": "rectangle", + "x": -699.1583320545828, + "y": -28079.370826300204, + "width": 2343.400696964967, + "height": 958.8117474169176, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#fcc2d7", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bnd", + "roundness": null, + "seed": 1281583735, + "version": 1675, + "versionNonce": 1121957493, + "isDeleted": false, + "boundElements": [ + { + "id": "WE4CGE40vviVrq9TGA3-M", + "type": "arrow" + } + ], + "updated": 1762209585356, + "link": null, + "locked": false + }, + { + "id": "c95pq3z5z6u6q5ymZ1Y4d", + "type": "arrow", + "x": -36.31751744638996, + "y": -27935.736893343405, + "width": 0, + "height": 80.87921218805423, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bne", + "roundness": null, + "seed": 261948311, + "version": 4977, + "versionNonce": 1875364469, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "6tgkMMxD3KUbs3kVBLPXm" + } + ], + "updated": 1762209578075, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 80.87921218805423 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "tIxQFC98P41VV871K12Zf", + "focus": -0.024016021188068382, + "gap": 13.258017750722502 + }, + "endBinding": { + "elementId": "ckm99xXOZ_rouZIXotPls", + "focus": 0.16612808675705043, + "gap": 18.322169000115537 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "6tgkMMxD3KUbs3kVBLPXm", + "type": "text", + "x": -1150.952407836914, + "y": -24534.84575137091, + "width": 101.90481567382812, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bnf", + "roundness": null, + "seed": 646346935, + "version": 98, + "versionNonce": 953249045, + "isDeleted": false, + "boundElements": [], + "updated": 1762201931983, + "link": null, + "locked": false, + "text": "Aanstelling", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "c95pq3z5z6u6q5ymZ1Y4d", + "originalText": "Aanstelling", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "_Lkj6uD3Slct57r3gLYWM", + "type": "arrow", + "x": -116.31385149844141, + "y": -27695.739950989508, + "width": 266.6213529164793, + "height": 152.1153757758002, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bng", + "roundness": null, + "seed": 1187269079, + "version": 4790, + "versionNonce": 225800501, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "SAhb8hSvuc_WOKjMvxg8m" + } + ], + "updated": 1762209578075, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -120.00366594794855, + 60.003057646103116 + ], + [ + -266.6213529164793, + 152.1153757758002 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "jFNNesX_-sVUSKwxOU6x_", + "focus": -0.20291011248910568, + "gap": 15.292931860112942 + }, + "endBinding": { + "elementId": "uzTYGVGApEa5VI2AAg0rC", + "focus": -0.3673961460304299, + "gap": 27.16151904036549 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "SAhb8hSvuc_WOKjMvxg8m", + "type": "text", + "x": -1329.2548119388332, + "y": -24252.507877748478, + "width": 100.01841735839844, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bnh", + "roundness": null, + "seed": 2104162039, + "version": 99, + "versionNonce": 984416885, + "isDeleted": false, + "boundElements": [], + "updated": 1762201931983, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "_Lkj6uD3Slct57r3gLYWM", + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "etrqDEPoa6u7LdJVBBpvY", + "type": "arrow", + "x": 517.541704956649, + "y": -27944.736893343405, + "width": 0.43800449018976906, + "height": 86.89861638968432, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bni", + "roundness": null, + "seed": 1090453527, + "version": 5125, + "versionNonce": 1064855541, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "KI3j1J62_1W9_1QcER1ic" + } + ], + "updated": 1762209578075, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -0.43800449018976906, + 86.89861638968432 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "I1Tn98FmwvmeDFGFPqDw6", + "focus": 0.18433922448382375, + "gap": 11.44472523150398 + }, + "endBinding": { + "elementId": "IHc35CCwEDR7xS8J_ypOY", + "focus": -0.09765625665629703, + "gap": 12.302764798478165 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "KI3j1J62_1W9_1QcER1ic", + "type": "text", + "x": -653.6297051253599, + "y": -24520.836049270096, + "width": 101.90481567382812, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bnj", + "roundness": null, + "seed": 1131734327, + "version": 111, + "versionNonce": 1950841589, + "isDeleted": false, + "boundElements": [], + "updated": 1762202010212, + "link": null, + "locked": false, + "text": "Aanstelling", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "etrqDEPoa6u7LdJVBBpvY", + "originalText": "Aanstelling", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "nkyhaaaCADMlQw-YJ96tD", + "type": "arrow", + "x": 480.00088061420433, + "y": -27684.739535186018, + "width": 20.001196202200276, + "height": 120.00623044921304, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bnk", + "roundness": { + "type": 2 + }, + "seed": 70329943, + "version": 5308, + "versionNonce": 1287433909, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "0uUVyFfm78ENMJjRWqJCg" + } + ], + "updated": 1762209578076, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -20.000880614204334, + 60.00264184261323 + ], + [ + 0.00031558799594222364, + 120.00623044921304 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "F3I1Ca8Lmb18lSqPJ0amD", + "focus": 0.5237695766367657, + "gap": 16 + }, + "endBinding": { + "elementId": "XTIImqJxaCuAxnxnnaRPb", + "focus": -0.0796258932324548, + "gap": 28.419794879865776 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "0uUVyFfm78ENMJjRWqJCg", + "type": "text", + "x": -770.0092086791993, + "y": -24264.28535746494, + "width": 100.01841735839844, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bnl", + "roundness": null, + "seed": 570966903, + "version": 110, + "versionNonce": 468079701, + "isDeleted": false, + "boundElements": [], + "updated": 1762202010212, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "nkyhaaaCADMlQw-YJ96tD", + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "SxU7k1lsjkAQhQhiEVU1T", + "type": "text", + "x": -648.4749430312095, + "y": -28055.941525556103, + "width": 327.4232824599801, + "height": 81.37820784773909, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bnp", + "roundness": null, + "seed": 1633374199, + "version": 997, + "versionNonce": 1895601455, + "isDeleted": false, + "boundElements": [], + "updated": 1762271542467, + "link": null, + "locked": false, + "text": "eHerkenning\nMachtigingenregister", + "fontSize": 35.381829499017, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "eHerkenning\nMachtigingenregister", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "rodLYz3LSJcmKnPNdOpkW", + "type": "text", + "x": -650.4488760048143, + "y": -27096.6115076645, + "width": 279.5870818502383, + "height": 81.37820784773909, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bo9", + "roundness": null, + "seed": 671141495, + "version": 1180, + "versionNonce": 2063238529, + "isDeleted": false, + "boundElements": [], + "updated": 1762271542004, + "link": null, + "locked": false, + "text": "eHerkenning\nDienstencatalogus", + "fontSize": 35.381829499017, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "eHerkenning\nDienstencatalogus", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "WE4CGE40vviVrq9TGA3-M", + "type": "arrow", + "x": -76.31703422887594, + "y": -27675.738342995945, + "width": 20.000483217514017, + "height": 125.28743541971926, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "boA", + "roundness": { + "type": 2 + }, + "seed": 1508763543, + "version": 4984, + "versionNonce": 825116021, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "eGki2Ri3Wrqf_p24JDI3u" + } + ], + "updated": 1762209578076, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -20.000483217514017, + 60.00144965254003 + ], + [ + -5.229471071799267, + 125.28743541971926 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "9DMSCZeJcbHrkXQQORhmo", + "focus": 0.38700456974909414, + "gap": 16 + }, + "endBinding": { + "elementId": "EA5TmauKzzRcpVYlBjqD9", + "focus": -0.12189225624732951, + "gap": 20.52727300737106 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "eGki2Ri3Wrqf_p24JDI3u", + "type": "text", + "x": 49.99079132080078, + "y": -23315.285357464938, + "width": 100.01841735839844, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "boB", + "roundness": null, + "seed": 1025170615, + "version": 106, + "versionNonce": 456059861, + "isDeleted": false, + "boundElements": [], + "updated": 1762201931983, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "WE4CGE40vviVrq9TGA3-M", + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "CQDi5H3MSMwX2347-QGOe", + "type": "rectangle", + "x": -220, + "y": -26919.417030294022, + "width": 182.01759766038205, + "height": 158.92029120482397, + "angle": 0, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "frameId": null, + "index": "boc", + "roundness": { + "type": 3 + }, + "seed": 1462669079, + "version": 1852, + "versionNonce": 1861799681, + "isDeleted": false, + "boundElements": [ + { + "id": "upeK8VWE9GciZSkIVsesX", + "type": "arrow" + }, + { + "id": "110qgmWaZ5RbVS1oTZ_FB", + "type": "arrow" + } + ], + "updated": 1762278166596, + "link": null, + "locked": false + }, + { + "id": "SsPr9uwx23p9IFZ7a-l1E", + "type": "text", + "x": -210.27614742913102, + "y": -26808.008379668045, + "width": 162.56989181607653, + "height": 26.536372124262765, + "angle": 0, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "frameId": null, + "index": "bod", + "roundness": null, + "seed": 718967863, + "version": 1694, + "versionNonce": 1313751265, + "isDeleted": false, + "boundElements": [], + "updated": 1762210849023, + "link": null, + "locked": false, + "text": "Service-X", + "fontSize": 21.22909769941021, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Service-X", + "autoResize": false, + "lineHeight": 1.25 + }, + { + "type": "ellipse", + "version": 1867, + "versionNonce": 895187375, + "isDeleted": false, + "id": "KFEeHxPDPBy00grLByJjp", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -166.88920849081933, + "y": -26904.569492731785, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 75.67780198400858, + "height": 73.71214478961875, + "seed": 1896412503, + "groupIds": [ + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "boe", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849023, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1806, + "versionNonce": 2071297217, + "isDeleted": false, + "id": "gAYUKI7G8-guwUYPk7yUM", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -153.12960813009067, + "y": -26896.706863954216, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1628320375, + "groupIds": [ + "1FdE-dy1TSU-BQNAWBAY4", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bof", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1776, + "versionNonce": 1044278223, + "isDeleted": false, + "id": "tC9vdNe5rCG2BAojIBjMc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -148.21546514411602, + "y": -26891.792720968242, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1403964311, + "groupIds": [ + "1FdE-dy1TSU-BQNAWBAY4", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bog", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1779, + "versionNonce": 470432929, + "isDeleted": false, + "id": "V237YFxeihcoS96fNM2Qh", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -148.70687944271322, + "y": -26883.438677892093, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 354369719, + "groupIds": [ + "1FdE-dy1TSU-BQNAWBAY4", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "boh", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1788, + "versionNonce": 775821807, + "isDeleted": false, + "id": "IozxmAEF5FXiUic5zwl4S", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -148.70687944271322, + "y": -26873.610391920145, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1996755415, + "groupIds": [ + "1FdE-dy1TSU-BQNAWBAY4", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "boi", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1856, + "versionNonce": 1874591873, + "isDeleted": false, + "id": "uBv5PVzvXlgEeYxP6PPPh", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -143.79273645673857, + "y": -26885.89574938508, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 577879799, + "groupIds": [ + "finoTulY_KnaMfV1Icdge", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "boj", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1831, + "versionNonce": 2053309455, + "isDeleted": false, + "id": "cWROiKAOBoX7fXQgApPI_", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -138.87859347076392, + "y": -26880.981606399106, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 703383575, + "groupIds": [ + "finoTulY_KnaMfV1Icdge", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bok", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1832, + "versionNonce": 340412513, + "isDeleted": false, + "id": "2wbA8IWo6ZZZhGT-K_9_r", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -139.3700077693611, + "y": -26872.62756332294, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1533652279, + "groupIds": [ + "finoTulY_KnaMfV1Icdge", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bol", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1841, + "versionNonce": 1655024175, + "isDeleted": false, + "id": "ITTwRDNcJqUjo1hjiOlgW", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -139.3700077693611, + "y": -26862.799277350994, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1380773463, + "groupIds": [ + "finoTulY_KnaMfV1Icdge", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bom", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1840, + "versionNonce": 1132762177, + "isDeleted": false, + "id": "d365ZDgFV-q3zLysgMDQR", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -132.98162188759488, + "y": -26879.015949204713, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1231752055, + "groupIds": [ + "tmgktR2kFglPxov6WgC2l", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bon", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1815, + "versionNonce": 334400591, + "isDeleted": false, + "id": "IppPGnQIFQnv4qSWaYjRL", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -128.06747890162023, + "y": -26874.10180621874, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 755532951, + "groupIds": [ + "tmgktR2kFglPxov6WgC2l", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "boo", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1816, + "versionNonce": 1363829793, + "isDeleted": false, + "id": "joPPPIlv3gDw_kTy7IQ3C", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -128.55889320021743, + "y": -26865.747763142583, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1826216375, + "groupIds": [ + "tmgktR2kFglPxov6WgC2l", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bop", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1825, + "versionNonce": 169224815, + "isDeleted": false, + "id": "ro81nCaveJngLd0Q9bjr0", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -128.55889320021743, + "y": -26855.919477170628, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 235113175, + "groupIds": [ + "tmgktR2kFglPxov6WgC2l", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "boq", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1858, + "versionNonce": 1770731521, + "isDeleted": false, + "id": "aoeQEZCG8QnpouJHx7CZE", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -125.11899311003526, + "y": -26870.170491829955, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 2098862071, + "groupIds": [ + "F9uyPnL0sV5lq9gp-_V8b", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bor", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1833, + "versionNonce": 837092495, + "isDeleted": false, + "id": "lvanf6B9690b17yVcnmDg", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -120.20485012406061, + "y": -26865.25634884398, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 539099415, + "groupIds": [ + "F9uyPnL0sV5lq9gp-_V8b", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bos", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1834, + "versionNonce": 239505377, + "isDeleted": false, + "id": "ToQMj7ROwwPEXw4s0ooQF", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -120.6962644226578, + "y": -26856.90230576783, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 680511031, + "groupIds": [ + "F9uyPnL0sV5lq9gp-_V8b", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bot", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1843, + "versionNonce": 1259575983, + "isDeleted": false, + "id": "RbAac18E8JInxOI7V1FSY", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": -120.6962644226578, + "y": -26847.074019795877, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 625469271, + "groupIds": [ + "F9uyPnL0sV5lq9gp-_V8b", + "cHvzGW5A6k2jw4anDUYv-", + "-4-Aar7Hn1SdO8fmAHTcf", + "iYk65fYeTF3t_D2HgJnBO", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "index": "bou", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210849024, + "link": null, + "locked": false + }, + { + "id": "b_BBY-2yhbMj7YeL9a7B_", + "type": "rectangle", + "x": -97.44921417061141, + "y": -26773.927383089638, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "46xHkSgbtWOD5thUxWlvP", + "qvlsJpmSUhdXLkEEmTupu", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "frameId": null, + "index": "bov", + "roundness": { + "type": 3 + }, + "seed": 1419699319, + "version": 1264, + "versionNonce": 74505103, + "isDeleted": false, + "boundElements": [ + { + "id": "upeK8VWE9GciZSkIVsesX", + "type": "arrow" + } + ], + "updated": 1762278152404, + "link": null, + "locked": false + }, + { + "id": "HHyjbxg6wq3tY-CN5fmET", + "type": "rectangle", + "x": -55.97947961179125, + "y": -26773.927383387945, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "46xHkSgbtWOD5thUxWlvP", + "qvlsJpmSUhdXLkEEmTupu", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "frameId": null, + "index": "bow", + "roundness": null, + "seed": 911818135, + "version": 1352, + "versionNonce": 1797078369, + "isDeleted": false, + "boundElements": [], + "updated": 1762210777928, + "link": null, + "locked": false + }, + { + "id": "kYrsJbBl9vSxCk-IXZIFf", + "type": "text", + "x": -77.85451783536155, + "y": -26773.9876988707, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "46xHkSgbtWOD5thUxWlvP", + "qvlsJpmSUhdXLkEEmTupu", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "frameId": null, + "index": "box", + "roundness": null, + "seed": 1571517111, + "version": 1089, + "versionNonce": 238086465, + "isDeleted": false, + "boundElements": [], + "updated": 1762210777928, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "eqRTiWwqtQ-gR4mKfDUzy", + "type": "text", + "x": -89.05795902071713, + "y": -26773.987699003123, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "46xHkSgbtWOD5thUxWlvP", + "qvlsJpmSUhdXLkEEmTupu", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "frameId": null, + "index": "boy", + "roundness": null, + "seed": 54133719, + "version": 1109, + "versionNonce": 228858145, + "isDeleted": false, + "boundElements": [], + "updated": 1762210777928, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "GvlY1skWQUMjKhg2WWLsU", + "type": "rectangle", + "x": -57.680566636116964, + "y": -26775.01103789962, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "46xHkSgbtWOD5thUxWlvP", + "qvlsJpmSUhdXLkEEmTupu", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "frameId": null, + "index": "boz", + "roundness": null, + "seed": 1461285111, + "version": 1403, + "versionNonce": 988171521, + "isDeleted": false, + "boundElements": [], + "updated": 1762210777928, + "link": null, + "locked": false + }, + { + "id": "OlJNK6cbDa217M_Na-UuX", + "type": "rectangle", + "x": -22.971684338024716, + "y": -26773.740111994925, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "46xHkSgbtWOD5thUxWlvP", + "qvlsJpmSUhdXLkEEmTupu", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "frameId": null, + "index": "bp0", + "roundness": null, + "seed": 315505175, + "version": 1327, + "versionNonce": 225903841, + "isDeleted": false, + "boundElements": [], + "updated": 1762210777928, + "link": null, + "locked": false + }, + { + "id": "25gharb9xp5VNt4PtPqIB", + "type": "text", + "x": -50.164510631527264, + "y": -26775.197153009653, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "XbwSU2xR3ZGl4Ath_QpS0", + "qvlsJpmSUhdXLkEEmTupu", + "Q7tpzCNl3wLFBEqvf9BHY" + ], + "frameId": null, + "index": "bp1", + "roundness": null, + "seed": 1263329079, + "version": 1305, + "versionNonce": 1719878497, + "isDeleted": false, + "boundElements": [ + { + "id": "fkyjDair8vrwOFXakk3Vf", + "type": "arrow" + } + ], + "updated": 1762278137635, + "link": null, + "locked": false, + "text": "2+", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "2+", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "AkWauviK9tdq7A_ABVTNK", + "type": "rectangle", + "x": 940, + "y": -26920, + "width": 182.01759766038205, + "height": 158.92029120482397, + "angle": 0, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "frameId": null, + "index": "bp2", + "roundness": { + "type": 3 + }, + "seed": 49930327, + "version": 2089, + "versionNonce": 572704015, + "isDeleted": false, + "boundElements": [ + { + "id": "qFMoo3YNqpx2NG_78dYib", + "type": "arrow" + }, + { + "id": "1vEPSXk8ZtjLUFiGiahid", + "type": "arrow" + } + ], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "id": "EyEh8KkE_BS0wsnypMDqW", + "type": "text", + "x": 949.723852570869, + "y": -26807.248640395053, + "width": 162.56989181607653, + "height": 26.536372124262765, + "angle": 0, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "frameId": null, + "index": "bp3", + "roundness": null, + "seed": 2074721655, + "version": 1956, + "versionNonce": 438507361, + "isDeleted": false, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false, + "text": "Service-Z", + "fontSize": 21.22909769941021, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Service-Z", + "autoResize": false, + "lineHeight": 1.25 + }, + { + "type": "ellipse", + "version": 2100, + "versionNonce": 1589988143, + "isDeleted": false, + "id": "qf8eFVrOo__-6hS_uEp70", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 993.1107915091807, + "y": -26905.15246243775, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 75.67780198400858, + "height": 73.71214478961875, + "seed": 1218508439, + "groupIds": [ + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bp4", + "frameId": null, + "roundness": null, + "boundElements": [ + { + "id": "qFMoo3YNqpx2NG_78dYib", + "type": "arrow" + } + ], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2039, + "versionNonce": 1399554881, + "isDeleted": false, + "id": "fTRTuILIbH9TB2-DFm3bm", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1006.8703918699102, + "y": -26897.289833660194, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 546573239, + "groupIds": [ + "xWOhhGKtO9iKcMirIdcou", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bp5", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2010, + "versionNonce": 225578319, + "isDeleted": false, + "id": "c72OCYdxN_kyiBjSP_YjT", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1011.7845348558849, + "y": -26892.37569067422, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1873247447, + "groupIds": [ + "xWOhhGKtO9iKcMirIdcou", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bp6", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2012, + "versionNonce": 1148941089, + "isDeleted": false, + "id": "uQHhOKWVIBDdj0c1VAAk_", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1011.2931205572868, + "y": -26884.021647598063, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 695192055, + "groupIds": [ + "xWOhhGKtO9iKcMirIdcou", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bp7", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2021, + "versionNonce": 1770097519, + "isDeleted": false, + "id": "ifz4fZDMgzAPcMTJM9dFl", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1011.2931205572868, + "y": -26874.19336162611, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1525773079, + "groupIds": [ + "xWOhhGKtO9iKcMirIdcou", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bp8", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2091, + "versionNonce": 297953025, + "isDeleted": false, + "id": "z_8544F232FRNxWi2ePOT", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1016.2072635432614, + "y": -26886.47871909105, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 2090924087, + "groupIds": [ + "__Ihvk7NsC7I35ASY-EO0", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bp9", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2064, + "versionNonce": 792479119, + "isDeleted": false, + "id": "Xly3_SgrCFGcoe_h8MWFH", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1021.1214065292361, + "y": -26881.564576105076, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 73587031, + "groupIds": [ + "__Ihvk7NsC7I35ASY-EO0", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpA", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2067, + "versionNonce": 633331425, + "isDeleted": false, + "id": "Z5TBeicv3e6d36nqWHNw2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1020.6299922306389, + "y": -26873.21053302892, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 931894903, + "groupIds": [ + "__Ihvk7NsC7I35ASY-EO0", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpB", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2076, + "versionNonce": 2111486895, + "isDeleted": false, + "id": "y-ZbNBgrSgkEqz2eENEcb", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1020.6299922306389, + "y": -26863.382247056972, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1021292439, + "groupIds": [ + "__Ihvk7NsC7I35ASY-EO0", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpC", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2074, + "versionNonce": 1862490817, + "isDeleted": false, + "id": "sbOjSMyA3V3MgPhgpvWoe", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1027.018378112406, + "y": -26879.598918910684, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1855169719, + "groupIds": [ + "_l22yw-OQThJWAvccchTy", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpD", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2049, + "versionNonce": 2038787535, + "isDeleted": false, + "id": "s-i2H3HGJL694DjD3jKBZ", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1031.9325210983807, + "y": -26874.68477592471, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1816917463, + "groupIds": [ + "_l22yw-OQThJWAvccchTy", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpE", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2051, + "versionNonce": 1579965089, + "isDeleted": false, + "id": "HLhI9httsvROkhk3k4cbC", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1031.4411067997826, + "y": -26866.330732848553, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1830626039, + "groupIds": [ + "_l22yw-OQThJWAvccchTy", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpF", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2060, + "versionNonce": 760536047, + "isDeleted": false, + "id": "5xDlpNKMNl7ePIJlAWCnR", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1031.4411067997826, + "y": -26856.502446876606, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1368108055, + "groupIds": [ + "_l22yw-OQThJWAvccchTy", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2091, + "versionNonce": 602562177, + "isDeleted": false, + "id": "RHpnlPfclSPiee7fvn_LS", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1034.8810068899647, + "y": -26870.753461535933, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1972113719, + "groupIds": [ + "KjwWkWMS3WAUvjcQbgOf9", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpH", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2068, + "versionNonce": 760317455, + "isDeleted": false, + "id": "d7H5byDHwix4Cq5_Ldw8y", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1039.7951498759394, + "y": -26865.83931854996, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1115869783, + "groupIds": [ + "KjwWkWMS3WAUvjcQbgOf9", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpI", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2067, + "versionNonce": 788325985, + "isDeleted": false, + "id": "XtNTOaniVZ5q_Z2JHrwVe", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1039.3037355773422, + "y": -26857.485275473795, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 21262199, + "groupIds": [ + "KjwWkWMS3WAUvjcQbgOf9", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpJ", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 2076, + "versionNonce": 2020863023, + "isDeleted": false, + "id": "2YhAyf4Yfhb30vrT8RF3C", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 1039.3037355773422, + "y": -26847.656989501847, + "strokeColor": "#6741d9", + "backgroundColor": "#eebefa", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1813342359, + "groupIds": [ + "KjwWkWMS3WAUvjcQbgOf9", + "BrvB72Xlc4J0jqCS5nStF", + "zJSfWymZLv8gEBVQqxFiW", + "iXUsJ2JnEJPPcgB59JTWR", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "index": "bpK", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210860516, + "link": null, + "locked": false + }, + { + "id": "Sxjpl3ryUdCHVZkA6EzDw", + "type": "rectangle", + "x": 1066.5390741908677, + "y": -26774.510350159893, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "HxIhx6u-rh2gbOyS4BOji", + "mDThnzArRMgKFOdRZ9LzY", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "frameId": null, + "index": "bpL", + "roundness": { + "type": 3 + }, + "seed": 11156919, + "version": 1265, + "versionNonce": 1704360379, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575039, + "link": null, + "locked": false + }, + { + "id": "PlQWRq4yam5J4zsDAPX4i", + "type": "rectangle", + "x": 1108.008808749688, + "y": -26774.5103504582, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "HxIhx6u-rh2gbOyS4BOji", + "mDThnzArRMgKFOdRZ9LzY", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "frameId": null, + "index": "bpM", + "roundness": null, + "seed": 304574167, + "version": 1358, + "versionNonce": 833981019, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575039, + "link": null, + "locked": false + }, + { + "id": "g1ZznZ3ECipeW-YqnfLOB", + "type": "text", + "x": 1086.1337705261167, + "y": -26774.570665940948, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "HxIhx6u-rh2gbOyS4BOji", + "mDThnzArRMgKFOdRZ9LzY", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "frameId": null, + "index": "bpN", + "roundness": null, + "seed": 455179255, + "version": 1093, + "versionNonce": 350848763, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575039, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "wj9ZjVlLHYGymOyFq-CDH", + "type": "text", + "x": 1074.930329340761, + "y": -26774.57066607337, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "HxIhx6u-rh2gbOyS4BOji", + "mDThnzArRMgKFOdRZ9LzY", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "frameId": null, + "index": "bpO", + "roundness": null, + "seed": 1335682327, + "version": 1112, + "versionNonce": 901050267, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575039, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "XiBFQKTYQHbPH5qiOzoj-", + "type": "rectangle", + "x": 1106.3077217253613, + "y": -26775.59400496987, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "HxIhx6u-rh2gbOyS4BOji", + "mDThnzArRMgKFOdRZ9LzY", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "frameId": null, + "index": "bpP", + "roundness": null, + "seed": 1863199287, + "version": 1402, + "versionNonce": 1179272251, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575039, + "link": null, + "locked": false + }, + { + "id": "46Meh_BZjndw1ukwL_FyJ", + "type": "rectangle", + "x": 1141.0166040234544, + "y": -26774.323079065172, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "HxIhx6u-rh2gbOyS4BOji", + "mDThnzArRMgKFOdRZ9LzY", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "frameId": null, + "index": "bpQ", + "roundness": null, + "seed": 1448725335, + "version": 1333, + "versionNonce": 244057307, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575039, + "link": null, + "locked": false + }, + { + "id": "BDIFtHFJYkkYB7u-iMpjN", + "type": "text", + "x": 1113.8237777299519, + "y": -26775.780120079908, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "QIX4WhqNwU0VHBPN2ZcSi", + "mDThnzArRMgKFOdRZ9LzY", + "FoSgKmwc1GZmFlU6Mr6rB" + ], + "frameId": null, + "index": "bpR", + "roundness": null, + "seed": 1372866679, + "version": 1306, + "versionNonce": 906801531, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575039, + "link": null, + "locked": false, + "text": "4", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "4", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "swA5vVBmSI7fGuJ_rw1hv", + "type": "arrow", + "x": -139.99999999999875, + "y": -27219.999999999996, + "width": 19.99999999999875, + "height": 279.99999999999636, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpS", + "roundness": { + "type": 2 + }, + "seed": 792863127, + "version": 3163, + "versionNonce": 1080924623, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "bue_9Kv1E3TlM2Q_XN_Tr" + } + ], + "updated": 1762427426224, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 19.99999999999875, + 139.99999999999636 + ], + [ + 19.99999999999875, + 279.99999999999636 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "9z3pprmmWORQVT9ErQBxw", + "focus": 0.03169681208783552, + "gap": 17.417244037718774 + }, + "endBinding": { + "elementId": "bVEI9mF_I-D7-r952tSmf", + "focus": -0.5052322895524326, + "gap": 32 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "bue_9Kv1E3TlM2Q_XN_Tr", + "type": "text", + "x": -127.552978515625, + "y": -22769.828285971947, + "width": 95.10595703125, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpT", + "roundness": null, + "seed": 265803447, + "version": 103, + "versionNonce": 2025038555, + "isDeleted": false, + "boundElements": [], + "updated": 1762181928875, + "link": null, + "locked": false, + "text": "Autorisatie", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "swA5vVBmSI7fGuJ_rw1hv", + "originalText": "Autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "FlQP00oNGruBJfXHn0IMb", + "type": "arrow", + "x": 456.4759103315245, + "y": -27254.761989638828, + "width": 3.524089668475483, + "height": 314.7619896388278, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpU", + "roundness": { + "type": 2 + }, + "seed": 2050615255, + "version": 3626, + "versionNonce": 1720704405, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "2f_UpGMARYmMSIwYU221l" + } + ], + "updated": 1762209578077, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 3.524089668475483, + 194.7619896388278 + ], + [ + 3.524089668475483, + 314.7619896388278 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "uXgoD89oppTQcPATZ6No-", + "focus": -0.019965274951152828, + "gap": 19.865293465747527 + }, + "endBinding": { + "elementId": "hSQc06kmbdlvLZHiyh0UJ", + "focus": -0.3407230864352578, + "gap": 20 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "2f_UpGMARYmMSIwYU221l", + "type": "text", + "x": 412.447021484375, + "y": -22769.828285971947, + "width": 95.10595703125, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpV", + "roundness": null, + "seed": 746378487, + "version": 85, + "versionNonce": 567155157, + "isDeleted": false, + "boundElements": [], + "updated": 1762181773120, + "link": null, + "locked": false, + "text": "Autorisatie", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "FlQP00oNGruBJfXHn0IMb", + "originalText": "Autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "rXnwf2x-CgC80hrCbU6s5", + "type": "rectangle", + "x": 981.8658536547746, + "y": -28187.263106656595, + "width": 188.2434291679236, + "height": 186.42385861006738, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ffec99", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "UBTz0WVD7dTFw_wYwdv2W", + "83j7KJ0UhKJInX3yuv2WA" + ], + "frameId": null, + "index": "bpW", + "roundness": { + "type": 3 + }, + "seed": 774184471, + "version": 1226, + "versionNonce": 554778459, + "isDeleted": false, + "boundElements": [ + { + "id": "Bwyv0GyNaf5681mVGxHzv", + "type": "arrow" + } + ], + "updated": 1762209575039, + "link": null, + "locked": false + }, + { + "id": "4DcAIsX5GGmNqaBe7VN1U", + "type": "image", + "x": 1034.7989834680666, + "y": -28138.207263365548, + "width": 88.3121708098049, + "height": 88.3121708098049, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "ThZuRKiapU9TH8jfEjN8m", + "UBTz0WVD7dTFw_wYwdv2W", + "83j7KJ0UhKJInX3yuv2WA" + ], + "frameId": null, + "index": "bpX", + "roundness": null, + "seed": 572998455, + "version": 1421, + "versionNonce": 1762040827, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575039, + "link": null, + "locked": false, + "status": "saved", + "fileId": "e21a81d007aa429a6881761880032f610f46617a", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "oygSI6OtVCVaUf-ON5zyG", + "type": "text", + "x": 1031.1214856590022, + "y": -28174.630767522554, + "width": 89.73216394260524, + "height": 24.570714929872917, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "ThZuRKiapU9TH8jfEjN8m", + "UBTz0WVD7dTFw_wYwdv2W", + "83j7KJ0UhKJInX3yuv2WA" + ], + "frameId": null, + "index": "bpY", + "roundness": null, + "seed": 1491584087, + "version": 1225, + "versionNonce": 258434203, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false, + "text": "Bedrijf B", + "fontSize": 19.65657194389833, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Bedrijf B", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "rKYAVpFtjaVk8cCQkFADp", + "type": "text", + "x": 1003.6416070880196, + "y": -27977.61501454282, + "width": 144.69192230135783, + "height": 24.570714929872917, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "hP9qS-7EA5jrQwFfZAG6o", + "9mzGetNM_y5Jsp7qZqnYy", + "snsgWmn56ffpfHrvftvqM", + "gke0XUb3EIvl-X1M8pZm1", + "sWcYNMfLEmRw1vcDfTOhM", + "83j7KJ0UhKJInX3yuv2WA" + ], + "frameId": null, + "index": "bpZ", + "roundness": null, + "seed": 574300535, + "version": 1662, + "versionNonce": 199629115, + "isDeleted": false, + "boundElements": [ + { + "id": "Bwyv0GyNaf5681mVGxHzv", + "type": "arrow" + } + ], + "updated": 1762209575040, + "link": null, + "locked": false, + "text": "Tekenbevoegde", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Tekenbevoegde", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "zn4vObTaQbk5UpfLCiSXO", + "type": "image", + "x": 1040.9693917920886, + "y": -28048.634195727776, + "width": 70.0363526201069, + "height": 70.0363526201069, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "ukOIknMKPaLVM9K55Sr3g", + "2hAy7QqBT_1c3A03wm1zs", + "XT8RqwHYnU_kWfBL7JOY6", + "sWcYNMfLEmRw1vcDfTOhM", + "83j7KJ0UhKJInX3yuv2WA" + ], + "frameId": null, + "index": "bpa", + "roundness": null, + "seed": 1600510615, + "version": 1901, + "versionNonce": 1004878299, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false, + "status": "saved", + "fileId": "ebbbf7d44e2b8252a57c53ae5d8b94fdea1ea5cc", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "6QVeVTbs_JEBUMJsGlPpU", + "type": "rectangle", + "x": 1276.714432813249, + "y": -28187.263106656595, + "width": 188.2434291679236, + "height": 186.42385861006738, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ffec99", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "LR8N6rUldtmPud3K6Rqax", + "vkgYzYv7aV01BN88yHIte" + ], + "frameId": null, + "index": "bpb", + "roundness": { + "type": 3 + }, + "seed": 1427926967, + "version": 1350, + "versionNonce": 746014331, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false + }, + { + "id": "C-6excFQK1yt3_HSyO5hh", + "type": "text", + "x": 1327.267398265839, + "y": -28174.630767522554, + "width": 87.13749704588163, + "height": 24.570714929872917, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "vutxTdACZpx90ur0zUnG9", + "LR8N6rUldtmPud3K6Rqax", + "vkgYzYv7aV01BN88yHIte" + ], + "frameId": null, + "index": "bpc", + "roundness": null, + "seed": 1032020183, + "version": 1357, + "versionNonce": 610189083, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false, + "text": "Bedrijf C", + "fontSize": 19.65657194389833, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Bedrijf C", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "oYBz55MROJ7s3Kf0ZC8R-", + "type": "text", + "x": 1312.445663460786, + "y": -28132.732253554575, + "width": 128.71179724913839, + "height": 87.27514234223845, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "vkgYzYv7aV01BN88yHIte" + ], + "frameId": null, + "index": "bpd", + "roundness": null, + "seed": 439299575, + "version": 1042, + "versionNonce": 1846420411, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false, + "text": "ZZP", + "fontSize": 75.89142812368563, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "ZZP", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "8gUh2W8c-sKCPUHcO4QQ5", + "type": "text", + "x": 1342.117561752494, + "y": -27977.61501513201, + "width": 69.36799919930738, + "height": 49.141429859745834, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "Ratfk5-uKPbm1Y3vYdo_J", + "iceWAWOpzTYlwJKMGvczc", + "rTiZKXD_by-DAlQJEzvE8", + "DBV0XAHaYSIwLuyk8BsKq", + "_gvjlQjmBzGv1Yi3VRHZG", + "vkgYzYv7aV01BN88yHIte" + ], + "frameId": null, + "index": "bpe", + "roundness": null, + "seed": 1176786711, + "version": 1762, + "versionNonce": 1638397019, + "isDeleted": false, + "boundElements": [ + { + "id": "uKDwV6Z7bXxRz7KX9En8z", + "type": "arrow" + } + ], + "updated": 1762209575040, + "link": null, + "locked": false, + "text": "ZZP'er\nJoost", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "ZZP'er\nJoost", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "GVAlg4sT-jQjrtpC5Bwt6", + "type": "image", + "x": 1341.7833849055378, + "y": -28048.63419631697, + "width": 70.0363526201069, + "height": 70.0363526201069, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "xWM86uL-u5W4ljf29IbDM", + "zAFtwtBa0GksnuPq6Z727", + "8r8px0tQ6P6pt5g2n888E", + "_gvjlQjmBzGv1Yi3VRHZG", + "vkgYzYv7aV01BN88yHIte" + ], + "frameId": null, + "index": "bpf", + "roundness": null, + "seed": 1205296183, + "version": 1977, + "versionNonce": 1737808283, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false, + "status": "saved", + "fileId": "ebbbf7d44e2b8252a57c53ae5d8b94fdea1ea5cc", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "-tVqAxWzDpMZtknW7ZFq_", + "type": "rectangle", + "x": -136.93683293043114, + "y": -28183, + "width": 188.2434291679236, + "height": 186.42385861006738, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ffec99", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "r-sAdivnibVEHsW3kI-S7", + "bnkL0j1SFsgp3CwfYgG4o", + "Okdjk4U22s-kyfDms7EV0" + ], + "frameId": null, + "index": "bpg", + "roundness": { + "type": 3 + }, + "seed": 1663876439, + "version": 1289, + "versionNonce": 1218244155, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false + }, + { + "id": "hZGuwraKeJf5BjioyVDoY", + "type": "image", + "x": -86.20341748447345, + "y": -28136.58580891174, + "width": 86.77659852692989, + "height": 86.77659852692989, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#ffec99", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "U6Op0f-n_lAepGur0E7yw", + "r-sAdivnibVEHsW3kI-S7", + "bnkL0j1SFsgp3CwfYgG4o", + "Okdjk4U22s-kyfDms7EV0" + ], + "frameId": null, + "index": "bph", + "roundness": null, + "seed": 1803090551, + "version": 1470, + "versionNonce": 1157197531, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false, + "status": "saved", + "fileId": "25d6473c393dcaa08bfeb9e87a3b1cc1dc3263ed", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "E-00vlinyL2yKjLNZ52F5", + "type": "text", + "x": -86.82711777145005, + "y": -28172.25875368032, + "width": 88.06135832672874, + "height": 24.570714929872917, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#ffec99", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "U6Op0f-n_lAepGur0E7yw", + "r-sAdivnibVEHsW3kI-S7", + "bnkL0j1SFsgp3CwfYgG4o", + "Okdjk4U22s-kyfDms7EV0" + ], + "frameId": null, + "index": "bpi", + "roundness": null, + "seed": 1434489751, + "version": 1442, + "versionNonce": 1329388411, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false, + "text": "Bedrijf A", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Bedrijf A", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "tIxQFC98P41VV871K12Zf", + "type": "text", + "x": -110.40094073293449, + "y": -27973.565626024, + "width": 144.69192230135783, + "height": 24.570714929872917, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "CVFVcUxI8kA8wJaLwSKBd", + "-5YHnQjCV2nWyjsGhkbgj", + "SUp-FoSxwByjSqvzOFCVt", + "bnkL0j1SFsgp3CwfYgG4o", + "Okdjk4U22s-kyfDms7EV0" + ], + "frameId": null, + "index": "bpj", + "roundness": null, + "seed": 158861495, + "version": 1659, + "versionNonce": 1672066075, + "isDeleted": false, + "boundElements": [ + { + "id": "c95pq3z5z6u6q5ymZ1Y4d", + "type": "arrow" + }, + { + "id": "jFRzvCDoEGb-2JaefMTU9", + "type": "arrow" + } + ], + "updated": 1762209575040, + "link": null, + "locked": false, + "text": "Tekenbevoegde", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Tekenbevoegde", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "j4RLf405cVZsBIdO8prbo", + "type": "image", + "x": -77.8332951330467, + "y": -28043.601979028812, + "width": 70.0363526201069, + "height": 70.0363526201069, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "NuxBR18H9FFUzKMlyRIBE", + "0AzTgKNBkKCjTzKM3gI27", + "REEVepHeuzUP-nPuC5WaU", + "Okdjk4U22s-kyfDms7EV0" + ], + "frameId": null, + "index": "bpk", + "roundness": null, + "seed": 1963186647, + "version": 1932, + "versionNonce": 466732539, + "isDeleted": false, + "boundElements": [ + { + "id": "jFRzvCDoEGb-2JaefMTU9", + "type": "arrow" + } + ], + "updated": 1762209575040, + "link": null, + "locked": false, + "status": "saved", + "fileId": "ebbbf7d44e2b8252a57c53ae5d8b94fdea1ea5cc", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "84CJw6VklhzE4JkiJfmrJ", + "type": "rectangle", + "x": 430.451555057316, + "y": -28192, + "width": 188.2434291679236, + "height": 186.42385861006738, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff9db", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "C7erEVStgH2Qx2vdNvY1f", + "LtakVXTL7czqAznSOTgH8", + "vMGOhTbRx7OO0ZrHUvF9V", + "VG_oYDtbIHP9qVPP224JX" + ], + "frameId": null, + "index": "bpl", + "roundness": { + "type": 3 + }, + "seed": 1563985655, + "version": 1511, + "versionNonce": 1396526747, + "isDeleted": false, + "boundElements": [ + { + "id": "Bwyv0GyNaf5681mVGxHzv", + "type": "arrow" + }, + { + "id": "jFRzvCDoEGb-2JaefMTU9", + "type": "arrow" + } + ], + "updated": 1762209575040, + "link": null, + "locked": false + }, + { + "id": "ib0YL5ctQ9VhIkipTACkt", + "type": "image", + "x": 497.4600625312287, + "y": -28121.978702962122, + "width": 54.88403025617933, + "height": 54.88403025617933, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "Ke48JTNYPqohXR2EE_8My", + "LtakVXTL7czqAznSOTgH8", + "vMGOhTbRx7OO0ZrHUvF9V", + "VG_oYDtbIHP9qVPP224JX" + ], + "frameId": null, + "index": "bpm", + "roundness": null, + "seed": 1889177623, + "version": 1389, + "versionNonce": 1398632571, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false, + "status": "saved", + "fileId": "9488ea2e35c4743e75d9d6e17bd42751c4edce9a", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "PrJAhQSAstE0YGaG4rbXJ", + "type": "text", + "x": 459.9734335571666, + "y": -28179.844674596163, + "width": 131.639944733577, + "height": 49.141429859745834, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "xY8LiWqMk0yhNp2Ihc2Kw", + "Ke48JTNYPqohXR2EE_8My", + "LtakVXTL7czqAznSOTgH8", + "vMGOhTbRx7OO0ZrHUvF9V", + "VG_oYDtbIHP9qVPP224JX" + ], + "frameId": null, + "index": "bpn", + "roundness": null, + "seed": 421426487, + "version": 1366, + "versionNonce": 552577307, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575040, + "link": null, + "locked": false, + "text": "Bedrijf X\n(Intermediair)", + "fontSize": 19.65657194389833, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Bedrijf X\n(Intermediair)", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "I1Tn98FmwvmeDFGFPqDw6", + "type": "text", + "x": 458.66296635761955, + "y": -27980.75233350478, + "width": 144.69192230135783, + "height": 24.570714929872917, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "rGK4ugRu2b2cepRtAAZGA", + "Iz3ASBdMO5EQAyR2-SKOb", + "hXrx2DJ6M9LJEuQFNw0Fr", + "vMGOhTbRx7OO0ZrHUvF9V", + "VG_oYDtbIHP9qVPP224JX" + ], + "frameId": null, + "index": "bpo", + "roundness": null, + "seed": 237549143, + "version": 1610, + "versionNonce": 1022479803, + "isDeleted": false, + "boundElements": [ + { + "id": "etrqDEPoa6u7LdJVBBpvY", + "type": "arrow" + } + ], + "updated": 1762209575040, + "link": null, + "locked": false, + "text": "Tekenbevoegde", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Tekenbevoegde", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "kPjTnjrsnjvhQ8Je4ZWGw", + "type": "image", + "x": 489.55509328058815, + "y": -28052.823493859418, + "width": 70.0363526201069, + "height": 70.0363526201069, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "WO-SU0KTF0UW3AX1iw0-N", + "tgakUUG8AeXrLBiUKNQIi", + "eY2-Jc6n2A4uAPNnHFOv7", + "KfU6ejE61mn49XZGXjZcX", + "bjfE_Z4V5WWucaRukEbNn", + "VG_oYDtbIHP9qVPP224JX" + ], + "frameId": null, + "index": "bpp", + "roundness": null, + "seed": 646828919, + "version": 1962, + "versionNonce": 1686100731, + "isDeleted": false, + "boundElements": [ + { + "id": "etrqDEPoa6u7LdJVBBpvY", + "type": "arrow" + } + ], + "updated": 1762209575040, + "link": null, + "locked": false, + "status": "saved", + "fileId": "ebbbf7d44e2b8252a57c53ae5d8b94fdea1ea5cc", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "DzKAm8JbctpAcFWOKmbFx", + "type": "arrow", + "x": 570.7128405530287, + "y": -27680.36126367634, + "width": 30.25756531043305, + "height": 111.72405563192297, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpq", + "roundness": { + "type": 2 + }, + "seed": 1787972759, + "version": 5595, + "versionNonce": 392903765, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "Ee5w92HpUK3pTKuZcnmhC" + } + ], + "updated": 1762209578077, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 29.28715944697126, + 55.62437033293463 + ], + [ + -0.9704058634617923, + 111.72405563192297 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "XWyPIyUNGntwcwM-r2zQG", + "focus": 0.04773943410866287, + "gap": 13.136105761269661 + }, + "endBinding": { + "elementId": "XTIImqJxaCuAxnxnnaRPb", + "focus": -0.10646038362505256, + "gap": 31.9960985972116 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "Ee5w92HpUK3pTKuZcnmhC", + "type": "text", + "x": -660.9313658462897, + "y": -24221.85130580458, + "width": 100.01841735839844, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpr", + "roundness": null, + "seed": 1709875639, + "version": 113, + "versionNonce": 1020817211, + "isDeleted": false, + "boundElements": [], + "updated": 1762202010213, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "DzKAm8JbctpAcFWOKmbFx", + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "xzGTuGQY1mxCoh4SowOOR", + "type": "arrow", + "x": 661.2387745039827, + "y": -27223.316059370693, + "width": 161.23877450398265, + "height": 283.3160593706925, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bps", + "roundness": { + "type": 2 + }, + "seed": 968577751, + "version": 3480, + "versionNonce": 466282933, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "2czr7-GwixyvOM2_3lxkI" + } + ], + "updated": 1762209578077, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -61.022125739823764, + 163.31605937069253 + ], + [ + -161.23877450398265, + 283.3160593706925 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "5CSFTGcoSIAl1scpR_QIl", + "focus": -0.27418428885918505, + "gap": 21.52355043026546 + }, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "2czr7-GwixyvOM2_3lxkI", + "type": "text", + "x": 472.447021484375, + "y": -22809.828285971947, + "width": 95.10595703125, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpt", + "roundness": null, + "seed": 1855512567, + "version": 112, + "versionNonce": 1791985525, + "isDeleted": false, + "boundElements": [], + "updated": 1762179636651, + "link": null, + "locked": false, + "text": "Autorisatie", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "xzGTuGQY1mxCoh4SowOOR", + "originalText": "Autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "JF4UI4EIEyu4eUsqK2jjq", + "type": "arrow", + "x": 1185.487171962647, + "y": -27240, + "width": 620.1345461847901, + "height": 300.9653992904787, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpu", + "roundness": null, + "seed": 109562135, + "version": 3147, + "versionNonce": 405389429, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "biWVewAIXznYY6CR8qgai" + } + ], + "updated": 1762209578077, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -285.4871719626469, + 180 + ], + [ + -620.1345461847901, + 300.9653992904787 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "FtEvpUGUOzFAWqj9uO821", + "focus": -0.5246517253629719, + "gap": 10.810869239867316 + }, + "endBinding": { + "elementId": "hSQc06kmbdlvLZHiyh0UJ", + "focus": -0.6374454515330465, + "gap": 20.646533509474455 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "biWVewAIXznYY6CR8qgai", + "type": "text", + "x": 892.447021484375, + "y": -22769.828285971947, + "width": 95.10595703125, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpv", + "roundness": null, + "seed": 1325174327, + "version": 94, + "versionNonce": 1626740533, + "isDeleted": false, + "boundElements": [], + "updated": 1762181773120, + "link": null, + "locked": false, + "text": "Autorisatie", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "JF4UI4EIEyu4eUsqK2jjq", + "originalText": "Autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "qFMoo3YNqpx2NG_78dYib", + "type": "arrow", + "x": 1413.695401393013, + "y": -27220, + "width": 293.69540139301307, + "height": 300, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpy", + "roundness": { + "type": 2 + }, + "seed": 2006648215, + "version": 3797, + "versionNonce": 17989583, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "NmhTf93FeptkgWisQTlVe" + } + ], + "updated": 1762278127134, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -153.69540139301307, + 160 + ], + [ + -293.69540139301307, + 300 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "fVYpugqYwmAu4HaSvygba", + "focus": -0.42483768673827516, + "gap": 14.396606607973808 + }, + "endBinding": { + "elementId": "AkWauviK9tdq7A_ABVTNK", + "focus": 0.05591080298594686, + "gap": 9.918358233490098 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "NmhTf93FeptkgWisQTlVe", + "type": "text", + "x": 1232.447021484375, + "y": -22769.828285971947, + "width": 95.10595703125, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bpz", + "roundness": null, + "seed": 594819767, + "version": 125, + "versionNonce": 1436498683, + "isDeleted": false, + "boundElements": [], + "updated": 1762181915918, + "link": null, + "locked": false, + "text": "Autorisatie", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "qFMoo3YNqpx2NG_78dYib", + "originalText": "Autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "hSQc06kmbdlvLZHiyh0UJ", + "type": "rectangle", + "x": 400, + "y": -26920, + "width": 182.01759766038205, + "height": 158.92029120482397, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "frameId": null, + "index": "bq2", + "roundness": { + "type": 3 + }, + "seed": 1626079767, + "version": 1954, + "versionNonce": 1158196879, + "isDeleted": false, + "boundElements": [ + { + "id": "FlQP00oNGruBJfXHn0IMb", + "type": "arrow" + }, + { + "id": "110qgmWaZ5RbVS1oTZ_FB", + "type": "arrow" + }, + { + "id": "t0-rXf5lNQjcAklVnj4Lo", + "type": "arrow" + }, + { + "id": "JF4UI4EIEyu4eUsqK2jjq", + "type": "arrow" + } + ], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "id": "5iPc0BoyyF_BunPWJxxn3", + "type": "text", + "x": 409.72385355369715, + "y": -26808.59134937403, + "width": 162.56989181607653, + "height": 26.536372124262762, + "angle": 0, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "frameId": null, + "index": "bq3", + "roundness": null, + "seed": 577873719, + "version": 1827, + "versionNonce": 1651164385, + "isDeleted": false, + "boundElements": [], + "updated": 1762246745012, + "link": null, + "locked": false, + "text": "MOZa", + "fontSize": 21.22909769941021, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "MOZa", + "autoResize": false, + "lineHeight": 1.25 + }, + { + "type": "ellipse", + "version": 1967, + "versionNonce": 1345455279, + "isDeleted": false, + "id": "jWHcr08MlZIGDE5MKwBJ5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 453.1107915091802, + "y": -26905.152462437763, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 75.67780198400858, + "height": 73.71214478961875, + "seed": 709208151, + "groupIds": [ + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bq4", + "frameId": null, + "roundness": null, + "boundElements": [ + { + "id": "FlQP00oNGruBJfXHn0IMb", + "type": "arrow" + } + ], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1906, + "versionNonce": 123806145, + "isDeleted": false, + "id": "kFUbQJsWkcJfi-tyXT3G7", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 466.8703918699093, + "y": -26897.2898336602, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1446806903, + "groupIds": [ + "0Zij-DXEX4n8YGpT-75zW", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bq5", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1878, + "versionNonce": 1946916559, + "isDeleted": false, + "id": "Td1pbRPhVvXp21Oe585DL", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 471.784534855884, + "y": -26892.375690674227, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1436204695, + "groupIds": [ + "0Zij-DXEX4n8YGpT-75zW", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bq6", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1880, + "versionNonce": 1429815713, + "isDeleted": false, + "id": "LQiyIHP2dpU8TL9x0Y_o3", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 471.29312055728633, + "y": -26884.02164759807, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 2064962487, + "groupIds": [ + "0Zij-DXEX4n8YGpT-75zW", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bq7", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1889, + "versionNonce": 657319151, + "isDeleted": false, + "id": "1w3f_T1r9XHvRYQv7_y4L", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 471.29312055728633, + "y": -26874.193361626123, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1322206423, + "groupIds": [ + "0Zij-DXEX4n8YGpT-75zW", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bq8", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1958, + "versionNonce": 381838721, + "isDeleted": false, + "id": "QnbG-7yJQW6uHJBII-v_W", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 476.207263543261, + "y": -26886.478719091057, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1616810487, + "groupIds": [ + "jOW07dH2cbt6RbUe9ozUR", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bq9", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1932, + "versionNonce": 2032234255, + "isDeleted": false, + "id": "KFaB0khzbxvdgQp9Rsgba", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 481.1214065292356, + "y": -26881.564576105084, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1489451799, + "groupIds": [ + "jOW07dH2cbt6RbUe9ozUR", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqA", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1934, + "versionNonce": 926682465, + "isDeleted": false, + "id": "B-_E8P06Gbxiql5dtcY5o", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 480.629992230638, + "y": -26873.210533028927, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1283309623, + "groupIds": [ + "jOW07dH2cbt6RbUe9ozUR", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqB", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1943, + "versionNonce": 1952363823, + "isDeleted": false, + "id": "NEoVlrERlXk4BswpD92bb", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 480.629992230638, + "y": -26863.382247056972, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1298571607, + "groupIds": [ + "jOW07dH2cbt6RbUe9ozUR", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqC", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1946, + "versionNonce": 234207553, + "isDeleted": false, + "id": "qJ3Rt6BtUdBYJE9WpiGzi", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 487.0183781124051, + "y": -26879.59891891069, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 1020681847, + "groupIds": [ + "NMwxALMPCTiYESdXh3NaI", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqD", + "frameId": null, + "roundness": null, + "boundElements": [ + { + "id": "110qgmWaZ5RbVS1oTZ_FB", + "type": "arrow" + } + ], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1916, + "versionNonce": 1078867791, + "isDeleted": false, + "id": "bzePD0uNNiM4sejkPJnw4", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 491.93252109837977, + "y": -26874.684775924718, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1569814423, + "groupIds": [ + "NMwxALMPCTiYESdXh3NaI", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqE", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1918, + "versionNonce": 1548675361, + "isDeleted": false, + "id": "J8O_zPR3RS5BS2sbcTn2M", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 491.4411067997821, + "y": -26866.33073284856, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 634154167, + "groupIds": [ + "NMwxALMPCTiYESdXh3NaI", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqF", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1927, + "versionNonce": 55080303, + "isDeleted": false, + "id": "EP5FHpO3rplIX7Y_23ufW", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 491.4411067997821, + "y": -26856.502446876613, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1361821143, + "groupIds": [ + "NMwxALMPCTiYESdXh3NaI", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqG", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1961, + "versionNonce": 196549889, + "isDeleted": false, + "id": "P1oo6vSTcf8tGFlyg2bUo", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 494.8810068899643, + "y": -26870.75346153594, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 16.708086152313587, + "height": 33.41617230462718, + "seed": 851700471, + "groupIds": [ + "FWqCw41CJvwTB1rEYS7DS", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqH", + "frameId": null, + "roundness": null, + "boundElements": [ + { + "id": "swA5vVBmSI7fGuJ_rw1hv", + "type": "arrow" + } + ], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1935, + "versionNonce": 76935055, + "isDeleted": false, + "id": "WelbGnolrE71VoJ2__TKS", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 499.79514987593893, + "y": -26865.839318549966, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1192850455, + "groupIds": [ + "FWqCw41CJvwTB1rEYS7DS", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqI", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1935, + "versionNonce": 732812513, + "isDeleted": false, + "id": "l4R9BM4wHxZ2Oz9TMOYQb", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 499.3037355773413, + "y": -26857.48527547381, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 102816055, + "groupIds": [ + "FWqCw41CJvwTB1rEYS7DS", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqJ", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "type": "rectangle", + "version": 1952, + "versionNonce": 242165167, + "isDeleted": false, + "id": "72I8IGKd9pp9eF2-6ppni", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "angle": 0, + "x": 499.3037355773413, + "y": -26847.656989501862, + "strokeColor": "#1971c2", + "backgroundColor": "#ffd43b", + "width": 8.84545737475425, + "height": 2.94848579158475, + "seed": 1967037015, + "groupIds": [ + "FWqCw41CJvwTB1rEYS7DS", + "9FDl00jpiJEFiMPF6bys4", + "4A3oBkj8xMGpzZl7OGOgY", + "5hVlw7DnEtPFcgtXsqtSU", + "akiMguSCLYTjYb8TjYb_L" + ], + "index": "bqK", + "frameId": null, + "roundness": null, + "boundElements": [], + "updated": 1762210990750, + "link": null, + "locked": false + }, + { + "id": "jt6IYw8v8W6tmE53dUseY", + "type": "rectangle", + "x": 519.4929641723734, + "y": -26774.510351824036, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "uIFXLz9THy_Ikkw4Ee_dv", + "UE8-xyNGwZ9E94kwsbhKW", + "47Cgm_mEHPZU-Rx05v1Gh", + "akiMguSCLYTjYb8TjYb_L" + ], + "frameId": null, + "index": "bqL", + "roundness": { + "type": 3 + }, + "seed": 2034710391, + "version": 1264, + "versionNonce": 1901295579, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "QlqcqUb-zh-Vr32pbRC7v", + "type": "rectangle", + "x": 560.9626987311935, + "y": -26774.51035212235, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "uIFXLz9THy_Ikkw4Ee_dv", + "UE8-xyNGwZ9E94kwsbhKW", + "47Cgm_mEHPZU-Rx05v1Gh", + "akiMguSCLYTjYb8TjYb_L" + ], + "frameId": null, + "index": "bqM", + "roundness": null, + "seed": 1753165975, + "version": 1356, + "versionNonce": 1433257083, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "IPcANhPIGY98i4YLw6S6e", + "type": "text", + "x": 539.0876605076228, + "y": -26774.57066760509, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "uIFXLz9THy_Ikkw4Ee_dv", + "UE8-xyNGwZ9E94kwsbhKW", + "47Cgm_mEHPZU-Rx05v1Gh", + "akiMguSCLYTjYb8TjYb_L" + ], + "frameId": null, + "index": "bqN", + "roundness": null, + "seed": 1553663415, + "version": 1089, + "versionNonce": 634748187, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "_phTlQLk8vKvlLQy-4esb", + "type": "text", + "x": 527.8842193222667, + "y": -26774.570667737513, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "uIFXLz9THy_Ikkw4Ee_dv", + "UE8-xyNGwZ9E94kwsbhKW", + "47Cgm_mEHPZU-Rx05v1Gh", + "akiMguSCLYTjYb8TjYb_L" + ], + "frameId": null, + "index": "bqO", + "roundness": null, + "seed": 1153382103, + "version": 1111, + "versionNonce": 1515859695, + "isDeleted": false, + "boundElements": [ + { + "id": "S5P9rHYxH7HoVhBLyTYUu", + "type": "arrow" + } + ], + "updated": 1762248417206, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "q7uDF86Nt-qtNqlzRS_lG", + "type": "rectangle", + "x": 559.2616117068669, + "y": -26775.59400663401, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "uIFXLz9THy_Ikkw4Ee_dv", + "UE8-xyNGwZ9E94kwsbhKW", + "47Cgm_mEHPZU-Rx05v1Gh", + "akiMguSCLYTjYb8TjYb_L" + ], + "frameId": null, + "index": "bqP", + "roundness": null, + "seed": 931152887, + "version": 1410, + "versionNonce": 2131700751, + "isDeleted": false, + "boundElements": [ + { + "id": "jEtESAk-FWvTx7MxH8YQh", + "type": "arrow" + } + ], + "updated": 1762347954514, + "link": null, + "locked": false + }, + { + "id": "MUNyU-29ck7aEPYyUvGXW", + "type": "rectangle", + "x": 593.9704940049601, + "y": -26774.323080729322, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "uIFXLz9THy_Ikkw4Ee_dv", + "UE8-xyNGwZ9E94kwsbhKW", + "47Cgm_mEHPZU-Rx05v1Gh", + "akiMguSCLYTjYb8TjYb_L" + ], + "frameId": null, + "index": "bqQ", + "roundness": null, + "seed": 81964311, + "version": 1322, + "versionNonce": 1103507195, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "XhMvUyJngyqfO9RlN97Kg", + "type": "text", + "x": 566.7776677114571, + "y": -26775.780121744043, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "sdRwqH8ifApunqs1Ms3vt", + "UE8-xyNGwZ9E94kwsbhKW", + "47Cgm_mEHPZU-Rx05v1Gh", + "akiMguSCLYTjYb8TjYb_L" + ], + "frameId": null, + "index": "bqR", + "roundness": null, + "seed": 140177975, + "version": 1309, + "versionNonce": 1113511745, + "isDeleted": false, + "boundElements": [ + { + "id": "v1iZpUTceCV5V7KA4l02b", + "type": "arrow" + } + ], + "updated": 1762210668840, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "110qgmWaZ5RbVS1oTZ_FB", + "type": "arrow", + "x": -502.28226255379207, + "y": -27204.670663366596, + "width": 302.28226255379207, + "height": 264.6706633665963, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bqn", + "roundness": { + "type": 2 + }, + "seed": 767512311, + "version": 3386, + "versionNonce": 495903969, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "XaU4xxrmeSm4aDygdYius" + } + ], + "updated": 1762278181385, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 182.28226255379207, + 124.67066336659627 + ], + [ + 302.28226255379207, + 264.6706633665963 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "dC9EIDBl3J5kGmFYdKGKa", + "focus": 0.7562091101129246, + "gap": 21.851650259555754 + }, + "endBinding": { + "elementId": "CQDi5H3MSMwX2347-QGOe", + "focus": 0.09265130058185851, + "gap": 21.524184070023374 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "XaU4xxrmeSm4aDygdYius", + "type": "text", + "x": -350.5369931334583, + "y": -27082.662592568853, + "width": 95.10595703125, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bqo", + "roundness": null, + "seed": 352868375, + "version": 96, + "versionNonce": 1732320399, + "isDeleted": false, + "boundElements": [], + "updated": 1762278159077, + "link": null, + "locked": false, + "text": "Autorisatie", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "110qgmWaZ5RbVS1oTZ_FB", + "originalText": "Autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "OedRF0K74olRJZSxFeeto", + "type": "text", + "x": -696.700122412346, + "y": -28240, + "width": 469.0472096757614, + "height": 118.74362970865101, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bqp", + "roundness": null, + "seed": 2090024247, + "version": 683, + "versionNonce": 432647387, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false, + "text": "Machtigen", + "fontSize": 103.25533018143568, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtigen", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "Bwyv0GyNaf5681mVGxHzv", + "type": "arrow", + "x": 989.6416070880186, + "y": -27979.968269425546, + "width": 349.45221790821597, + "height": 45.89270933419175, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bqq", + "roundness": null, + "seed": 935624279, + "version": 2204, + "versionNonce": 1680825845, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "JLAGjJzMZ1HvLkopTTFhy" + } + ], + "updated": 1762209578078, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -349.45221790821597, + -45.89270933419175 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": { + "elementId": "84CJw6VklhzE4JkiJfmrJ", + "focus": 0.5469549000663978, + "gap": 22.37803316948589 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "JLAGjJzMZ1HvLkopTTFhy", + "type": "text", + "x": 739.1353315079341, + "y": -23695.19998155758, + "width": 151.56033325195312, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bqr", + "roundness": null, + "seed": 963681143, + "version": 95, + "versionNonce": 1991978971, + "isDeleted": false, + "boundElements": [], + "updated": 1762208010626, + "link": null, + "locked": false, + "text": "Ketenmachtiging", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "Bwyv0GyNaf5681mVGxHzv", + "originalText": "Ketenmachtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "jFRzvCDoEGb-2JaefMTU9", + "type": "arrow", + "x": 43.58590214400229, + "y": -27976.11800839016, + "width": 356.462377480314, + "height": 48.31175016581983, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bqs", + "roundness": null, + "seed": 635180183, + "version": 2669, + "versionNonce": 481174709, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "mdCmaESjuKwn0QlkoM_vN" + } + ], + "updated": 1762209578078, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 356.462377480314, + -48.31175016581983 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "tIxQFC98P41VV871K12Zf", + "focus": -0.1707910950907057, + "gap": 9.641073191430324 + }, + "endBinding": { + "elementId": "84CJw6VklhzE4JkiJfmrJ", + "focus": -0.5424383599192566, + "gap": 31.401120151336293 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "mdCmaESjuKwn0QlkoM_vN", + "type": "text", + "x": -945.7801666259766, + "y": -24632.285357464938, + "width": 151.56033325195312, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bqt", + "roundness": null, + "seed": 616262071, + "version": 84, + "versionNonce": 2143723957, + "isDeleted": false, + "boundElements": [], + "updated": 1762208004506, + "link": null, + "locked": false, + "text": "Ketenmachtiging", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "jFRzvCDoEGb-2JaefMTU9", + "originalText": "Ketenmachtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "jFNNesX_-sVUSKwxOU6x_", + "type": "ellipse", + "x": -127.28026098653254, + "y": -27848.83827695372, + "width": 182.2099863465829, + "height": 172.55647673726426, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#a5d8ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "uJYyJLr51_ZgDfwlS3d8b", + "VbYDdsZfSPugRO_8SVLKk" + ], + "frameId": null, + "index": "bqu", + "roundness": { + "type": 2 + }, + "seed": 1932729047, + "version": 1160, + "versionNonce": 885225147, + "isDeleted": false, + "boundElements": [ + { + "id": "WE4CGE40vviVrq9TGA3-M", + "type": "arrow" + }, + { + "id": "_Lkj6uD3Slct57r3gLYWM", + "type": "arrow" + }, + { + "id": "OP40NkjswmkAszqLo5C0C", + "type": "arrow" + } + ], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "ckm99xXOZ_rouZIXotPls", + "type": "image", + "x": -90.42866349220276, + "y": -27836.535512155235, + "width": 92.80480705389928, + "height": 92.80480705389928, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "fK5VVZQPrb63HHFn_uaXS", + "uJYyJLr51_ZgDfwlS3d8b", + "VbYDdsZfSPugRO_8SVLKk" + ], + "frameId": null, + "index": "bqv", + "roundness": null, + "seed": 903325687, + "version": 1272, + "versionNonce": 1891320827, + "isDeleted": false, + "boundElements": [ + { + "id": "c95pq3z5z6u6q5ymZ1Y4d", + "type": "arrow" + } + ], + "updated": 1762209575041, + "link": null, + "locked": false, + "status": "saved", + "fileId": "693a2a6f72e66b88295e872fd167c77f6a19152e", + "scale": [ + 1, + 1 + ], + "crop": null, + "initialWidth": 1.2277712023808363, + "initialHeight": 1.2277712023808363 + }, + { + "type": "text", + "version": 2378, + "versionNonce": 1552990523, + "isDeleted": false, + "id": "9DMSCZeJcbHrkXQQORhmo", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": -94.30952821956816, + "y": -27743.73070514087, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "width": 116.26852107009374, + "height": 49.141429859745834, + "seed": 179147031, + "groupIds": [ + "Xt8vOxM2UAlUjNJH-MVh1", + "fK5VVZQPrb63HHFn_uaXS", + "uJYyJLr51_ZgDfwlS3d8b", + "VbYDdsZfSPugRO_8SVLKk" + ], + "boundElements": [ + { + "id": "_Lkj6uD3Slct57r3gLYWM", + "type": "arrow" + }, + { + "id": "WE4CGE40vviVrq9TGA3-M", + "type": "arrow" + }, + { + "id": "OP40NkjswmkAszqLo5C0C", + "type": "arrow" + } + ], + "updated": 1762209575041, + "link": null, + "locked": false, + "fontSize": 19.656571943898335, + "fontFamily": 1, + "text": "Machtigingen\nbeheerder", + "baseline": 18, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtigingen\nbeheerder", + "index": "bqw", + "frameId": null, + "roundness": null, + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "QUK9MTaFbENqxS54HaWEg", + "type": "rectangle", + "x": 10.315742620755827, + "y": -27827.91193508981, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VrYmcq4iZS3wJ6Tux17s8", + "OYE7V3rs1_O7pynZr-B_P", + "TBhREigxW3ZEGilWIJ3EA", + "VbYDdsZfSPugRO_8SVLKk" + ], + "frameId": null, + "index": "bqx", + "roundness": { + "type": 3 + }, + "seed": 1529435703, + "version": 1206, + "versionNonce": 2116708123, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "VlCPFtAwFDcwtO4-fMaDE", + "type": "rectangle", + "x": 51.78547717957599, + "y": -27827.911935388125, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VrYmcq4iZS3wJ6Tux17s8", + "OYE7V3rs1_O7pynZr-B_P", + "TBhREigxW3ZEGilWIJ3EA", + "VbYDdsZfSPugRO_8SVLKk" + ], + "frameId": null, + "index": "bqy", + "roundness": null, + "seed": 1848604503, + "version": 1297, + "versionNonce": 1613024187, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "epx4F_6aNkdA1lLKIzfK2", + "type": "text", + "x": 29.91043895600569, + "y": -27827.972250870873, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VrYmcq4iZS3wJ6Tux17s8", + "OYE7V3rs1_O7pynZr-B_P", + "TBhREigxW3ZEGilWIJ3EA", + "VbYDdsZfSPugRO_8SVLKk" + ], + "frameId": null, + "index": "bqz", + "roundness": null, + "seed": 974419063, + "version": 1031, + "versionNonce": 715758683, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "iQTK9ig6df_vSrYhBRrve", + "type": "text", + "x": 18.706997770649195, + "y": -27827.972251003288, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VrYmcq4iZS3wJ6Tux17s8", + "OYE7V3rs1_O7pynZr-B_P", + "TBhREigxW3ZEGilWIJ3EA", + "VbYDdsZfSPugRO_8SVLKk" + ], + "frameId": null, + "index": "br0", + "roundness": null, + "seed": 1989987735, + "version": 1051, + "versionNonce": 965433595, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "ddpZtEvDTMhIVDVKhJuDK", + "type": "rectangle", + "x": 50.084390155249366, + "y": -27828.9955898998, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VrYmcq4iZS3wJ6Tux17s8", + "OYE7V3rs1_O7pynZr-B_P", + "TBhREigxW3ZEGilWIJ3EA", + "VbYDdsZfSPugRO_8SVLKk" + ], + "frameId": null, + "index": "br1", + "roundness": null, + "seed": 1862075063, + "version": 1347, + "versionNonce": 1246527899, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "qSzyFRvh7k3B-0XzbKCLN", + "type": "rectangle", + "x": 84.79327245334252, + "y": -27827.724663995104, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VrYmcq4iZS3wJ6Tux17s8", + "OYE7V3rs1_O7pynZr-B_P", + "TBhREigxW3ZEGilWIJ3EA", + "VbYDdsZfSPugRO_8SVLKk" + ], + "frameId": null, + "index": "br2", + "roundness": null, + "seed": 333026263, + "version": 1271, + "versionNonce": 1176475195, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "3y2vqTCVU0DOXKd2OW41A", + "type": "text", + "x": 57.600446159839976, + "y": -27829.181705009825, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "mKow9pZ9-8BKwIXZdDoTj", + "OYE7V3rs1_O7pynZr-B_P", + "TBhREigxW3ZEGilWIJ3EA", + "VbYDdsZfSPugRO_8SVLKk" + ], + "frameId": null, + "index": "br3", + "roundness": null, + "seed": 1296498935, + "version": 1246, + "versionNonce": 1273435867, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "XWyPIyUNGntwcwM-r2zQG", + "type": "ellipse", + "x": 438.1081270012146, + "y": -27857.838276953727, + "width": 182.2099863465829, + "height": 172.55647673726426, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#a5d8ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "538Rn98OLf_cNcGrxC9JR", + "EZFYT8yFLdSFwtir_89xz" + ], + "frameId": null, + "index": "br4", + "roundness": { + "type": 2 + }, + "seed": 214551063, + "version": 1208, + "versionNonce": 2050327419, + "isDeleted": false, + "boundElements": [ + { + "id": "DzKAm8JbctpAcFWOKmbFx", + "type": "arrow" + }, + { + "id": "nkyhaaaCADMlQw-YJ96tD", + "type": "arrow" + }, + { + "id": "etrqDEPoa6u7LdJVBBpvY", + "type": "arrow" + } + ], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "IHc35CCwEDR7xS8J_ypOY", + "type": "image", + "x": 474.9597244955439, + "y": -27845.535512155242, + "width": 92.80480705389928, + "height": 92.80480705389928, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "C7piHUmXTaDC_WIj3EmuI", + "538Rn98OLf_cNcGrxC9JR", + "EZFYT8yFLdSFwtir_89xz" + ], + "frameId": null, + "index": "br5", + "roundness": null, + "seed": 525758263, + "version": 1317, + "versionNonce": 1159798971, + "isDeleted": false, + "boundElements": [ + { + "id": "etrqDEPoa6u7LdJVBBpvY", + "type": "arrow" + } + ], + "updated": 1762209575041, + "link": null, + "locked": false, + "status": "saved", + "fileId": "693a2a6f72e66b88295e872fd167c77f6a19152e", + "scale": [ + 1, + 1 + ], + "crop": null, + "initialWidth": 1.2277712023808363, + "initialHeight": 1.2277712023808363 + }, + { + "type": "text", + "version": 2430, + "versionNonce": 1362521595, + "isDeleted": false, + "id": "F3I1Ca8Lmb18lSqPJ0amD", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "angle": 0, + "x": 471.0788597681785, + "y": -27752.73070514087, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "width": 116.26852107009374, + "height": 49.141429859745834, + "seed": 1062301783, + "groupIds": [ + "1FQ1BZXwEZzbAB7efQns6", + "C7piHUmXTaDC_WIj3EmuI", + "538Rn98OLf_cNcGrxC9JR", + "EZFYT8yFLdSFwtir_89xz" + ], + "boundElements": [ + { + "id": "nkyhaaaCADMlQw-YJ96tD", + "type": "arrow" + }, + { + "id": "DzKAm8JbctpAcFWOKmbFx", + "type": "arrow" + } + ], + "updated": 1762209575041, + "link": null, + "locked": false, + "fontSize": 19.656571943898335, + "fontFamily": 1, + "text": "Machtigingen\nbeheerder", + "baseline": 18, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtigingen\nbeheerder", + "index": "br6", + "frameId": null, + "roundness": null, + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Iqc1RGKK9NsfEkA0KSZvh", + "type": "rectangle", + "x": 575.704130608503, + "y": -27836.91193508981, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "zZPZuPx4ZKzM0Hq7Obniy", + "k9zjJO7482qRLn-stbvVX", + "uboqy7ZPL9gGxn4SUphUJ", + "EZFYT8yFLdSFwtir_89xz" + ], + "frameId": null, + "index": "br7", + "roundness": { + "type": 3 + }, + "seed": 1720667511, + "version": 1182, + "versionNonce": 1137273659, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "k0_NVqJ4AUzNOJiTjSlzM", + "type": "rectangle", + "x": 617.1738651673222, + "y": -27836.911935388125, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "zZPZuPx4ZKzM0Hq7Obniy", + "k9zjJO7482qRLn-stbvVX", + "uboqy7ZPL9gGxn4SUphUJ", + "EZFYT8yFLdSFwtir_89xz" + ], + "frameId": null, + "index": "br8", + "roundness": null, + "seed": 1616152215, + "version": 1274, + "versionNonce": 2140031963, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "OfogtQn0dNmsncvIRZzih", + "type": "text", + "x": 595.2988269437519, + "y": -27836.972250870873, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "zZPZuPx4ZKzM0Hq7Obniy", + "k9zjJO7482qRLn-stbvVX", + "uboqy7ZPL9gGxn4SUphUJ", + "EZFYT8yFLdSFwtir_89xz" + ], + "frameId": null, + "index": "br9", + "roundness": null, + "seed": 458595255, + "version": 1008, + "versionNonce": 2100172923, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "qSpTW-p7gwdO86tuXisBH", + "type": "text", + "x": 584.0953857583954, + "y": -27836.972251003288, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "zZPZuPx4ZKzM0Hq7Obniy", + "k9zjJO7482qRLn-stbvVX", + "uboqy7ZPL9gGxn4SUphUJ", + "EZFYT8yFLdSFwtir_89xz" + ], + "frameId": null, + "index": "brA", + "roundness": null, + "seed": 1001852119, + "version": 1028, + "versionNonce": 443240731, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "xh22osOBGe2PIAU19TI7f", + "type": "rectangle", + "x": 615.4727781429965, + "y": -27837.9955898998, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "zZPZuPx4ZKzM0Hq7Obniy", + "k9zjJO7482qRLn-stbvVX", + "uboqy7ZPL9gGxn4SUphUJ", + "EZFYT8yFLdSFwtir_89xz" + ], + "frameId": null, + "index": "brB", + "roundness": null, + "seed": 1829591543, + "version": 1325, + "versionNonce": 1488483771, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "-es5Wgs4Imm5TzndTQqW6", + "type": "rectangle", + "x": 650.1816604410897, + "y": -27836.724663995104, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "zZPZuPx4ZKzM0Hq7Obniy", + "k9zjJO7482qRLn-stbvVX", + "uboqy7ZPL9gGxn4SUphUJ", + "EZFYT8yFLdSFwtir_89xz" + ], + "frameId": null, + "index": "brC", + "roundness": null, + "seed": 1952252695, + "version": 1250, + "versionNonce": 1731724891, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "i2oxdRNDSxlv3d7q27erO", + "type": "text", + "x": 622.9888341475862, + "y": -27838.181705009825, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "F-cf-ogz0n5xPx09lDEOu", + "k9zjJO7482qRLn-stbvVX", + "uboqy7ZPL9gGxn4SUphUJ", + "EZFYT8yFLdSFwtir_89xz" + ], + "frameId": null, + "index": "brD", + "roundness": null, + "seed": 35293239, + "version": 1223, + "versionNonce": 1824293627, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "-Szb8Wl-M3WWJ7lqCUry0", + "type": "arrow", + "x": 1414.3104364205374, + "y": -27912.071099442015, + "width": 80, + "height": 372.0710994420151, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "brG", + "roundness": { + "type": 2 + }, + "seed": 1006845847, + "version": 1588, + "versionNonce": 1565640213, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "SeNWcEvIrrHaIMfubby_E" + } + ], + "updated": 1762209578079, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 5.689563579462629, + 152.0710994420151 + ], + [ + -74.31043642053737, + 372.0710994420151 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": { + "elementId": "r1djFzlTwot6n_txMGl_E", + "focus": 0.154495968898911, + "gap": 13.906638195177415 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "SeNWcEvIrrHaIMfubby_E", + "type": "text", + "x": 243.27094357303315, + "y": -24387.103881355768, + "width": 100.01841735839844, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#fff0f6", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "brH", + "roundness": null, + "seed": 1657091255, + "version": 88, + "versionNonce": 1343258905, + "isDeleted": false, + "boundElements": [], + "updated": 1762166913655, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "-Szb8Wl-M3WWJ7lqCUry0", + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "dC9EIDBl3J5kGmFYdKGKa", + "type": "rectangle", + "x": -580.4308153908988, + "y": -27364.51269726586, + "width": 161.51264405830227, + "height": 137.99038363970547, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "3KyqMt6WAH5vZMcxiFPly", + "HYasGiRI3BVKsqGbeoBnE", + "wOWQtnPWmXW5s5TqJKJvL" + ], + "frameId": null, + "index": "brb", + "roundness": null, + "seed": 468767543, + "version": 1487, + "versionNonce": 456739457, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "nnbOtGkFmNUMo-HRsYrBH" + }, + { + "id": "110qgmWaZ5RbVS1oTZ_FB", + "type": "arrow" + } + ], + "updated": 1762248928413, + "link": null, + "locked": false + }, + { + "id": "nnbOtGkFmNUMo-HRsYrBH", + "type": "text", + "x": -575.4308153908988, + "y": -27354.487221277705, + "width": 146.98193359375, + "height": 117.93943166339001, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "3KyqMt6WAH5vZMcxiFPly", + "HYasGiRI3BVKsqGbeoBnE", + "wOWQtnPWmXW5s5TqJKJvL" + ], + "frameId": null, + "index": "brc", + "roundness": null, + "seed": 50287703, + "version": 1638, + "versionNonce": 898519649, + "isDeleted": false, + "boundElements": [], + "updated": 1762248928413, + "link": null, + "locked": false, + "text": "Wie: Loes\nNamens: Bedrijf-A\nVoor: Bedrijf-A\nVestnr: 34567...\nDienst: Service-X\nLoA: EH2+", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "middle", + "containerId": "dC9EIDBl3J5kGmFYdKGKa", + "originalText": "Wie: Loes\nNamens: Bedrijf-A\nVoor: Bedrijf-A\nVestnr: 34567...\nDienst: Service-X\nLoA: EH2+", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "j8E3syyBUXrmTlKJmFhmi", + "type": "rectangle", + "x": -607.909160607369, + "y": -27387.512331312013, + "width": 109.77551451067279, + "height": 27.143793659413816, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "3KyqMt6WAH5vZMcxiFPly", + "HYasGiRI3BVKsqGbeoBnE", + "wOWQtnPWmXW5s5TqJKJvL" + ], + "frameId": null, + "index": "brd", + "roundness": null, + "seed": 1122021751, + "version": 1378, + "versionNonce": 1150545441, + "isDeleted": false, + "boundElements": [], + "updated": 1762248928413, + "link": null, + "locked": false + }, + { + "id": "dIuSPhVh0zFWKdK5zFwir", + "type": "text", + "x": -596.2658018275798, + "y": -27383.76872015994, + "width": 86.48879657895867, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#099268", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "3KyqMt6WAH5vZMcxiFPly", + "HYasGiRI3BVKsqGbeoBnE", + "wOWQtnPWmXW5s5TqJKJvL" + ], + "frameId": null, + "index": "bre", + "roundness": null, + "seed": 1960405655, + "version": 1285, + "versionNonce": 252936705, + "isDeleted": false, + "boundElements": [], + "updated": 1762248928414, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "5CSFTGcoSIAl1scpR_QIl", + "type": "rectangle", + "x": 577.8799388209982, + "y": -27364.08413489978, + "width": 168.84585050534477, + "height": 119.24452509882016, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "6CfmUzm7A4g33R6JbSxD-", + "G455_E006NVsRbgOR1sRZ", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "brv", + "roundness": null, + "seed": 692859319, + "version": 1619, + "versionNonce": 257407835, + "isDeleted": false, + "boundElements": [ + { + "id": "xzGTuGQY1mxCoh4SowOOR", + "type": "arrow" + }, + { + "id": "p9pRYo6G-JACJFXJHqoam", + "type": "text" + } + ], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "p9pRYo6G-JACJFXJHqoam", + "type": "text", + "x": 582.8799388209982, + "y": -27353.603302210115, + "width": 146.98193359375, + "height": 98.28285971949168, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "6CfmUzm7A4g33R6JbSxD-", + "G455_E006NVsRbgOR1sRZ", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "brw", + "roundness": null, + "seed": 980083415, + "version": 1743, + "versionNonce": 656964737, + "isDeleted": false, + "boundElements": [], + "updated": 1762246838843, + "link": null, + "locked": false, + "text": "Wie: Piet\nNamens: Bedrijf-X\nVoor: Bedrijf-B\nDienst: MOZa\nLoA: EH3", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "middle", + "containerId": "5CSFTGcoSIAl1scpR_QIl", + "originalText": "Wie: Piet\nNamens: Bedrijf-X\nVoor: Bedrijf-B\nDienst: MOZa\nLoA: EH3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "0wbPvveKizXQ5EAn9lydh", + "type": "rectangle", + "x": 551.8048290998304, + "y": -27387.484317792216, + "width": 109.77551451067279, + "height": 27.143793659413816, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "6CfmUzm7A4g33R6JbSxD-", + "G455_E006NVsRbgOR1sRZ", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "brx", + "roundness": null, + "seed": 1389785079, + "version": 1457, + "versionNonce": 1332614459, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575041, + "link": null, + "locked": false + }, + { + "id": "SkQbEU5P4mbWQ4c3oJ_6Q", + "type": "text", + "x": 563.4481878796196, + "y": -27383.74070664015, + "width": 86.48879657895867, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "6CfmUzm7A4g33R6JbSxD-", + "G455_E006NVsRbgOR1sRZ", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "bry", + "roundness": null, + "seed": 747854103, + "version": 1387, + "versionNonce": 1158526427, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "s6gYEC3tkN5JLQlmx-a4T", + "type": "rectangle", + "x": 706.1089180974786, + "y": -27259.429658834066, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "80QWJER3t-dnCyl1R9vDJ", + "X0OLHg0chgZ0CMBUYgBrq", + "MKALn2SqWP_YSAyB5DfWa", + "56GQI3otoEMTXzKGJXIDH", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "bs1", + "roundness": { + "type": 3 + }, + "seed": 493829239, + "version": 1234, + "versionNonce": 1932542587, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "PdlxgV9Y8RkCNwhqGQ202", + "type": "rectangle", + "x": 747.5786526562988, + "y": -27259.42965913238, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "80QWJER3t-dnCyl1R9vDJ", + "X0OLHg0chgZ0CMBUYgBrq", + "MKALn2SqWP_YSAyB5DfWa", + "56GQI3otoEMTXzKGJXIDH", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "bs2", + "roundness": null, + "seed": 861836695, + "version": 1328, + "versionNonce": 580401947, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "lkHVAZByH0j8-Htmb2wJE", + "type": "text", + "x": 725.7036144327285, + "y": -27259.48997461512, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "80QWJER3t-dnCyl1R9vDJ", + "X0OLHg0chgZ0CMBUYgBrq", + "MKALn2SqWP_YSAyB5DfWa", + "56GQI3otoEMTXzKGJXIDH", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "bs3", + "roundness": null, + "seed": 1078315703, + "version": 1062, + "versionNonce": 1605902267, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "XYhp1c1e40eqHUUdGU2x3", + "type": "text", + "x": 714.500173247372, + "y": -27259.489974747543, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "80QWJER3t-dnCyl1R9vDJ", + "X0OLHg0chgZ0CMBUYgBrq", + "MKALn2SqWP_YSAyB5DfWa", + "56GQI3otoEMTXzKGJXIDH", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "bs4", + "roundness": null, + "seed": 1355373527, + "version": 1082, + "versionNonce": 78803035, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "MbMus22NPRYTqhkrLel9F", + "type": "rectangle", + "x": 745.8775656319722, + "y": -27260.51331364404, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "80QWJER3t-dnCyl1R9vDJ", + "X0OLHg0chgZ0CMBUYgBrq", + "MKALn2SqWP_YSAyB5DfWa", + "56GQI3otoEMTXzKGJXIDH", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "bs5", + "roundness": null, + "seed": 1761462519, + "version": 1378, + "versionNonce": 56208635, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "x8EhC1p47qE1g0r502WB-", + "type": "rectangle", + "x": 780.5864479300653, + "y": -27259.242387739352, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "80QWJER3t-dnCyl1R9vDJ", + "X0OLHg0chgZ0CMBUYgBrq", + "MKALn2SqWP_YSAyB5DfWa", + "56GQI3otoEMTXzKGJXIDH", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "bs6", + "roundness": null, + "seed": 375886359, + "version": 1303, + "versionNonce": 1865438619, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "XCOBZAckJR8PuiOinBGWR", + "type": "text", + "x": 753.3936216365628, + "y": -27260.699428754073, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "lI1EbSCFFVSv_Uyq1Naum", + "X0OLHg0chgZ0CMBUYgBrq", + "MKALn2SqWP_YSAyB5DfWa", + "56GQI3otoEMTXzKGJXIDH", + "UAzu-MvoY8kEicbzY4ZLV" + ], + "frameId": null, + "index": "bs7", + "roundness": null, + "seed": 1106982711, + "version": 1275, + "versionNonce": 1198058043, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "uXgoD89oppTQcPATZ6No-", + "type": "rectangle", + "x": 368.6634959601988, + "y": -27393.871808203396, + "width": 169.3245889374854, + "height": 119.24452509882016, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "B6PsHl4S6KwMo-MfPr0Fd", + "uCmZHe1aaoHMs5yhdt7Df", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bs8", + "roundness": null, + "seed": 1109211223, + "version": 1575, + "versionNonce": 15067867, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "gf3BY68hEsqBGvuqI-IHl" + }, + { + "id": "FlQP00oNGruBJfXHn0IMb", + "type": "arrow" + } + ], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "gf3BY68hEsqBGvuqI-IHl", + "type": "text", + "x": 373.6634959601988, + "y": -27383.390975513732, + "width": 146.98193359375, + "height": 98.28285971949168, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "B6PsHl4S6KwMo-MfPr0Fd", + "uCmZHe1aaoHMs5yhdt7Df", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bs9", + "roundness": null, + "seed": 748819831, + "version": 1689, + "versionNonce": 1747909871, + "isDeleted": false, + "boundElements": [], + "updated": 1762246829275, + "link": null, + "locked": false, + "text": "Wie: Piet\nNamens: Bedrijf-X\nVoor: Bedrijf-A\nDienst: MOZa\nLoA: EH3", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "middle", + "containerId": "uXgoD89oppTQcPATZ6No-", + "originalText": "Wie: Piet\nNamens: Bedrijf-X\nVoor: Bedrijf-A\nDienst: MOZa\nLoA: EH3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "FdmBICy7VBLt_4ZSDL9Wl", + "type": "rectangle", + "x": 340, + "y": -27415.98634711087, + "width": 109.77551451067279, + "height": 27.143793659413816, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "B6PsHl4S6KwMo-MfPr0Fd", + "uCmZHe1aaoHMs5yhdt7Df", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bsA", + "roundness": null, + "seed": 1758350999, + "version": 1407, + "versionNonce": 1025537211, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "2w0AtAdrEw8V1QeFBb89N", + "type": "text", + "x": 351.6433587797901, + "y": -27412.242735958804, + "width": 86.48879657895867, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "B6PsHl4S6KwMo-MfPr0Fd", + "uCmZHe1aaoHMs5yhdt7Df", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bsB", + "roundness": null, + "seed": 22438839, + "version": 1336, + "versionNonce": 474490203, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "h2_1XdSDyurv_cXI9KJ0a", + "type": "rectangle", + "x": 491.85228390898646, + "y": -27287.93168815272, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "XOLzTkcmB3On-Xo-tarJn", + "Zn4TkOFZkhhK9tjEexuVu", + "lX-LEnM5Wq8T3fqwCVPLm", + "YH4VrjoItXHkDEbiK80iV", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bsE", + "roundness": { + "type": 3 + }, + "seed": 766692119, + "version": 1211, + "versionNonce": 1752220155, + "isDeleted": false, + "boundElements": [ + { + "id": "FlQP00oNGruBJfXHn0IMb", + "type": "arrow" + } + ], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "675tPvLS0oXsx__gfsLPt", + "type": "rectangle", + "x": 533.3220184678066, + "y": -27287.931688451026, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "XOLzTkcmB3On-Xo-tarJn", + "Zn4TkOFZkhhK9tjEexuVu", + "lX-LEnM5Wq8T3fqwCVPLm", + "YH4VrjoItXHkDEbiK80iV", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bsF", + "roundness": null, + "seed": 494358583, + "version": 1302, + "versionNonce": 714918555, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "nWgEx2TfwjdYWMyJImfoG", + "type": "text", + "x": 511.44698024423633, + "y": -27287.992003933774, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "XOLzTkcmB3On-Xo-tarJn", + "Zn4TkOFZkhhK9tjEexuVu", + "lX-LEnM5Wq8T3fqwCVPLm", + "YH4VrjoItXHkDEbiK80iV", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bsG", + "roundness": null, + "seed": 1756246359, + "version": 1036, + "versionNonce": 662617915, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "9xPqxngvf7H4dY48ZNpXe", + "type": "text", + "x": 500.24353905887983, + "y": -27287.99200406619, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "XOLzTkcmB3On-Xo-tarJn", + "Zn4TkOFZkhhK9tjEexuVu", + "lX-LEnM5Wq8T3fqwCVPLm", + "YH4VrjoItXHkDEbiK80iV", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bsH", + "roundness": null, + "seed": 682356343, + "version": 1059, + "versionNonce": 1769545691, + "isDeleted": false, + "boundElements": [ + { + "id": "FlQP00oNGruBJfXHn0IMb", + "type": "arrow" + } + ], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "WvawkQx0h-htvMz7MS2cc", + "type": "rectangle", + "x": 531.6209314434809, + "y": -27289.015342962695, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "XOLzTkcmB3On-Xo-tarJn", + "Zn4TkOFZkhhK9tjEexuVu", + "lX-LEnM5Wq8T3fqwCVPLm", + "YH4VrjoItXHkDEbiK80iV", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bsI", + "roundness": null, + "seed": 1479870359, + "version": 1351, + "versionNonce": 178154619, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "Xvje8zYk22jcLqoTb0k2s", + "type": "rectangle", + "x": 566.3298137415732, + "y": -27287.744417058006, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "XOLzTkcmB3On-Xo-tarJn", + "Zn4TkOFZkhhK9tjEexuVu", + "lX-LEnM5Wq8T3fqwCVPLm", + "YH4VrjoItXHkDEbiK80iV", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bsJ", + "roundness": null, + "seed": 629013687, + "version": 1276, + "versionNonce": 1051796763, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "SHHb_DKzshKAbJVerfljm", + "type": "text", + "x": 539.1369874480706, + "y": -27289.201458072726, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "Vj56xuj7g_fDlXpRTIW36", + "Zn4TkOFZkhhK9tjEexuVu", + "lX-LEnM5Wq8T3fqwCVPLm", + "YH4VrjoItXHkDEbiK80iV", + "wVrYrlJws0dun5rzgq3OU" + ], + "frameId": null, + "index": "bsK", + "roundness": null, + "seed": 69946839, + "version": 1254, + "versionNonce": 488884667, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "9z3pprmmWORQVT9ErQBxw", + "type": "rectangle", + "x": -230.50997101686517, + "y": -27371.66065017815, + "width": 162.6286361838998, + "height": 134.2434061404303, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "YcNnR8H3y92vIucRqVh_4", + "EfZ0cuK6o-oOVQod7kKT2", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsL", + "roundness": null, + "seed": 2136046327, + "version": 1302, + "versionNonce": 723049051, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "gmIOjGgzpp0zOqAAcVT-v" + }, + { + "id": "swA5vVBmSI7fGuJ_rw1hv", + "type": "arrow" + } + ], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "gmIOjGgzpp0zOqAAcVT-v", + "type": "text", + "x": -225.50997101686517, + "y": -27363.50866293963, + "width": 146.98193359375, + "height": 117.93943166339001, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "YcNnR8H3y92vIucRqVh_4", + "EfZ0cuK6o-oOVQod7kKT2", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsM", + "roundness": null, + "seed": 1265959959, + "version": 1536, + "versionNonce": 627234555, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "Wie: Jan\nNamens: Bedrijf-A\nVoor: Bedrijf-A\nVestnr: 12345...\nDienst: Service-X\nLoA: EH3", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "middle", + "containerId": "9z3pprmmWORQVT9ErQBxw", + "originalText": "Wie: Jan\nNamens: Bedrijf-A\nVoor: Bedrijf-A\nVestnr: 12345...\nDienst: Service-X\nLoA: EH3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "VUF34jxICz7ICWfvJdKp4", + "type": "rectangle", + "x": -256.31751744638996, + "y": -27395.736893343405, + "width": 109.77551451067279, + "height": 27.143793659413816, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "YcNnR8H3y92vIucRqVh_4", + "EfZ0cuK6o-oOVQod7kKT2", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsN", + "roundness": null, + "seed": 411724087, + "version": 1206, + "versionNonce": 1689228347, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "ybUE8I4ieKtM1tMuz_lMj", + "type": "text", + "x": -244.6741586666003, + "y": -27391.993282191324, + "width": 86.4599609375, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#099268", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "YcNnR8H3y92vIucRqVh_4", + "EfZ0cuK6o-oOVQod7kKT2", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsO", + "roundness": null, + "seed": 603335255, + "version": 1126, + "versionNonce": 1405572315, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "YfpieO3FydWfD1xkC4bJ1", + "type": "rectangle", + "x": -110.41357409418697, + "y": -27252.93980542732, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VH2oJWGfqcMFEQcZsxd-l", + "uFSwIaV9XGIDVkAxV-LuG", + "gjNAUzm8TG8qMDBvFu3Ni", + "y_rhc3sg1WOKUXrrXNWTB", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsR", + "roundness": { + "type": 3 + }, + "seed": 1706857911, + "version": 1240, + "versionNonce": 1465778555, + "isDeleted": false, + "boundElements": [ + { + "id": "swA5vVBmSI7fGuJ_rw1hv", + "type": "arrow" + } + ], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "Wlmw2Qp6O9NASYxouQ2dn", + "type": "rectangle", + "x": -68.94383953536726, + "y": -27252.939805725633, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VH2oJWGfqcMFEQcZsxd-l", + "uFSwIaV9XGIDVkAxV-LuG", + "gjNAUzm8TG8qMDBvFu3Ni", + "y_rhc3sg1WOKUXrrXNWTB", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsS", + "roundness": null, + "seed": 1395574487, + "version": 1330, + "versionNonce": 1488329243, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "9khHPrdJNZD7Rniwq0n8G", + "type": "text", + "x": -90.81887775893756, + "y": -27253.00012120838, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VH2oJWGfqcMFEQcZsxd-l", + "uFSwIaV9XGIDVkAxV-LuG", + "gjNAUzm8TG8qMDBvFu3Ni", + "y_rhc3sg1WOKUXrrXNWTB", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsT", + "roundness": null, + "seed": 1904071671, + "version": 1064, + "versionNonce": 1958878907, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "x85sPT84nSumvKSIBjG97", + "type": "text", + "x": -102.02231894429406, + "y": -27253.000121340796, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VH2oJWGfqcMFEQcZsxd-l", + "uFSwIaV9XGIDVkAxV-LuG", + "gjNAUzm8TG8qMDBvFu3Ni", + "y_rhc3sg1WOKUXrrXNWTB", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsU", + "roundness": null, + "seed": 1219378455, + "version": 1086, + "versionNonce": 103059291, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "GqOVq2ecbXba-luwN97dC", + "type": "rectangle", + "x": -70.64492655969343, + "y": -27254.023460237302, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VH2oJWGfqcMFEQcZsxd-l", + "uFSwIaV9XGIDVkAxV-LuG", + "gjNAUzm8TG8qMDBvFu3Ni", + "y_rhc3sg1WOKUXrrXNWTB", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsV", + "roundness": null, + "seed": 1815380535, + "version": 1380, + "versionNonce": 1865411579, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "vzveasLtEt6RMwA5OyEab", + "type": "rectangle", + "x": -35.93604426159982, + "y": -27252.752534332612, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "VH2oJWGfqcMFEQcZsxd-l", + "uFSwIaV9XGIDVkAxV-LuG", + "gjNAUzm8TG8qMDBvFu3Ni", + "y_rhc3sg1WOKUXrrXNWTB", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsW", + "roundness": null, + "seed": 217391959, + "version": 1305, + "versionNonce": 602322075, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "bD6f2-s7CoEc0ZKArEwBn", + "type": "text", + "x": -63.128870555103276, + "y": -27254.209575347333, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "epj7i5WQT_m9FfGJSLEf8", + "uFSwIaV9XGIDVkAxV-LuG", + "gjNAUzm8TG8qMDBvFu3Ni", + "y_rhc3sg1WOKUXrrXNWTB", + "xLRhKR1hApuYhEeOmzy40" + ], + "frameId": null, + "index": "bsX", + "roundness": null, + "seed": 1262788727, + "version": 1278, + "versionNonce": 1945856315, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "FtEvpUGUOzFAWqj9uO821", + "type": "rectangle", + "x": 1126.0751097211687, + "y": -27376.599817107548, + "width": 162.6286361838998, + "height": 125.78894786767908, + "angle": 0, + "strokeColor": "#099268", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "8ODEgEIDzVpg_Pd_o8jQe", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsY", + "roundness": null, + "seed": 1223129495, + "version": 1350, + "versionNonce": 349211099, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "xsAbYBcPocwalWmKII5Qp" + }, + { + "id": "JF4UI4EIEyu4eUsqK2jjq", + "type": "arrow" + } + ], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "xsAbYBcPocwalWmKII5Qp", + "type": "text", + "x": 1131.0751097211687, + "y": -27362.846773033456, + "width": 146.98193359375, + "height": 98.28285971949168, + "angle": 0, + "strokeColor": "#099268", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "8ODEgEIDzVpg_Pd_o8jQe", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsZ", + "roundness": null, + "seed": 2064789175, + "version": 1478, + "versionNonce": 338735311, + "isDeleted": false, + "boundElements": [], + "updated": 1762246844377, + "link": null, + "locked": false, + "text": "Wie: Joost\nNamens: Bedrijf-C\nVoor: Bedrijf-C\nDienst: MOZa\nLoA: EH3", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "middle", + "containerId": "FtEvpUGUOzFAWqj9uO821", + "originalText": "Wie: Joost\nNamens: Bedrijf-C\nVoor: Bedrijf-C\nDienst: MOZa\nLoA: EH3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "W8zX0ElfPJLcR_YbEluPr", + "type": "rectangle", + "x": 1100, + "y": -27400, + "width": 109.77551451067279, + "height": 27.143793659413816, + "angle": 0, + "strokeColor": "#099268", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "8ODEgEIDzVpg_Pd_o8jQe", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsa", + "roundness": null, + "seed": 1013530583, + "version": 1274, + "versionNonce": 956003259, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "FyTk3rVF6nZO58aZgL0R1", + "type": "text", + "x": 1111.6433587797883, + "y": -27396.256388847934, + "width": 86.48879657895867, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#099268", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "8ODEgEIDzVpg_Pd_o8jQe", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsb", + "roundness": null, + "seed": 520170743, + "version": 1200, + "versionNonce": 40584283, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "zo-KKheoekL5NYeeWqOjS", + "type": "rectangle", + "x": 1248.5071730119844, + "y": -27262.943329267022, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iDdFKrUyhIgUd3Nd80_9g", + "KX-QZcBqbbYS2f4BS6UOG", + "Qe9EslxjZk3z5bxbrGUPJ", + "JlOmcb1-NyoMPiYkMMhze", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsc", + "roundness": { + "type": 3 + }, + "seed": 2120119831, + "version": 1200, + "versionNonce": 2060976379, + "isDeleted": false, + "boundElements": [ + { + "id": "JF4UI4EIEyu4eUsqK2jjq", + "type": "arrow" + } + ], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "b1j3zz-FZr5hBqo9xZCYv", + "type": "rectangle", + "x": 1289.9769075708045, + "y": -27262.94332956533, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iDdFKrUyhIgUd3Nd80_9g", + "KX-QZcBqbbYS2f4BS6UOG", + "Qe9EslxjZk3z5bxbrGUPJ", + "JlOmcb1-NyoMPiYkMMhze", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsd", + "roundness": null, + "seed": 1366661943, + "version": 1290, + "versionNonce": 197405083, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false + }, + { + "id": "vrzQzsOa7OrlOoCqE3qoN", + "type": "text", + "x": 1268.1018693472342, + "y": -27263.003645048084, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iDdFKrUyhIgUd3Nd80_9g", + "KX-QZcBqbbYS2f4BS6UOG", + "Qe9EslxjZk3z5bxbrGUPJ", + "JlOmcb1-NyoMPiYkMMhze", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bse", + "roundness": null, + "seed": 1017846871, + "version": 1024, + "versionNonce": 1247952443, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575042, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "vyG9xAKJ7eSl8gl-7Gfjo", + "type": "text", + "x": 1256.8984281618777, + "y": -27263.00364518049, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iDdFKrUyhIgUd3Nd80_9g", + "KX-QZcBqbbYS2f4BS6UOG", + "Qe9EslxjZk3z5bxbrGUPJ", + "JlOmcb1-NyoMPiYkMMhze", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsf", + "roundness": null, + "seed": 1674803575, + "version": 1044, + "versionNonce": 26525403, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "Or09VvGfqABBelB60CXe2", + "type": "rectangle", + "x": 1288.2758205464788, + "y": -27264.026984077005, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iDdFKrUyhIgUd3Nd80_9g", + "KX-QZcBqbbYS2f4BS6UOG", + "Qe9EslxjZk3z5bxbrGUPJ", + "JlOmcb1-NyoMPiYkMMhze", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsg", + "roundness": null, + "seed": 2083730071, + "version": 1341, + "versionNonce": 2079206267, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "9NLRYQNZ_4jpmE5iTUt9A", + "type": "rectangle", + "x": 1322.984702844571, + "y": -27262.75605817231, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iDdFKrUyhIgUd3Nd80_9g", + "KX-QZcBqbbYS2f4BS6UOG", + "Qe9EslxjZk3z5bxbrGUPJ", + "JlOmcb1-NyoMPiYkMMhze", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsh", + "roundness": null, + "seed": 511625143, + "version": 1265, + "versionNonce": 229704731, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "oceS1QKmK6WZzqtNLKgDu", + "type": "text", + "x": 1295.7918765510685, + "y": -27264.213099187036, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "S5EfeZwTpOUDSwm9WibMD", + "KX-QZcBqbbYS2f4BS6UOG", + "Qe9EslxjZk3z5bxbrGUPJ", + "JlOmcb1-NyoMPiYkMMhze", + "tQ_uurYu1k-m8aZJ_AeVQ" + ], + "frameId": null, + "index": "bsi", + "roundness": null, + "seed": 1490729175, + "version": 1239, + "versionNonce": 1590675643, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "UEYwwaID6Zm3bSsgZvCCo", + "type": "rectangle", + "x": 144.18057724241135, + "y": -28152.736893343405, + "width": 170.44058106308265, + "height": 96.92468258686506, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "BcdCrMPd3D4h09XqHlv0E", + "Hdy71R_y_FaamomMhdKTO", + "AqnDK2LE3viWcgH7BW1fW", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bsu", + "roundness": null, + "seed": 1413221975, + "version": 1999, + "versionNonce": 1961687387, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "GzSww6mXoR8FGynUOvDvH" + } + ], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "GzSww6mXoR8FGynUOvDvH", + "type": "text", + "x": 149.18057724241135, + "y": -28143.587695937767, + "width": 146.98193359375, + "height": 78.62628777559334, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "BcdCrMPd3D4h09XqHlv0E", + "Hdy71R_y_FaamomMhdKTO", + "AqnDK2LE3viWcgH7BW1fW", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bsv", + "roundness": null, + "seed": 7744375, + "version": 2108, + "versionNonce": 1968593391, + "isDeleted": false, + "boundElements": [], + "updated": 1762246787227, + "link": null, + "locked": false, + "text": "Wie: Bedrijf-X\nNamens: Bedrijf-A\nDienst: MOZa \nLoA: EH3", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "middle", + "containerId": "UEYwwaID6Zm3bSsgZvCCo", + "originalText": "Wie: Bedrijf-X\nNamens: Bedrijf-A\nDienst: MOZa \nLoA: EH3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "73O_vUyLO2ymZSmcskXS8", + "type": "rectangle", + "x": 120, + "y": -28180, + "width": 109.77551451067279, + "height": 27.143793659413816, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "BcdCrMPd3D4h09XqHlv0E", + "Hdy71R_y_FaamomMhdKTO", + "AqnDK2LE3viWcgH7BW1fW", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bsw", + "roundness": null, + "seed": 363832471, + "version": 1782, + "versionNonce": 1461493403, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "-_bCQ3qbS1vN7y83KNc34", + "type": "text", + "x": 131.6433587797901, + "y": -28176.256388847927, + "width": 86.48879657895867, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "BcdCrMPd3D4h09XqHlv0E", + "Hdy71R_y_FaamomMhdKTO", + "AqnDK2LE3viWcgH7BW1fW", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bsx", + "roundness": null, + "seed": 1939667383, + "version": 1712, + "versionNonce": 1558451003, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "H6m6taTxy58cEwBCt2fw8", + "type": "rectangle", + "x": 273.7442148447526, + "y": -28070.61908438854, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "0W4UJnKUC5GZYXeUpUi_T", + "kzGw9ke7yCtiH0HjoeP0G", + "xRV7dOeOvz5GUyk8lCVZD", + "W9B9UNbEF91eHRAYT08tA", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bt0", + "roundness": { + "type": 3 + }, + "seed": 1815683351, + "version": 1209, + "versionNonce": 1863578587, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "I_L3p8LcxPyKiSrsb3hgg", + "type": "rectangle", + "x": 315.21394940357277, + "y": -28070.619084686856, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "0W4UJnKUC5GZYXeUpUi_T", + "kzGw9ke7yCtiH0HjoeP0G", + "xRV7dOeOvz5GUyk8lCVZD", + "W9B9UNbEF91eHRAYT08tA", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bt1", + "roundness": null, + "seed": 616752695, + "version": 1303, + "versionNonce": 1035911291, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "DiB5xKpWADBOyo1ZAvkwL", + "type": "text", + "x": 293.33891118000247, + "y": -28070.679400169603, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "0W4UJnKUC5GZYXeUpUi_T", + "kzGw9ke7yCtiH0HjoeP0G", + "xRV7dOeOvz5GUyk8lCVZD", + "W9B9UNbEF91eHRAYT08tA", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bt2", + "roundness": null, + "seed": 1847002967, + "version": 1037, + "versionNonce": 1386674459, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "ivn7f4bTkuMVrfoN0aTVP", + "type": "text", + "x": 282.135469994646, + "y": -28070.67940030202, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "0W4UJnKUC5GZYXeUpUi_T", + "kzGw9ke7yCtiH0HjoeP0G", + "xRV7dOeOvz5GUyk8lCVZD", + "W9B9UNbEF91eHRAYT08tA", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bt3", + "roundness": null, + "seed": 1988756599, + "version": 1057, + "versionNonce": 1530863035, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "4keKi_aZgPHGVbPl24VAV", + "type": "rectangle", + "x": 313.51286237924614, + "y": -28071.702739198525, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "0W4UJnKUC5GZYXeUpUi_T", + "kzGw9ke7yCtiH0HjoeP0G", + "xRV7dOeOvz5GUyk8lCVZD", + "W9B9UNbEF91eHRAYT08tA", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bt4", + "roundness": null, + "seed": 769678743, + "version": 1353, + "versionNonce": 849981019, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "Fhfh9PhstTzwKetg4Uroo", + "type": "rectangle", + "x": 348.2217446773393, + "y": -28070.431813293835, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "0W4UJnKUC5GZYXeUpUi_T", + "kzGw9ke7yCtiH0HjoeP0G", + "xRV7dOeOvz5GUyk8lCVZD", + "W9B9UNbEF91eHRAYT08tA", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bt5", + "roundness": null, + "seed": 391025335, + "version": 1277, + "versionNonce": 733555451, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "dmwLJ_KLAZeAbPYMYjY20", + "type": "text", + "x": 321.02891838383584, + "y": -28071.888854308556, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "P3f8zyrXWI3mqR92lWj83", + "kzGw9ke7yCtiH0HjoeP0G", + "xRV7dOeOvz5GUyk8lCVZD", + "W9B9UNbEF91eHRAYT08tA", + "jG48_GrcDMuyKCP3kv3pp" + ], + "frameId": null, + "index": "bt6", + "roundness": null, + "seed": 1534665687, + "version": 1256, + "versionNonce": 451941275, + "isDeleted": false, + "boundElements": [ + { + "id": "jFRzvCDoEGb-2JaefMTU9", + "type": "arrow" + } + ], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "qX-aKkuTQef7wCzjSnBE5", + "type": "rectangle", + "x": 706.0751097211687, + "y": -28156.599817107563, + "width": 169.32458893748534, + "height": 96.92468258686506, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "DOuaRsZj2zeV45TM11JC0", + "rGNG-0AfTgXPuZ-u-mXmp", + "4bL6-tDHBE6naY9h0WGi-", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "bt7", + "roundness": null, + "seed": 443846903, + "version": 2047, + "versionNonce": 545318971, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "yR5lq288HGMynq0clU5yr" + } + ], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "yR5lq288HGMynq0clU5yr", + "type": "text", + "x": 711.0751097211687, + "y": -28147.450619701925, + "width": 146.98193359375, + "height": 78.62628777559334, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "DOuaRsZj2zeV45TM11JC0", + "rGNG-0AfTgXPuZ-u-mXmp", + "4bL6-tDHBE6naY9h0WGi-", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "bt8", + "roundness": null, + "seed": 2110085655, + "version": 2148, + "versionNonce": 705589121, + "isDeleted": false, + "boundElements": [], + "updated": 1762246796523, + "link": null, + "locked": false, + "text": "Wie: Bedrijf-X\nNamens: Bedrijf-B\nDienst: MOZa \nLoA: EH3", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "middle", + "containerId": "qX-aKkuTQef7wCzjSnBE5", + "originalText": "Wie: Bedrijf-X\nNamens: Bedrijf-B\nDienst: MOZa \nLoA: EH3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "O_sgpUTmc6Zq5u6oZMhOy", + "type": "rectangle", + "x": 680, + "y": -28180, + "width": 109.77551451067279, + "height": 27.143793659413816, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "DOuaRsZj2zeV45TM11JC0", + "rGNG-0AfTgXPuZ-u-mXmp", + "4bL6-tDHBE6naY9h0WGi-", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "bt9", + "roundness": null, + "seed": 174063415, + "version": 1828, + "versionNonce": 1709856123, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "Hr9ETHocfKDLtjO9wLRCQ", + "type": "text", + "x": 691.6433587797901, + "y": -28176.256388847927, + "width": 86.48879657895867, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e3fafc", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "DOuaRsZj2zeV45TM11JC0", + "rGNG-0AfTgXPuZ-u-mXmp", + "4bL6-tDHBE6naY9h0WGi-", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "btA", + "roundness": null, + "seed": 849936471, + "version": 1760, + "versionNonce": 2056777243, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "__7os5HnWRV4WDbr9UCtE", + "type": "rectangle", + "x": 829.3899467736273, + "y": -28069.636255791353, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "FCYTHeL2kTPb67JwEJQtA", + "_rWWInLbcATj3Vv0zTleg", + "Gr-iYUjL5l-0NSBPnbuNX", + "XdMEjg5qvglOH7p00STK4", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "btD", + "roundness": { + "type": 3 + }, + "seed": 756493239, + "version": 1230, + "versionNonce": 592016059, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "3FUELAgHENNQuuztBx2XP", + "type": "rectangle", + "x": 870.8596813324475, + "y": -28069.63625608966, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "FCYTHeL2kTPb67JwEJQtA", + "_rWWInLbcATj3Vv0zTleg", + "Gr-iYUjL5l-0NSBPnbuNX", + "XdMEjg5qvglOH7p00STK4", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "btE", + "roundness": null, + "seed": 1053203671, + "version": 1321, + "versionNonce": 279012187, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "3P_YQ6CW7UCp3Pw2EX8yO", + "type": "text", + "x": 848.9846431088772, + "y": -28069.696571572407, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "FCYTHeL2kTPb67JwEJQtA", + "_rWWInLbcATj3Vv0zTleg", + "Gr-iYUjL5l-0NSBPnbuNX", + "XdMEjg5qvglOH7p00STK4", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "btF", + "roundness": null, + "seed": 128641527, + "version": 1055, + "versionNonce": 988954619, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "TfE2dU83D3U6SOSCg8wkc", + "type": "text", + "x": 837.7812019235207, + "y": -28069.696571704822, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "FCYTHeL2kTPb67JwEJQtA", + "_rWWInLbcATj3Vv0zTleg", + "Gr-iYUjL5l-0NSBPnbuNX", + "XdMEjg5qvglOH7p00STK4", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "btG", + "roundness": null, + "seed": 80253719, + "version": 1075, + "versionNonce": 1816037531, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "GSCmPNBNWU78AhFTZmDjI", + "type": "rectangle", + "x": 869.1585943081218, + "y": -28070.71991060133, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "FCYTHeL2kTPb67JwEJQtA", + "_rWWInLbcATj3Vv0zTleg", + "Gr-iYUjL5l-0NSBPnbuNX", + "XdMEjg5qvglOH7p00STK4", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "btH", + "roundness": null, + "seed": 513022007, + "version": 1372, + "versionNonce": 171490619, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "A2eC2jVoiEM50gP-Y-CBQ", + "type": "rectangle", + "x": 903.867476606214, + "y": -28069.44898469664, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "FCYTHeL2kTPb67JwEJQtA", + "_rWWInLbcATj3Vv0zTleg", + "Gr-iYUjL5l-0NSBPnbuNX", + "XdMEjg5qvglOH7p00STK4", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "btI", + "roundness": null, + "seed": 988936535, + "version": 1296, + "versionNonce": 541285851, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "s4FMXIaUkwKerNcb7RguT", + "type": "text", + "x": 876.6746503127115, + "y": -28070.90602571136, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "z2sWx6yf4bY4bdRVOotFj", + "_rWWInLbcATj3Vv0zTleg", + "Gr-iYUjL5l-0NSBPnbuNX", + "XdMEjg5qvglOH7p00STK4", + "MIdWwLfZbSQOV0QFfXL3k" + ], + "frameId": null, + "index": "btJ", + "roundness": null, + "seed": 255243895, + "version": 1270, + "versionNonce": 695265915, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "fVYpugqYwmAu4HaSvygba", + "type": "rectangle", + "x": 1346.0751097211678, + "y": -27356.599817107548, + "width": 161.71411060690667, + "height": 122.2032104995732, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "8oTWJtRY9yWkYJ0_KAX6I", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btK", + "roundness": null, + "seed": 841404311, + "version": 1463, + "versionNonce": 444850971, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "Rm6-ZWvx8Y_8512FaV-tr" + }, + { + "id": "qFMoo3YNqpx2NG_78dYib", + "type": "arrow" + } + ], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "Rm6-ZWvx8Y_8512FaV-tr", + "type": "text", + "x": 1351.0751097211678, + "y": -27344.639641717506, + "width": 146.98193359375, + "height": 98.28285971949168, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "8oTWJtRY9yWkYJ0_KAX6I", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btL", + "roundness": null, + "seed": 1844888759, + "version": 1578, + "versionNonce": 737068987, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "Wie: Joost\nNamens: Bedrijf-C\nVoor: Bedrijf-C\nDienst: Service-Z\nLoA: EH4", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "middle", + "containerId": "fVYpugqYwmAu4HaSvygba", + "originalText": "Wie: Joost\nNamens: Bedrijf-C\nVoor: Bedrijf-C\nDienst: Service-Z\nLoA: EH4", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "B7xwk06AjFYD68PnFzql-", + "type": "rectangle", + "x": 1320, + "y": -27380, + "width": 109.77551451067279, + "height": 27.143793659413816, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "8oTWJtRY9yWkYJ0_KAX6I", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btM", + "roundness": null, + "seed": 1380652503, + "version": 1382, + "versionNonce": 1611027707, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "OZTTglFBe-F6AMzxuA4BZ", + "type": "text", + "x": 1331.6433587797892, + "y": -27376.25638884792, + "width": 86.4599609375, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "8oTWJtRY9yWkYJ0_KAX6I", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btN", + "roundness": null, + "seed": 104350455, + "version": 1314, + "versionNonce": 1611136411, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "ifEYosaWqOdB8memGJCxl", + "type": "rectangle", + "x": 1465.9360599951715, + "y": -27246.783110136574, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "kFTWVuRhP2SzUOnw7NOIx", + "yvOrymo88Is2G4mGbiJd4", + "hvOWPArX1z_wSyAl5fpvS", + "eey6FvdpMjnhCCUbj6Nv4", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btO", + "roundness": { + "type": 3 + }, + "seed": 1514327063, + "version": 1297, + "versionNonce": 252416571, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "4CxPcnEjkPPKy_Gt00hKn", + "type": "rectangle", + "x": 1507.4057945539907, + "y": -27246.783110434888, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "kFTWVuRhP2SzUOnw7NOIx", + "yvOrymo88Is2G4mGbiJd4", + "hvOWPArX1z_wSyAl5fpvS", + "eey6FvdpMjnhCCUbj6Nv4", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btP", + "roundness": null, + "seed": 442446135, + "version": 1389, + "versionNonce": 234066651, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "7BL57rejVLdsLFClI0rDw", + "type": "text", + "x": 1485.5307563304204, + "y": -27246.843425917636, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "kFTWVuRhP2SzUOnw7NOIx", + "yvOrymo88Is2G4mGbiJd4", + "hvOWPArX1z_wSyAl5fpvS", + "eey6FvdpMjnhCCUbj6Nv4", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btQ", + "roundness": null, + "seed": 535949911, + "version": 1125, + "versionNonce": 1028816763, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "F8LnCVIgdqAx5xCu88do-", + "type": "text", + "x": 1474.327315145064, + "y": -27246.843426050058, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "kFTWVuRhP2SzUOnw7NOIx", + "yvOrymo88Is2G4mGbiJd4", + "hvOWPArX1z_wSyAl5fpvS", + "eey6FvdpMjnhCCUbj6Nv4", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btR", + "roundness": null, + "seed": 600805239, + "version": 1143, + "versionNonce": 1198184475, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "AJsQjyhxuZAMxSAQ4wi6T", + "type": "rectangle", + "x": 1505.7047075296641, + "y": -27247.866764946557, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "kFTWVuRhP2SzUOnw7NOIx", + "yvOrymo88Is2G4mGbiJd4", + "hvOWPArX1z_wSyAl5fpvS", + "eey6FvdpMjnhCCUbj6Nv4", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btS", + "roundness": null, + "seed": 1346144407, + "version": 1433, + "versionNonce": 1781472443, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "m7D_qr9xbsHaYbbM_g5K1", + "type": "rectangle", + "x": 1540.4135898277573, + "y": -27246.595839041867, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "kFTWVuRhP2SzUOnw7NOIx", + "yvOrymo88Is2G4mGbiJd4", + "hvOWPArX1z_wSyAl5fpvS", + "eey6FvdpMjnhCCUbj6Nv4", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btT", + "roundness": null, + "seed": 317545911, + "version": 1364, + "versionNonce": 21089627, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "cwnSNMP6YuNHBxOHgR0XT", + "type": "text", + "x": 1513.2207635342556, + "y": -27248.052880056595, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "Jd90vtA7fmq1XmJ0jn_IZ", + "yvOrymo88Is2G4mGbiJd4", + "hvOWPArX1z_wSyAl5fpvS", + "eey6FvdpMjnhCCUbj6Nv4", + "i8qOqN4tsnOEhEtTnNWFK" + ], + "frameId": null, + "index": "btU", + "roundness": null, + "seed": 788958935, + "version": 1338, + "versionNonce": 1341483515, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "4", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "4", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "XTIImqJxaCuAxnxnnaRPb", + "type": "ellipse", + "x": 433.8653966744869, + "y": -27544.736893343405, + "width": 182.2099863465829, + "height": 172.55647673726426, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "YcP05Kybnb1bEIbhfwEuN", + "K4eeIog8ZcGLEHtrGciYe", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "btV", + "roundness": { + "type": 2 + }, + "seed": 253533175, + "version": 1406, + "versionNonce": 189559451, + "isDeleted": false, + "boundElements": [ + { + "id": "nkyhaaaCADMlQw-YJ96tD", + "type": "arrow" + }, + { + "id": "DzKAm8JbctpAcFWOKmbFx", + "type": "arrow" + } + ], + "updated": 1762209575043, + "link": null, + "locked": false + }, + { + "id": "k24WJnIxQCKlnH8qo4-jt", + "type": "text", + "x": 468.2710584690358, + "y": -27445.82044066405, + "width": 109.46734897711784, + "height": 49.141429859745834, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "rmC6CHcK15wwSv1i0ftg0", + "Fc8J9P1cajNQEDHaOAPY1", + "aMbw79PlIDU48Qsjh25V8", + "YcP05Kybnb1bEIbhfwEuN", + "K4eeIog8ZcGLEHtrGciYe", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "btW", + "roundness": null, + "seed": 1463026967, + "version": 1777, + "versionNonce": 1452217467, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575043, + "link": null, + "locked": false, + "text": "Medewerker\nPiet", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Medewerker\nPiet", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "mNyPajfbhSmhFg6TUx0uu", + "type": "image", + "x": 484.97248372862214, + "y": -27522.13183560792, + "width": 73.11632469113093, + "height": 73.11632469113093, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "K4eeIog8ZcGLEHtrGciYe", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "btX", + "roundness": null, + "seed": 918637111, + "version": 1133, + "versionNonce": 374131995, + "isDeleted": false, + "boundElements": [ + { + "id": "nkyhaaaCADMlQw-YJ96tD", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false, + "status": "saved", + "fileId": "708df2cd28b89e43cd6bf026b73c84d2b1680761", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "5OIyJtUzhr-p52af7-2bp", + "type": "rectangle", + "x": 571.4614002817752, + "y": -27513.982265507548, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "D8CUgAT6e7Vw_2vjrGVXY", + "p5T8aH8M4ViMIRUfK7NzR", + "TqfmBHV6KVJzJbpm5FxxJ", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "btY", + "roundness": { + "type": 3 + }, + "seed": 2057890647, + "version": 1198, + "versionNonce": 1393193403, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "uuiZbPpDoKZoottYFVmpc", + "type": "rectangle", + "x": 612.9311348405954, + "y": -27513.982265805855, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "D8CUgAT6e7Vw_2vjrGVXY", + "p5T8aH8M4ViMIRUfK7NzR", + "TqfmBHV6KVJzJbpm5FxxJ", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "btZ", + "roundness": null, + "seed": 1597991031, + "version": 1289, + "versionNonce": 1038778971, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "xJ526CfvUfKBecHKfv-bj", + "type": "text", + "x": 591.0560966170251, + "y": -27514.04258128861, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "D8CUgAT6e7Vw_2vjrGVXY", + "p5T8aH8M4ViMIRUfK7NzR", + "TqfmBHV6KVJzJbpm5FxxJ", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "bta", + "roundness": null, + "seed": 575226263, + "version": 1023, + "versionNonce": 1069514491, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "i1TnoK58UFDQcnHoSnolT", + "type": "text", + "x": 579.8526554316686, + "y": -27514.042581421018, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "D8CUgAT6e7Vw_2vjrGVXY", + "p5T8aH8M4ViMIRUfK7NzR", + "TqfmBHV6KVJzJbpm5FxxJ", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "btb", + "roundness": null, + "seed": 1425733303, + "version": 1046, + "versionNonce": 51111835, + "isDeleted": false, + "boundElements": [ + { + "id": "DzKAm8JbctpAcFWOKmbFx", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "CuspR-ZIUXqefxZjzcwqi", + "type": "rectangle", + "x": 611.2300478162688, + "y": -27515.06592031753, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "D8CUgAT6e7Vw_2vjrGVXY", + "p5T8aH8M4ViMIRUfK7NzR", + "TqfmBHV6KVJzJbpm5FxxJ", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "btc", + "roundness": null, + "seed": 1845037015, + "version": 1339, + "versionNonce": 1040333883, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "H2r8O6UoBn4eUU5_jHche", + "type": "rectangle", + "x": 645.9389301143619, + "y": -27513.794994412834, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "D8CUgAT6e7Vw_2vjrGVXY", + "p5T8aH8M4ViMIRUfK7NzR", + "TqfmBHV6KVJzJbpm5FxxJ", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "btd", + "roundness": null, + "seed": 458749175, + "version": 1264, + "versionNonce": 1015348443, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "ArMDL5CJqPjuWIjsygnRG", + "type": "text", + "x": 618.7461038208585, + "y": -27515.252035427562, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "QDCknZS4srIlaywoniOrt", + "p5T8aH8M4ViMIRUfK7NzR", + "TqfmBHV6KVJzJbpm5FxxJ", + "njhxnaZOZN-e9LIZBBUec" + ], + "frameId": null, + "index": "bte", + "roundness": null, + "seed": 1419525655, + "version": 1240, + "versionNonce": 707176827, + "isDeleted": false, + "boundElements": [ + { + "id": "DzKAm8JbctpAcFWOKmbFx", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "r1djFzlTwot6n_txMGl_E", + "type": "ellipse", + "x": 1198.0881450376555, + "y": -27538.596232507945, + "width": 182.2099863465829, + "height": 172.55647673726426, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "5C1h_RXi52IcMaJq0pp60", + "PAPQPN1DCMyJFmCqo812-", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "btp", + "roundness": { + "type": 2 + }, + "seed": 782506615, + "version": 1545, + "versionNonce": 472498715, + "isDeleted": false, + "boundElements": [ + { + "id": "-Szb8Wl-M3WWJ7lqCUry0", + "type": "arrow" + }, + { + "id": "uKDwV6Z7bXxRz7KX9En8z", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "nbOLR7ApeCh8LH_9X-CQx", + "type": "text", + "x": 1257.4576247070854, + "y": -27433.78280824542, + "width": 69.36799919930738, + "height": 49.141429859745834, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "uCDRGNAdlPgIGx_wXsT3J", + "SYu2qVSLblz4TPqYOzX7u", + "YrinI3ChZ8mo0BARIsF5u", + "5C1h_RXi52IcMaJq0pp60", + "PAPQPN1DCMyJFmCqo812-", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "btq", + "roundness": null, + "seed": 1179104151, + "version": 1947, + "versionNonce": 1684313083, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "ZZP'er\nJoost", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "ZZP'er\nJoost", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "FicUfF_L3vGCZxM4h9_2A", + "type": "image", + "x": 1257.0578608693513, + "y": -27510.094203189292, + "width": 70.0363526201069, + "height": 70.0363526201069, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "BrnbITReLzSfV_CNfpjlO", + "yHz8-1870s5rFV9OZx-d6", + "A1w7ecjbFGUUylto-7RVC", + "PAPQPN1DCMyJFmCqo812-", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "btr", + "roundness": null, + "seed": 341518519, + "version": 1771, + "versionNonce": 1548115099, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false, + "status": "saved", + "fileId": "ebbbf7d44e2b8252a57c53ae5d8b94fdea1ea5cc", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "ShUDg4JlMlMLmycm-S6C6", + "type": "rectangle", + "x": 1335.684148644944, + "y": -27517.66989064403, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "TlUflc7npEEcoS-z6JrJq", + "Q-c4LaewMxpY92ffBplrG", + "RkmMa0432zbZCe1bQ5tDU", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "bts", + "roundness": { + "type": 3 + }, + "seed": 1988295127, + "version": 1257, + "versionNonce": 1378226491, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "W0x_Cj9zDAwGrGBmi613s", + "type": "rectangle", + "x": 1377.153883203764, + "y": -27517.669890942343, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "TlUflc7npEEcoS-z6JrJq", + "Q-c4LaewMxpY92ffBplrG", + "RkmMa0432zbZCe1bQ5tDU", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "btt", + "roundness": null, + "seed": 567518967, + "version": 1346, + "versionNonce": 661008859, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "9cq23w_XhXaD6zlOjIdcQ", + "type": "text", + "x": 1355.2788449801928, + "y": -27517.73020642509, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "TlUflc7npEEcoS-z6JrJq", + "Q-c4LaewMxpY92ffBplrG", + "RkmMa0432zbZCe1bQ5tDU", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "btu", + "roundness": null, + "seed": 886157335, + "version": 1083, + "versionNonce": 1830370939, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "7BCYV7WieiTOIZys7pJRn", + "type": "text", + "x": 1344.0754037948373, + "y": -27517.730206557513, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "TlUflc7npEEcoS-z6JrJq", + "Q-c4LaewMxpY92ffBplrG", + "RkmMa0432zbZCe1bQ5tDU", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "btv", + "roundness": null, + "seed": 158438711, + "version": 1101, + "versionNonce": 1845606171, + "isDeleted": false, + "boundElements": [ + { + "id": "-Szb8Wl-M3WWJ7lqCUry0", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "UrwjeguBaZ4FJl_3rVwrB", + "type": "rectangle", + "x": 1375.4527961794374, + "y": -27518.753545454012, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "TlUflc7npEEcoS-z6JrJq", + "Q-c4LaewMxpY92ffBplrG", + "RkmMa0432zbZCe1bQ5tDU", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "btw", + "roundness": null, + "seed": 1192744535, + "version": 1390, + "versionNonce": 2022841275, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "V1d1JcNLsKGow1qFUCWZW", + "type": "rectangle", + "x": 1410.1616784775315, + "y": -27517.482619549322, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "TlUflc7npEEcoS-z6JrJq", + "Q-c4LaewMxpY92ffBplrG", + "RkmMa0432zbZCe1bQ5tDU", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "btx", + "roundness": null, + "seed": 882439031, + "version": 1322, + "versionNonce": 1760357467, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "7m9mZTK1p2lAGGgfv3zMo", + "type": "text", + "x": 1382.968852184028, + "y": -27518.93966056405, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "EVgkU5sbnuoRxEg97hrqL", + "Q-c4LaewMxpY92ffBplrG", + "RkmMa0432zbZCe1bQ5tDU", + "yuLbsDfcV4XJzFjBi91sJ" + ], + "frameId": null, + "index": "bty", + "roundness": null, + "seed": 1245277335, + "version": 1297, + "versionNonce": 1927588091, + "isDeleted": false, + "boundElements": [ + { + "id": "-Szb8Wl-M3WWJ7lqCUry0", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "4", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "4", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "EA5TmauKzzRcpVYlBjqD9", + "type": "ellipse", + "x": -136.31751744638996, + "y": -27535.736893343405, + "width": 182.2099863465829, + "height": 172.55647673726426, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "N3q3ecT-x2g1IJCrANUDA", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "btz", + "roundness": { + "type": 2 + }, + "seed": 61718967, + "version": 1228, + "versionNonce": 737923483, + "isDeleted": false, + "boundElements": [ + { + "id": "WE4CGE40vviVrq9TGA3-M", + "type": "arrow" + }, + { + "id": "OP40NkjswmkAszqLo5C0C", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "ffV8vPyN2q0JE0EhKs6vx", + "type": "image", + "x": -86.83006555750899, + "y": -27510.65517066037, + "width": 79.55074823294485, + "height": 79.55074823294485, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "m-3BA9nBeyMVVFfwiyYdJ", + "N3q3ecT-x2g1IJCrANUDA", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "bu0", + "roundness": null, + "seed": 1914335959, + "version": 1579, + "versionNonce": 1416024955, + "isDeleted": false, + "boundElements": [ + { + "id": "WE4CGE40vviVrq9TGA3-M", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false, + "status": "saved", + "fileId": "89153ff21bce9db4c81e5ca2b799580617710770", + "scale": [ + 1, + 1 + ], + "crop": null, + "initialWidth": 1.2277712023808363, + "initialHeight": 1.2277712023808363 + }, + { + "id": "QEjvNlILD5CCWVDqbM72o", + "type": "text", + "x": -99.94619845745137, + "y": -27430.50571778565, + "width": 109.46734897711784, + "height": 49.141429859745834, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "gecBngiARhhiEI1djvR6c", + "z5d2ZCpdhVE1-LNAKwrO4", + "m-3BA9nBeyMVVFfwiyYdJ", + "N3q3ecT-x2g1IJCrANUDA", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "bu1", + "roundness": null, + "seed": 236191735, + "version": 1598, + "versionNonce": 550808603, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "Medewerker\nJan", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Medewerker\nJan", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "RuIVnNoh3cVos3fwpxUpr", + "type": "rectangle", + "x": 11.452794161983093, + "y": -27495.625800379625, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "2M7vS3XlQHnHJQpnXACss", + "eNWVzB3H4LQnmJFHr397s", + "qGLfPJIsN8GxYtdrcZSPs", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "bu2", + "roundness": { + "type": 3 + }, + "seed": 1235151127, + "version": 1190, + "versionNonce": 524185787, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "AcZ0S-m35hLx39B0j2VO_", + "type": "rectangle", + "x": 52.92252872080326, + "y": -27495.62580067794, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "2M7vS3XlQHnHJQpnXACss", + "eNWVzB3H4LQnmJFHr397s", + "qGLfPJIsN8GxYtdrcZSPs", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "bu3", + "roundness": null, + "seed": 1647291959, + "version": 1281, + "versionNonce": 21406043, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "JGAKAKfx5BeXVtKW5_yRD", + "type": "text", + "x": 31.047490497232957, + "y": -27495.686116160687, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "2M7vS3XlQHnHJQpnXACss", + "eNWVzB3H4LQnmJFHr397s", + "qGLfPJIsN8GxYtdrcZSPs", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "bu4", + "roundness": null, + "seed": 1923796823, + "version": 1015, + "versionNonce": 541048315, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "NQi1Z68BEWUvBT9Oa5avB", + "type": "text", + "x": 19.84404931187646, + "y": -27495.6861162931, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "2M7vS3XlQHnHJQpnXACss", + "eNWVzB3H4LQnmJFHr397s", + "qGLfPJIsN8GxYtdrcZSPs", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "bu5", + "roundness": null, + "seed": 1164233847, + "version": 1035, + "versionNonce": 120342171, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "ri4yfxzgr5k2TxC9hsbFC", + "type": "rectangle", + "x": 51.22144169647663, + "y": -27496.709455189615, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "2M7vS3XlQHnHJQpnXACss", + "eNWVzB3H4LQnmJFHr397s", + "qGLfPJIsN8GxYtdrcZSPs", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "bu6", + "roundness": null, + "seed": 1713513879, + "version": 1331, + "versionNonce": 1019132731, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "Rma3y3_CdwJrWD5goNrOY", + "type": "rectangle", + "x": 85.93032399456979, + "y": -27495.43852928492, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "2M7vS3XlQHnHJQpnXACss", + "eNWVzB3H4LQnmJFHr397s", + "qGLfPJIsN8GxYtdrcZSPs", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "bu7", + "roundness": null, + "seed": 1947687607, + "version": 1255, + "versionNonce": 1297718235, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "jhkQxfQA1BqSs3TwcI2cd", + "type": "text", + "x": 58.73749770106633, + "y": -27496.89557029964, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "jFcl_1qr931lWVbse3g8x", + "eNWVzB3H4LQnmJFHr397s", + "qGLfPJIsN8GxYtdrcZSPs", + "gMnou1RJZHTm4_Kr6fzEY" + ], + "frameId": null, + "index": "bu8", + "roundness": null, + "seed": 870902743, + "version": 1229, + "versionNonce": 353331323, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "uzTYGVGApEa5VI2AAg0rC", + "type": "ellipse", + "x": -540, + "y": -27535.736893343405, + "width": 182.2099863465829, + "height": 172.55647673726426, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "mhbYlXQRWMG7H8Xjf9KF0", + "o1q8XZ6s2V5VEHjQONh4V", + "lShqzyq_V5le65AUZxfnN" + ], + "frameId": null, + "index": "bu9", + "roundness": { + "type": 2 + }, + "seed": 1638619383, + "version": 1212, + "versionNonce": 1235394843, + "isDeleted": false, + "boundElements": [ + { + "id": "_Lkj6uD3Slct57r3gLYWM", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false + }, + { + "id": "PG8UtJHaQlMugA4KxC6m9", + "type": "text", + "x": -504.2750573661692, + "y": -27425.035641070812, + "width": 109.46734897711784, + "height": 49.141429859745834, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "iKMmL2SzL1FsJlMugM51P", + "t4u66iFxDph66XAEIDiW-", + "YVlGSyb4uwavsF3AOKwgo", + "mhbYlXQRWMG7H8Xjf9KF0", + "o1q8XZ6s2V5VEHjQONh4V", + "lShqzyq_V5le65AUZxfnN" + ], + "frameId": null, + "index": "buA", + "roundness": null, + "seed": 1122181655, + "version": 1592, + "versionNonce": 215701083, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575044, + "link": null, + "locked": false, + "text": "Medewerker\nLoes", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "Medewerker\nLoes", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "wHJqmgzBbFhQNpQqqQlpg", + "type": "image", + "x": -491.4982856026354, + "y": -27504.644757443602, + "width": 78.62628777559334, + "height": 78.62628777559334, + "angle": 0, + "strokeColor": "transparent", + "backgroundColor": "#a5d8ff", + "fillStyle": "hachure", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "o1q8XZ6s2V5VEHjQONh4V", + "lShqzyq_V5le65AUZxfnN" + ], + "frameId": null, + "index": "buB", + "roundness": null, + "seed": 2021967671, + "version": 1274, + "versionNonce": 561369851, + "isDeleted": false, + "boundElements": [ + { + "id": "_Lkj6uD3Slct57r3gLYWM", + "type": "arrow" + } + ], + "updated": 1762209575044, + "link": null, + "locked": false, + "status": "saved", + "fileId": "421878bc33eecd83135e6a41f4df0e9e94b9b17f", + "scale": [ + 1, + 1 + ], + "crop": null + }, + { + "id": "uKDwV6Z7bXxRz7KX9En8z", + "type": "arrow", + "x": 1340, + "y": -27920, + "width": 60, + "height": 360, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 60, + "groupIds": [], + "frameId": null, + "index": "buT", + "roundness": { + "type": 2 + }, + "seed": 1926387575, + "version": 828, + "versionNonce": 472712405, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "gxKmxEXD8k0ccZTSfBjJu" + } + ], + "updated": 1762209578079, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -60, + 160 + ], + [ + -60, + 360 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "8gUh2W8c-sKCPUHcO4QQ5", + "focus": 0.5560603885140699, + "gap": 8.736111256568051 + }, + "endBinding": { + "elementId": "r1djFzlTwot6n_txMGl_E", + "focus": -0.1009070731552772, + "gap": 21.7625818614933 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "gxKmxEXD8k0ccZTSfBjJu", + "type": "text", + "x": -10.899955749511719, + "y": -24412.5, + "width": 101.79991149902344, + "height": 25, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e7f5ff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 60, + "groupIds": [], + "frameId": null, + "index": "buU", + "roundness": null, + "seed": 1134973079, + "version": 17, + "versionNonce": 632360057, + "isDeleted": false, + "boundElements": [], + "updated": 1762166913652, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 20, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "uKDwV6Z7bXxRz7KX9En8z", + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "OgvWp9i4z9xjsC36CTYW1", + "type": "rectangle", + "x": 280, + "y": -26740, + "width": 180, + "height": 40, + "angle": 0, + "strokeColor": "#6741d9", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "FdCwTevojBmAwNSsIrDlR" + ], + "frameId": null, + "index": "buX", + "roundness": { + "type": 3 + }, + "seed": 1580803001, + "version": 370, + "versionNonce": 527846613, + "isDeleted": false, + "boundElements": [ + { + "id": "KPfLHcVjb3B7cenABqLOV", + "type": "arrow" + } + ], + "updated": 1762210522331, + "link": null, + "locked": false + }, + { + "id": "nCbBLIQ6amRieL84vWX32", + "type": "text", + "x": 298.68333589083477, + "y": -26731, + "width": 136.5798797607422, + "height": 23, + "angle": 0, + "strokeColor": "#6741d9", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "solid", + "roughness": 1, + "opacity": 100, + "groupIds": [ + "FdCwTevojBmAwNSsIrDlR" + ], + "frameId": null, + "index": "buY", + "roundness": null, + "seed": 2125350041, + "version": 388, + "versionNonce": 1251491259, + "isDeleted": false, + "boundElements": [], + "updated": 1762210626860, + "link": null, + "locked": false, + "text": "BSN-gerechtigd", + "fontSize": 20, + "fontFamily": 7, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "BSN-gerechtigd", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "YT2zKLyJTeix70PVSBxaw", + "type": "rectangle", + "x": -10.509971016865165, + "y": -27351.66065017815, + "width": 162.6286361838998, + "height": 134.2434061404303, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "o08I-0TjuzsGRD5vTzhb7", + "Vp1BLsvDjJ0nM_XL7gsOR", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "buZ", + "roundness": null, + "seed": 182002421, + "version": 1309, + "versionNonce": 1678966139, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "csyhXiDrhr2PeajEaMxYr" + }, + { + "id": "t0-rXf5lNQjcAklVnj4Lo", + "type": "arrow" + } + ], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "csyhXiDrhr2PeajEaMxYr", + "type": "text", + "x": -5.509971016865165, + "y": -27343.50866293963, + "width": 146.98193359375, + "height": 117.93943166339001, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "o08I-0TjuzsGRD5vTzhb7", + "Vp1BLsvDjJ0nM_XL7gsOR", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "bua", + "roundness": null, + "seed": 1107491925, + "version": 1535, + "versionNonce": 972430977, + "isDeleted": false, + "boundElements": [], + "updated": 1762246821138, + "link": null, + "locked": false, + "text": "Wie: Jan\nNamens: Bedrijf-A\nVoor: Bedrijf-A\nVestnr: 12345...\nDienst: MOZa\nLoA: EH3", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "middle", + "containerId": "YT2zKLyJTeix70PVSBxaw", + "originalText": "Wie: Jan\nNamens: Bedrijf-A\nVoor: Bedrijf-A\nVestnr: 12345...\nDienst: MOZa\nLoA: EH3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "wPHaT247FetqJMPllMOf0", + "type": "rectangle", + "x": -36.31751744638996, + "y": -27375.736893343405, + "width": 109.77551451067279, + "height": 27.143793659413816, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "o08I-0TjuzsGRD5vTzhb7", + "Vp1BLsvDjJ0nM_XL7gsOR", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "bub", + "roundness": null, + "seed": 493529525, + "version": 1212, + "versionNonce": 1621822299, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "CAXHLq7mkpzR6l2XciuSC", + "type": "text", + "x": -24.674158666600306, + "y": -27371.993282191324, + "width": 86.48879657895867, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [ + "o08I-0TjuzsGRD5vTzhb7", + "Vp1BLsvDjJ0nM_XL7gsOR", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "buc", + "roundness": null, + "seed": 2117446421, + "version": 1132, + "versionNonce": 730261499, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "2lIwcVhxNE57gjzIGCbGP", + "type": "rectangle", + "x": 109.58642590581303, + "y": -27232.93980542732, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "gHTAfvpcZ1qZuk5Czz7H3", + "Yl7YxcnEG4yi1tafneoS6", + "KrWfI8Q6JclP4VQI0KaIk", + "t_sdiKsjQEdr_MX-LRzq1", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "buf", + "roundness": { + "type": 3 + }, + "seed": 101820213, + "version": 1246, + "versionNonce": 872296603, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "RaUP9HJbRtLFXq7BQQeoi", + "type": "rectangle", + "x": 151.05616046463274, + "y": -27232.939805725633, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "gHTAfvpcZ1qZuk5Czz7H3", + "Yl7YxcnEG4yi1tafneoS6", + "KrWfI8Q6JclP4VQI0KaIk", + "t_sdiKsjQEdr_MX-LRzq1", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "bug", + "roundness": null, + "seed": 69269653, + "version": 1336, + "versionNonce": 197354811, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "_iUHTXZxD7_b0W67K34Cn", + "type": "text", + "x": 129.18112224106244, + "y": -27233.00012120838, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "gHTAfvpcZ1qZuk5Czz7H3", + "Yl7YxcnEG4yi1tafneoS6", + "KrWfI8Q6JclP4VQI0KaIk", + "t_sdiKsjQEdr_MX-LRzq1", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "buh", + "roundness": null, + "seed": 452926965, + "version": 1070, + "versionNonce": 1782121947, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "4pKI3ozaqilWyXIbQDRFk", + "type": "text", + "x": 117.97768105570594, + "y": -27233.000121340796, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "gHTAfvpcZ1qZuk5Czz7H3", + "Yl7YxcnEG4yi1tafneoS6", + "KrWfI8Q6JclP4VQI0KaIk", + "t_sdiKsjQEdr_MX-LRzq1", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "bui", + "roundness": null, + "seed": 1907464021, + "version": 1092, + "versionNonce": 1987154555, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "Pg8mJcpkC-uEf1nTTd5TS", + "type": "rectangle", + "x": 149.35507344030657, + "y": -27234.023460237302, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "gHTAfvpcZ1qZuk5Czz7H3", + "Yl7YxcnEG4yi1tafneoS6", + "KrWfI8Q6JclP4VQI0KaIk", + "t_sdiKsjQEdr_MX-LRzq1", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "buj", + "roundness": null, + "seed": 848159925, + "version": 1386, + "versionNonce": 1362070299, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "jLSXt3KTnwibNhQAHIqyj", + "type": "rectangle", + "x": 184.06395573840018, + "y": -27232.752534332612, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "gHTAfvpcZ1qZuk5Czz7H3", + "Yl7YxcnEG4yi1tafneoS6", + "KrWfI8Q6JclP4VQI0KaIk", + "t_sdiKsjQEdr_MX-LRzq1", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "buk", + "roundness": null, + "seed": 557418005, + "version": 1311, + "versionNonce": 1592094651, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "Y9dR5l0XkxM6tjUTptAQW", + "type": "text", + "x": 156.87112944489672, + "y": -27234.209575347333, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "Z1rX_A7h28Z_6_FQ0uciJ", + "Yl7YxcnEG4yi1tafneoS6", + "KrWfI8Q6JclP4VQI0KaIk", + "t_sdiKsjQEdr_MX-LRzq1", + "RalOdD0U3BFrl_uC0vp1I" + ], + "frameId": null, + "index": "bul", + "roundness": null, + "seed": 1890188149, + "version": 1284, + "versionNonce": 1370865755, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false, + "text": "3", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "t0-rXf5lNQjcAklVnj4Lo", + "type": "arrow", + "x": 96.42187526037989, + "y": -27195.736893343405, + "width": 303.57648417282496, + "height": 255.73775891872356, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bum", + "roundness": { + "type": 2 + }, + "seed": 915207605, + "version": 3529, + "versionNonce": 47682453, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "393gzSyXm4w8JSzVdm4yS" + } + ], + "updated": 1762209578079, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 143.5781247396201, + 135.73689334340452 + ], + [ + 303.57648417282496, + 255.73775891872356 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "YT2zKLyJTeix70PVSBxaw", + "focus": 0.4485119941150577, + "gap": 21.680350694314257 + }, + "endBinding": { + "elementId": "hSQc06kmbdlvLZHiyh0UJ", + "focus": 0.211215095971093, + "gap": 27.473721615199626 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "393gzSyXm4w8JSzVdm4yS", + "type": "text", + "x": 192.447021484375, + "y": -22769.828285971947, + "width": 95.10595703125, + "height": 19.656571943898335, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#e6fcf5", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bun", + "roundness": null, + "seed": 1429108501, + "version": 108, + "versionNonce": 1761044629, + "isDeleted": false, + "boundElements": [], + "updated": 1762181773120, + "link": null, + "locked": false, + "text": "Autorisatie", + "fontSize": 15.725257555118667, + "fontFamily": 8, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "t0-rXf5lNQjcAklVnj4Lo", + "originalText": "Autorisatie", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "OP40NkjswmkAszqLo5C0C", + "type": "arrow", + "x": 23.682482553609788, + "y": -27675.742252620366, + "width": 26.631454050788307, + "height": 135.50939978806127, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "buo", + "roundness": { + "type": 2 + }, + "seed": 932967829, + "version": 4995, + "versionNonce": 1102934613, + "isDeleted": false, + "boundElements": [ + { + "type": "text", + "id": "DkzHvH34yWSYD8gdM_E_1" + } + ], + "updated": 1762209578080, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 20.000000000000256, + 60.005359276961826 + ], + [ + -6.631454050788051, + 135.50939978806127 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "9DMSCZeJcbHrkXQQORhmo", + "focus": -0.6843167306398831, + "gap": 16 + }, + "endBinding": { + "elementId": "EA5TmauKzzRcpVYlBjqD9", + "focus": 0.24886377533014525, + "gap": 22.31546165854779 + }, + "startArrowhead": null, + "endArrowhead": "arrow", + "elbowed": false + }, + { + "id": "DkzHvH34yWSYD8gdM_E_1", + "type": "text", + "x": 180, + "y": -23291.766557353872, + "width": 100.01841735839844, + "height": 24.57071492987292, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "transparent", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bup", + "roundness": null, + "seed": 1211125, + "version": 110, + "versionNonce": 95915797, + "isDeleted": false, + "boundElements": [], + "updated": 1762201931985, + "link": null, + "locked": false, + "text": "Machtiging", + "fontSize": 19.656571943898335, + "fontFamily": 5, + "textAlign": "center", + "verticalAlign": "middle", + "containerId": "OP40NkjswmkAszqLo5C0C", + "originalText": "Machtiging", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "LTCaalz3hBbmvWfgXVMDN", + "type": "rectangle", + "x": -453.4758495009728, + "y": -27224.521285614428, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iQZuQse194ntCzYl5C_Jj", + "D_RIQBDzf2DdZoTqHWdYK", + "ZL7xrNf-pPbGrTCs1KmaH", + "l_mho_yMXyCU8IfDzXK77" + ], + "frameId": null, + "index": "buq", + "roundness": { + "type": 3 + }, + "seed": 536459829, + "version": 1371, + "versionNonce": 1567504955, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "9AkAL2gprCN9OLBgVInte", + "type": "rectangle", + "x": -412.00611494215264, + "y": -27224.521285912742, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iQZuQse194ntCzYl5C_Jj", + "D_RIQBDzf2DdZoTqHWdYK", + "ZL7xrNf-pPbGrTCs1KmaH", + "l_mho_yMXyCU8IfDzXK77" + ], + "frameId": null, + "index": "bur", + "roundness": null, + "seed": 1838066581, + "version": 1459, + "versionNonce": 1237400283, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "LH2Fe2gN1bQ51S2Gud4WD", + "type": "text", + "x": -433.88115316572294, + "y": -27224.581601395483, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iQZuQse194ntCzYl5C_Jj", + "D_RIQBDzf2DdZoTqHWdYK", + "ZL7xrNf-pPbGrTCs1KmaH", + "l_mho_yMXyCU8IfDzXK77" + ], + "frameId": null, + "index": "bus", + "roundness": null, + "seed": 306082037, + "version": 1196, + "versionNonce": 19605371, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "ZunU3gEg1yMNSF81cbzQb", + "type": "text", + "x": -445.0845943510785, + "y": -27224.581601527905, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iQZuQse194ntCzYl5C_Jj", + "D_RIQBDzf2DdZoTqHWdYK", + "ZL7xrNf-pPbGrTCs1KmaH", + "l_mho_yMXyCU8IfDzXK77" + ], + "frameId": null, + "index": "but", + "roundness": null, + "seed": 193890901, + "version": 1218, + "versionNonce": 1508802587, + "isDeleted": false, + "boundElements": [ + { + "id": "110qgmWaZ5RbVS1oTZ_FB", + "type": "arrow" + } + ], + "updated": 1762209575045, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "g7JrX6eYNev-83bAso5G3", + "type": "rectangle", + "x": -413.70720196647835, + "y": -27225.604940424404, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iQZuQse194ntCzYl5C_Jj", + "D_RIQBDzf2DdZoTqHWdYK", + "ZL7xrNf-pPbGrTCs1KmaH", + "l_mho_yMXyCU8IfDzXK77" + ], + "frameId": null, + "index": "buu", + "roundness": null, + "seed": 173307829, + "version": 1510, + "versionNonce": 1040041147, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "gVvzPYF-6CKi273IOJ6zN", + "type": "rectangle", + "x": -378.9983196683861, + "y": -27224.334014519714, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "iQZuQse194ntCzYl5C_Jj", + "D_RIQBDzf2DdZoTqHWdYK", + "ZL7xrNf-pPbGrTCs1KmaH", + "l_mho_yMXyCU8IfDzXK77" + ], + "frameId": null, + "index": "buv", + "roundness": null, + "seed": 146127125, + "version": 1433, + "versionNonce": 888894811, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "1CirMoYUWGZsbUC4FKaQf", + "type": "text", + "x": -406.19114596188774, + "y": -27225.791055534442, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "jWeGmybIChq_zPQjo8dGg", + "D_RIQBDzf2DdZoTqHWdYK", + "ZL7xrNf-pPbGrTCs1KmaH", + "l_mho_yMXyCU8IfDzXK77" + ], + "frameId": null, + "index": "buw", + "roundness": null, + "seed": 539479669, + "version": 1410, + "versionNonce": 775557627, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false, + "text": "2+", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "2+", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "LT51GVzTOkuM1EhW8M-AC", + "type": "line", + "x": -574.5110962415547, + "y": -26340, + "width": 1500, + "height": 0, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "buy", + "roundness": { + "type": 2 + }, + "seed": 1504619157, + "version": 479, + "versionNonce": 572405173, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1500, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "3dgx1754RJ__ip6LdYs9u", + "type": "line", + "x": -574.5110962415547, + "y": -26140, + "width": 1500, + "height": 0, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "buz", + "roundness": { + "type": 2 + }, + "seed": 403083253, + "version": 508, + "versionNonce": 1016575765, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1500, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "755XOCrjS6kH0ZS9_aU3_", + "type": "line", + "x": -574.5110962415547, + "y": -26240, + "width": 1500, + "height": 0, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bv0", + "roundness": { + "type": 2 + }, + "seed": 16435541, + "version": 503, + "versionNonce": 1125780597, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1500, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "ULgt4D-BUCwgcBWRbjF0u", + "type": "text", + "x": -111.86062573800967, + "y": -26304, + "width": 46.199981689453125, + "height": 35, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bv4", + "roundness": null, + "seed": 635492021, + "version": 482, + "versionNonce": 1701492181, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "text": "BSN", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "BSN", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "3oY-o7PdL8biw1Ma3KgJj", + "type": "text", + "x": -553.8606257380097, + "y": -26204, + "width": 492.7998046875, + "height": 35, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bv5", + "roundness": null, + "seed": 1365129237, + "version": 520, + "versionNonce": 1050620725, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "text": "PseudoID (Persistent Pseudoniem)", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "PseudoID (Persistent Pseudoniem)", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Y8Oytt5UbGQq4jxvhZ3ha", + "type": "text", + "x": -511.10235506345475, + "y": -26106.841667945417, + "width": 446.5998229980469, + "height": 35, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bv6", + "roundness": null, + "seed": 1567124853, + "version": 622, + "versionNonce": 1797063829, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "text": "Pseudo (Specifiek Pseudoniem)", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Pseudo (Specifiek Pseudoniem)", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "HhS9a6L1kO0hbXULoj8hd", + "type": "line", + "x": -574.5110962415547, + "y": -26040, + "width": 1500, + "height": 0, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bv7", + "roundness": { + "type": 2 + }, + "seed": 1229256405, + "version": 520, + "versionNonce": 1587128821, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1500, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "m0qpQmG0B4t4gNAHzapoF", + "type": "line", + "x": -573.9821343229027, + "y": -25936.185115941873, + "width": 1499.471038081348, + "height": 3.8148840581270633, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bv8", + "roundness": { + "type": 2 + }, + "seed": 260658229, + "version": 534, + "versionNonce": 2048566101, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1499.471038081348, + -3.8148840581270633 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "ouUPDGeXerK6dArT2S99U", + "type": "line", + "x": -574.5110962415547, + "y": -25840, + "width": 1500, + "height": 0, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bv9", + "roundness": { + "type": 2 + }, + "seed": 1008403861, + "version": 541, + "versionNonce": 1643475125, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1500, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "fozE7MlazfQcLJAAEdoO6", + "type": "line", + "x": -574.5110962415547, + "y": -25740, + "width": 1500, + "height": 0, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvA", + "roundness": { + "type": 2 + }, + "seed": 1110412021, + "version": 538, + "versionNonce": 332370453, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1500, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "jtmiZeSrjQSg_frD0KB_C", + "type": "line", + "x": -574.5110962415547, + "y": -25540, + "width": 1500, + "height": 0, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvB", + "roundness": { + "type": 2 + }, + "seed": 306996309, + "version": 541, + "versionNonce": 1017022325, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1500, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "-ytdsYAYtj8W4W9Lv6JBT", + "type": "line", + "x": -573.7394351766319, + "y": -25638.188735111056, + "width": 1499.2283389350773, + "height": 1.8112648889436969, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvC", + "roundness": { + "type": 2 + }, + "seed": 1883705781, + "version": 544, + "versionNonce": 1319620821, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1499.2283389350773, + -1.8112648889436969 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "tOWqaTWY-i3JnAy_97k_R", + "type": "line", + "x": -574.5110962415547, + "y": -25340, + "width": 1500, + "height": 0, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvD", + "roundness": { + "type": 2 + }, + "seed": 155521813, + "version": 551, + "versionNonce": 1468067381, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877736, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1500, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "iE8xOFyKE8jr48qSxLmrc", + "type": "line", + "x": -574.5110962415547, + "y": -25440, + "width": 1500, + "height": 0, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvE", + "roundness": { + "type": 2 + }, + "seed": 1237051509, + "version": 541, + "versionNonce": 370106261, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1500, + 0 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "LhRrujYGGuQot8yK5Bk5q", + "type": "text", + "x": -111.86062573800967, + "y": -26004, + "width": 46.199981689453125, + "height": 35, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvF", + "roundness": null, + "seed": 1936789973, + "version": 499, + "versionNonce": 1351132405, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "KVK", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "KVK", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "7NAXzBf2fgpfW-WQgR8K_", + "type": "text", + "x": -131.86062573800967, + "y": -25904, + "width": 61.5999755859375, + "height": 35, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvG", + "roundness": null, + "seed": 1937379125, + "version": 482, + "versionNonce": 1785871957, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "RSIN", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "RSIN", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Uup65xAERO5rJCmIW0EtP", + "type": "text", + "x": -164.86062573800967, + "y": -25804, + "width": 92.39996337890625, + "height": 35, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvH", + "roundness": null, + "seed": 2017222805, + "version": 499, + "versionNonce": 983673781, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "PROBAS", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "PROBAS", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "75H0dYBDIXlxVFGVSrHsN", + "type": "text", + "x": -160.86062573800967, + "y": -25704, + "width": 92.39996337890625, + "height": 35, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvI", + "roundness": null, + "seed": 1198360053, + "version": 514, + "versionNonce": 557608213, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "TTR-BD", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "TTR-BD", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "P5p7i4xYDseBCKRArAotz", + "type": "text", + "x": -151.86062573800967, + "y": -25604, + "width": 76.99996948242188, + "height": 35, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvJ", + "roundness": null, + "seed": 1410531157, + "version": 496, + "versionNonce": 1572340341, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "eIDAS", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "eIDAS", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "YkigOuQ-fvc2k-BYdqjsZ", + "type": "text", + "x": -311.8606257380097, + "y": -25504, + "width": 246.39990234375, + "height": 35, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvK", + "roundness": null, + "seed": 344083637, + "version": 502, + "versionNonce": 618261461, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "Vestigingsnummer", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Vestigingsnummer", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "2jCG7Y2joxSxQcFsbs4Am", + "type": "text", + "x": -311.8606257380097, + "y": -25404, + "width": 246.39990234375, + "height": 35, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvL", + "roundness": null, + "seed": 409005589, + "version": 516, + "versionNonce": 1991747893, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "KVK intermediair", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "KVK intermediair", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "DPWVBP9J5FgMJkvRqeKTu", + "type": "line", + "x": -35.503141442945434, + "y": -26442.54527658932, + "width": 0.9920452013907379, + "height": 1102.5452765893206, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvM", + "roundness": { + "type": 2 + }, + "seed": 1587831669, + "version": 498, + "versionNonce": 884390549, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0.9920452013907379, + 1102.5452765893206 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "E22mpT23ppPDHVTiOqEOS", + "type": "ellipse", + "x": -395.6291736997948, + "y": -27141.42083397271, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "qhw7Y3NupBIoyXPIxS6ei" + ], + "frameId": null, + "index": "bvQ", + "roundness": { + "type": 2 + }, + "seed": 1920602261, + "version": 597, + "versionNonce": 1580110939, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "5lUIKDFmXOzNGP-2FHwTk", + "type": "text", + "x": -380.6291736997948, + "y": -27133.42083397271, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "qhw7Y3NupBIoyXPIxS6ei" + ], + "frameId": null, + "index": "bvR", + "roundness": null, + "seed": 242562549, + "version": 593, + "versionNonce": 565268731, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false, + "text": "1", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "1", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "KRShVssqWXNpdD9ufbQhm", + "type": "ellipse", + "x": -140, + "y": -27140, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "TBtbV3-fGju8QXtNrtIjy" + ], + "frameId": null, + "index": "bvS", + "roundness": { + "type": 2 + }, + "seed": 747570549, + "version": 593, + "versionNonce": 720599451, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false + }, + { + "id": "znjchCQAlUPgn2lZ0eYe0", + "type": "text", + "x": -125, + "y": -27132, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "TBtbV3-fGju8QXtNrtIjy" + ], + "frameId": null, + "index": "bvT", + "roundness": null, + "seed": 668503765, + "version": 590, + "versionNonce": 1730645563, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575045, + "link": null, + "locked": false, + "text": "2", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "2", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Ox9FQEk8N6A7pzZyRashr", + "type": "ellipse", + "x": 160, + "y": -27140, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "CNKrC-k5DBEzEeKhHQfiL" + ], + "frameId": null, + "index": "bvU", + "roundness": { + "type": 2 + }, + "seed": 1798925083, + "version": 619, + "versionNonce": 2033192667, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false + }, + { + "id": "CflWWtNobkeA7ZMqHLZn1", + "type": "text", + "x": 175, + "y": -27132, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "CNKrC-k5DBEzEeKhHQfiL" + ], + "frameId": null, + "index": "bvV", + "roundness": null, + "seed": 1555255227, + "version": 617, + "versionNonce": 60783483, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false, + "text": "3", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "VL4SnISNXS8JhW3ZEK6hg", + "type": "ellipse", + "x": 440, + "y": -27140, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "zeUvunsn9zMO0zvawycaP" + ], + "frameId": null, + "index": "bvW", + "roundness": { + "type": 2 + }, + "seed": 698809691, + "version": 626, + "versionNonce": 850940955, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false + }, + { + "id": "GRoT-4mzWSPJbpAqFccGx", + "type": "text", + "x": 455, + "y": -27132, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "zeUvunsn9zMO0zvawycaP" + ], + "frameId": null, + "index": "bvX", + "roundness": null, + "seed": 338991611, + "version": 624, + "versionNonce": 107813051, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false, + "text": "4", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "4", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "4NGUZqW1IzS-tusJzQ2tb", + "type": "ellipse", + "x": 610.1624865731187, + "y": -27142.841667945417, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "2bE_tJ3V8IK3tzlc9T5ta" + ], + "frameId": null, + "index": "bvY", + "roundness": { + "type": 2 + }, + "seed": 1023279995, + "version": 649, + "versionNonce": 1549814107, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false + }, + { + "id": "8bdbQhyMv6e-ohIxxJyh7", + "type": "text", + "x": 625.1624865731187, + "y": -27134.841667945417, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "2bE_tJ3V8IK3tzlc9T5ta" + ], + "frameId": null, + "index": "bvZ", + "roundness": null, + "seed": 1325784091, + "version": 647, + "versionNonce": 971269627, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false, + "text": "5", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "5", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "EP2hNeswLsS6ySFa1p4De", + "type": "ellipse", + "x": 980, + "y": -27140, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "0lQCUG6c4bPQzbjLuOlBB" + ], + "frameId": null, + "index": "bva", + "roundness": { + "type": 2 + }, + "seed": 1004578139, + "version": 628, + "versionNonce": 1442573979, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false + }, + { + "id": "64q3lktEmKRWTZu0YxPFK", + "type": "text", + "x": 994, + "y": -27133, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "0lQCUG6c4bPQzbjLuOlBB" + ], + "frameId": null, + "index": "bvb", + "roundness": null, + "seed": 16335355, + "version": 642, + "versionNonce": 1666802491, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false, + "text": "6", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "6", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "XWEMU9_C_FIig0ocR6CTp", + "type": "ellipse", + "x": 1300, + "y": -27140, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "DXOXYT4r_A0Nps5RlNnTm" + ], + "frameId": null, + "index": "bvc", + "roundness": { + "type": 2 + }, + "seed": 476749499, + "version": 620, + "versionNonce": 442450907, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false + }, + { + "id": "QThI7IdEm3Ml6eVsriFnJ", + "type": "text", + "x": 1315, + "y": -27132, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "DXOXYT4r_A0Nps5RlNnTm" + ], + "frameId": null, + "index": "bvd", + "roundness": null, + "seed": 616370011, + "version": 618, + "versionNonce": 52433019, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575046, + "link": null, + "locked": false, + "text": "7", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "7", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "giQAJbLe6kPexuTBpDlA8", + "type": "ellipse", + "x": 5.4889037584453035, + "y": -26420, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "s2v1MIKCl9u9eSoa6spNT" + ], + "frameId": null, + "index": "bve", + "roundness": { + "type": 2 + }, + "seed": 702858389, + "version": 808, + "versionNonce": 2005704693, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false + }, + { + "id": "BJfS6fLwpQXh9tVCTzOG-", + "type": "text", + "x": 20.488903758445304, + "y": -26412, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "s2v1MIKCl9u9eSoa6spNT" + ], + "frameId": null, + "index": "bvf", + "roundness": null, + "seed": 1852402165, + "version": 804, + "versionNonce": 624875861, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "1", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "1", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "1pD8EF-dIbsNRT0K1IOBT", + "type": "line", + "x": 85.4889037584453, + "y": -26440, + "width": 1.3889964893460274, + "height": 1104, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvg", + "roundness": { + "type": 2 + }, + "seed": 236511669, + "version": 551, + "versionNonce": 1193469621, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 1.3889964893460274, + 1104 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "v75gw6-XxNi-SX98xoe_p", + "type": "line", + "x": 205.4889037584453, + "y": -26440, + "width": 3, + "height": 1100, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvh", + "roundness": { + "type": 2 + }, + "seed": 1803238229, + "version": 546, + "versionNonce": 534661141, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -3, + 1100 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "GGePwVaTkhI3ZKV5BIcZW", + "type": "line", + "x": 325.4889037584453, + "y": -26440, + "width": 0, + "height": 1100, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvi", + "roundness": { + "type": 2 + }, + "seed": 687643931, + "version": 548, + "versionNonce": 23494005, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 1100 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "AtihheYox7RpWhFrBooh8", + "type": "line", + "x": 445.4889037584453, + "y": -26440, + "width": 0, + "height": 1100, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvj", + "roundness": { + "type": 2 + }, + "seed": 529394363, + "version": 523, + "versionNonce": 1661011669, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 1100 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "apxBTDp4A0s1ZQKTnYgNE", + "type": "line", + "x": 565.4889037584453, + "y": -26440, + "width": 0, + "height": 1100, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvk", + "roundness": { + "type": 2 + }, + "seed": 425700565, + "version": 527, + "versionNonce": 927163445, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 1100 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "fSa4XHkyJCbbG4MeHOCkh", + "type": "line", + "x": 685.4889037584453, + "y": -26440, + "width": 0, + "height": 1100, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvl", + "roundness": { + "type": 2 + }, + "seed": 566878331, + "version": 528, + "versionNonce": 34805141, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 1100 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "b5e-hVsGJyYEH_dHPRFGo", + "type": "ellipse", + "x": 125.4889037584453, + "y": -26420, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "8yAXg_NVivgU3m6oKEWvU" + ], + "frameId": null, + "index": "bvm", + "roundness": { + "type": 2 + }, + "seed": 1924488251, + "version": 814, + "versionNonce": 782605045, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false + }, + { + "id": "uDBlDaa4W3CKNQQP6tQNs", + "type": "text", + "x": 140.4889037584453, + "y": -26412, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "8yAXg_NVivgU3m6oKEWvU" + ], + "frameId": null, + "index": "bvn", + "roundness": null, + "seed": 768875739, + "version": 811, + "versionNonce": 629175381, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "2", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "2", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "49UQzUJolfJl7dLOLaxbc", + "type": "ellipse", + "x": 245.4889037584453, + "y": -26420, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "ddS04vNUGllDO9i06U_U_" + ], + "frameId": null, + "index": "bvo", + "roundness": { + "type": 2 + }, + "seed": 1150415739, + "version": 838, + "versionNonce": 578363829, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false + }, + { + "id": "I5uDZVMr-KC161ppfeSNK", + "type": "text", + "x": 260.4889037584453, + "y": -26412, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "ddS04vNUGllDO9i06U_U_" + ], + "frameId": null, + "index": "bvp", + "roundness": null, + "seed": 513526811, + "version": 836, + "versionNonce": 1253384981, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "3", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "3", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "hrGWItMGfeA3zCkk145W0", + "type": "ellipse", + "x": 365.4889037584453, + "y": -26420, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "pKgeJCZBbtE1WdVVWCUJK" + ], + "frameId": null, + "index": "bvq", + "roundness": { + "type": 2 + }, + "seed": 984790517, + "version": 853, + "versionNonce": 44693621, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false + }, + { + "id": "uXjcONofDLCoE1ijIYHlD", + "type": "text", + "x": 380.4889037584453, + "y": -26412, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "pKgeJCZBbtE1WdVVWCUJK" + ], + "frameId": null, + "index": "bvr", + "roundness": null, + "seed": 120729429, + "version": 851, + "versionNonce": 69018069, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "4", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "4", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "0xe_hOz_Q1447jfKmwWal", + "type": "ellipse", + "x": 485.4889037584453, + "y": -26420, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "s0P68sNOk40E69CoePolA" + ], + "frameId": null, + "index": "bvs", + "roundness": { + "type": 2 + }, + "seed": 1696110811, + "version": 879, + "versionNonce": 874782517, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false + }, + { + "id": "RfcUCFVsJePdRvfLnvN5B", + "type": "text", + "x": 500.4889037584453, + "y": -26412, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "s0P68sNOk40E69CoePolA" + ], + "frameId": null, + "index": "bvt", + "roundness": null, + "seed": 904316283, + "version": 877, + "versionNonce": 958689429, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "5", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "5", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "WH7StlrIodRsSvSCKuTEh", + "type": "ellipse", + "x": 605.4889037584453, + "y": -26420, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "ef5u7FI-VMAg8kNyrPgXT" + ], + "frameId": null, + "index": "bvu", + "roundness": { + "type": 2 + }, + "seed": 581460501, + "version": 856, + "versionNonce": 1356043765, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false + }, + { + "id": "MHGjiq2rPGoXV3_2gVaDi", + "type": "text", + "x": 619.4889037584452, + "y": -26413, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "ef5u7FI-VMAg8kNyrPgXT" + ], + "frameId": null, + "index": "bvv", + "roundness": null, + "seed": 400381813, + "version": 870, + "versionNonce": 1714884437, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "6", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "6", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "kdBu9dSHhF9OOYJ4w191i", + "type": "ellipse", + "x": 725.4889037584453, + "y": -26420, + "width": 40, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "6I61bnP7EUpKFxvpZy3F0" + ], + "frameId": null, + "index": "bvw", + "roundness": { + "type": 2 + }, + "seed": 1146736149, + "version": 860, + "versionNonce": 1738824885, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false + }, + { + "id": "Dtxer3ALfQHBsmAEVe2ah", + "type": "text", + "x": 740.4889037584453, + "y": -26412, + "width": 12, + "height": 25, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "6I61bnP7EUpKFxvpZy3F0" + ], + "frameId": null, + "index": "bvx", + "roundness": null, + "seed": 1484866421, + "version": 858, + "versionNonce": 1556151829, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "7", + "fontSize": 20, + "fontFamily": 6, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "7", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "5St4WGHbE-j0mOHkNX58B", + "type": "line", + "x": 805.4889037584453, + "y": -26440, + "width": 0, + "height": 1100, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bvy", + "roundness": { + "type": 2 + }, + "seed": 1024714971, + "version": 551, + "versionNonce": 1015182197, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 0, + 1100 + ] + ], + "lastCommittedPoint": null, + "startBinding": null, + "endBinding": null, + "startArrowhead": null, + "endArrowhead": null, + "polygon": false + }, + { + "id": "Is58UGAtGwvKrMJJvaH36", + "type": "text", + "x": 0, + "y": -26200, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwM", + "roundness": null, + "seed": 176101883, + "version": 535, + "versionNonce": 1193117249, + "isDeleted": false, + "boundElements": [], + "updated": 1762252944288, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "pPsblCfHhybhmz-6im9mj", + "type": "text", + "x": 0, + "y": -26100, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwN", + "roundness": null, + "seed": 1921204859, + "version": 544, + "versionNonce": 400419105, + "isDeleted": false, + "boundElements": [], + "updated": 1762252929413, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "O1sLXN0LR0p34ht0jaPlm", + "type": "text", + "x": 480, + "y": -25400, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwO", + "roundness": null, + "seed": 2124152981, + "version": 562, + "versionNonce": 268109825, + "isDeleted": false, + "boundElements": [], + "updated": 1762252960387, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "h9gPS6r3TILsSQY2mGtpP", + "type": "text", + "x": 0, + "y": -26000, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwW", + "roundness": null, + "seed": 1180570005, + "version": 558, + "versionNonce": 982191457, + "isDeleted": false, + "boundElements": [], + "updated": 1762252928226, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "L1cqslebagwVU7ywjAGZ9", + "type": "text", + "x": 0, + "y": -25900, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwX", + "roundness": null, + "seed": 1638236027, + "version": 596, + "versionNonce": 273170849, + "isDeleted": false, + "boundElements": [], + "updated": 1762252926819, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "ijcg07vH5-bucJ2bCLJw2", + "type": "text", + "x": 120, + "y": -26200, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwa", + "roundness": null, + "seed": 1902579829, + "version": 591, + "versionNonce": 914977409, + "isDeleted": false, + "boundElements": [], + "updated": 1762252942538, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "JCfIhB-ovxxgk3NxhIo52", + "type": "text", + "x": 360, + "y": -26300, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwb", + "roundness": null, + "seed": 1993142555, + "version": 586, + "versionNonce": 874241473, + "isDeleted": false, + "boundElements": [], + "updated": 1762252948561, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "o_xEmI5W475UdksVSbwKv", + "type": "text", + "x": 240, + "y": -25500, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwc", + "roundness": null, + "seed": 352461563, + "version": 584, + "versionNonce": 1754517633, + "isDeleted": false, + "boundElements": [], + "updated": 1762252958263, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "WZLjbJMbjqVEzjDI_8wv-", + "type": "text", + "x": 0, + "y": -25500, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwd", + "roundness": null, + "seed": 798630107, + "version": 585, + "versionNonce": 1949620481, + "isDeleted": false, + "boundElements": [], + "updated": 1762252955444, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "nYoFySdhMchTswk2c1Iwm", + "type": "text", + "x": 120, + "y": -25500, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwe", + "roundness": null, + "seed": 1870162619, + "version": 632, + "versionNonce": 687951041, + "isDeleted": false, + "boundElements": [], + "updated": 1762252956935, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "kMZo1nihK0hFOEu2Le3h8", + "type": "text", + "x": 360, + "y": -25400, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwf", + "roundness": null, + "seed": 774930587, + "version": 600, + "versionNonce": 615015489, + "isDeleted": false, + "boundElements": [], + "updated": 1762252959351, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "uvBvhL42ZwmiztzlwzJa-", + "type": "text", + "x": 120, + "y": -25900, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwm", + "roundness": null, + "seed": 2110876091, + "version": 579, + "versionNonce": 1389987297, + "isDeleted": false, + "boundElements": [], + "updated": 1762252925480, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "B15B7plSLybEI3p_ttaP9", + "type": "text", + "x": 120, + "y": -26000, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwn", + "roundness": null, + "seed": 177594267, + "version": 574, + "versionNonce": 1897248335, + "isDeleted": false, + "boundElements": [], + "updated": 1762252923633, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "kZgyC69jpd9uu9i5b65s3", + "type": "text", + "x": 120, + "y": -26100, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwo", + "roundness": null, + "seed": 22258043, + "version": 579, + "versionNonce": 259839201, + "isDeleted": false, + "boundElements": [], + "updated": 1762252930668, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "N7PvXUhYzxvXBlC1fUleR", + "type": "text", + "x": 360, + "y": -25900, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwr", + "roundness": null, + "seed": 814952693, + "version": 579, + "versionNonce": 1256582415, + "isDeleted": false, + "boundElements": [], + "updated": 1762252910226, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "pZ53cJ9v2a93ncUhUfSOb", + "type": "text", + "x": 360, + "y": -26000, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bws", + "roundness": null, + "seed": 1178761493, + "version": 588, + "versionNonce": 1043829967, + "isDeleted": false, + "boundElements": [], + "updated": 1762252908475, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Eq-BSKgwIIOrKuWZyAgsR", + "type": "text", + "x": 240, + "y": -25900, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwu", + "roundness": null, + "seed": 1229710677, + "version": 594, + "versionNonce": 1140897409, + "isDeleted": false, + "boundElements": [], + "updated": 1762252921351, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Ez4K8Xfs_p-vDChgDtX6M", + "type": "text", + "x": 240, + "y": -26000, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwv", + "roundness": null, + "seed": 1535052149, + "version": 585, + "versionNonce": 2141512623, + "isDeleted": false, + "boundElements": [], + "updated": 1762252918851, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "h8WBhDIu5AdPXka3PpNzX", + "type": "text", + "x": 240, + "y": -26300, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bww", + "roundness": null, + "seed": 1944527253, + "version": 585, + "versionNonce": 219130369, + "isDeleted": false, + "boundElements": [], + "updated": 1762252947569, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "jy-gzaCQhdp0CCany8pmg", + "type": "text", + "x": 600, + "y": -26300, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwx", + "roundness": null, + "seed": 1950414523, + "version": 577, + "versionNonce": 1500673345, + "isDeleted": false, + "boundElements": [], + "updated": 1762252950507, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "mmQ9lVCo18JkeLTV0WxtP", + "type": "text", + "x": 600, + "y": -26000, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwy", + "roundness": null, + "seed": 146050203, + "version": 577, + "versionNonce": 1371294465, + "isDeleted": false, + "boundElements": [], + "updated": 1762254357144, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Nx3UwawiCadDRCrF3ujj9", + "type": "text", + "x": 720, + "y": -26100, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bwz", + "roundness": null, + "seed": 1677028987, + "version": 580, + "versionNonce": 322985889, + "isDeleted": false, + "boundElements": [], + "updated": 1762252935694, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "8uJCBRzQjpx4Mx15NCjyf", + "type": "text", + "x": 720, + "y": -26200, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bx0", + "roundness": null, + "seed": 1492589659, + "version": 582, + "versionNonce": 815230657, + "isDeleted": false, + "boundElements": [], + "updated": 1762252941101, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Oe7hPTqkHwXLFCIcOb4Za", + "type": "text", + "x": 480, + "y": -25900, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bx4", + "roundness": null, + "seed": 1436273627, + "version": 582, + "versionNonce": 1578269537, + "isDeleted": false, + "boundElements": [], + "updated": 1762254352112, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "0vaUYnSlBuBOV6Ar4meYq", + "type": "text", + "x": 480, + "y": -26000, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bx5", + "roundness": null, + "seed": 934671803, + "version": 581, + "versionNonce": 675331745, + "isDeleted": false, + "boundElements": [], + "updated": 1762254362643, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "q74wgUdML05QPtItFSdll", + "type": "text", + "x": 480, + "y": -26300, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bx6", + "roundness": null, + "seed": 1605757851, + "version": 573, + "versionNonce": 687743361, + "isDeleted": false, + "boundElements": [], + "updated": 1762252949485, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Y1nh5fFlP3-n6JRpgZgEn", + "type": "text", + "x": 720, + "y": -26000, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxC", + "roundness": null, + "seed": 1094700949, + "version": 627, + "versionNonce": 1486072673, + "isDeleted": false, + "boundElements": [], + "updated": 1762252936976, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "X4tg9WtwWzDBWyhSCuSWp", + "type": "text", + "x": 440, + "y": -26740, + "width": 65.90625, + "height": 60, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxM", + "roundness": null, + "seed": 1672229723, + "version": 286, + "versionNonce": 876524225, + "isDeleted": false, + "boundElements": [ + { + "id": "KPfLHcVjb3B7cenABqLOV", + "type": "arrow" + } + ], + "updated": 1762347957145, + "link": null, + "locked": false, + "text": "✔️", + "fontSize": 48, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✔️", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "-0ylej-HGKKXDlRpiiX_c", + "type": "text", + "x": 240.1493649993738, + "y": -26489.019958327302, + "width": 61.5999755859375, + "height": 35, + "angle": 4.997661940071875, + "strokeColor": "#228be6", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxN", + "roundness": null, + "seed": 2127373077, + "version": 531, + "versionNonce": 1865672737, + "isDeleted": false, + "boundElements": [ + { + "id": "KPfLHcVjb3B7cenABqLOV", + "type": "arrow" + } + ], + "updated": 1762246754228, + "link": null, + "locked": false, + "text": "MOZa", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "MOZa", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "R_sOVKpKsXSwEhj_8Eail", + "type": "text", + "x": 360.1493649993738, + "y": -26488.019958327302, + "width": 61.5999755859375, + "height": 35, + "angle": 4.997661940071875, + "strokeColor": "#228be6", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxO", + "roundness": null, + "seed": 1611431157, + "version": 547, + "versionNonce": 305967777, + "isDeleted": false, + "boundElements": [ + { + "id": "S5P9rHYxH7HoVhBLyTYUu", + "type": "arrow" + } + ], + "updated": 1762347957145, + "link": null, + "locked": false, + "text": "MOZa", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "MOZa", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "cw8qdX54TYPag4L-zkHnD", + "type": "text", + "x": 480.1493649993738, + "y": -26488.019958327302, + "width": 61.5999755859375, + "height": 35, + "angle": 4.997661940071875, + "strokeColor": "#228be6", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxP", + "roundness": null, + "seed": 2070607675, + "version": 535, + "versionNonce": 1787503343, + "isDeleted": false, + "boundElements": [ + { + "id": "jEtESAk-FWvTx7MxH8YQh", + "type": "arrow" + } + ], + "updated": 1762347955442, + "link": null, + "locked": false, + "text": "MOZa", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "MOZa", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "aF6bxjUGxAkdfVQCI7vsV", + "type": "text", + "x": 600.1493649993738, + "y": -26488.019958327302, + "width": 61.5999755859375, + "height": 35, + "angle": 4.997661940071875, + "strokeColor": "#228be6", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxQ", + "roundness": null, + "seed": 1051881397, + "version": 539, + "versionNonce": 1510206529, + "isDeleted": false, + "boundElements": [ + { + "id": "v1iZpUTceCV5V7KA4l02b", + "type": "arrow" + } + ], + "updated": 1762347954514, + "link": null, + "locked": false, + "text": "MOZa", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "MOZa", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "sbfuzpZmgy4elc-u5ZQMv", + "type": "text", + "x": 692.4840224698983, + "y": -26526.07595538749, + "width": 138.59994506835938, + "height": 35, + "angle": 4.997661940071875, + "strokeColor": "#9c36b5", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxR", + "roundness": null, + "seed": 230162619, + "version": 559, + "versionNonce": 205031477, + "isDeleted": false, + "boundElements": [ + { + "id": "1vEPSXk8ZtjLUFiGiahid", + "type": "arrow" + } + ], + "updated": 1762210496179, + "link": null, + "locked": false, + "text": "Service-Z", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Service-Z", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "hgKKNITdhCdQ7YseQSLcI", + "type": "text", + "x": -27.515977530101686, + "y": -26526.07595538749, + "width": 138.59994506835938, + "height": 35, + "angle": 4.997661940071875, + "strokeColor": "#9c36b5", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxS", + "roundness": null, + "seed": 1344763515, + "version": 602, + "versionNonce": 1173571803, + "isDeleted": false, + "boundElements": [ + { + "id": "upeK8VWE9GciZSkIVsesX", + "type": "arrow" + } + ], + "updated": 1762210626860, + "link": null, + "locked": false, + "text": "Service-X", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Service-X", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "tObeefyAj55Qn749JxKB4", + "type": "text", + "x": 92.48402246989832, + "y": -26526.07595538749, + "width": 138.59994506835938, + "height": 35, + "angle": 4.997661940071875, + "strokeColor": "#9c36b5", + "backgroundColor": "#eebefa", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxT", + "roundness": null, + "seed": 517414389, + "version": 623, + "versionNonce": 132871547, + "isDeleted": false, + "boundElements": [ + { + "id": "fkyjDair8vrwOFXakk3Vf", + "type": "arrow" + } + ], + "updated": 1762210626860, + "link": null, + "locked": false, + "text": "Service-X", + "fontSize": 28, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Service-X", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "L5I0m0hCdld1l1Hjuo57_", + "type": "text", + "x": -898.7198024733756, + "y": -25956.20868920477, + "width": 494.99969482421875, + "height": 45, + "angle": 4.709191978363906, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxW", + "roundness": null, + "seed": 500653621, + "version": 411, + "versionNonce": 253114261, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "Identificerende Kenmerken", + "fontSize": 36, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Identificerende Kenmerken", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "39gYocZ6NxhGJ93vSFDFT", + "type": "text", + "x": 826.3277428631368, + "y": -26298.796513030597, + "width": 572, + "height": 25, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxX", + "roundness": null, + "seed": 1840631765, + "version": 540, + "versionNonce": 1782001999, + "isDeleted": false, + "boundElements": [], + "updated": 1762252732475, + "link": null, + "locked": false, + "text": "Identificeert een natuurlijk persoon of éénmanszaak.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Identificeert een natuurlijk persoon of éénmanszaak.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "iia0rxqoo4yBP_wkI60xQ", + "type": "text", + "x": 825, + "y": -26220, + "width": 583, + "height": 50, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxY", + "roundness": null, + "seed": 1255400699, + "version": 706, + "versionNonce": 1475037857, + "isDeleted": false, + "boundElements": [], + "updated": 1762275899865, + "link": null, + "locked": false, + "text": "Niet-herleidbare vervanging voor de identificatie van\neen natuurlijk persoon.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Niet-herleidbare vervanging voor de identificatie van\neen natuurlijk persoon.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "-t527JRRqi78t1WgEO4b9", + "type": "text", + "x": 824.9069088904293, + "y": -26102.775586987857, + "width": 660, + "height": 25, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxa", + "roundness": null, + "seed": 1463015061, + "version": 358, + "versionNonce": 2139474127, + "isDeleted": false, + "boundElements": [], + "updated": 1762254293833, + "link": null, + "locked": false, + "text": "Identificeert een handelende persoon met vertegenwoordiging.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Identificeert een handelende persoon met vertegenwoordiging.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "GPHY1EW0Fh22ehtkbdw1H", + "type": "text", + "x": 824.9069088904293, + "y": -25999.607805258118, + "width": 550, + "height": 25, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxb", + "roundness": null, + "seed": 1264921429, + "version": 342, + "versionNonce": 25010689, + "isDeleted": false, + "boundElements": [], + "updated": 1762248806260, + "link": null, + "locked": false, + "text": "KVK-nummer van de vertegenwoordigde dienstafnemer.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "KVK-nummer van de vertegenwoordigde dienstafnemer.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "MUu_N31r1XO9F-h7oxCkN", + "type": "text", + "x": 826.385430129767, + "y": -25901.282755386845, + "width": 484, + "height": 25, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxc", + "roundness": null, + "seed": 1252922837, + "version": 376, + "versionNonce": 1671468271, + "isDeleted": false, + "boundElements": [], + "updated": 1762249412386, + "link": null, + "locked": false, + "text": "RSIN van de vertegenwoordigde dienstafnemer.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "RSIN van de vertegenwoordigde dienstafnemer.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "Lnzh6Aqpw_o5X1K5-yMqX", + "type": "text", + "x": 828.6163125305666, + "y": -25499.474246864687, + "width": 616, + "height": 25, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxf", + "roundness": null, + "seed": 1480046549, + "version": 288, + "versionNonce": 1356776405, + "isDeleted": false, + "boundElements": [], + "updated": 1762209877737, + "link": null, + "locked": false, + "text": "Vestigingsnummer van de vertegenwoordigde dienstafnemer.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Vestigingsnummer van de vertegenwoordigde dienstafnemer.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "p0pXn-kcBRMOLbAkJkZO7", + "type": "text", + "x": 833.3038776444159, + "y": -25398.307529048, + "width": 341, + "height": 25, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxg", + "roundness": null, + "seed": 2139471733, + "version": 388, + "versionNonce": 1780027375, + "isDeleted": false, + "boundElements": [], + "updated": 1762248800962, + "link": null, + "locked": false, + "text": "KVK-nummer van de intermediair.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "KVK-nummer van de intermediair.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "rseKLVD5zE9J_Fe2xi2ZC", + "type": "text", + "x": 828.5067667371454, + "y": -25614.561798654082, + "width": 737, + "height": 50, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxh", + "roundness": null, + "seed": 187820955, + "version": 365, + "versionNonce": 238185665, + "isDeleted": false, + "boundElements": [], + "updated": 1762275058943, + "link": null, + "locked": false, + "text": "Identificeert een niet natuurlijk persoon bij eHerkenning via eIDAS\nbinnen Elektronische Toegangsdiensten.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Identificeert een niet natuurlijk persoon bij eHerkenning via eIDAS\nbinnen Elektronische Toegangsdiensten.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "wwG1pf7vwrSd__dhoPnBF", + "type": "text", + "x": 827.3068141215726, + "y": -25819.161890724125, + "width": 737, + "height": 50, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxi", + "roundness": null, + "seed": 5804725, + "version": 335, + "versionNonce": 1932929569, + "isDeleted": false, + "boundElements": [], + "updated": 1762249406011, + "link": null, + "locked": false, + "text": "Door de Belastingdienst uitgereikt nummer aan organisaties die niet\nstaan ingeschreven in het Handelsregister.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Door de Belastingdienst uitgereikt nummer aan organisaties die niet\nstaan ingeschreven in het Handelsregister.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "fW7GOoDkGb5InrXmM5WAR", + "type": "text", + "x": 829.1694108085544, + "y": -25727.122319914793, + "width": 770, + "height": 75, + "angle": 0, + "strokeColor": "#343a40", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 2, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxj", + "roundness": null, + "seed": 1160159259, + "version": 346, + "versionNonce": 225311297, + "isDeleted": false, + "boundElements": [], + "updated": 1762260890635, + "link": null, + "locked": false, + "text": "Door de Belastingdienst en Douane uitgereikt nummer aan restgroepen\ndie niet staan ingeschreven in het Handelsregister, zoals buitenlandse\norganisaties en fiscale eenheden.", + "fontSize": 20, + "fontFamily": 8, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "Door de Belastingdienst en Douane uitgereikt nummer aan restgroepen\ndie niet staan ingeschreven in het Handelsregister, zoals buitenlandse\norganisaties en fiscale eenheden.", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "hscmLhUdonObGJlmh-2PG", + "type": "rectangle", + "x": -395.3584824010011, + "y": -27494.415183942503, + "width": 47.3981637257741, + "height": 25.629550237954817, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "vTPZDiTaOJVqG8LyEY2FZ", + "np_z5uM2OXjt-fhclWJSg", + "t_V-Mz4fHL75h0V5E03Uo", + "oDakJ_LB_5sHPhRry6Cwb" + ], + "frameId": null, + "index": "bxk", + "roundness": { + "type": 3 + }, + "seed": 844830581, + "version": 1431, + "versionNonce": 825172731, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575048, + "link": null, + "locked": false + }, + { + "id": "wvJQufh3T_zLNwrOGciG-", + "type": "rectangle", + "x": -353.8887478421809, + "y": -27494.415184240817, + "width": 34.849133258306814, + "height": 25.689866369530584, + "angle": 0, + "strokeColor": "#868e96", + "backgroundColor": "#e64980", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "vTPZDiTaOJVqG8LyEY2FZ", + "np_z5uM2OXjt-fhclWJSg", + "t_V-Mz4fHL75h0V5E03Uo", + "oDakJ_LB_5sHPhRry6Cwb" + ], + "frameId": null, + "index": "bxl", + "roundness": null, + "seed": 2119327957, + "version": 1519, + "versionNonce": 1860635547, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575048, + "link": null, + "locked": false + }, + { + "id": "-AzP15TONvuNgO5xb3Vrx", + "type": "text", + "x": -375.7637860657512, + "y": -27494.475499723558, + "width": 14.386319091532428, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#e64980", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "vTPZDiTaOJVqG8LyEY2FZ", + "np_z5uM2OXjt-fhclWJSg", + "t_V-Mz4fHL75h0V5E03Uo", + "oDakJ_LB_5sHPhRry6Cwb" + ], + "frameId": null, + "index": "bxm", + "roundness": null, + "seed": 1398373941, + "version": 1256, + "versionNonce": 1255727163, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575048, + "link": null, + "locked": false, + "text": "H", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "H", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "B8CG1W_E4GNBtjCpN7HAr", + "type": "text", + "x": -386.9672272511068, + "y": -27494.47549985598, + "width": 11.013125102885176, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "vTPZDiTaOJVqG8LyEY2FZ", + "np_z5uM2OXjt-fhclWJSg", + "t_V-Mz4fHL75h0V5E03Uo", + "oDakJ_LB_5sHPhRry6Cwb" + ], + "frameId": null, + "index": "bxn", + "roundness": null, + "seed": 676720533, + "version": 1278, + "versionNonce": 1055334619, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575048, + "link": null, + "locked": false, + "text": "E", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "E", + "autoResize": true, + "lineHeight": 1.15 + }, + { + "id": "Gk-8zEkPWEZAzFVlbm1rJ", + "type": "rectangle", + "x": -355.58983486650664, + "y": -27495.49883875248, + "width": 4.699858721654109, + "height": 29.028596616989162, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "vTPZDiTaOJVqG8LyEY2FZ", + "np_z5uM2OXjt-fhclWJSg", + "t_V-Mz4fHL75h0V5E03Uo", + "oDakJ_LB_5sHPhRry6Cwb" + ], + "frameId": null, + "index": "bxo", + "roundness": null, + "seed": 2071803125, + "version": 1570, + "versionNonce": 1688489339, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575048, + "link": null, + "locked": false + }, + { + "id": "fLFwEvlmg6s4iCacbKoa8", + "type": "rectangle", + "x": -320.8809525684144, + "y": -27494.227912847797, + "width": 4.914315206883841, + "height": 25.914891150720035, + "angle": 0.14069642804146554, + "strokeColor": "transparent", + "backgroundColor": "#fff", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "vTPZDiTaOJVqG8LyEY2FZ", + "np_z5uM2OXjt-fhclWJSg", + "t_V-Mz4fHL75h0V5E03Uo", + "oDakJ_LB_5sHPhRry6Cwb" + ], + "frameId": null, + "index": "bxp", + "roundness": null, + "seed": 1750388309, + "version": 1493, + "versionNonce": 2136139291, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575048, + "link": null, + "locked": false + }, + { + "id": "Efuaiu0RbSTwoXk-MwZN-", + "type": "text", + "x": -348.073778861916, + "y": -27495.684953862525, + "width": 25.727109002516087, + "height": 25.68986607121726, + "angle": 0, + "strokeColor": "#ffffff", + "backgroundColor": "#1971c2", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "solid", + "roughness": 0, + "opacity": 100, + "groupIds": [ + "kwuFwPRwAuAXWxT6HPVdo", + "np_z5uM2OXjt-fhclWJSg", + "t_V-Mz4fHL75h0V5E03Uo", + "oDakJ_LB_5sHPhRry6Cwb" + ], + "frameId": null, + "index": "bxq", + "roundness": null, + "seed": 2108832693, + "version": 1470, + "versionNonce": 1172662971, + "isDeleted": false, + "boundElements": [], + "updated": 1762209575048, + "link": null, + "locked": false, + "text": "2+", + "fontSize": 22.339013974971532, + "fontFamily": 7, + "textAlign": "center", + "verticalAlign": "top", + "containerId": null, + "originalText": "2+", + "autoResize": false, + "lineHeight": 1.15 + }, + { + "id": "upeK8VWE9GciZSkIVsesX", + "type": "arrow", + "x": -100, + "y": -26740, + "width": 118.73845433510141, + "height": 190.9653974287976, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ebfbee", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxt", + "roundness": null, + "seed": 1329422139, + "version": 114, + "versionNonce": 1025935567, + "isDeleted": false, + "boundElements": [], + "updated": 1762347820667, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 118.73845433510141, + 190.9653974287976 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "b_BBY-2yhbMj7YeL9a7B_", + "focus": 1.2434774123121561, + "gap": 10.49320890689513 + }, + "endBinding": { + "elementId": "hgKKNITdhCdQ7YseQSLcI", + "focus": 0.09302460136715093, + "gap": 16 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "fkyjDair8vrwOFXakk3Vf", + "type": "arrow", + "x": -20, + "y": -26740, + "width": 168.13010741938743, + "height": 162.2115299714751, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ebfbee", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxv", + "roundness": null, + "seed": 68989909, + "version": 157, + "versionNonce": 75467521, + "isDeleted": false, + "boundElements": [], + "updated": 1762347837674, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 168.13010741938743, + 162.2115299714751 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "25gharb9xp5VNt4PtPqIB", + "focus": 0.22411999614656838, + "gap": 10.494740011180388 + }, + "endBinding": { + "elementId": "tObeefyAj55Qn749JxKB4", + "focus": 0.6916495878576145, + "gap": 15.07980760798091 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "v1iZpUTceCV5V7KA4l02b", + "type": "arrow", + "x": 576.8639132237086, + "y": -26734.090255672825, + "width": 45.4040315795462, + "height": 213.52660599412047, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ebfbee", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxw", + "roundness": null, + "seed": 1466635547, + "version": 491, + "versionNonce": 236895265, + "isDeleted": false, + "boundElements": [], + "updated": 1762347954515, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + 45.4040315795462, + 213.52660599412047 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "XhMvUyJngyqfO9RlN97Kg", + "focus": 0.571674557716645, + "gap": 16 + }, + "endBinding": { + "elementId": "aF6bxjUGxAkdfVQCI7vsV", + "focus": 0.06598093195472841, + "gap": 15.575962051112953 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "jEtESAk-FWvTx7MxH8YQh", + "type": "arrow", + "x": 557.704949446659, + "y": -26730.814175273415, + "width": 28.03334229802317, + "height": 217.0138531161465, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ebfbee", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxx", + "roundness": null, + "seed": 1480759477, + "version": 378, + "versionNonce": 335835951, + "isDeleted": false, + "boundElements": [], + "updated": 1762347955444, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -28.03334229802317, + 217.0138531161465 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "q7uDF86Nt-qtNqlzRS_lG", + "focus": 0, + "gap": 16 + }, + "endBinding": { + "elementId": "cw8qdX54TYPag4L-zkHnD", + "focus": 0.5915166634882913, + "gap": 16 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "S5P9rHYxH7HoVhBLyTYUu", + "type": "arrow", + "x": 531.4909316866883, + "y": -26732.880801666295, + "width": 117.57591595938078, + "height": 221.63050435510377, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ebfbee", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxy", + "roundness": null, + "seed": 351186875, + "version": 538, + "versionNonce": 607106689, + "isDeleted": false, + "boundElements": [], + "updated": 1762347957146, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -117.57591595938078, + 221.63050435510377 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "_phTlQLk8vKvlLQy-4esb", + "focus": -1.0428718083170276, + "gap": 16 + }, + "endBinding": { + "elementId": "R_sOVKpKsXSwEhj_8Eail", + "focus": 0.05126443802606238, + "gap": 14.747212186544138 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "KPfLHcVjb3B7cenABqLOV", + "type": "arrow", + "x": 389.9126081400805, + "y": -26686.35474381688, + "width": 91.00622510119729, + "height": 174.26272299986886, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ebfbee", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "bxz", + "roundness": null, + "seed": 672364091, + "version": 561, + "versionNonce": 965052879, + "isDeleted": false, + "boundElements": [], + "updated": 1762347846861, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -91.00622510119729, + 174.26272299986886 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "OgvWp9i4z9xjsC36CTYW1", + "focus": -0.3721121231997532, + "gap": 13.64525618312473 + }, + "endBinding": { + "elementId": "-0ylej-HGKKXDlRpiiX_c", + "focus": 0.26000085065086453, + "gap": 16 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "1vEPSXk8ZtjLUFiGiahid", + "type": "arrow", + "x": 950.5335673278385, + "y": -26742.611812961746, + "width": 150.0188510529938, + "height": 161.8624445571768, + "angle": 0, + "strokeColor": "#2f9e44", + "backgroundColor": "#ebfbee", + "fillStyle": "solid", + "strokeWidth": 1, + "strokeStyle": "dashed", + "roughness": 0, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "by0", + "roundness": null, + "seed": 1514205429, + "version": 303, + "versionNonce": 972708193, + "isDeleted": false, + "boundElements": [], + "updated": 1762347877608, + "link": null, + "locked": false, + "points": [ + [ + 0, + 0 + ], + [ + -150.0188510529938, + 161.8624445571768 + ] + ], + "lastCommittedPoint": null, + "startBinding": { + "elementId": "AkWauviK9tdq7A_ABVTNK", + "focus": -0.062478253120229, + "gap": 21.782162335915515 + }, + "endBinding": { + "elementId": "sbfuzpZmgy4elc-u5ZQMv", + "focus": 0.4435734097505321, + "gap": 10.856118721293115 + }, + "startArrowhead": null, + "endArrowhead": "triangle", + "elbowed": false + }, + { + "id": "DinOBQ2qumP51-5-An8M0", + "type": "text", + "x": 240, + "y": -26100, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "by1", + "roundness": null, + "seed": 1602715695, + "version": 613, + "versionNonce": 1772343457, + "isDeleted": false, + "boundElements": [], + "updated": 1762252931637, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "gIsUSlCDCSLm8Ic227ZIT", + "type": "text", + "x": 360, + "y": -26100, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "by2", + "roundness": null, + "seed": 750441391, + "version": 595, + "versionNonce": 261020769, + "isDeleted": false, + "boundElements": [], + "updated": 1762252932757, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "IVkoRe8ggSF-6_R-qA8RH", + "type": "text", + "x": 480, + "y": -26100, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "by3", + "roundness": null, + "seed": 1735755727, + "version": 587, + "versionNonce": 1266284577, + "isDeleted": false, + "boundElements": [], + "updated": 1762252933717, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + }, + { + "id": "H1aA_kfxW4geCXdy2rRtP", + "type": "text", + "x": 600, + "y": -26100, + "width": 43.9375, + "height": 40, + "angle": 0, + "strokeColor": "#1e1e1e", + "backgroundColor": "#b2f2bb", + "fillStyle": "solid", + "strokeWidth": 4, + "strokeStyle": "solid", + "roughness": 2, + "opacity": 100, + "groupIds": [], + "frameId": null, + "index": "by4", + "roundness": null, + "seed": 341780815, + "version": 586, + "versionNonce": 144778209, + "isDeleted": false, + "boundElements": [], + "updated": 1762252934593, + "link": null, + "locked": false, + "text": "✅", + "fontSize": 32, + "fontFamily": 5, + "textAlign": "left", + "verticalAlign": "top", + "containerId": null, + "originalText": "✅", + "autoResize": true, + "lineHeight": 1.25 + } + ], + "appState": { + "gridSize": 20, + "gridStep": 5, + "gridModeEnabled": true, + "viewBackgroundColor": "#ffffff", + "lockedMultiSelections": {} + }, + "files": { + "83a74977708d75361f44dabc8f179b40205d7422": { + "mimeType": "image/png", + "id": "83a74977708d75361f44dabc8f179b40205d7422", + "dataURL": "data:image/png;base64,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", + "created": 1750423795990, + "lastRetrieved": 1763130743829 + }, + "4875a3ba63a03226b397f189b1625e43248d09d2": { + "mimeType": "image/png", + "id": "4875a3ba63a03226b397f189b1625e43248d09d2", + "dataURL": "data:image/png;base64,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", + "created": 1750423883743, + "lastRetrieved": 1763130743829 + }, + "a290e5bf6303127ae129b00af21ec58726257300": { + "mimeType": "image/png", + "id": "a290e5bf6303127ae129b00af21ec58726257300", + "dataURL": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABaAAAAG3CAYAAABCPPL4AAAAAXNSR0IArs4c6QAAIABJREFUeF7s3Ql8VNXdx/9z7r2TTPawJcga9s0NkM01ImjVClqNC2ir4NI+z9+2tmrVp/Y/PF3U2qdaK1WCaOsukc1dRIkbIoiUVURFQZB9DZnJzN3+/3PJYKQgk2QmmZl85qUvablzl/c5M/fO9577O1LwQgABBBBAAAEEEEAAAQQQQAABBBBAAAEEEEAgAQIyAetklQgggAACCCCAAAIIIIAAAggggAACCCCAAAIICAJoOgECCCCAAAIIIIAAAggggAACCCCAAAIIIIBAQgQIoBPCykoRQAABBBBAAAEEEEAAAQQQQAABBBBAAAEECKDpAwgggAACCCCAAAIIIIAAAggggAACCCCAAAIJESCATggrK0UAAQQQQAABBBBAAAEEEEAAAQQQQAABBBAggKYPIIAAAggggAACCCCAAAIIIIAAAggggAACCCREgAA6IaysFAEEEEAAAQQQQAABBBBAAAEEEEAAAQQQQIAAmj6AAAIIIIAAAggggAACCCCAAAIIIIAAAgggkBABAuiEsLJSBBBAAAEEEEAAAQQQQAABBBBAAAEEEEAAAQJo+gACCCCAAAIIIIAAAggggAACCCCAAAIIIIBAQgQIoBPCykoRQAABBBBAAAEEEEAAAQQQQAABBBBAAAEECKDpAwgggAACCCCAAAIIIIAAAggggAACCCCAAAIJESCATggrK0UAAQQQQAABBBBAAAEEEEAAAQQQQAABBBAggKYPIIAAAggggAACCCCAAAIIIIAAAggggAACCCREgAA6IaysFAEEEEAAAQQQQAABBBBAAAEEEEAAAQQQQIAAmj6AAAIIIIAAAggggAACCCCAAAIIIIAAAgggkBABAuiEsLJSBBBAAAEEEEAAAQQQQAABBBBAAAEEEEAAAQJo+gACCCCAAAIIIIAAAggggAACCCCAAAIIIIBAQgQIoBPCykoRQAABBBBAAAEEEEAAAQQQQAABBBBAAAEECKDpAwgggAACCCCAAAIIIIAAAggggAACCCCAAAIJESCATggrK0UAAQQQQAABBBBAAAEEEEAAAQQQQAABBBAggKYPIIAAAggggAACCCCAAAIIIIAAAggggAACCCREgAA6IaysFAEEEEAAAQQQQAABBBBAAAEEEEAAAQQQQIAAmj6AAAIIIIAAAggggAACCCCAAAIIIIAAAgggkBABAuiEsLJSBBBAAAEEEEAAAQQQQAABBBBAAAEEEEAAAQJo+gACCCCAAAIIIIAAAggggAACCCCAAAIIIIBAQgQIoBPCykoRQAABBBBAAAEEEEAAAQQQQAABBBBAAAEECKDpAwgggAACCCCAAAIIIIAAAggggAACCCCAAAIJESCATggrK0UAAQQQQAABBBBAAAEEEEAAAQQQQAABBBAggKYPIIAAAggggAACCCCAAAIIIIAAAggggAACCCREgAA6IaysFAEEEEAAAQQQQAABBBBAAAEEEEAAAQQQQIAAmj6AAAIIIIAAAggggAACCCCAAAIIIIAAAgggkBABAuiEsLJSBBBAAAEEEEAAAQQQQAABBBBAAAEEEEAAAQJo+gACCCCAAAIIIIAAAggggAACCCCAAAIIIIBAQgQIoBPCykoRQAABBBBAAAEEEEAAAQQQQAABBBBAAAEECKDpAwgggAACCCCAAAIIIIAAAggggAACCCCAAAIJESCATggrK0UAAQQQQAABBBBAAAEEEEAAAQQQQAABBBAggKYPIIAAAggggAACCCCAAAIIIIAAAggggAACCCREgAA6IaysFAEEEEAAAQQQQAABBBBAAAEEEEAAAQQQQIAAmj6AAAIIIIAAAggggAACCCCAAAIIIIAAAgggkBABAuiEsLJSBBBAAAEEEEAAAQQQQAABBBBAAAEEEEAAAQJo+gACCCCAAAIIIIAAAggggAACCCCAAAIIIIBAQgQIoBPCykoRQAABBBBAAAEEEEAAAQQQQAABBBBAAAEECKDpAwgggAACCCCAAAIIIIAAAggggAACCCCAAAIJESCATggrK0UAAQQQQAABBBBAAAEEEEAAAQQQQAABBBAggKYPIIAAAggggAACCCCAAAIIIIAAAggggAACCCREgAA6IaysFAEEEEAAAQQQQAABBBBAAAEEEEAAAQQQQIAAmj6AAAIIIIAAAggggAACCCCAAAIIIIAAAgggkBABAuiEsLJSBBBAAAEEEEAAAQQQQAABBBBAAAEEEEAAAQJo+gACCCCAAAIIIIAAAggggAACCCCAAAIIIIBAQgQIoBPCykoRQAABBBBAAAEEEEAAAQQQQAABBBBAAAEECKDpAwgggAACCCCAAAIIIIAA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6CZAZ5cIIIAAAgggkBSB2vOc2CODasd1nf/UnjTXzqxIyGQ6KQLsBAEEEEAAAQQQQACBphGovRDhoebgsb8/eG4d+/8H/7tpWsFeEyJQ1wuwhOyMjSCAAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSNAADp1+pqWIoAAAggggAACCCCAAAIIIIAAAggggAACSRUgAJ1UbnaGAAIIIIAAAggggAACCCCAAAIIIIAAAgikjgAB6NTpa1qKAAIIIIAAAggggAACCCCAAAIIIIAAAggkVYAAdFK52RkCCCCAAAIIIIAAAggggAACCCCAAAIIIJA6AgSgU6evaSkCCCCAAAIIIIAAAggggAACCCCAAAIIIJBUAQLQSeVmZwgggAACCCCAAAIIIIAAAggggAACCCCAQOoIEIBOnb6mpQgggAACCCCAAAIIIIAAAggggAACCCCAQFIFCEAnlZudIYAAAggggAACCCCAAAIIIIAAAggggAACqSPw/wGoDL4ktAQezAAAAABJRU5ErkJggg==", + "created": 1750423958524, + "lastRetrieved": 1763130743829 + }, + "67f00ba8d75e950dd6aae04f858d0c81baea1681": { + "mimeType": "image/png", + "id": "67f00ba8d75e950dd6aae04f858d0c81baea1681", + "dataURL": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABaAAAAMdCAYAAABtJNFZAAAAAXNSR0IArs4c6QAAIABJREFUeF7s3QecpVV9N/Df1N2lIx0WFhHFgppoQlETW5qJiSavxpaIERUlxtdEjSUqaOzEWKKJYkWqgKhoLK812FtiLKCCgiIg0suys7NTXs7z3Lszu2yZ2Z3nzr13vo+fEdi99zzn+Z7z3Jn53XP/ZyAOAgQIECBAgAABAgQIECBAgAABAgQIECDQgMBAA21qkgABAgQIECBAgAABAgQIECBAgAABAgQIRABtEhAgQIAAAQIECBAgQIAAAQIECBAgQIBAIwIC6EZYNUqAAAECBAgQIECAAAECBAgQIECAAAECAmhzgAABAgQIECBAgAABAgQIECBAgAABAgQaERBAN8KqUQIECBAgQIAAAQIECBAgQIAAAQIECBAQQJsDBAgQIECAAAECBAgQIECAAAECBAgQINCIgAC6EVaNEiBAgAABAgQIECBAgAABAgQIECBAgIAA2hwgQIAAAQIECBAgQIAAAQIECBAgQIAAgUYEBNCNsGqUAAECBAgQIECAAAECBAgQIECAAAECBATQ5gABAgQIECBAgAABAgQIECBAgAABAgQINCIggG6EVaMECBAgQIAAAQIECBAgQIAAAQIECBAgIIA2BwgQIECAAAECBAgQIECAAAECBAgQIECgEQEBdCOsGiVAgAABAgQIECBAgAABAgQIECBAgAABAbQ5QIAAAQIECBAgQIAAAQIECBAgQIAAAQKNCAigG2HVKAECBAgQIECAAAECBAgQIECAAAECBAgIoM0BAgQIECBAgAABAgQIECBAgAABAgQIEGhEQADdCKtGCRAgQIAAAQIECBAgQIAAAQIECBAgQEAAbQ4QIECAAAECBAgQIECAAAECBAgQIECAQCMCAuhGWDVKgAABAgQIECBAgAABAgQIECBAgAABAgJoc4AAAQIECBAgQIAAAQIECBAgQIAAAQIEGhEQQDfCqlECBAgQIECAAAECBAgQIECAAAECBAgQEECbAwQIECBAgAABAgQIECBAgAABAgQIECDQiIAAuhFWjRIgQIAAAQIECBAgQIAAAQIECBAgQICAANocIECAAAECBAgQIECAAAECBAgQIECAAIFGBATQjbBqlAABAgQIECBAgAABAgQIECBAgAABAgQE0OYAAQIECBAgQIAAAQIECBAgQIAAAQIECDQiIIBuhFWjBAgQIECAAAECBAgQIECAAAECBAgQICCANgcIECBAgAABAgQIECBAgAABAgQIECBAoBEBAXQjrBolQIAAAQIECBAgQIAAAQIECBAgQIAAAQG0OUCAAAECBAgQIECAAAECBAgQIECAAAECjQgIoBth1SgBAgQIECBAgAABAgQIECBAgAABAgQICKDNAQIECBAgQIAAAQIECBAgQIAAAQIECBBoREAA3QirRgkQIECAAAECBAgQIECAAAECBAgQIEBAAG0OECBAgAABAgQIECBAgAABAgQIECBAgEAjAgLoRlg1SoAAAQIECBAgQIAAAQIECBAgQIAAAQICaHOAAAECBAgQIECAAAECBAgQIECAAAECBBoREEA3wqpRAgQIECBAgAABAgQIECBAgAABAgQIEBBAmwMECBAgQIAAAQIECBAgQIAAAQIECBAg0IiAALoRVo0SIECAAAECBAgQIECAAAECBAgQIECAgADaHCBAgAABAgQIECBAgAABAgQIECBAgACBRgQE0I2wapQAAQIECBAgQIAAAQIECBAgQIAAAQIEBNDmAAECBAgQIECAAAECBAgQIECAAAECBAg0IiCAboRVowQIECBAgAABAgQIECBAgAABAgQIECAggDYHCBAgQIAAAQIECBAgQIAAAQIECBAgQKARAQF0I6waJUCAAAECBAgQIECAAAECBAgQIECAAAEBtDlAgAABAgQIECBAgAABAgQIECBAgAABAo0ICKAbYdUoAQIECBAgQIAAAQIECBAgQIAAAQIECAigzQECBAgQIECAAAECBAgQIECAAAECBAgQaERAAN0Iq0YJECBAgAABAgQIECBAgAABAgQIECBAQABtDhAgQIAAAQIECBAgQIAAAQIECBAgQIBAIwIC6EZYNUqAAAECBAgQIECAAAECBAgQIECAAAECAmhzgAABAgQIECBAgAABAgQIECBAgAABAgQaERBAN8KqUQIECBAgQIAAAQIECBAgQIAAAQIECBAQQJsDBAgQIECAAAECBAgQIECAAAECBAgQINCIgAC6EVaNEiBAgAABAgQIECBAgAABAgQIECBAgIAA2hwgQIAAAQIECBAgQIAAAQIECBAgQIAAgUYEBNCNsGqUAAECBAgQIECAAAECBAgQIECAAAECBATQ5gABAgQIECBAgAABAgQIECBAgAABAgQINCIggG6EVaMECBAgQIAAAQIECBAgQIAAAQIECBAgIIA2BwgQIECAAAECBAgQIECAAAECBAgQIECgEQEBdCOsGiVAgAABAgQIECBAgAABAgQIECBAgAABAbQ5QIAAAQIECBAgQIAAAQIECBAgQIAAAQKNCAigG2HVKAECBAgQIECAAAECBAgQIECAAAECBAgIoM0BAgQIECBAgAABAgQIECBAgAABAgQIEGhEQADdCKtGCRAgQIAAAQIECBAgQIAAAQIECBAgQEAAbQ4QIECAAAECBAgQIECAAAECBAgQIECAQCMCAuhGWDVKgAABAgQIECBAgAABAgQIECBAgAABAgJoc4AAAQIECBAgQIAAAQIECBAgQIAAAQIEGhEQQDfCqlECBAgQIECAAAECBAgQIECAAAECBAgQEECbAwQIECBAgAABAgQIECBAgAABAgQIECDQiIAAuhFWjRIgQIAAAQIECBAgQIAAAQIECBAgQICAANocIECAAAECBAgQIECAAAECBAgQIECAAIFGBATQjbBqlAABAgQIECBAgAABAgQIECBAgAABAgQE0OYAAQIECBAgQIAAAQIECBAgQIAAAQIECDQiIIBuhFWjBAgQIECAAAECBAgQIECAAAECBAgQICCANgcIECBAgAABAgQIECBAgAABAgQIECBAoBEBAXQjrBolQIAAAQIECBAgQIAAAQIECBAgQIAAAQG0OUCAAAECBAgQIECAAAECBAgQIECAAAECjQgIoBth1SgBAgQIECBAgAABAgQIECBAgAABAgQICKDNAQIECBAgQIAAAQIECBAgQIAAAQIECBBoREAA3QirRgkQIECAAAECBAgQIECAAAECBAgQIEBAAG0OECBAgAABAgQIECBAgAABAgQIECBAgEAjAgLoRlg1SoAAAQIECBAgQIAAAQIECBAgQIAAAQICaHOAAAECBAgQIECAAAECBAgQIECAAAECBBoREEA3wqpRAgQIECBAgAABAgQIECBAgAABAgQIEBBAmwMECBAgQIAAAQIECBAgQIAAAQIECBAg0IiAALoRVo0SIECAAAECBAgQIECAAAECBAgQIECAgADaHCBAgAABAgQIECBAgAABAgQIECBAgACBRgQE0I2wapQAAQIECBAgQIAAAQIECBAgQIAAAQIEBNDmAAECBAgQIECAAAECBAgQIECAAAECBAg0IiCAboRVowQIECBAgAABAgQIECBAgAABAgQIECAggDYHCBAgQIAAAQIECBAgQIAAAQIECBAgQKARAQF0I6waJUCAAAECBAgQIECAAAECBAgQIECAAAEBtDlAgAABAgQIECBAgAABAgQIECBAgAABAo0ICKAbYdUoAQIECBAgQIAAAQIECBAgQIAAAQIECAigzQECBAgQIECAAAECBAgQIECAAAECBAgQaERAAN0Iq0YJECBAgAABAgQIECBAgAABAgQIECBAQABtDhAgQIAAAQIECBAgQIAAAQIECBAgQIBAIwIC6EZYNUqAAAECBAgQIECAAAECBAgQIECAAAECAmhzgAABAgQIECBAgAABAgQIECBAgAABAgQaERBAN8KqUQIECBAgQIAAAQIECBAgQIAAAQIECBAQQJsDBAgQIECAAAECBAgQIECAAAECBAgQINCIgAC6EVaNEiBAgAABAgQIECBAgAABAgQIECBAgIAA2hwgQIAAAQIECBAgQIAAAQIECBAgQIAAgUYEBNCNsGqUAAECBAgQIECAAAECBAgQIECAAAECBATQ5gABAgQIECBAgAABAgQIECBAgAABAgQINCIggG6EVaMECBAgQIAAAQIECBAgQIAAAQIECBAgIIA2BwgQIECAAAECBAgQIECAAAECBAgQIECgEQEBdCOsGiVAgAABAgQIECBAgAABAgQIECBAgAABAbQ5QIAAAQIECBAgQIAAAQIECBAgQIAAAQKNCAigG2HVKAECBAgQIECAAAECBAgQIECAAAECBAgIoM0BAgQIECBAgAABAgQIECBAgAABAgQIEGhEQADdCKtGCRAgQIAAAQIECBAgQIAAAQIECBAgQEAAbQ4QIECAAAECBAgQIECAAAECBAgQIECAQCMCAuhGWDVKgAABAgQIECBAgAABAgQIECBAgAABAgJoc4AAAQIECBAgQIAAAQIECBAgQIAAAQIEGhEQQDfCqlECBAgQIECAAAECBAgQIECAAAECBAgQEECbAwQIECBAgAABAgQIECBAgAABAgQIECDQiIAAuhFWjRIgQIAAAQIECBAgQIAAAQIECBAgQICAANocIECAAAECBAgQIECAAAECBAgQIECAAIFGBATQjbBqlAABAgQIECBAgAABAgQIECBAgAABAgQE0OYAAQIECBAgQIAAAQIECBAgQIAAAQIECDQiIIBuhFWjBAgQIECAAAECBAgQIECAAAECBAgQICCANgcIECBAgAABAgQIECBAgAABAgQIECBAoBEBAXQjrBolQIAAAQIECBAgQIAAAQIECBAgQIAAAQG0OUCAAAECBAgQIECAAAECBAgQIECAAAECjQgIoBth1SgBAgQIECBAgAABAgQIECBAgAABAgQICKDNAQIECBAgQIAAAQIECBAgQIAAAQIECBBoREAA3QirRgkQIECAAAECBAgQIECAAAECBAgQIEBAAG0OECBAgAABAgQIECBAgAABAgQIECBAgEAjAgLoRlg1SoAAAQIECBAgQIAAAQIECBAgQIAAAQICaHOAAAECBAgQIECAAAECBAgQIECAAAECBBoREEA3wqpRAgQIECBAgAABAgQIECBAgAABAgQIEBBAmwMECBAgQIAAAQIECBAgQIAAAQIECBAg0IiAALoRVo0SIECAAAECBAgQIECAAAECBAgQIECAgADaHCBAgAABAgQIECBAgAABAgQIECBAgACBRgQE0I2wapQAAQIECBAgQIAAAQIECBAgQIAAAQIEBNDmAAECBAgQIECAAAECBAgQIECAAAECBAg0IiCAboRVowQIECBAgAABAgQIECBAgAABAgQIECAggDYHCBAgQIAAAQIECBAgQIAAAQIECBAgQKARAQF0I6waJUCAAAECBAgQIECAAAECBAgQIECAAAEBtDlAgAABAgQIECBAgAABAgQIECBAgAABAo0ICKAbYdUoAQIECBAgQIAAAQIECBAgQIAAAQIECAigzQECBAgQIECAAAECBAgQIECAAAECBAgQaERAAN0Iq0YJECBAgAABAgQIECBAgAABAgQIECBAQABtDhAgQIAAAQIECBAgQIAAAQIECBAgQIBAIwIC6EZYNUqAAAECBAgQIECAAAECBAgQIECAAAECAmhzgAABAgQIECBAgAABAgQIECBAgAABAgQaERBAN8KqUQIECBAgQIAAAQIECBAgQIAAAQIECBAQQJsDBAgQIECAAAECBAgQIECAAAECBAgQINCIgAC6EVaNEiBAgAABAgQIECBAgAABAgQIECBAgIAA2hwgQIAAAQIECBAgQIAAAQIECBAgQIAAgUYEBNCNsGqUAAECBAgQIECAAAECBAgQIECAAAECBATQ5gABAgQIECBAgAABAgQIECBAgAABAgQINCIggG6EVaMECBAgQIAAAQIECBAgQIAAAQIECBAgIIA2BwgQIECAAAECBAgQIECAAAECBAgQIECgEQEBdCOsGiVAgAABAgQIECBAgAABAgQIECBAgAABAbQ5QIAAAQIECBAgQIAAAQIECBAgQIAAAQKNCAigG2HVKAECBAgQIECAAAECBAgQIECAAAECBAgIoM0BAgQIECBAgAABAgQIECBAgAABAgQIEGhEQADdCKtGCRAgQIAAAQIECBAgQIAAAQIECBAgQEAAbQ4QIECAAAECBAgQIECAAAECBAgQIECAQCMCAuhGWDVKgAABAgQIECBAgAABAgQIECBAgAABAgJoc4AAAQIECBAgQIAAAQIECBAgQIAAAQIEGhEQQDfCqlECBAgQIECAAAECBAgQIECAAAECBAgQEECbAwQIECBAgAABAgQIECBAgAABAgQIECDQiIAAuhFWjRIgQIAAAQIECBAgQIAAAQIECBAgQICAANocIECAAAECBAgQIECAAAECBAgQIECAAIFGBATQjbBqlAABAgQIECBAgAABAgQIECBAgAABAgQE0OYAAQIECBAgQIAAAQIECBAgQIAAAQIECDQiIIBuhFWjBAgQIECAAAECBAgQIECAAAECBAgQICCANgcIECBAgAABAgQIECBAgAABAgQIECBAoBEBAXQjrBolQIAAAQIECBAgQIAAAQIECBAgQIAAAQG0OUCAAAECBAgQIECAAAECBAgQIECAAAECjQgIoBth1SgBAgQIECBAgAABAgQIECBAgAABAgQICKDNAQIECBAgQIAAAQIECBAgQIAAAQIECBBoREAA3QirRgkQIECAAAECBAgQIECAAAECBAgQIEBAAG0OECBAgAABAgQIECBAgAABAgQIECBAgEAjAgLoRlg1SoAAAQIECBAgQIAAAQIECBAgQIAAAQICaHOAAAECBAgQIECAAAECBAgQIECAAAECBBoREEA3wqpRAgQIECBAgAABAgQIECBAgAABAgQIEBBAmwMECBAgQIAAAQIECBAgQIAAAQIECBAg0IiAALoRVo0SIECAAAECBAgQIECAAAECBAgQIECAgADaHCBAgAABAgQIECBAgAABAgQIECBAgACBRgQE0I2wapQAAQIECBAgQIAAAQIECBAg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1Px83jyKCykWN8FzF08KhyJAgAABAgQIECBAgACB7gps7Rvr7s7O0QgQIECAQGcEijYYxZ/2Rf2KoHjudk52zlW5V8aya5LbJtmvtRv59kl2vpkwutgdXbyWrkry2/K/s/ltJvPb7Jlf55Hl382/FS02ils7dF7I7urOCBiFAAECBAgQIECAAAECBAj0QEAA3QN0hyRAgACBngoUr33tQLr4b9Eso65dyO3AuThG+09PF+/gBAgQIECAAAECBAgQIECgmwIC6G5qOxYBAgQI9KNA+7WwCKPbvZzbf3fT3s6bX0G7V/Sm/y1CZzcCBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa8a3iUzAAAMkklEQVSv0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYAQF0Y0tv4QQIECBAgAABAgQIECBAgAABAgQIEKhXQABdr6/RCRAgQIAAAQIECBAgQIAAAQIECBAg0FgBAXRjS2/hBAgQIECAAAECBAgQIECAAAECBAgQqFdAAF2vr9EJECBAgAABAgQIECBAgAABAgQIECDQWAEBdGNLb+EECBAgQIAAAQIECBAgQIAAAQIECBCoV0AAXa+v0QkQIECAAAECBAgQIECAAAECBAgQINBYgf8fxQDRryXS6+IAAAAASUVORK5CYII=", + "created": 1750424024998, + "lastRetrieved": 1763130743829 + }, + "f6c358754b9f1ab00bf1a7add91e70d20d080960": { + "mimeType": "image/png", + "id": "f6c358754b9f1ab00bf1a7add91e70d20d080960", + "dataURL": "data:image/png;base64,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f+aBp159my03KtBS8yWZABNgAkyACTABJsAEmAATYAJMgAkwASYQUQIsQG+uOCU0WwfU1U1eUl9z2XQjeXSnbVNiMEM63KIhBOiMKafuv6C7eebkRjtjRjX7GTUSJwHaGdxYMHXqhOtPW/nwmk3dkwxdR9ZwmAc1pGVLWxDpzfXJdc++2f3pI6789c/cR2VoxkBE2zwuNhNgAkyACTABJsAEmAATYAJMgAkwASbABJhAgARYgH437CGB7cvtrWdsYyQueEva7bDpCPUChZJIq9HtmUcuk8nGlC7NyNpvxE2Axv04MXXXZ0+8KSnoIElkCSL4j4duk5Is07b15roa0nXt9otuvOesGx555hmPYM6WG6GrNS4QE2ACTIAJMAEmwASYABNgAkyACTABJsAEwkuABejh6wZc8Mc+pLFm7qF1jd+tE2LvLimRtorM0FBlr2KhQas/Qy1bT+ybss8uCWlhHcVIb3HKgB4SoK84bq+T99lmxtVv9/RLXRNhe/acrGdDF/qYhlTvjf989qvn/OqvX3M9np3FOiMdUVx4JsAEmAATYAJMgAkwASbABJgAE2ACTIAJMIGKEAibCFYRCCNcdMiSA///ubbmT26fTJ7XZ8smezCDFSJ0KPjB69lMp+XEPbaTYxdsrZm9AwRROsJb3ARox4bjpMU7Tjpzn52f7c9YdSGrHsuypeP1/Mam7vtuf+qFT1x628MPu/HtDMREOJa46EyACTABJsAEmAATYAJMgAkwASbABJgAE2ACFSQQaZUyIG5Dlhyn1tfvsGt97aVJoe0zYEsSwrHlqLg3tLQl6bWGOeOwJQM1zY310rZlWMTxEusobgI0njPUifboeSff1JfJHCiECIOvuG1LKXUhdEPXel96q+srn7r10cteeumlftc2BMIzys0bE2ACTIAJMAEmwASYABNgAkyACTABJsAEmAATKIkAC9CFYxuyIbiytfX09qRxoUXU0S+l7fpxVMaWQwiC33PdxBY589A9hLRikawaNwEaUebEzyVH7fXxvedNvbw3nbE0ISo2eAEfasuy9dqEQcka47bv3rn6i1f9/XFkPWNzMrYLfzR4TybABJgAE2ACTIAJMAEmwASYABNgAkyACTABJjA8ARagi4sMCHPICJV7N9bM2S9Rf8HkhH5cr5RQ6yy9ArYcsNow+9I0cc/tujp2ml1vp00NqdkR3+IoQDui7vGLt97+wkOW3//ahs6GhK5XIlPdsqXUE7pGbQ21r9/7wutfOvmqm3/oxjUEcc56jvjDw8VnAkyACTABJsAEmAATYAJMgAkwASbABJhAmAhEXqmsEMyhbOjPtbccNtcwvlwjtG07bRupo8H5Qw8ZO5A949DdZWpcm26nTWIBukJRkf+yzuKWfzrz6Ac7mlILM6ZlCyGCypx37DZgrVGXMOz13f0/ueaBx7/6yweffsktNmc9568/3oMJMAEmwASYABNgAkyACTABJsAEmAATYAJMoEgCLEAXCcyzuxIO7R2I6pe3NH1yUU3N2WmSTQM2kSGcTFJ/xUUhpJU2RcPktt7pB+8mSGp1biZr1Os1jhnQCB3HT/z60w47b+vxrRf1BGPDIS1bWpogoy5hUF1t4r5rH3jyoi/ffP+f3VjmrOfS2wA+kgkwASbABJgAE2ACTIAJMAEmwASYABNgAkwgD4GoC5VhqOChRQpPqKmZtWtjwxfHGfpxXbZtSCLbBeyLEC2wCmI6Izvmz7Qm7rGTbvYNCFhyxGCLtQC997ZTFl529L4PdPWlhab5lgGNdGfbtGy9JVVDpmW/svqldV/76j1PXeMuMjg0gBKDeOFbYAJMgAkwASbABJgAE2ACTIAJMAEmwASYABMIKYFYqJUhYAuOEKJNlOWwhobl+9fVnF+nacv7pVS2HNin7EK0lCRnHbF7b21HWz0WI6R41GhcBWjHNGXixImpm05deW//QGZnoQnLjZ1yhbEjPNu21HVNUEdTquf2J1688vf3P3vFnS++uNa9yNCgSbkuyudhAkyACTABJsAEmAATYAJMgAkwASbABJgAE2ACwxGIh1wZnrr1ZpVqH21qOn6fVO0nNkm5c9qx3yVLK+NChdKWlGyps2YdvkxoCUMbtPiNxRZXARqV4/iHf2HV7t86duE2Z27o7bcMTcPvyrFZyHhOGjo11CbtdZ29P/vLMy9+42s3PfC0R3jmRQbLQZrPwQSYABNgAkyACTABJsAEmAATYAJMgAkwASZQEAEWoAvCVPROQxmmS4gaD2htPm5asuZcSXJq32YhelQZ0bDaMPvSNHbXOX0TFm+btNKmDkuOmGxxFqCdxf4uOGLpPu9ZsM1f1nX2kqFpGDkotfKklBiKIKEJobWmas01XT2/ufGR/15++V8feYiF55g8EXwbTIAJMAEmwASYABNgAkyACTABJsAEmAATiCiBUkWviN5u4MUeEqKXt7S0LDe0U+cYxumWlDN6bZs0IUwxmBFdgjWHIGlb9lb7L6CWmVM0sz8NBTLwG/TpgnEWoB1kB8yaVXPeMYufIkkzJJEUxQvQEK0dj+fahEE1CZ06+wZuveHR/1565V8evtOtF/Z59ilA+bRMgAkwASbABJgAE2ACTIAJMAEmwASYABNgAoURiI1iWdjtVmQvlekMr19a2tzcuq+unzK3xvhQv23PzkB9JLI154fjI51/E4Lg95xsTpkzj1ia0RPJOklOanVc6jPuArTjBX3PZ0/4bkLXPmLZ0hKF1j05FW3Ztm0YukYtqVr52obuP//lyecvv/i2h/6M87oDGriGE3O8MQEmwASYABNgAkyACTABJsAEmAATYAJMgAkwgUoRiItgWSl+xVz3HQsV7trY2H5oInHCVEM7jYSY1zO4WKHjz+tmRY9cN0KQnTapdd6kzJR9FibsgQxRfOw3wDTuArTjA33mXrse/oFl2/22sz8tXf+ULT2Ptg2zDUm6oQlqrE2m3+4ZuOGG1U/98Nt3PnqPJxB5gcFinkrelwkwASbABJgAE2ACTIAJMAEmwASYABNgAkzAVwIsQPuKd9iTvyMj+gCimoXNzSdsV5N8X7+gPaBA90ubDBKmmxH97jqCAD2QoakH7dLVPHNyI8RoFqCDr8hRXNHxgV4+Z86YH75v+SNrNvVMTegaspWHy4C3LVtKTRN6XcKghK51r+8buO6mx57+yeW3D3k8I0acrGr3zyiKxocyASbABJgAE2ACTIAJMAEmwASYABNgAkyACTCB8hFgAbp8LIs90zuE6HlEyW1SqZXL6+tOG6vrK7psux4ntIhs3WurIIikJcloTFozDl0qkg0pDXYcLEAXi7/i+zsi9P+desjvtp3YfljvQMaGyOyWys12lpoQQjTW1lDGNF9c/cq667/9t9VXP/G/dc+7+70jhip+R1wAJsAEmAATYAJMgAkwASbABJgAE2ACTIAJMAEmkEOABehwhMQ7bBOOSKUWrkzVHmfo2vEpIcZ22Uhsdaw5IFIKsy+ttW0zpXer/XbRzbRZI+Jlv4F7jbsFB+7RqfMrjt3vPcu3mXx9V1/agtiMe7ds26ivSVAyoZNpyvvu+e+rV9/40HO/veOFFza54YpjnUUIwxG+XAomwASYABNgAkyACTABJsAEmAATYAJMgAkwASYwPAEWoMMTGcpGYWjxuElE7ce0NJ0wv6b2aIPkkjQRpUmSmTatKcu2y3TsPKfG7EsLocWuGqtBgHYyoOdMbp90/cmrnu7szzSkkgZBg25O1ax75IU1t73e3fvTP62549677iLYsSjRmoXn8DyzXBImwASYABNgAkyACTABJsAEmAATYAJMgAkwgTwEYqdcxqTGczNctcV1dbsd2VD73gnCOKqmLjFu7OFLSE/Vkm1JWwiCVwMEzbjUZzUI0KqutAfOPeGmsY0NK59fu/H+fmlef/W9j9/+h9XPKZsNhDQWLYRHtJMKzxsTYAJMgAkwASbABJgAE2ACTIAJMAEmwASYABOICoG4CJZR4V1sOd/l8buyqaltbH3yyI+cfNDKpC4OTuh6MmNZ1D2QIV0TpkeIjnLdVoMAjVhwsqDnTxu3275bz2i++LYHbvcEiBqE4IUFi31qeH8mwASYABNgAkyACTABJsAEmAATYAJMgAkwgdAQiLJIGRqIARRECdHvsF+YP7lj1odWzD+0NVW7av7U8Qu6+tONA6ZFli3Jsm1b1zVbDHoNR62eq0WAzg2dYes5gPjiSzABJsAEmAATYAJMgAkwASbABJgAE2ACTIAJMAFfCERNmPQFQsROijpTixYOWTKs2nnOjjtP6thj/+2mH2Xo2qLmupraDb39ZFo2fIVh30ACfxOOGB32eq82AVrZpzj1xBsTYAJMgAkwASbABJgAE2ACTIAJMAEmwASYABOIC4GwC5Fx4ezHfXgXLXxHZvSqnWbM3mWr8QcvnbXV0oktjXv2m5k2aM6w6ujPWMqqQ2XbhjEGqk2A9iM++JxMgAkwASbABJgAE2ACTIAJMAEmwASYABNgAkyg4gTCKD5WHEpEC4CsaGzvyKLdYdy46Wfsu/P2TfXJg9pSdXvM6GiZtqlvoK7ftBwDYtN2kqht/NE1ERZRmgXoiAYhF5sJMAEmwASYABNgAkyACTABJsAEmAATYAJMgAl4CbAAHc94UDYdjrDsuUVx8tIddt1lxoTdFk+duGtfxlzalKrZiqQkyNCbegeISMKow4RdB5F0XTucMwQZKyxAxzMu+a6YABNgAkyACTABJsAEmAATYAJMgAkwASbABKqMQJCiYpWhDcXtjmjTgdLNamtrOm3fnWbJjL0ikdR23Xeb6XM1TcxJm1ad4x0N2w7borQJH2lHo7Z0oeHvfmdKswAdivDhQjABJsAEmAATYAJMgAkwASbABJgAE2ACTIAJMIHREWABenT8ong0rDpQ77DqGFrEEDeyfF5HQzqTnLXP1jNm7jF3yvbdfQO7jWmo225cU6rFtO166M6d/QOUccVpIinl5nMMnUvDUoeDW+7PQnmxAF0oKd6PCTABJsAEmAATYAJMgAkwASbABJgAE2ACTIAJhJgAC9AhrpwAiubNkMbfzdxrzps3L3ng5NScnrS9kyCaefCOM2ZNamue2m9ac3WisYYOJ+nNmy0ldfWnc/06HLFb1zRvvG1JnJaaENqAZT2158XXLiCiflfMfodgHgAfvgQTYAJMgAkwASbABJgAE2ACTIAJMAEmwASYABNgAqMgwAL0KODF8FBlrYFbg9ir/rzjVucRJXs76tuSidqWjy1fODWhya0l0XSSNK02qXfsOn1iq5TUQkQNRFRPhPUOJXUNpGE3XdCG9RBZgC4IFe/EBJgAE2ACTIAJMAEmwASYABNgAkyACTABJsAEQkuABejQVk2oCoY0Z/xR1h3ehQ3fVdADFs1q0gfscYY0WiXZrf/f3h3cAAQFQRjecSAcSJ6Eg0QRogAH7WhEH0rSi4TnCRpwdPg7mHyZ42bHpNJM2TR2bZ7E6X6G2iR3vwFROBszFRbMP5OH72hiFUluO/w6zEvPBfSvukAYBBBAAAEEEEAAAQQQQAABBBBAAAEEPgtcKE6CzX1hS5UAAAAASUVORK5CYII=", + "created": 1750424063755, + "lastRetrieved": 1763130743829 + }, + "926b2fb3670f767cbce8054d47de2eb62fe9fcd4": { + "mimeType": "image/png", + "id": "926b2fb3670f767cbce8054d47de2eb62fe9fcd4", + "dataURL": "data:image/png;base64,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", + "created": 1750424346408, + "lastRetrieved": 1763130743829 + }, + "b51e50c7cb906dd0d7108fdfb919139ea0bb955c": { + "mimeType": "image/jpeg", + "id": "b51e50c7cb906dd0d7108fdfb919139ea0bb955c", + "dataURL": "data:image/jpeg;base64,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", + "created": 1750424422812, + "lastRetrieved": 1763130743829 + }, + "de05584155117ae20f48c6b11cfef05b28c66ac8": { + "mimeType": "image/png", + "id": "de05584155117ae20f48c6b11cfef05b28c66ac8", + "dataURL": "data:image/png;base64,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", + "created": 1750424477285, + "lastRetrieved": 1763130743829 + }, + "9451b2424c9252d8fc74839a946f6dc4c466acda": { + "mimeType": "image/png", + "id": "9451b2424c9252d8fc74839a946f6dc4c466acda", + "dataURL": "data:image/png;base64,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", + "created": 1750425442293, + "lastRetrieved": 1763130743829 + }, + "6f678ec65c6911ad61b1e68da56b44fb3b275748": { + "mimeType": "image/png", + "id": "6f678ec65c6911ad61b1e68da56b44fb3b275748", + "dataURL": "data:image/png;base64,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", + "created": 1750434389109, + "lastRetrieved": 1763130743829 + }, + "3c0e98095226c9e3930b94a4c63579099ed01c84": { + "mimeType": "image/png", + "id": "3c0e98095226c9e3930b94a4c63579099ed01c84", + "dataURL": "data:image/png;base64,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QMzpMjth2nr9RosRQAABBBBAAAEETCAQU/H3zwnTJugImoAAAggggAACCCBgPYGYz8qrCNPW6zdajAACCCCAAAIIIGACgRj7p2cJ0yboCJqAAAIIIIAAAgggYD2BmMrPzhGmrddvtBgBBBBAAAEEEEDABAIxn585T5g2QUfQBAQQQAABBBBAAAHrCcR8Ya8mTFuv32gxAggggAACCCCAgAkEYqoqnYRpE3QETUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat12e0GAEEEEAAAQQQQMAkAoRpk3QEzUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat12e0GAEEEEAAAQQQQMAkAoRpk3QEzUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat12e0GAEEEEAAAQQQQMAkAoRpk3QEzUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat12e0GAEEEEAAAQQQQMAkAoRpk3QEzUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat12e0GAEEEEAAAQQQQMAkAoRpk3QEzUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat12e0GAEEEEAAAQQQQMAkAoRpk3QEzUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat12e0GAEEEEAAAQQQQMAkAoRpk3QEzUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat12e0GAEEEEAAAQQQQMAkAoRpk3QEzUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat12e0GAEEEEAAAQQQQMAkAoRpk3QEzUAAAQQQQAABBBCwngBh2np9RosRQAABBBBAAAEETCJAmDZJR9AMBBBAAAEEEEAAAesJEKat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TDtC+qO9CfTulou+3XPRLb9rxibLgUiABEiABEiABEiABEjgQAjsq21AZVUddu6rw5GH5mVMUGdcTH8cr0duXhd8tlf+gZwn9yEBEiABEiABEiABEiCBViPwn121qEs04PDC3IwcI+NietWuWgzt9yk60hm5PByEBEiABEiABEiABEggkwQch3r1tv04NkPGb8bF9Dvba1B6ZLdMnjPHIgESIAESIAESIAESIIGMESj7aB9OOuyQjIxHMZ0RjByEBEiABEiABEiABEigoxCgmO4oV4rzJAESIAESIAESIAESaHcEKKbb3SXhhEiABEiABEiABEiABDoKAYrpjnKlOE8SIAESIAESIAESIIF2R4Biut1dEk6IBEiABEiABEiABEigoxCgmO4oV4rzJAESIAESIAESIAESaHcEKKbb3SXhhEiABEiABEiABEiABDoKAYrpjnKlOE8SIAESIAESIAESIIF2R4Biut1dEk6IBEiABEiABEiABEigoxCgmO4oV4rzJAESIAESIAESIAESaHcEKKbb3SXhhEiABEiABEiABEiABDoKAYrpjnKlOE8SIAESIAESIAESIIF2R4Biut1dEk6IBEiABEiABEiABEigoxDo1GL6/ednYHnOSFz49aE4xLgicbz//Owkr3WUS8d5kgAJkAAJkAAJkAAJtDWBTi2mseV1zFpQgf7jJuBL/QRq9++VGHjWN3HKYW19CXh8EiABEiABEiABEiCBjkqgc4tpRDnQ3t9W5I/CBWcebTnWHfUyct4kQAIkQAIkQAIkQAJtQaCTi2kA297ErHlbUTx2Ar78GcBzq3dh0LnjcXLPAPneTYtRtmQ9KqvrAeSgoO8QjBpzCo4o9LfZvhjPvrQV/W03e+3LmLEEGHX5mTja2dTdLoZh3x6O2LyFWFNZC/QagQvPOS4k3Ne+PANLMAqXn+nuqQ6Exc++hK39z8I3fds8vultlC1dh4oqZ25ATn539B0+BmcO7e3tU7cTqxcuxPKtVXBn370/Ro49A0er80sxp40vz8DKonEY3X0FFq2ogHuInO7oP3IsztADADXb38eiRWuwNVbtHsPZpnh4Kc48Tln72915x4adi0HlC7BUz2UgRp91GnqVz8eCpVv1+ANHn4XTBiu4aZxDW7w7eEwSIAESIAESIAESaIJA5xfTqMHal2djSe1wXHDOQKyZ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kAAJkAAJZCsBiulsvfI8bxIgARIgARIgARIggRYToJhuMUIOQAIkQAIkQAIkQAIkkK0EKKaz9crzvEmABEiABEiABEiABFpMgGK6xQg5AAmQAAmQAAmQAAmQQLYSoJjO1ivP8yYBEiABEiABEiABEmgxAYrpFiPkACRAAiRAAiRAAiRAAtlKgGI6W688z5sESIAESIAESIAESKDFBCimW4yQA5AACZAACZAACZAACWQrAYrpbL3yPG8SIAESIAESIAESIIEWE6CYbjFCDkACJEACJEACJEACJJCtBCims/XK87xJgARIgARIgARIgARaTIBiusUIOQAJkAAJkAAJkAAJkEC2EqCYztYrz/MmARIgARIgARIgARJoMQGK6RYj5AAkQAIkQAIkQAIkQALZSoBiOluvPM+bBEiABEiABEiABEigxQQopluMkAOQAAmQAAmQAAmQAAlkKwGK6Wy98jxvEiABEiABEiABEiCBFhOgmG4xQg5AAiRAAiRAAiRAAiSQrQQoprP1yvO8SYAESIAESIAESIAEWkyAYrrFCDkACZAACZAACZAACZBAthKgmM7WK8/zJgESIAESIAESIAESaDEBiukWI+QAJEACJEACJEACJEAC2UqAYjpbrzzPmwRIgARIgARIgARIoMUEKKZbjJADkAAJkAAJkAAJkAAJZCsBiulsvfI8bxIgARIgARIgARIggRYToJhuMUIOQAIkQAIkQAIkQAIkkK0EKKaz9crzvEmABEiABEiABEiABFpMgGK6xQg5AAmQAAmQAAmQAAmQQLYSoJjO1ivP8yYBEiABEiABEiABEmgxAYrpFiPkACRAAp2RQHzHJlTsjCMBIC+vED2K+6FPYX5nPNXmn1N8PWZPm4pX/1uEUT+egsuP7dn8MbgHCZAACXQSAhTTneRC8jRIgAQySCBRicUP34THVztSOvjJ7XEkTvr6hbigdAgKM3i4jjZUomIhfjP1T/gAR+OiSdehtJgPGR3tGnK+JEACmSNAMZ05lhyJBEigsxCIvY8Zd92LJTuBgt4DUYQdrkvt/RThxCun4Irh2evGxlY8hKkPv409nz4LEyeej8HZ/GTRWe55ngcJkMABE6CYPmB03JEESKCzEkhsfhF33vYstuQGzmsi9m+88ti9mPtBAgUnXoMp3x+BIgEgEa9ELFGEPkUpXNp4JbbtTKCw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", + "created": 1751026693829, + "lastRetrieved": 1763130743829 + }, + "43a41e07b0cf2a1cbdc4fde7a2333cb21b1a7c9a": { + "mimeType": "image/png", + "id": "43a41e07b0cf2a1cbdc4fde7a2333cb21b1a7c9a", + "dataURL": "data:image/png;base64,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AAlkCgGKnkzxFO0kARIgARIgARLwRICixxM+3kwCJEACJEACJJApBCh6MsVTtJMESIAESIAESMATAYoeT/h4MwmQAAmQAAmQQKYQoOjJFE/RThIgARIgARIgAU8EKHo84ePNJEACJEACJEACmUKAoidTPEU7SYAESIAESIAEPBGg6PGEjzeTAAmQAAmQAAlkCgGKnkzxFO0kARIgARIgARLwRCAp0eOpRd5MAiRAAiRAAiRAAiEikFdVVVUVIntoCgmQAAmQAAmQAAmkhABFT0qwslISIAESIAESIIGwEaDoCZtHaA8JkAAJkAAJkEBKCFD0pAQrKyUBEkv6zuMAACAASURBVCABEiABEggbAYqesHmE9pAACZAACZAACaSEAEVPSrCyUhIgARIgARIggbARoOgJm0doDwmQAAmQAAmQQEoIUPSkBCsrJQESIAESIAESCBsBip6weYT2kAAJkAAJkAAJpIQARU9KsLJSEiABEiABEiCBsBGg6AmbR2gPCZAACZAACZBASghQ9KQEKyslARIgARIgARIIGwGKnrB5hPaQAAmQAAmQAAmkhABFT0qwslISIAESIAESIIGwEaDoCZtHaA8JkAAJkAAJkEBKCFD0pAQrKyUBEiABEiABEggbAYqesHmE9pAACZAACZAACaSEAEVPSrCyUhIgARIgARIggbARoOgJm0doDwmQAAmQAAmQQEoIUPSkBCsrJQESIAESIAESCBsBip6weYT2kAAJkAAJkAAJpIQARU9KsLJSEiABEiABEiCBsBGg6AmbR2gPCZAACZAACZBASghQ9KQEKyslARIgARIgARIIGwGKnrB5hPaQAAmQAAmQAAmkhABFT0qwZkelH9xxCwZhENY82FXfodI3cEafxbhs3t24ptiHvir1vQcMH4EPBjYHsBFPXTweM/qq/3bfhmLz/I6Y/tUQnOHyNst+urw/XMUWY2jn6cDUyZh6ioVlH09D66HL0TdWJsJ7LHpg4azz0FpyW4Sr5INekvFhBSTq5xVHWLfjmWW0b0BDjPZrfEqNinCeq7aDyBheAWi4eu5NFlVg4CV5bqyZeQ9OnlAGqOPD5Eu1DjLOooGR9q5Q9KQdeeY0mDbRE324HWorely8zKNiaewPFD12okd9ucRFT/RlYiNGLEWPGM5uhY/fosc0boDYizPl4sPwEv8lIiTFFR/H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", + "created": 1751025280372, + "lastRetrieved": 1763130743829 + }, + "37084cd4e7ea7eacf139b20ffe8bf0ce3b4c48b3": { + "mimeType": "image/png", + "id": "37084cd4e7ea7eacf139b20ffe8bf0ce3b4c48b3", + "dataURL": "data:image/png;base64,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cRTNJAESIAESIAESCIcAxU84HFkLCZAACZAACZBATAhQ/MTEUTSTBEiABEiABEggHAIUP+FwZC0kQAIkQAIkQAIxIUDxExNH0UwSIAESIAESIIFwCFD8hMORtZAACZAACZAACcSEAMVPTBxFM0mABEiABEiABMIhQPETDkfWQgIkQAIkQAIkEBMCFD8xcRTNJAESIAESIAESCIcAxU84HFkLCZAACZAACZBATAhQ/MTEUTSTBEiABEiABEggHAIUP+FwZC0kQAIkQAIkQAIxIUDxExNH0UwSIAESIAESIIFwCFD8hMORtZAACZAACZAACcSEAMVPTBxFM0mABEiABEiABMIhQPETDkfWQgIkQAIkQAIkEBMCFD8xcRTNJAESIAESIAESCIcAxU84HFkLCZAACZAACZBATAhQ/MTEUTSTBEiABEiABEggHAIUP+FwZC0kQAIkQAIkQAIxIUDxExNH0UwSIAESIAESIIFwCFD8hMORtZAACZAACZAACcSEAMVPTBxFM0mABEiABEiABMIhQPETDkfWQgIkQAIkQAIkEBMCFD8xcRTNJAESIAESIAESCIcAxU84HFkLCZAACZAACZBATAhQ/MTEUTSTBEiABEiABEggHAIUP+FwZC0kQAIkQAIkQAIxIUDxExNH0UwSIAESIAESIIFwCFD8hMORtZAACZAACZAACcSEAMVPTBxFM0mABEiABEiABMIhQPETDkfWQgIkQAIkQAIkEBMCFD8xcRTNJAESIAESIAESCIcAxU84HFkLCZAACZAACZBATAhQ/MTEUTSTBEiABEiABEggHAIUP+FwZC0kQAIkQAIkQAIxIUDxExNH0UwSIAESIAESIIFwCFD8hMORtZAACZAACZAACcSEAMVPTBxFM0mABEiABEiABMIhQPETDkfWQgIkQAIkQAIkEBMCFD8xcRTNJAESIAESIAESCIcAxU84HFkLCZAACZAACZBATAhQ/MTEUTSTBEiABEiABEggHAIUP+FwZC0kQAIkQAIkQAIxIUDxExNH0UwSIAESIAESIIFwCFD8hMORtZAACZAACZAACcSEAMVPTBxFM0mABEiABEiABMIhQPETDkfWQgIkQAIkQAIkEBMCFD8xcRTNJAESIAESIAESCIcAxU84HFkLCZAACZAACZBATAhQ/MTEUTSTBEiABEiABEggHAIUP+FwZC0kQAIkQAIkQAIxIUDxExNH0UwSIAESIAESIIFwCFD8hMORtZAACZAACZAACcSEAMVPTBxFM0mABEiABEiABMIhQPETDkfWQgIkQAIkQAIkEBMCFD8xcRTNJAESIAESIAESCIcAxU84HFkLCZAACZAACZBATAhQ/MTEUTSTBEiABEiABEggHAIUP+FwZC0kQAIkQAIkQAIxIUDxExNH0UwSIAESIAESIIFwCFD8hMORtZAACZAACZAACcSEgFT81NTUKOZXVVWhuroaRUVFyv/pl/65+Lf57zHpM80kARIgARIgARLIQwK6JikrK0NpaalrDyl+8tD57BIJkAAJkAAJFCIBip9C9Dr7TAIkQAIkQAIFTEAXP7Vr10ZJSQkjPwU8Fth1EiABEiABEigIAm7ix5yuI0Bw2asghgM7SQIkQAIkQAL5TyCI+BFCiOIn/8cCe0gCJEACJEACBUGA4qcg3MxOkgAJkAAJkAAJ6AS8cn4sO9Vr7AthALjVnQOJBEiABEiABEggbgQofuLmMdpLAiRAAiRAAiSQMgHzuYNuu7304A5zflLGzBtJgARIgARIgASiRIBb3aPkDdpCAiRAAiRAAiSQcQIUPxlHzAZIgARIgARIgASiRIDiJ0reoC0kQAIkQAIkQAIZJ0Dxk3HEbIAESIAESIAESCBKBCh+ouQN2kICJEACJEACJJBxAhQ/GUfMBkiABEiABEiABKJEgG91j5I3aAsJkAAJkAAJkEDGCVD8ZBwxGyABEiABEiABEogSAYqfKHmDtpAACZAACZAACWScgJv4sb/Jiyc8Z9wVbIAESIAESIAESCAbBPzED19vkQ0vsA0SIAESIAESIIGsEfASP0L4UPxkzRVsiARIgARIgARIIBsEGPnJBmW2QQIkQAIkQAIkEBkCfuJHN5Q5P5FxGQ0hARIgARIgARJIhwB3e6VDj/eSAAmQAAmQAAnEjgDFT+xcRoNJgARIgARIgATSIUDxkw493ksCJEACJEACJBA7Any3V+xcRoNJgARIgARIgATSIUDxkw493ksCJEACJEACJBA7AhQ/sXMZDSYBEiABEiABEkiHAMVPOvR4LwmQAAmQAAmQQOwIUPzEzmU0mARIgARIgARIIB0CFD/p0OO9JEACJEACJEACsSKgCx9hdO3atVFSUuKwn+/2ipVLaSwJkAAJkAAJkIAfAa/Ijy58RB18vYUfSX5OAiRAAiRAAiQQCwJBxI8QQRQ/sXAnjSQBEiABEiABEvAj4CZ+zFEfih8/ioX++QdP4Yibv0lQ6DUIS8d1kVBZhYm/ehx/Xmv6qNsZeHPKKWij/Wn9m0/hwge+QeUOoKxTNzw85Tz0bBBFwEsw4uRZmGuY1gmPvzsUPaNoat7btBlzxjyO2+bvQDVK0HnQ+Xjq+iPQUO/3mtfRb9ACfK//u1NPvPnkmcaYCxPPti9m45qbFmPhjn1Aqw4YM/ESXNi+NLwmAn/XwmuSNZFAPhLwEz/M+clHr4fdp4AP5KWP3o/zZu5ItF7eCVNmDUVvXdxsfA+XnDsXC832HdcX70w8Ec3Dtjnt+ih+0kYYUgXr50zFKePNihroMfoWPN1PG1hZEz9fY+wvnsZzpiGOpt3wzOzz0DWkviLgdy2s5lgPCeQrAT/xo/eby175OgLC6FeQB/LXs9HrsoWoNNqrg74PjMCk4+smLJCJn2598c4Uip8w3JSvdYQnfvZi/defYc7z7+O5BY1x2z8HJxnJk4if8qPwzD/Pp/jJ18HHfsWWQJCcH9E5ip/YujgLhvuKH+dyV4Neg/DmuC6JpQnNzO/m/AVDH1iODdVi2aszJk4cjN4HZaEPSTfByE/SyDJ2wxq8eNvTGL1AhFxK0Pncc/D4yO6JaGGgyE84/ty2+B8YettiLBOmtOqAUeMuwtAjTQI/XQa+37V0G+D9JFAYBPhW98Lwc2Z76fNA/m7GRJz12JaEDU074/FZg9GzdmbNymzt4UyWmbWRtSsEsih+Mk6c4ifjiNlAYRCg+CkMP2e2l14P5BVz0G/w+4lkU9TBBdNux9gjM2tS5mun+Mk845BaoPgJCSSrIYH8IUDxkz++zF1PXMXPGvzp0kcwybQRrGLwVZj/23auti4Ycweump/4uO8Dv8ek4yXFq9bgzSfmYOr8tVi2do9WoATNftoWAy7uh2tOaQ1nYGkvVr8zF2NnfIaPvtyDauWuEjRo1RhH9+qGKwecgGNbB92ZIxc/x65ZhEnj38KLX2zBdqUBYVMnjBl3Pnq71e3Wl4Ob4eTzz8SIvoehuVeULCUW7sMliA+ClLG0sPh5HH3tZxpz8Yl8d5y53rJzL8F/Rx5mM9TKvdngq7Dgt5u9d955iR/7Z25YXHcwWm9Y/fxE9H4oEeXseN11mHO+nq6/Hk9d+hDu074Pna+7Di+Kz7Z/jWcfmIOpH27ABiVZWoyZDhh+/Xm48EjbVsdkIj9pj6vNWDp/ASa9tBT//WaHNp7V/pY1LUeb9q3Qs+dRGNDrKBxxkPN7U7Xxe8x5/l942vId1frXqhwdj+yIXr26od9xHaXju2rFIjz82AK8tHgLNojdc+Iqr4PO3Y7C8Kv7ord9F52FTWc8/q7I2RLf+Vdw22NLsXCl9pwob4wefU/DvVd3R5tYR59z98jPh5YpfvLBi7nug8sD+bvnH8RZD21IWNfpBLz2ZD8c4mFvkElVbIc/b+w3MNXsrPGnPfHalDNxiPFw240FYybhqvm6UJIb0ezci/DmyCMkwsle3il+xj8A3HvzN9gurboZRs28HkPbWz/c9sHzGHjzZ6ZEcMnNTdti/JRhGGi7V5RMjYX3gAnigyBlrK3Yk4FLcMGUMRjbzVSqahGu6fUiDO1bfhSe+uf5ONZc0RfP4+hhuogqxxV/vRU3HeYThYuo+EHfi/Bhv88w8Fo3/9fBgAdG4F7zpoCA4ifdcSW27F917UL8V/2F4H05jg7YjU8ffRy/nun5DTXqtApE8WdxdMEjuMnzu1qCo6+7HE+d3y7xXbWwaYZRs85HwweewOgPXb7zGTzywA8ZP889AYqf3Psg/hbIHsiXr8XAwQuwzOidfPK3d95vUt32wVPo7SowrLU16HsRFtyuCRlH5EGO3fkgdnOPfcIN4MaeA/Hpvd2Nh3XVBzPR8+ZlLmLJVl/TTnh85lDLmUcps/Ax1c8H4vYgZezNfDphHH79svYLXkQPbJGdqnf+gq6jl1tu6zV+NB4+JZEwbMkfM3ZSxVT8lNdBgx17vP1vn6ADiJ90xxVWvG777iYnfhw/enxut37ngv1IUau0iUMbmwZN62D7Ju8fO66R5QBfZxaJNwGKn3j7LxrW2x/IZSVAdWKSw8Hd8Pi0YIcVek+qkkMSPQm0wpiXh+PCgwBH0rX0vhJcMG1MwHykFMSPZdtzsn2xi4Vk70+w8Bs0QYRNkDKOduwCtFUP/OPv/XGEUnA35tw2HjctsN1lEYzb8eK1f8DoxWqZhHiKqfjxc4TyeSuMf3k4Buo7Hn3FT7Ljwj6uNuPZqyZh3JeBjFMLmQXaxndw4blv4L9J3G4RP44jMXwq+ukZeOfxU9SdfXY2AWyQL60GuJFFYk+A4if2LoxAB/weOk3bYtS9Ysuv/1HNnpOqZclD9LscA8ZfgtuOa42GYnlL5DiMfxrXzk+cMnfy2NH4U++6WHDPHbgqcRwzOl59FV68WA2ZV21fj+8WL8bTs3agnzhROhBSmfhphiumXIJrujVB7arN+OixJzB0lmmXm3kic/SlBEcPvghTLlfze6q2r8Gc8U9g9ALzL9cOmDj/N+gnjE6DhV/3ggibIGWc7diXvvRlK+GEj3Blr1fwruMmk2izlUn8ak9D/BjthZPAnkzOj9p0HfQafTkm9hM5anvx3ZynMXD8clNulE2Q+4mfdMeVRHxU9B2IP93cXVtC3ottX8zFhcMWSk/M/u7R+3GW+SBT7Ts6Vs/Bq9qNT594BL+eKc+LskcHcXBnTLn3PPRsX1f9rq5YhNtuehFzjTMtTd8J2XOoUw88NbEvjj2oFFUbv8akm57G06YcRET2HDG/byk/T5cAxU+6BHl/wF9ckkMNJey8JlX7xHL0zSPw7IAm1lps+R36r8rVzz+I3ub8o6atcMnlZ+KCXh1wSIOgSc7mpuyTZQn6jr8Fk0xLNM4JvTFGzboJQ1sD9r7AtiSmtiTJk9EiU+mw8BuyQYRNkDKydj6aMA5DTUtfegK8+aDCjoO6oc2sxYYQMiIDlsnNnDAdX/HjXGZ1Rm4sSzM+4ifdceU4MLLnOfjw3mOt53G55lBZI3PC//qPD/NYcBeI1oRwEfXSI7fu9ye+U47IT3knPP7yUMuRGlVv/gVdx5qWVpn34/c4yNvPKX7y1rVZ7Jj0gVwXY/s/jec2meyQ5K3YrfSaVO2fBemhMblsX4QRg17EXPOrB/QKypuh79X9MHbAYY5DF93bCBIpsD/MEw9qe19kk4Ro2x6x0l/bkBYLH3BBhE2QMtJm7GNFmXx6YIFpqWXAA7/DIQ89gkkrtRpa9cBrf++PbeacIYtYjKv4MU3cJlhvjrkD17rtePQRP+mOK3vkxfKaEN1GV/FjF+u2JTvtfnfxk8JSMjzEj2yHnv3oDYqfII/RvCzjJn7MLzYVHecJz3np/pA65fZAlq3fy35JmswIW/wY24mVkPnrGHrZAvcdLOLwxZmDA75INVzx45Z46TZRpCJ+zCy8PB9E2AQpI2/Dzq0DJr58FF48V1/yUiM6bSzLJ2J57HI0uyexTdwqFvNL/HiyTVL8pDuupPe7ip8g3wln1DMR/UpF/IhdXdcr0dRA7z0LdOZTSM9FVhNpAoz8RNo9MTHO44EsSzTuMXoEnu5nW67Suhq2+BnwwO9xr/mcoCpxdslbuHfGZ1i40pSUraP2EWcJjwR50AeP/Eh/YYcc+XGwcBleQaIHqYsf+06xxhhxczs8/IC2fV3/tW6bpHrcfAaaPfAG1LQte0SB4kd3pd0v6Y4raUQysPgx5eOYxlq4kR/9PB+Kn5jMFpExk+InMq6IsSGev0bX4KlLHzEOdlN76b7tPZmcn5NHj8af+qXx3iRFCM3BNeOXmc7ZkT+wnd5JT/w4cpCkiZfO/A9dwNgnkLRZeETf1IMETQdTSpYQk9kybN/SXtGqHJVr1fdyJc7+se06alWOZmt3qGc7OVhR/OjuS3dcORKOZblo9l17xtKR88Wu9qMKhJ32vK9E5Mf+Y6Etxs8dhoH++yTU7vslg4syjPzEeKIJ13SKn3B5FmZtfg8d2bkhnXritSfPdBx4mNRur7LGGDD2osRuL2Xn1hp8NPd13PvEPlzzsrYzSnhF7BTquwAY1BMjBhyFQ1pru0c2foTbBr9iygWS52GELX7w9Wz0vGyh5aDGzoMGYeLVXZRdNUnv9kqGhc8odSTNNu2EKX+9CL2VHTNLcO+1s/Ccno+j1ZWM+IH9MEPdHtuhhutfmopTHjC29RhWOxPdkxQ/6IDxc3+DgQ22Y/32BmiuTK6yBPYRmHRKA8UX321qjCPa+wvt5HZ7ycdaUsterbrhmZnnoSs2Y311EzRfm964ciQ8ow563HwRHu7bUdlRWbXiI9x07SuYb87lM8SPM+EZTdtizMRLMPAw8X1Td7NdOH655Wwjc9K3fLdXf/Rs30A7H2svtq1YihefeAOTqk/DR6Zzsyh+CnP6SbXXFD+pkuN9CQJ+4gdind+22wpAx6t/hzkXi8X6xOW9nPK1M4naww/mSVJ2gJ781k6Y8u5Q9Pb1b3qRHyCF81h6DcJH47pok0DqLPy65tgR43cDgKTEj8uZPo4zV6Tb32WCIVnxk+hQ0HyToOfBZF38mHyj+iDNcRX0dR/mMWFKGnYI5wBjx7Lj7Yvnceywz4Id/GnfDRbgOcTITwCHFEgRip8CcXRGuxnkoYPNePHaScYBdao9zpec+uWSJHOqMbRdQuJ1GoEThKVbzmX00hU/6lk9wR/0HTBx7m/Qz7QEkCoL37Gw8T1ccu5cLPQq2Kkteqz9AQu13XPJiR/AKbBkB0xKDj6U7s7xFz8DB5lPGzcrhouw9HZxzKJ9ycXW+YC7gjIvfmbiiJsT56abrTQS2tMaV7Lvqc+IsRxyGGDs2KpL/YRnwPKuwCDPIS57+X79C6UAxU+heDqT/Qzy0BHtbxdLT7aD7MQOq1mDjbM4/MSPqCbQ8fnKwYqXYOiRYqliOxZMeBxXvWw+cFACJIu7vfTW030HU/Isgg2ETx+8B7+e5fJqgKadMWXm+aj9wF3GS2iD7iQzWrdHdSynX5tstI0tR/6RUtRPiHoIm57n4NN7j1Wiac4lH9IFwhgAACAASURBVEt4Q9mF5ncAZsbFT9USjDh3lvTIBjObtMbV9iUYMXgW5pqXtswomtZB2Sb9xcC2E54B+InyBk1LsH1TYrOB86yjNXjqqsdx35eSDQkmO5od1xNTxp6JrvoPgiDPIYqfYA+AAihF8VMATs54F4M8dDQjtr3zFHqO/sZ0gi3QoNcgvDmui3LGThDxI6qqWrMEzz6xAM99uAHf6w/Ssjpo1qktrrj8TFx4vOSt7ttX4cUZr9veMl2CZtrb02/L4jk/Fp+k+fbtlFj4Dord+G7OP3DTY99gmc5XnId0+Wm46dwuytuwLdGbvnoExbdirYA1qiMXNaKoOYnWdCK0pRk/8SP07/d4avzzmLRghzr2tLeDX3L5aRh4mD57ipyUv+Gmx5YbfS5r2hhHH3cUrrz8NPRs7X8YZsbFj7B94yLcdttcvPSl6S3lPSU2pjOuqtbjzceex6S5G/C98UZ17W3oAzbgysELpCc8626pWrMIk8a/hRe/2KK9Db4EDQ5uhoFXn48L1j6Ns1zffK/XsBerP3gLD8/8DO9+Ld7qrv29vBydj+uGEcIfnm91//8fJrJzfih+gn5B874cxU/eu5gdJAESIIEQCdh/7CT5ioig2/FDtJhVkYCDAMUPBwUJkAAJkICFwOo5M/HwjqNwZa/D0OYgdWckqnZj9ZcLcNuYBVhoXhJzRP3W48V7Xse2Xqej35HN0Fx7fYx4h95/5/4D1zz0gyWhOej5U3QRCYRJgOInTJqsiwRIgARiT0CSaO7RJ8dZPq4vqZVVEvRcrdhDZQciRoCvt4iYQ2gOCZAACeSWgPOwQld7Op2A157sZz2vy/FmeffeyI67yG3f2XqhEKD4KRRPs58kQAIkEITAmtfhejSA+X5l199g9LadwCw700vWbLO+A/Ha7d2TeJlwEONZhgSCEaD4CcaJpUiABEigYAhUrViCZ19aiJcWrMWytaYjD5Qdla0w4OJ+uOYUyY5KhdBefPfBW3ju5aWYs1js1DJtWRe7tbodgeFX90Vv+26tgqHLjkaBAMVPFLxAG0iABEiABEiABLJGgAnPWUPNhkiABEiABEiABKJEoLy83NOcopqamhp7Cf1PVVVVqK6uhlBSupoSZc23mP8epY7TFhIgARIgARIggcIkQPFTmH5nr0mABEiABEigYAlQ/BSs69lxEiABEiABEihMAhQ/hel39poESIAESIAECpYAxU/Bup4dJwESIAESIIHCJEDxU5h+Z69JgARIgARIoGAJUPwUrOvZcRIgARIgARIoTAIUP4Xpd/aaBEiABEiABAqWAMVPwbqeHScBEiABEiCBwiRA8VOYfmevSYAESIAESKBgCVD8FKzr2XESIAESIAESKEwCFD+F6Xf2mgRIgARIgAQKlgDFT8G6nh0nARIgARIggcIkQPFTmH5nr0mABEiABEigYAlQ/BSs69lxEiABEiABEihMAhQ/hel39poESIAESIAECpYAxU/Bup4dJwESIAESIIHCJEDxU5h+Z69JgARIgARIoGAJUPwUrOvZcRIgARIgARIoTAIUP4Xpd/aaBEiABEiABAqWAMVPwbqeHScBEiABEiCBwiRA8VOYfmevSYAESIAESKBgCVD8FKzr2XESIAESIAESKEwCFD+F6Xf2mgRIgARIgAQKlkDS4qempsaAVVVVherqahQVFSn/Z770cva/FyxpdpwESIAESIAESCASBEITP8XFxUqHzOIoEj2kESRAAiRAAiRAAiRgIpCW+BFRHxH9EcLHHOGhAOIYIwESIAESIAESiCqB0MSPEEBm0WMXQHFf/qKgi+oQpl0kQAIkQAIkkByBpMWPXr0QA/v378e+ffuUyI++7JWvS1+lpaXJkWVpEiABEiABEiCBWBIoqvEIeYiPDhw4gFq1asWyczSaBEiABEiABEiABOwEfMWPuCHuS1p0OwmQAAmQAAmQAAnoBDzFjx1TPufFUODxS0ECJEACJEAChUEgsPjJZ+HD6FZhDHb2kgRIgARIgASUOd8r50dHJBM+jJRwAJEACZAACZAACcSRgK/4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", + "created": 1751028365757, + "lastRetrieved": 1763130743829 + }, + "89153ff21bce9db4c81e5ca2b799580617710770": { + "mimeType": "image/png", + "id": "89153ff21bce9db4c81e5ca2b799580617710770", + "dataURL": "data:image/png;base64,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AD5rTYJycpiqAcBgvGWkj/watuWl+w13AJy8Au1Zq9bQae/ElbsA4g6APexRdWkC+KRluDNUDgAbBmPU40czIAQAhhdmh5IK1RodnLpyEyAEgA4hY3pbBBAA2sLlzGCVA8CaZJQSIb8zoF20Cu4AuMisZaRmSxU6NptveSJ4BNASEQYIIoAAIAikyDIqB4BViQgNRtANEHcARF5RPGpNLZTpRPbKXQBxB4CHV6qoQABg6LTKAWA0Fqafi4YZutJdSbgD0F3+Ilb/2XyRJuaKLUvhDkBLRBggiAACgCCQIsuoHABSkSCtTkRE4pSiFgKA+218K7tA0wvllieCANASEQYIIoAAIAikyDIqB4B4yE9rk1GROKWohQDgfhuPzs5TrlRteSIIAC0RYYAgAggAgkCKLKNyAAj7vbRxMC4SpxS1EADcb+OBqRwVq/WWJ4IA0BIRBggigAAgCKTIMioHAK+m0dYRdAO8dD8hAIi8wrpTa+9ElmqNK3cBNJQhAHTHHxVXRQBg6LrKAcCwIz3aR5rRFhDH/xNAAHD3ZmjoerMLoJkDAcAMJYwRQQCfsiIoCq6hegDYPJygoFcTTNXd5RAA3O1fqV6n/ZM5UyeBAGAKEwYJIIAAIACi6BKqB4B1qRhFA+gG+M59hQAg+ipztt58pUaHp1t3AcQjAGd9UX01BACGO2DPbOFXGuRdwVCaZUnzxUpytlxZa6ZAMhw4Eg0GMmbGqjJGG9uf1HbvNsWv20wa119/tJHeNNttHZzWny9X+meLlZ83oykZDByNhgNS8dOo/rOtyZ7/MnP+GOMcAQQA51hjJRAAARAAARBgQwABgI0VEAICIAACIAACzhFAAHCONVYCARAAARAAATYEEADYWAEhIAACIAACIOAcAQQA51hjJRAAARAAARBgQwABgI0VEAICIAACIAACzhFAAHCONVYCARAAARAAATYEEADYWAEhIAACIAACIOAcAQQA51hjJRAAARAAARBgQwABgI0VEAICIAACIAACzhFAAHCONVYCARAAARAAATYEEADYWAEhIAACIAACIOAcAQQA51hjJRAAARAAARBgQwABgI0VEAICIAACIAACzhFAAHCONVYCARAAARAAATYEEADYWAEhIAACIAACIOAcAQQA51hjJRAAARAAARBgQwABgI0VEAICIAACIAACzhFAAHCONVYCARAAARAAATYEEADYWAEhIAACIAACIOAcAQQA51hjJRAAARAAARBgQwABgI0VEAICIAACIAACzhFAAHCONVYCARAAARAAATYEEADYWAEhIAACIAACIOAcAQQA51hjJRAAARAAARBgQwABgI0VEAICIAACIAACzhH4PwSQY+Fn2tiBAAAAAElFTkSuQmCC", + "created": 1750418318218, + "lastRetrieved": 1763130743829 + }, + "c2fa720fbef5bb40038163ca3eb4fab673fe2244": { + "mimeType": "image/png", + "id": "c2fa720fbef5bb40038163ca3eb4fab673fe2244", + "dataURL": "data:image/png;base64,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SQQQQMC1AoQ01zYNBUMAAQQQKCgBQlpByfNeBBBAAAEjQEijHyCAAAIIIBAiQEijSyCAAAIIFKQAIa0g9Xk3AggggIArBQhprmwWCoUAAgh4RoCQ5pmmpqIIIIAAAtEKENKileI6BBBAAIH8ECCk5Ycqz0QAAQQQiGkBQlpMNx+FRwABBGJegJAW801IBRBAAAGUbsAZAAAgAElEQVQE8lqAkJbXojwPAQQQQCA7AoS07GhxLQIIIICAJwQIaZ5oZiqJAAIIuFaAkObapqFgCCCAAAIFJUBIKyh53osAAgggYAQIafQDBBBAAAEEEEAAAQQQQMBFArt3787z0iTs2rUrLTdPTUpKys3t3IsAAggggAACCCCAAAIIxKwAIS1mm46CI4AAAggggAACCCCAQDwKENLisVWpEwIIIIAAAggggAACCMSsACEtZpuOgiOAAAIIIIAAAggggEA8ChDS4rFVqRMCCCCAAAIIIIAAAgjErAAhLWabjoIjgAACCCCAAAIIIIBAPAoQ0uKxVakTAggggAACCCCAAAIIxKwAIS1mm46CI4AAAggggAACCCCAQDwKENLisVWpEwIIIIAAAggggAACCMSsACEtZpuOgiOAAAIIIIAAAggggEA8ChDS4rFVqRMCCCCAAAIIIIAAAgjErAAhLWabjoIjgAACCCCAAAIIIIBAPAoQ0uKxVakTAggggAACCCCAAAIIxKwAIS1mm46CI4AAAggggAACCCCAQDwKENLisVWpEwIIIIAAAggggAACCMSsACEtZpuOgiOAAAIIIIAAAggggEA8ChDS4rFVqRMCCCCAAAIIIIAAAgjErAAhLWabjoIjgAACCCCAAAIIIIBAPAoQ0uKxVakTAggggAACCCCAAAIIxKwAIS1mm46CI4AAAggggAACCCCAQDwKENLisVWpEwIIIIAAAggggAACCMSsACEtZpuOgiOAAAIIIIAAAggggEA8ChDS4rFVqRMCCCCAAAIIIIAAAgjErAAhLWabjoIjgAACCCCAAAIIIIBAPAoQ0uKxVakTAggggAACCCCAAAIIxKwAIS1mm46CI4AAAggggAACCCCAQDwKENLisVWpEwIIIIAAAggggAACCMSsACEtZpuOgiOAAAIIIIAAAggggEA8ChDS4rFVqRMCCCCAAAIIIIAAAgjErAAhzdZ0KSkpMduQFBwB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2HoerXXH6+int7fGP/TA/AH1me9E3HZ/xM4H15Y77rMhYtOT25uSdP6/tdX/EQe375q1ft75r3WH7dvbI778w4itOyN+6fD2nbxWGPQfAQIECBAgQIAAgUUSENKEtJHjvbXt/d/fGvGteyKOflp72WHrRdPz+q+1HX/rubOv3N56Hi7iZT8b8arnRjxtdeOReX2OcggQIECAAAECBAjURUBIE9IKjdXWy6Wv/EE7UP3M/u1NPo78mYjnHjz5+8pa2/H/8P72zpDfu699/vGHtZ+Da20w4j8CBAgQIECAAAECiywgpAlpE43/Bx+N+Pa2vfHdezdEa9v81s76rZdeH9z631Paz5e95GcjntgbsfuhiAM3tndubC2bbO0SuW332nLI1jvWjn1GxAmHRRzgvWcT9YODCRAgQIAAAQIEmisgpAlpU4/u1lLFW37c3pr/rl0Rd++OOPDJe+Ps4zfEbT+OC8uZagAAIABJREFU+Mcf7I23v3xD/K+bI66+I+LQp7ZfUt3air91B661uYj/CBAgQIAAAQIECBDoFxDShDTXBAECBAgQIECAAAECCQkIaUJaQsNRVQgQIECAAAECBAgQENKENFcBAQIECBAgQIAAAQIJCQhpQlpCw1FVCBAgQIAAAQIECBAQ0oQ0VwEBAgQIECBAgAABAgkJCGlCWkLDUVUIECBAgAABAgQIEBDShDRXAQECBAgQIECAAAECCQkIaUJaQsNRVQgQIECAAAECBAgQENKENFcBAQIECBAgQIAAAQIJCQhpQlpCw1FVCBAgQIAAAQIECBAQ0oQ0VwEBAgQIECBAgAABAgkJCGlCWkLDUVUIECBAgAABAgQIEBDShDRXAQECBAgQIECAAAECCQkIaUJaQsNRVQgQIECAAAECBAgQENKENFcBAQIECBAgQIAAAQIJCQhpQlpCw1FVCBAgQIAAAQIECBAQ0oQ0VwEBAgQIECBAgAABAgkJCGlCWkLDUVUIECBAgAABAgQIEBDShDRXAQECBAgQIECAAAECCQkIaUJaQsNRVQgQIECAAAECBAgQENISCGmGIQECBAgQIECAAAECBKoWWF5ennsVNuzYsWPvLKUuLS3NcrpzCRAgQIAAAQIECBAgUFsBIa22XafiBAgQIECAAAECBAg0UUBIa2KvahMBAgQIECBAgAABArUVENJq23UqToAAAQIECBAgQIBAEwWEtCb2qjYRIECAAAECBAgQIFBbASGttl2n4gQIECBAgAABAgQINFFASGtir2oTAQIECBAgQIAAAQK1FRDSatt1Kk6AAAECBAgQIECAQBMFhLQm9qo2ESBAgAABAgQIECBQWwEhrafr9uzZU9uOVHECBAgQIECAAAECBOYrcMABB8y3wIKlCWlCWsGh4jACBAgQIECAAAECiyUgpPX099LSUiW9705aJew+lAABAgQIECBAgECSAkKakJbkwFQpAgQIECBAgAABAosqIKQJaYs69rWbAAECBAgQIECAQJICQpqQluTAVCkCBAgQIECAAAECiyogpAlpizr2tZsAAQIECBAgQIBAkgJCmpCW5MBUKQIECBAgQIAAAQKLKiCkCWmLOva1mwABAgQIECBAgECSAkKakJbkwFQpAgQIECBAgAABAosqIKQJaYs69rWbAAECBAgQIECAQJICQpqQluTAVCkCBAgQIECAAAECiyogpAlpizr2tZsAAQIECBAgQIBAkgJCmpCW5MBUKQIECBAgQIAAAQKLKiCkCWmLOva1mwABAgQIECBAgECSAkKakJbkwFQpAgQIECBAgAABAosqIKQJaYs69rWbAAECBAgQIECAQJICQpqQluTAVCkCBAgQIECAAAECiyogpAlpizr2tZsAAQIECBAgQIBAkgJCmpCW5MBUKQIECBAgQIAAAQKLKiCkCWmLOva1mwABAgQIECBAgECSAkKakJbkwFQpAgQIECBAgAABAosqIKQJaYs69rWbAAECBAgQIECAQJICQpqQluTAVCkCBAgQIECAAAECiyogpAlpizr2tZsAAQIECBAgQIBAkgJCmpCW5MBUKQIECBAgQIAAAQKLKiCkCWmLOva1mwABAgQIECBAgECSAkKakJbkwFQpAgQIECBAgAABAosqIKQJaYs69rWbAAECBAgQIECAQJICQpqQluTAVCkCBAgQIECAAAECiyogpAlpizr2tZsAAQIECBAgQIBAkgJCmpCW5MBUKQIECBAgQIAAAQKLKiCkCWmLOva1mwABAgQIECBAgECSAkKakBY7f/JAXPu9O2PrPcux8ycPzjxQf/3X/s1QGQ987Evx+I+W+/59n6X9Y//fO3mqz3t863I8/JlvDp37pFcdGU966WFTlekkAgQIECBAgAABAikICGkLGtL27t0b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AgQINFBASFugkHb1N38Q/+EDF5c+jO+46veHPkNIK53dBxAgQIAAAQIECDREQEhboJDWauob3v0/4ts33lnq8BXSSuVVOAECBAgQIECAQMMFhLQFC2n3/vgn8bp3/lncu2N3aUNbSCuNVsEECBAgQIAAAQILICCkLVhIazX3zm33x2m//hdx1/b7SxniQloprAolQIAAAQIECBBYEAEhbQFDWqvJP77/p/HJi78Sl/zdNfHoY4/PdbgLaXPlVBgBAgQIECBAgMCCCQhpCxrSOs3eveeh+Oo1t8W3v39nbL17OXbtfnDmS+DS/3bGUBm7XvupeOz6u/v+/Z8dclAc9LWzp/q8Vlk//eDfDJ278awT45+/7l9NVaaTCBAgQIAAAQIECKQgIKQteEhLYRCqAwECBAgQIECAAAECawJCmpDmeiBAgAABAgQIECBAICEBIU1IS2g4qgoBAgQIECBAgAABAkKakOYqIECAAAECBAgQIEAgIQEhTUhLaDiqCgECBAgQIECAAAECQpqQ5iogQIAAAQIECBAgQCAhASFNSEtoOKoKAQIECBAgQIAAAQJCmpDmKiBAgAABAgQIECBAICEBIU1IS2g4qgoBAgQIECBAgAABAkKakOYqIECAAAECBAgQIEAgIQEhTUhLaDiqCgECBAgQIECAAAECQpqQ5iogQIAAAQIECBAgQCAhASFNSEtoOKoKAQIECBAgQIAAAQJCmpDmKiBAgAABAgQIECBAICEBIU1IS2g4qgoBAgQIECBAgAABAkKakOYqIECAAAECBAgQIEAgIQEhTUhLaDiqCgECBAgQIECAAAECQpqQ5iogQIAAAQIECBAgQCAhASFNSEtoOKoKAQIECBAgQIAAAQJCmpDmKiBAgAABAgQIECBAICEBIU1IS2g4qgoBAgQIECBAgAABAkKakOYqIECAAAECBAgQIEAgIQEhTUhLaDiqCgECBAgQIECAAAECQpqQ5iogQIAAAQIECBAgQCAhASFNSEtoOKoKAQIECBAgQIAAAQJCmpDmKiBAgAABAgQIECBAICEBIU1IS2g4qgoBAgQIECBAgAABAkKakOYqIECAAAECBAgQIEAgIQEhTUhLaDiqCgECBAgQIECAAAECQpqQ5iogQIAAAQIECBAgQCAhASFNSEtoOKoKAQIECBAgQIAAAQJCmpDmKiBAgAABAgQIECBAICEBIU1IS2g4qgoBAgQIECBAgAABAkJaAiHNMCRAgAABAgQIECBAgEDVAsvLy3OvwoYdO3bsnaXUpaWlWU53LgECBAgQIECAAAECBGorIKTVtutUnAABAgQIECBAgACBJgoIaU3sVW0iQIAAAQIECBAgQKC2AkJabbtOxQkQIECAAAECBAgQaKKAkNbEXtUmAgQIECBAgAABAgRqKyCk1bbrVJwAAQIECBAgQIAAgSYKCGlN7FVtIkCAAAECBAgQIECgtgJCWm27TsUJECBAgAABAgQIEGiigJDWxF7VJgIECBAgQIAAAQIEaisgpNW261ScAAECBAgQIECAAIEmCghpTexVbSJAgAABAgQIECBAoLYCQlptu07FCRAgQIAAAQIECBBoooCQ1sRe1SYCBAgQIECAAAECBGorIKTVtutUnAABAgQIECBAgACBJgoIaU3sVW0iQIAAAQIECBAgQKC2AkJabbtOxQkQIECAAAECBAgQaKKAkNbEXtUmAgQIECBAgAABAgRqKyCk1bbrVJwAAQIECBAgQIAAgSYKCGlN7FVtIkCAAAECBAgQIECgtgJCWm27TsUJECBAgAABAgQIEGiigJDWxF7VJgIECBAgQIAAAQIEaisgpNW261ScAAECBAgQIECAAIEmCghpTexVbSJAgAABAgQIECBAoLYCQlptu07FCRAgQIAAAQIE6iKwz1kX1KWq6tkj8MT5Z1biIaRVwu5DCRAgQIAAAQIEFkmgFdKqmvAvkvM821plnwlp8+xJZREgQIAAAQIECBDIEKhywq9DphOoss+EtOn6zFkECBAgQIAAAQIECgtUOeEvXEkH9glU2WdCmsFIgAABAgQIECBAoGSBKif8JTetscVX2WdCWmOHlYYRIECAAAECBAikIlDlhD8Vg7rVo8o+E9LqNlrUlwABAgQIECBAoHYCVU74a4eVSIWr7DMhLZFBoBoECBAgQIAAAQLNFahywt9c1XJbVmWfCWnl9q3SCRAgQIAAAQIECESVE3780wlU2WdC2nR95iwCBAgQIECAAAEChQWqnPAXrqQD+wSq7DMhzWAkQIAAAQIECBAgULJAlRP+kpvW2OKr7DMhrbHDSsMIECBAgAABAgRSEahywp+KQd3qUWWfCWl1Gy3qS4AAAQIECBAgUDuBKif8tcNKpMJV9pmQlsggUA0CBAgQ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AAECBAgkJCCkJdQZqkKAAAECBAgQIECAAAEhzRggQIAAAQIECBAgQIBAQgJCWkKdoSoECBAgQIAAAQIECBAQ0owBAgQIECBAgAABAgQIJCQgpCXUGapCgAABAgQIECBAgAABIc0YIECAAAECBAgQIECAQEICQlpCnaEqBAgQIECAAAECBAgQENKMAQIECBAgQIAAAQIECCQkIKQl1BmqQoAAAQIECBAgQIAAASHNGCBAgAABAgQIECBAgEBCAkJaQp2hKgQIECBAgAABAgQIEBDSjAECBAgQIECAAAECBAgkJCCkJdQZqkKAAAECBAgQIECAAAEhzRggQIAAAQIECBAgQIBAQgJCWkKdoSoECBAgQIAAAQIECBAQ0owBAgQIECBAgAABAgQIJCQgpCXUGapCgAABAgQIECBAgAABIc0YIECAAAECBAgQIECAQEICQlpCnaEqBAgQIECAAAECBAgQENKMAQIECBAgQIAAAQIECCQkIKQl1BmqQoAAAQIECBAgQIAAASHNGCBAgAABAgQIECBAgEBCAkJaQp2hKgQIECBAgAABAgQIEBDSjAECBAgQIECAAAECBAgkJCCkJdQZqkKAAAECBAgQIECAAAEhzRggQIAAAQIECBAgQIBAQgJCWkKdoSoECBAgQIAAAQIECBAQ0owBAgQIECBAgAABAgQIJCSQZEhLyEdVCBAgQIAAAQIECBAgUHuBDTt27Nhb+1ZoAAECBAgQIECAAAECBBoiIKQ1pCM1gwABAgQIECBAgACBZggIac3oR60gQIAAAQIECBAgQKAhAkJaQzpSMwgQIECAAAECBAgQaIaAkNaMftQKAgQIECBAgAABAgQaIiCkNaQjNYMAAQIECBAgQIAAgWYICGnN6EetIECAAAECBAgQIECgIQJCWkM6UjMIECBAgAABAgQIEGiGgJDWjH7UCgIECBAgQIAAAQIEGiIgpDWkIzWDAAECBAgQIECAAIFmCAhpzehHrSBAgAABAgQIECBAoCECQlpDOlIzCBAgQIAAAQIECBBohoCQ1ox+1AoCBAgQIECAAAECBBoiIKQ1pCM1gwABAgQIECBAgACBZggIac3oR60gQIAAAQIECBAgQKAhAkJaQzpSMwgQIECAAAECBAgQaIbA/wdWUUNC6zaznwAAAABJRU5ErkJggg==", + "created": 1751025249737, + "lastRetrieved": 1763130743829 + }, + "f5699aee6a55a10b506386b441837c15a9d838ce": { + "mimeType": "image/png", + "id": "f5699aee6a55a10b506386b441837c15a9d838ce", + "dataURL": "data:image/png;base64,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h7lXxTy3b/6tTXy65/6VbJ1txpURgbAGgM2xzR9TcynW7BFv/pmbB01A8POxNN7XMYl/XyU+Ffm5v/QNAQQQQMBnAgSAv09IVUlm2dfd4t8rmhu3GsTvoK+f+PTldTAwK/SZTz/mn7n8OVPS7/EFfFb57DyiOwgggAACARMgAARswuguAggggAACbggQANxQpA4EEEAAAQQCJkAACNiE0V0EEEAAAQTcECAAuKFIHQgggAACCARMgAAQsAmjuwgggAACCLghQABwQ5E6EEAAAQQQCJgAASBgE0Z3EUAAAQQQcEOAAOCGInUggAACCCAQMAECQMAmjO4igAACCCDghgABwA1F6kAAAQQQQCBgAgSAgE0Y3UUAAQQQQMANAQKAG4rUgQACCCCAQMAECAABmzC6iwACCCCAgBsCBAA3FKkDAQQQQACBgAkQAAI2YXQXAQQQQAABNwQIAG4oUgcCCCCAAAIBEyAABGzC6C4CCCCAAAJuCBAA3FCkDgQQQAABBAImQAAI2ITRXQQQQAABBNwQIAC4oUgdCCCAAAIIBEyAABCwCaO7CCCAAAIIuCFAAHBDkToQQAABBBAImAABIGATRncRQAABBBBwQ4AA4IYidSCAAAIIIBAwAQJAwCaM7iKAAAIIIOCGAAHADUXqQAABBBBAIGACBICATRjdRQABBBBAwA0BAoAbitSBAAIIIIBAwAQIAAGbMLqLAAIIIICAGwIEADcUqQMBBBBAAIGACRAAAjZhdBcBBBBAAAE3BAgAbihSBwIIIIAAAgETIAAEbMLoLgIIIIAAAm4IEADcUKQOBBBAAAEEAiZAAAjYhNFdBBBAAAEE3BAgALihSB0IIIAAAggETIAAELAJo7sIIIAAAgi4IUAAcEOROhBAAAEEEAiYAAEgYBNGdxFAAAEEEHBDgADghiJ1IIAAAgggEDABAkDAJozuIoAAAggg4IYAAcANRepAAAEEEEAgYAIEgIBNGN1FAAEEEEDADQECgBuK1IEAAggggEDABAgAAZswuosAAggggIAbAgQANxSpAwEEEEAAgYAJEAACNmF0FwEEEEAAATcECABuKFIHAggggAACARMgAARswuguAggggAACbggQANxQpA4EEEAAAQQCJkAACNiE0V0EEEAAAQTcECAAuKFIHQgggAACCARMgAAQsAmjuwgggAACCLghQABwQ5E6EEAAAQQQCJgAASBgE0Z3EUAAAQQQcEOAAOCGInUggAACCCAQMAECQMAmjO4igAACCCDghgABwA1F6kAAAQQQQCBgAgSAgE0Y3UUAAQQQQMANAQKAG4rUgQACCCCAQMAECAABmzC6iwACCCCAgBsCBAA3FKkDAQQQQACBgAkQAAI2YXQXAQQQQAABNwQIAG4oUgcCCCCAAAIBEyAABGzC6C4CCCCAAAJuCBAA3FCkDgQQQAABBAImQAAI2ITRXQQQQAABBNwQIAC4oUgdCCCAAAIIBEyAABCwCaO7CCCAAAIIuCFAAHBDkToQQAABBBAImAABIGATRncRQAABBBBwQ4AA4IYidSCAAAIIIBAwAQJAwCaM7iKAAAIIIOCGAAHADUXqQAABBBBAIGACBICATRjdRQABBBBAwA0BAoAbitSBAAIIIIBAwAQIAAGbMLqLAAIIIICAGwIEADcUqQMBBBBAAIGACRAAAjZhdBcBBBBAAAE3BAgAbihSBwIIIIAAAgETIAAEbMLoLgIIIIAAAm4IEADcUKQOBBBAAAEEAiZAAAjYhNFdBBBAAAEE3BAgALihSB0IIIAAAggETIAAELAJo7sIIIAAAgi4IUAAcEOROhBAAAEEEAiYAAEgYBNGdxFAAAEEEHBDgADghiJ1IIAAAgggEDABAkDAJozuIoAAAggg4IYAAcANRepAAAEEEEAgYAIEgIBNGN1FAAEEEEDADQECgBuK1IEAAggggEDABAgAAZswuosAAggggIAbAgQANxSpAwEEEEAAgYAJEAACNmF0FwEEEEAAATcECABuKFIHAggggAACARMgAARswuguAggggAACbggQANxQpA4EEEAAAQQCJkAACNiE0V0EEEAAAQTcECAAuKFIHQgggAACCARMgAAQsAmjuwgggAACCLghQABwQ5E6EEAAAQQQCJgAASBgE0Z3EUAAAQQQcEOAAOCGInUggAACCCAQMAECQMAmjO4igAACCCDghgABwA1F6kAAAQQQQCBgAgSAgE0Y3UUAAQQQQMANAQKAG4rUgQACCCCAQMAECAABmzC6iwACCCCAgBsCBAA3FKkDAQQQQACBgAn8P2IXIkulDUY2AAAAAElFTkSuQmCC", + "created": 1751029634669, + "lastRetrieved": 1763130743829 + }, + "e21a81d007aa429a6881761880032f610f46617a": { + "mimeType": "image/png", + "id": "e21a81d007aa429a6881761880032f610f46617a", + "dataURL": "data:image/png;base64,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", + "created": 1750417444919, + "lastRetrieved": 1763130743829 + }, + "ebbbf7d44e2b8252a57c53ae5d8b94fdea1ea5cc": { + "mimeType": "image/png", + "id": "ebbbf7d44e2b8252a57c53ae5d8b94fdea1ea5cc", + "dataURL": "data:image/png;base64,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", + "created": 1750417635797, + "lastRetrieved": 1763130743829 + }, + "25d6473c393dcaa08bfeb9e87a3b1cc1dc3263ed": { + "mimeType": "image/png", + "id": "25d6473c393dcaa08bfeb9e87a3b1cc1dc3263ed", + "dataURL": "data:image/png;base64,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", + "created": 1750417540985, + "lastRetrieved": 1763130743829 + }, + "9488ea2e35c4743e75d9d6e17bd42751c4edce9a": { + "mimeType": "image/png", + "id": "9488ea2e35c4743e75d9d6e17bd42751c4edce9a", + "dataURL": "data:image/png;base64,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", + "created": 1750418214861, + "lastRetrieved": 1763130743829 + }, + "693a2a6f72e66b88295e872fd167c77f6a19152e": { + "mimeType": "image/png", + "id": "693a2a6f72e66b88295e872fd167c77f6a19152e", + "dataURL": "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAgAAAAIACAYAAAD0eNT6AAAAAXNSR0IArs4c6QAAIABJREFUeF7sXQd4XMXVPVu0q94sS7JlW3LHBUI3phobQkuAhDgh1IQEAgkdAqElJIBJCJ1QE1oIkIQOAVNs0zvGNMvGTbIsWV2W1Xe12v3/u7JAllfa997Me2/e7p3v24+iKXfOnd05M3OLC1wYAUaAEWAEGAFGIOkQcCXdjHnCjAAjwAgwAowAIwAmALwIGAFGgBFgBBiBJESACUASKp2nzAgwAowAI8AIMAHgNcAIMAKMACPACCQhAkwAklDpPGVGgBFgBBgBRoAJAK8BRoARYAQYAUYgCRFgApCESucpMwKMACPACDACTAB4DTACjAAjwAgwAkmIABOAJFQ6T5kRYAQYAUaAEWACwGuAEWAEGAFGgBFIQgSYACSh0nnKjAAjwAgwAowAEwBeA4wAI8AIMAKMQBIiwAQgCZXOU2YEGAFGgBFgBJgA8BpgBBgBRoARYASSEAEmAEmodJ4yI8AIMAKMACPABIDXACPACDACjAAjkIQIMAFIQqXzlBkBRoARYAQYASYAvAYYAUaAEWAEGIEkRIAJQBIqnafMCDACjAAjwAgwAeA1wAgwAowAI8AIJCECTACSUOk8ZUaAEWAEGAFGgAkArwFGgBFgBBgBRiAJEWACkIRK5ykzAowAI8AIMAKOJwB1dXWFbrf7QJcrMgtw7QREpgHIA5ALIHP06CIfq5kRYAQSA4Gr55WlBj2Z0yIIT3MBUwFMiwATXEAOgCwAGds+9P2PWfwpXmSkpUkFpKs7gJ7eYKw+e+FCByJojQBdLmAzEFnjirhW98G9JjUl/MnVr5S3SBWGO2MENCLgSALQ1FS7VyTi/mkkgkNdLswCMOw8Ro8ucuQcNeqPqzECCY3A5QtmF8EVPghhzIMLBwGYMdL3PR4YXo8HWRlpcA3/kxGvix3+3hMMoqsnoLvdtgZhF/B52OV6ExHX0g5fz2t3LF5nuDOjQnC75ETAMZtjc3NzdjgcOgNwnQZE6EdAU2ECoAkmrsQIKIPAFYfO3jPS13cCXK7DAMyUJZjb7UZORjpcLnk/e72hENq7umWJSEeZLYjgCVck8uh1y1a9DSAir3PuiRHYHgF53wSTkN26dVN+MOg7D8A52672dY3EBEAXXFyZEbAFgd/N26nM5XWd5Aq7ToQLO8kWgjb97PR0eDxuaV33hSNo6+xEJGLaHr0m4nLd6M9MeeLqZz9rlSY4d8QIbENAWQIQiURczc0NJ0ciuBHAaKMaYwJgFDluxwiYj8DlC2YciojrUrgwX+RqP56kWelpSPF641XT/PcIaPPvQl9fWHMbvRXpmSIjLRVerzsc6gu/tDUVJ/3lieVb9fbD9RmB4RBQkgA0NDRMcbsjD0ci2FdUdUwARBHk9oyAXASuvhru3rdmHRVxR65ABHPk9r5jb2mpfqT55NkC0+bf2d2DYG/INNEHNn9fyrekpS8cCYV6e/96xUsrLjdtYO44qRBQjgA0NdX/IBLBA9us+IWVwQRAGELugBGQhsAV82cujLhwDYDp0jodoSOfNwUZ6akSTf4QNfgjwz+zCm3+6al++H0pMYcI9YXrgqHAsb9/6YsPzZKB+00OBJQhAJFIxN3U1HgTEDlfJvRMAGSiyX0xAsYQuPLQGVMjYdftEeBwYz3obxW1+E9Pk2r0Fwj2orOnR78wOlrQtb8/Jfbm/003kUgk2Bu67fIXP71AR9dclRHYDgElCEAk8pWvqWn0QwB+Kls/TABkI8r9MQLaEbj6+3ukB7u7L0EEvwPg195SrKbb5UZ2RhrI8l9WCfX1Rd/9zSr0Y5yWmorUYU7+scbtDYVWbXF1zLnh+a/bzZKL+01cBGwnAP2bf8EzgOtIM2BmAmAGqtwnIxAfgSsOmbl/JIJHAUyIX1teDbL4z0pPh1eqxX8Y7Z3dCEfMMfqjH+L+a3/9tgqhcF9bRzCy+7WLl6+XhyL3lAwI2EoAyNK/sbHhIZcLp5gFNhMAs5DlfhmBYRFwXb5gxrmA668A4txly0WRftDoCt0X7wpdx7Dk5he1+A+rt/kPTCMc7gt0hYPzrn7hiw90TI2rJjkCthKAxsaGW2S/+Q/VJxOAJF/hPH1LEfjtvJnFXg8ecQGHWDrwtsHS/H6k+fWfokeSlQL9UMAfM4rIyX+oPOFIpC/Q3fO9q1754mUzZOU+Ew8B2whAQ0PDQpcr8l+zIWUCYDbC3D8j0I/AFYfM2CcScT0LoMgOTHxeLzLI6E/i4F2BAHoC5lj897/5+5Fq4Np/uClGwpG+QCAw78qXP39HIgzcVYIiIPO7ohmi+vr6yW43lqM/gYephQmAqfBy54xAFIHLDp5xpMvtIkJPyXgsL/0x/tOlbv6B3t6ov79ZJV2nwZ9WOXpDoc62rs7S65eubtbahuslJwKWE4BtEf7ekRHkR4vKmABoQYnrMALGEbh8wcyT/t/Qj2J3WPrePyCx201hfjNA/5RVyOKfjP4o6I8ZhQz+ZJ78B2QMh8NRe4VwJPK2Lx+HXP1EuTnXF2aAwn1ajoC8b4xG0Rsb634JuP6usbpwNSYAwhByB0mCwNXz5nkDroY9XB7MckVc08OIlLqAzEi/+x5tr1sANAHYiAg+6w1jRYon8hPAdTP93RaYojH+00A3ALIKbaJbO7tMi/Fvhp0CzZ2MFAd7KkSA269fWk55VLgwAjERsJQAbEvs8zWAAqv0wQTAKqR5HCcicOkhk3LckdTjXcBRAOYByHLKPEyz+O8yL8Z/WqoPaT754RD6T/47uim6Iq4Trlu28nGn6JTltBYBSwlAY2P9n/6fqF5l5RSZAFiJNo/lFAQu/+6M2a6w68JIBD+2691eFCvaSGlDlVXosr+zqwfBUK+sLrfrx9STf1c3iATEKK2uSGj2dcvW1JgyKe7U0QhYRgCam5uzw+FQpZGUviIIMwEQQY/bJhoCV3x39vhIX/hKAL8AIO/e3GKgyOI/Mz1N6qhmxvgn10QiALILbfrkphgnRsELi5aWHy17bO7P+QhYRgAaG+sv/v+TBgUGsbQwAbAUbh5MXQRcly+YeToAeq+3xVJfFjQU4Y8i/VHEP1mFMvt1dpPRn/yS6vch3ZTNvz9AkZbohBFg4fVLy5+UPzvu0ckIyPsGxUGhoaH+S5cLs60GiwmA1YjzeKohcPmC2UVA+BEAh6omm155aNPPzsiAR7LFv1kx/k3b/CMRtHd2oi+smbJUtPuCM+5YvC6gF3Oun7gIWEIAmppq94pE3B/ZASMTADtQ5zFVQeB382ZOcXuxGBFMUUUmo3LQgZ+u/VM8XqNd7NCOTs9R4zkTwvxSUh/y9ZddwuEI2rq69MvswrmLlpTfIVse7s+5CFhCABob6+na0Za0lUwAnLs4WXIxBK6YP3vfiCv8AoB8sZ7UaJ1hMFnOcNJTjP/2ri6E+uTH+Pf7fcgw5dpf05t/7ClH0OjLSCu7+oXl5qU0VGOpsBQaEbCKAHwFYJZGmaRWYwIgFU7uzCEIXHXwzFl9HryNCPIcIvKIYlLQHAqeI6tELf67exDslW/xTxn9SFbZP67h6LW/WFKiCHDm9UvL75WFI/fjbARkr9Ed0Kirqyv0eFx1gPTvgybkmQBogokrJRAClx4yc4IngvcAlCTCtPpj/KfCJfEnpDsQQLcJMf79KSlITyNZ5RaJGQnLFy0tJ1sszcYDcmfCvamEgOx1usPcGhoafuRyRZ6wa9JMAOxCnse1AwGK5hf01L8JuPa1Y3zZY3rcbmRTjH+ZFv+hEDq75Fv80+ZPqYhll+jmLzU4UeS7i5auek22nNyf8xAwnQA0NtZf/f9s8w92QcMEwC7keVw7ELh8wYw/AS5Lg22ZNc9+i/90EAmQVfpj/HdJP/6atfmTkSKF943j568THtc/Fy1dearORlw9ARGwgAA0PA5EjrcLOyYAdiHP41qNwKUHz/qOxx2hLJuODfAzgFnU4j8tHSleeVOJWs93dlKiHKmqMWvz7z/5d6Ovr0+qvABaffko4kRBsmF1Xn8WEIC6TwDXHnZBwwTALuR5XKsRuHzBzFcTwdefcJOeKnfbZko3ADKLP8WLjDS5EQlJPuIo/R4KcuUdmHskHDnq+tdXvSQTC+7LeQhYQADqKfxvqV3QMAGwC3ke10oEfrdg5uFuYLGVY5o1llMs/n3eFGSmm/HmT5t/pynuid/oLIK7Fy0r/7VZOuR+nYGAFQSg2U4/ZCYAzliILKUYApctmLnUBcwX68X+1ileL7Ikx/g3w+Lfl+JFpiknf4pN0G3ayf+bGwDgy+uXlu9iv8ZZAjsRsIIAUOhJeSm7dKLFBEAnYFzdcQhcecjsGeFIeKVdrrayAHO73cjJyIBEg38EQyF0dHXLEjHajxmJiKLX/iA/f/M3/21ghMMBT8Gf3/lyi1RwuDNHIWAFAZBrcaMTXiYAOgHj6o5D4LIFM29yARc6TvBBApth8U+W820dZPEv7ycoGpMgLU0qSenf/Le9+YfMefOPtTbCwBF/Xlr+spPXDcsuhgATADH8uDUjYDsCly+YuQbAVNsFMSgABfiht3S6/pdV+gPn6EqWE3foFLr2TzVn8+/o7EZvXyiuDFIruFwXLlqy8hapfXJnjkKACYCj1MXCMgLbI3DZgp2mueD+2sm4yLb4Jwt6uvaXuaESOSGSIjMa4YDOKBOhWdb+I6+LyJ2Llq4628lrh2UXQ4AJgBh+3JoRsBWByw6ZdborErnPViEEBjfDh76zJ4BAMCgg1fZNo2/+FOFPpnHCtiHI1a/Xwmv/wTNzAS9ft7T8CGlAcUeOQ4AJgONUxgIzAt8icPn8mbfDhXOciInX44lG+pNZeoJBdPXIS3lPgYiyyNpf8uZPTxT9txTWvfnHwJnyAtiSpE2mzrkv4wgwATCOHbdkBGxH4PIFM5cBONh2QXQK4Ha5kZNpRoz/HmlGf1GXRBNO/mSU2J+J0OI3/x11tGnR0vIJOlXH1RMIASYACaRMnkryIXD5gpnrAEx20sxNs/inGP+Swvx6t23+MpMQDeioo6sLQZuu/bdbJy5sWbSkPN9Ja4dllYsAEwC5eHJvjIClCFy+YGYjgAJLBxUcLDM9HT6JMf4lpsqNzoyeJigYkRmbPwX56Q3ZfvIf0GBw0dJyv6A6ubmDEWAC4GDlseiMwOULZtoWaGvChBKcceYprASDCNTXN+CO2+432Fp3s4q1+eVTn3gCthod6JaaG5iKABMAU+HlzhkBcxG4fMFMeVFudIr6k58ei513nqGzFVcfjMC9dz+MTZs2WwKKy4Vjr1tS/pwlg/EgjkCACYAj1MRCMgKxEbCLAGRnZ+Gi3/4aHo+bVSOAwCeffI5nn7YmKV8EkTeuX7rKcQajAvBy0zgIMAHgJcIIOBgBuwjAdw8/GAceuI+DkVND9GCwF3+5/g4EAvJcF0eaWcTjmXH9q1+uVmP2LIXdCDABsFsDPD4jIICAHQSAQuL+9tKzkS45a58ADI5u+vyzL+Ojj1ZYMwcXrlu0pPxKawbjUVRHgAmA6hpi+RiBERCwgwDMmbM7vn/MYawXSQhs3lyHu/72oKTe4nazyXdAednVVyMctyZXSHgEmAAkvIp5gomMgNUEgAL4nHfh6Rg1it3HZa6ru+98CDU1tTK7HLavCML7Xr909fuWDMaDKI0AEwCl1cPCMQIjI2A1Adh5l5n4yfHHsFokI7B8+Rd45qkXJfcauzsXXDdct3TlpZYMxoMojQATAKXVw8IxAmoRgLN+8zOUlIxhtUhGIBTqw4033ImOjk7JPcfs7utFS8t3smIgHkNtBJgAqK0flo4RGBEBK28ApkyZiJ+ddjxrxCQEli17B8uWvG1S79t32+dC6V+WlFdZMhgPoiwCTACUVQ0LxgjER8BKAvDzX/wUkyeXxReKaxhCoLOzCzfecBd6e3sNtdfTKBKJnHL9slWP6GnDdRMPASYAiadTnlESIWAVARgzpgi/PvvnpsTHTyJ1xZ0qBQWi4EBmF5cLD163pPw0s8fh/tVGgAmA2vph6RiBERGwigD89MQfYtas6awNkxFoqG/CHbf/Q1pWw2HFjeCrRcvKdzZ5Oty94ggwAVBcQSweIzASAlYQgMLCApxz3i/59G/RUnz4wX9j7doKs0cLdXe1Zd/yfnW32QNx/+oiwARAXd2wZIxAXASsIACc9CeuGqRWqKiowv1/f1Rqn7E6c0Uw57pl5R+ZPhAPoCwCTACUVQ0LxgjER8BsAjB69Cice/7pfPqPrwqpNf5x379QWblJap8xOjt50dLyf5k9CPevLgJMANTVDUvGCMRFwGwCsPAnR+M735kVVw6uIBcBegKgpwBTSwRXL1pW/kdTx+DOlUaACYDS6mHhGIGRETCTAFC43/MuOB1uN6f8tWMd3nP3w6jetNm0oV0uPHLdkvJTTBuAO1YeASYAyquIBWQEhkfATAJw3MLvY7fdZjP8NiGwatVaPPrIk6aNHgGWXL+0/FDTBuCOlUeACYDyKmIBGQHrCUD+qFycf8Gv+PRv4+KLRCKgJEGULdCk8tmipeW7mdQ3d+sABJgAOEBJLCIjMBwCZt0A8OlfjTW3cuUaPP7oU2YJU71oafl4szrnftVHgAmA+jpiCRmBYREwgwAUFRXi7HNPY8t/Rdbdfff8E1VVNWZI07poaXmeGR1zn85AgAmAM/TEUjICMREwgwCcfOpCTJ8+hRFXBIHKiir8w5y4AF2LlpZnKDJNFsMGBJgA2AA6D8kIyEJANgEoLR2H0391sizxuB9JCJgUHbBv0dJyryQRuRsHIpDwBKCxsdGBamGRGQFtCPzrnB9rq6ix1i9OPxETJ07QWJurWYVAXV0j7rzjfuk5Ak66479WTcEx4/T2htDd3SUdayMAzJ27n6l7tKmd04QbG+sjRiYuqw0TAFlIcj8qIiCTAOw0YwpOOnmhitNkmQA88Z/n8fnnK6ViwQRgeziDwSC6u9VJj8AEQHC5MwEQBJCbK42ALALgcrmi6X4p7S8XNRHYsmUrbrvlXoRCfdIEZALQD2UkAgQCPQgEAtKwldEREwBBFJkACALIzZVGQBYB2G23nXHcwu8pPVcWDnh58TK88/aH0qBgAhDd/tHZ2Y1QqFcarrI6YgIgiCQTAEEAubnSCMggAB6PB+ddcAby83OVnisLR6fUIG69+V60t3dIgSPZCUAkEkZnZxf6+uTdqkhRzLZOmAAIoskEQBBAbq40AjIIwP4HzMHhR8xXep4s3LcILF/+OZ556iUpkCQzAaBNv6urC+FwWAqWZnTCBEAQVSYAggByc6URECUAGRnpuOCiXyE1NVXpebJw3yJAIYIpONAmCYmCkpUAhEIhdHV1Rt/+VS5MAAS1wwRAEEBurjQCogTgB8cdiT32+I7Sc2ThdkSgpqYW99z1sLCrWjISgGCwN+rm54TCBEBQS0wABAHk5kojIEIAxo4txlm/+RmH/FVaw8ML9/ST/8Onn34pJH2yEQCy8u/p6RHCzMrGTAAE0WYCIAggN1caAaMEgNz+KOhPWRnnglFawSMI197eidtuuU9oQ0sWAkDPJj093aDTv5MKEwBBbTEBEASQmyuNgFECsOtus/Gjhd9Xem4sXHwEPvpoBZ5/9uX4FYepkQwEgDb/fkv/kGGc7GrIBEAQeSYAggByc6URMEIAUlK8OO+CXyE3N1vpubFw8RGgze3BBx7HhvUb41eOUSPRCQBZ+NPmHw6r6eYXT2lMAOIhFOfvTAAEAeTmSiNghAAcetg8HHTQXKXnxcJpR6CpqQV/u/1+kGW73pLIBIAiJpKbH/n6O7UwARDUHBMAQQC5udII6CUAFOzn3PNPh9ebGEngwp0tcKWkweVLU1pPZgu3bNk7WLbkbd3DJCoB6O0lS/9uYS8J3YBKbsAEQBBQJgCCAHJzpRHQSwBOPPlHmDFjqtJz0i5cBMENHyPS1wtXSircGXlwZxXAnZp8TxsU1ObOvz2Ahvom7fABSEQC4DRL/5EUxgRA13LesTITAEEAubnSCOghALNmTcdPT/yh0vPRI1y4qxW9NTtmx0tWMlC1sQZ/v+8RXafeRCMAdOVPp/9EKUwABDXJBEAQQG5uOgKeviAyAo1IDWyBL9gOX18n6P+5IyG44rxfXnnjY5rk8/v9OO+C05GdnaWpvpZKra1tWLVqDdasXgfKVNfW1h5tlp2TjbzcbEzfaSpmzJyKnBxzTuShhvXo21o3oqh2kgE78Hn15dfx1lsfaFFftM61F58wYt0IXAi7vQh7UhD0ZCCQko0efx66UgsQ8qgTPZKMIWnzN2IHoRksGyoyARAEnQmAIIDc3BQEPOFeZHdWI7tzE9ICLYbH0EoAvn/MYZgzZ3fD4wxuSBv960vfwfJPvkA4DkGheAOzZk/HYYfPR15ejpTx+zv59vpfa6dWkQE78SHDt3vuehB1dY2aYIlHAEbqpMefi7aMCdiaXoI+j1/TeGZUIkt/Cuvb1+dcY7/hcGECILhimAAIAsjNpSLg7etBXts65LVXRk/4okULARg/fizOOPMUKRH/ysvX4Mn/voBgMKhLdL/fhx/9+Ghp9gfhrq3orflKlwyDK7t86fAWlMKdkW+4j1gNVcCH7ADuuvNBTadhEQIwMP+wy4PWzDK0ZE9FyGvtrQD59pObH90AJGJhAiCoVSYAggBycykIuBBBXvsGFLSuhjss740yHgHwej349W9OQ2FRgfA83nvvYyx+canhH1u6DTjyqEMwd989hWXRcv0fb5CUkllwp8tLgawSPm+9+QFefeX1eBDEfQKI28GgCkQEWnKmojl7GiIut56mhur2W/rT5m+ouSMaMQEQVBMTAEEAubkwAim9XRjb9DHSgluE+xraQTwCcNgR83HAAXOEx6WT7eOPPm148x8QgEjACScdJ3gToP/6fygALk8KfJP2AuASxoY6UAsfRPX0wD8eQ0VF1Yjzk3EDMHSAHl8ONhfshWBKphRsY3VCN1Dk5pfohQmAoIaZAAgCyM2FEMjsro9u/u6w+HV/LEFGIgATJpTgl786CW7B09jWre3RmPN6r/2HA46eA8678AxkZxkzSBzO+l+Pojw5xfAWTtbTZNi6quEzIGhLSyvuvON+BALDP9eYQQBofDIcrB21B9rTx0jBeHAntPHLWovShZPcIRMAQUCZAAgCyM0NI5DTWY3ipuWg63+zynAEgML9/uacX6CgQPyN+5mnXsTy5V9IncKee+2KY39whKE+Vbv+Vw2fwaB++UU5/vPv54bF2SwCEB3QBdTn74otmWWG9Dy0Ub+lfzdCIXlPaFIEM7ETJgCC4DIBEASQmxtCIKejCmOaPzXUVk+j4QjAUd87VMpbO7my3fzXu+Na++uRmerSrcRFl/waOTl6bwHUuv5XD58dNfHsM4vxycefxVSRqQRg24gN+bugJWuS3iWyXf1wmDZ/svR3Zkx/o5NnAmAUuW3tnE4AyK+1u7sHwWAAFOGK/ps+5PpCH3pTpY/H44bb7YXfn4KUFB98Pj/S0tJARmBcrEUgs7sOJQ0fmnryH5hRLAIwbdoknHzqj6VY/b//3id48X+vmQLg944+DPvso881UbXrf9XwiaUo+r249+5/ora2foc/W0EA6CagpmCO4ecASuTT0dEpbH9iyiI2uVMmAIIAO5EA9PT0oL29HZ2dncJvXfTempGRiaysTPj91rroCKrOkc1TQl0oq30DnrA+Nzmjkx1KADIzM6JX/1lZGUa73K7dPx/6D9as2SClr6GdTJ8+OUpU9BTVrv9Vw2c4LJubW3DX3x6KHiIGF0sIANkEuLyoHDNPt2EgWfpTgJ9kLUwABDXvFAJAQSza2raitbXVtFCWFA0uOzsbOTk5cLvNd9MRVJ3jmtNb/4Tat0yx9h8OjMEEgG6CTv35TzBlykRp2N1y0z1obpbvvUACFowehfMvOEOHrGpd/5PgauEzMpSx7AGsIgAkGXkHbBwzDxRdUEtJFkv/kbBgAqBlpYxQR3UCQNf4LS0t0Y2f/t2K4vF4kJubi7y8PCYCEgHPb1uHwi3Gg9MYEWUwASgsLIhm+pNZ/nT1TcK3UMPJ4/P58PurL9IsrmrX/yS4SvhoAfKhB/+DdWu/vdGxkgCQfI15s9GcPWVEUcmvn25B6dkz2QsTAMEVoCoBIIvWtrY2kHxWbfxDoSQiMHr06OitABcxBCjC36TNS0xz99NyA5Ca6sdlV5wH0qusYuYGRzdSV/3hQs2iqnb9bzYB0IuPFiCfe/ZlfPzRim+qWk0A6ClgQ8kChDyx0zfT7yK5+SVSQh8tehmuDhMAEfSIcTZqi4ktOIyu5rS46+pqo8Z9KpS0tHQUFxeDXMe4GENg9JavMKptnbHGAq2G2gCc+vPjMXWqvCeAW2++F01NxnMVjDS10aNH4TzNTwDqXf/T3NTBR9siuvmmu9HS3GobAaCBW7KnoCFv9g4C98f070o6S/+RNMcEQNu6HraWagSATv0NDQ22nfqHA4psAogEZGaaF71LUJXKNqfEPpNrXrH89E+ADCUAe8/ZDUcfc7g0rFQxclPx+p9AVgUfLQpvbGyOBnQaXKy+AaCxKWTw+nGHoc/t+0YUsoEiNz+7bkO14GdHHSYAgqirQgDoXaupqRFbtphjUCUI0zfN8/PzUVAgHjdeljxO6CevvQJFLZ/bImosL4BLLztHigsgTeiD95fjfy+8asrc9GQoVPH6XyV8tCjo3Xcpl8MS2wkACVCfvwu2bIsNQG6KdPJP1IQ+WnQzXB0mACLoKfIEQAu7trYWHR0dgrOxpjnZBNBtABdtCJTWvSWU0lfbKLFrxYoDQJn/KAywjLJ1axtuusGEQEBuNy6+5NfIztYSCEjN63/CVw18tGn6oQf+jXXrKpQgAN2+PGwcc1DUwDQZYvpr09COtZgAGEVuWzu7bwAikTBqamqj11tOKhQ7oKRkrJNEtkVWbziAKZsW2zICr5EAAAAgAElEQVQ2DRqLABxwwD447IiDpck0UiQ5o4PsvfduOPpYbU8Vql7/D8zdbny06CAY7MWia29BKLR9JD07ngAG5F1ZuAAdQWs8n7RgpGIdJgCCWrGTANDJn4z92tudcfIfCnVWVjbGjOGbgJGWYHZnTTTZj10lFgEYNSoPF1x0pjSR2tr6kwGNlFRGz2Bk3X7+hWdEg1NpKape/w/Ibjc+WjBctWotHn3kyR2q2kkA1qXPQrOvUIv4SVuHCYCg6u0kAGTsR/79Ti5sEzCy9sjvn/z/7SrD5QI457xfoqhotDSx1ny9Hv/655PCOQEoWNGJJ/0IO80Y2Rf8W8HVvf4fDK59+GhT8fPPvYyPPvzW/W+glZ0EoM4/HhvTtK4DbfNMtFpMAAQ1ahcBoFMBnf4ToYwdO5a9A4ZR5Lj695HZs2OMdav0PhwBWHDIgTh4/n5SxXj//U/w0v+WGDbWos2fkhTtM3cPzXKpfv0/eCJ24KMVyJtvvBuUHnhosZMAtKbk4+uM72idQlLWYwIgqHY7CAAZtmzcuNHwD6XglKU3JxfB0tJSpKSkSO/b6R1OqnkNvpB99h3DEYCxY4vw67NPkw7v6lXr8MR/n9P9HEDX/gt/cjR22knfiU/16/+hAFuNjxYFNzQ04fZb/x6zqp0EoMedhs+z99EyhaStwwRAUPVWEwB696+urk44y9b09DSMGzdeUBuJ13zqppcsS/wTC73hCADVvei3ZyEvL1c66J2dXXjj9Xfx4QefxvXbplP/rrvOwncPP1jzm/+3Ajvj+n8owNbho02177z9IV5evEw5AhBypWB5zv7aJpGktZgACCreagJAb/709p+Ipbh4jEa3rUScfew5Ta96Hq6IfZbMIxGAI446BPvtt5dpyqBnrlXla0Dv33S9TP9NhVz78vPzMG2nyZgxY6rhNeOk6/9YIJuNj1bFPnj/41i/vlI5AhBxufFRzkFap5GU9ZgACKrdSgJA0awqKytMCWVJ1/Dp6enIyMiAz+ePhu2lmO9040AfenagD6UQ7o+oFRFEbsfmHo8XEyeWcQKhQdCoTADKysbjl2ecJH0dWNWh067/rcJFzzjDuf8N9GHnE0AYLnycO0/PdJKuLhMAQZVbSQCampqimf1kFnp3p6x9lMKXrlO1FAqnSaePlpZmUJQtmYWiBJJnAJd+BFR+AqD1csnvzkFWVoYD1eXM63/VgF61ag0efeSpYcWykwCE3ClYns1PACOtGSYAgt8oqwgAbboVFRtAtwAyisvljl6j0mardeMfOi7dDFDo4ebmZmkGiXTrMGnSJMMyycBGpT4m1SyBL2RfnIeRngAIp2N/cAT23GtXlSDTJIvTr/81TdKCSs8/+zI+GpT9b+iQdhKAHnc6Ps+eYwEKzh2CCYCg7qwiALTRyhrL601BSUkJ/P5vk2WIwBAI9GDz5lppKTYphTDdSnABxjW8j8xu9dwAB3QzffpknHzqjx2nKr7+l6OyG2+4C62tW5W8AWA3wPg6ZgIQH6MRa8jalOOJUVlZGX2DFy3kLkWbv9crNzUvPQWQd4IsGcktkAugaiCgAd14vR5cdsV5oHXlnMLX/zJ01VDfhNtvi+3+N9C/nTcAtf7xqOJAQCOqmgmA4DfBCgLQ09ODqqoqQUkBOvlPmDBe+uY/IFhfX19Uzt7eXmFZiQA4a1MRnnLMDrK7ajC2Ua1QwEMF/cnxx2DnXWaaA4AJvfL1vxxQ3377A7yy+PURO7OTAKzLmI3mFHnRKuWgplYvTAAE9WEFAaAxRNP80pv/hAkTpF37DwcbkZVNm6pBSYpECtknFBTwl9cTDmJq9WKA8j3bUOLZAJBItPkTCXBK4et/OZp64B+PYcOGjcoSgE9z9kOvS84zpxzE1OuFCYCgTqwgADKu/0eNGgX6WFHIU4E8FkSK35+K0tIJIl0kTFvV0gEPBdbn8+HyK88z7WZJriL5+l8GnvTUt+jaW3fI/je0b7tuADq82ViZqT0ktAxMnNgHEwBBrZlNAOhtfcOGDUJSkqtfWVmZZZb1dPqvrNwo9BRAngnkDUBeAcle8joqUdT8mS0waLkBIMHIEJAMAlUvfP0vR0PlK7/GY48+HbczuwhAZdo01PtL4sqX7BWYAAiuALMJQEdHBzZv3iwkZWFhIXJz5YdsHUkosgxuaBCzXuckQf0Ie8K9mFzzCtxhuTEXtCwqrQSAXAHJJVD1wtf/cjT03DOL8fHH8UmpHQQg7HJjRfa+oFDAXEZGgAmA4AoxmwCIBv+hCH+TJ0+27PQ/ACfFK9iwYb1QfAAOCvTt4hy9ZSVGta0VXK36m2slAOkZ6fjd5efA7XLrH8SyFnz9LwvqG2+4E62tbXG7s4MA1KZOQFWq+rdRccGzoAITAEGQzSYA5F/f0dEfA91IyczMBJ2k7SiismdlZWHMmDF2iK7cmN5wABQUyB0W97DQMzmtBID6pLDAFB5Y1cLX/3I0U1/fgDtuu19TZ1YTgD6XB59nzUGv20luqZqgNKUSEwBBWM0mAFVVG9HTEzAsZVFRUTTMrx1FNHFRampq1HOBSz8C+e3rUdjypaVw6CEAlBiIEgSpWvj6X45m3nrrA7z68sjufwMjWU0AyO+f/P+5aEOACYA2nIatZTYBIANAkXj748dPQFpaquAsjTXv6elGVdUmY42BaEKiiRMnGW6fcA0jQGn9W0gLyM0HMRJOeghAXl4OLrz4LMufm7Tpma//teEUv9b9f38UFRXa4pJYSQA6PVlYmbUHItCW0yT+TBO/BhMAQR2bTQDWrl0r9I5OlvSyo/5phUzUg4E8AMh+gcu3CKT0daNs8+ug+ABWFD0EgOT5zTmnYcyYIitE0zUGX//rgmvYyoFAIOr+pzUniVUEoA8erMzeE93udDkTTZJemAAIKlp1AjB16lTbTmSULIgIjNFCroAkP5ftEcjsqUdJ/QdwwfzgQHoJwPz5+2P+IQcopzK+/pejkpUr1+DxR4fP/jd0FCsIAH0L1mbsgi0p1sQ5kYOkGr0wARDUg9kEYM2aNUISMgEQgk/ZxjmdmzCmabnp8uklAEVFo3HOeb80XS59A4hf/+sbT3tt/9T9tFdWoOazzyzGJxrc/wZEtYIAVKTvhAYfGwsbWR5MAIygNqiN2QRA9AmArtDtCqZDuQHWr19vGGGPh1wYpxhun+gNiQQUN31q6k2AXgJAmJ9/4a9QUJCvDPwyrv/NmozTCMBf/3Intm6N7/5nBQGgk//G9Gmo93HAH6PrkwmAUeS2tTObAIgbAY5HWlqa4CyNNe/uprwA2oyFYo1Atgtkw8BleAQoVfCYpk+iwYLMKEYIwGFHHIwDDtjHDHEM9Snj+t/QwBoaOYkA1NY24M47tLn/mU0A+lxerE+fydf+GtbYSFWYAAgCaDYBcLIb4NatW1FfbzwaYGpqWjR7IZeREUgJdWFs0yemeAcYIQDjxo/FmWedqoja1L3+J4CcRADeevMDvPqKNvc/MwkAWfuvy5iFHrc9BxtFFrYUMZgACMJoNgEQDabj5EBAmZlZGDuW3/Y0LdFIBDmd1Sjc8qVUDwEjBIDkPfHk4zBjxjRNoptZSeXrf6cRgH/8/VFUanT/M4MAUIjfzf4J2OwvRUTpiJNmrmi5fTMBEMTTbALQ3NwM+hgtlAZ48uRJoJDAVhbyAKD3/3DYeFpgKzMYWomNmWN5+oLIb1+HvPYKKVEDjRKAUaPycfa5v4jGcrCzhBo3oK+11k4RRhzbKTcAlOb7+utu0+z+J5MAkItfg39sNMAPR/iTu5SZAAjiaTYBkJMMqAi5udZGAxS9/ie1lJSMRUZGpqCGkrM5JQ7K7qxGducmpAdbgIgxl0GjBIBQ33vObjj6mMNtVUBv1WcIBzptlWGkwZ1CABa/tBTvvvORbhxFvADaPdlo9hWj2VfIiX10I6+tARMAbTgNW8tsAtDXF8L69WLpgMmYbuLEiZbFA6DTf2VlpVA6YALcTg8GwWWhVHMKGpTe04TUQAv8vR3whTqiRoOUV8AVGfmG5qqbHhcKRHXcwu9jt91m24ZHYP0HQLjPtvHjDewEAkBR/x74x2O61wHF8bjmop+OCEEYLoRdXvS6UhDwpKLbnYFObw7avLnR/8fFXASYAAjiazYBIPEqKysQDIpZeVuZWa+lpQWUxVCk+P0+lJaWiXTBbSUg8PgFJ6AvZDwNMblynnTKjzF16kQJ0ujvouqTJajavAXVjW1o3NKF7kAvegK9CIaMP03plyJ+C58vJeqtk56ehqLi0Rg3vgSlpSW2R1WktN533/kQOju74k9iSA2Px4sj/3i37nbcwDoEmAAIYm0FAaAxtmzZIiQpsXGyqPf7zc0L0N3djerqat2nhaGTy8vLw+jRo4XmrHJjCqVKYVVpg/T71c1c9t/fnoJgT48QlHQDtfAnx2DWLGuMAtvbO7Hi0y/x6adfoKnRuP2M0KQlNR49ehR222MX7LbbzsjKypDUq7ZuCMcH738MDQ3GyHyK34/Dr/qbtsG4li0IMAEQhN0KAiDqTz8wxZSUFIwfP9603AC9vb2oqqoCBQASLRMmlCI1Vd2NUc/8yBCSNnv6kDEVfQgreirJzs5GcXGxnu4srfvk705DT2eH8JhulxvzDz0ABx0017SnqGAwiLff/ADvvPOR8POT8IQld0DGlPsfMAcHHDgXdFtgdmltbcPDD/4bjQIEyp+Rie9edovZonL/AggwARAAj5paQQBoHBnPANSPz+eLkgDZ0QFpQ6up2Yxg0Hjq4gFVkIxlZc68/qcESJS+ORDoQSAQjOJBG9NwhU7/paWlgqvQvOZPXXEGuttapQ0waXIpjjn2cJCXgKxCROqzz77Cay+/ibb2dlndKtlPdlYWjvzeIZi9806myUdv/v9+7BlD1/6DhUrLysUhl/7VNDm5Y3EEmAAIYmgVAaAnAFlj0U3AmDFjpZ2w6dp/8+bNUk7+pI7CwtHIzc0T1Iz5zbff7HtANzV6bz/oaWbKlMkgd00Vy7NXn42O5gapohH5nLvvnthv/72RlSXm5bF+XSWWLnkLVVU1UmVUvbNZs6ZHiUBOTrY0UcnOaMlrb+GD9z5BOI5xqJZB0/MKsOCi67VU5To2IcAEQBB4WZtyPDHoGrmiYoNuP9zh+qUNh05heXm5hjcfOnkRMaE4BfTvMgq9iU+caH3cgniy00meTvZ0mqd/N7LZDzeGys8dz19zPtoaNseDx9DfiQjsvMsM7LzLTEyeXAav16Opn61b27Hyq1VY8elXqK01HmlS02AKV6KngP322xv77LsnMjKMp8ENhfqiCX7efOM9tLeLP/cMQJZZUIyDz79GYQRZNCYAgmvAKgJAYpJlPVnYyyx0G5CXl4+srKyoQZqWQmSkvb09Kgtd/cssdgf/ISLT2xuMbvb0Vj/wbi+L4MTCqqioCDk51sZp0Kqz/y26GK21xvM5aB2HvD5KSsZg3LgxyMnNRnZOFnwpvmjzjs5OtLW1o6mhOXrSb2pqkUY4tcqncj36Ds+aPT1KpvqJVPzgS3TCr95Ui6++XI3PVnyJrq5u6VPMLh6Hg87+g/R+uUN5CDABEMTSSgLQfwtQofuaWcsU6Sqagu6QGxIZ33m9Kd/YCdC4/ZtiEF1dXejs7DDlB5hOgGVlEy2LWjjYOI9O9fRmT5u+mZt9LF3k5uaisLBQi5osr7P4r79Dc5VYHArLhU7iAek7RERqzJhC5OblIj09PWo0SE9TXd3d2Nrahvq6BlRX14Ge7swsueMm4oAzLzdzCO5bEAEmAIIAWkkASFTyy21oSMxrT7KGJ6t4Mwtt9JTOtLOzc0TjPDNlGNq3ykmPlt11LTav+sJKOHisBEGgcNpszDnlvASZTWJOgwmAoF6tJgD01F5dvcl09i4Ii+7mFASFvBPMKnSqJ11t3dpqNCquWaJF3eKmTJkKl8u0IQx3/O7Dt6Pik3cMt+eGyYvA+N3mYtfjTkteABwwcyYAgkqymgCQuL29IWzcWCmUaEdw2lKbU6Ki0tIJSNn25iu1c1AY/Aiqq2vQ3a0/mplsWYbrr6ysFD6fenEPPn7iQXz91mKrYOBxEgiBifseitlH/jiBZpR4U2ECIKhTOwgAidze3oba2jpB6dVoPmbMmKgRolmloaERra1ikRTNkm2g3+LiMcjONg8Do/J/8dIT+GLxE0abc7skRmD6Icdg2rzvJTEC6k+dCYCgjuwiACS2jBDBgtMXbp6fnw/KU2BWIbc9ui2R5KVolphQNfTx12+9go+fuN+0eXPHiYvALkefhNK9D0rcCSbAzJgACCrRTgJAm1ptbS06OpwZ/YyCwNDJl97AzSoNDQ1obZUXyc4sOcn7Ytw482wgjMpdufxdvPPQbUabc7skRmDP43+FMbP3TGIE1J86EwBBHdlJAEh0et+mKHxk1e6kQi6HY8eau/kTHpWVG6WEJzYbW7KDmDJlitnD6O6/7usvsORv1+puxw0YgbmnXYyCSdMZCIURYAIgqBy7CcAACSB7AKfcBNB7P7n8mXnyH1DrunXrHGMsOXHiRFBQF5XKlpqNePHPv1VJJJbFIQjMO+cPyCoa5xBpk1NMJgCCeleBAPSTAIoUKJ42WBCOuM3pzZ+i/Vmx+ZMwa9eutTywT1wQhqlANyKZmWoZAga7OvHfS39udErcLokROPzK25CSajxEsRXQUTAwyoHQ1xeKRjWl/w6H+xAOR6K/GwO/U263Cy6XJxqumiItejzeaIAlurlzcmECIKg9VQjAwDTa2tpA7960kFUq9EWhkLdmWvvHmi8ZAFKEP1ULuT6mpvrg96dGE+OY5QopMv//XPIz9CrsQikyN1XaFowehQWHHIB33/kI1ZvMyb1g5VxT0jJw+BW3Wjmk5rHIjbqnpzv6NEh5EEQKkQHK6DkQPVWkLzvaMgEQRF01AkDTIUZbX29+qE+t0JGBW1FRsS3X24QDRf5ToVCa49TU1GhKZvL5T0tLlZ6W2Yx5vvjnS7ClptKMrpO+T0rIdeC8fbDbbjtHT5ObNm3Gfff80zG3VsMpMLekFAecdaUy+qUDEYX5plDmejN2ap0EkQEKaEYfq244tco2XD0mAIIIqkgAaEp0fUW3Ac3NTcIs1yhElO2NXPzsTHRDGNTV2Rcvga4Jyd6BTgmqpvyNp983/34jNn3xUbxq/HeNCNDmMGlyKfbaazfMnD0N7iGpoJ9+6n/4dPmXGntTs9rY2Xtgj+PPtF04+h0kA2na+K3K8UFEjnIw0Ed1IsAEQHCJqkoABqZFzJdS9tLHqmcB+gKQXzt97H4jC4V6sWFDhaCWxZpnZGSAgh3ZjYXRWSx/+mGsev1Fo8253TYECosKMHv2DHxn11kYNSpvWFw6Ojpx6833RU+sTi2T9z8MMw//kW3i02ZP+FHWUqs2/qGTpe87PetRrg9VCxMAQc2oTgAGE4GtW7eCPhQcx4xCV9t02qePSptdRcWGaPhkOwtZ95eUlESv/51Wvn5zMT5+8kGniW27vKTrSZMmYPLUiZg2bfKIm/5QYd9++wO8svh12+dgVICdv38CyuYcbLS5UDu64qffOdmpyo0KRXY99JuoNd260XGMtGMCYAS1QW2cQgAGT5OYcUdHR/QjSgYojzudcMm4jwzZVCyq2AHQk8jYsWOjb4ROKtVffoI37rvBSSJbLitd9RYU5KNk3BiMLSnGuJKx0X83+qNPm9gdt/0DTU0tls9FxoCUBZCyAVpdyLivrc2+U/9w86X1kZOTrdxvJBMAwRXqRAIweMr0Q0N5wQOBQNQqtre3D6FQaJsrTL8nAZ3m3W5P1GCN3rT7jdnI8pWM2LyCCJrf3G47gMEzpB8CcvejQEhOKVtrN+GFRRc5RVypcpKhJhUiurTuMzLSkZmViYyMNGTnZKNgVB5GFZBra17UPUxm+frr9Xjk4f/K7NKyvuaffw0yCootG48Gout+eutXudBhKTNTne8+EwDB1eJ0AiA4fUc0V8EOYCgJIJsAlX4IRlJkJBzGvy86GX2hXkfoe7CQ1y66zHEyDxaYCAARAScVT4oPR/z+DkuNXincNx1inFDIJoBuA1QoTAAEtcAEQBBAi5qrYAcwlAQ46SbAqa6ATicAzc1bcMdtf7fNk8fI19NaF8AItmwhuyZnbP4DeJJXUG5urhF4pbZhAiAIJxMAQQAtaq6KHcBQElBSMhbp6RkWoWB8mPceuRMbPnrTeAc2tXQ6ASDYyBiQjAKdUibssR++84OfmS5uv6vzVvT0OGvzHwCGnlDtdJEmOZgACC5TJgCCAFrUnIIBEQlQrZB9xfjx45QzDhqKU/nSF/Dps4+oBl9ceRKBAFAky1tvvhft7R1x56tChVlH/gST9j3EdFGc8OYfDwS7bQKYAMTTUJy/MwEQBNCi5uQSVFFhbzyA4aZKxmOlpROUNqjcvOoLLLvLeVkBE4EA0LqhwEAUIMgJZe5pF6Jg0gxTRSVPJnL1S4SSm5tj2wGACYDgCmICIAighc2JAKjiGzx02mRtPm7ceGUjh3W3teKpK86wUFtyhkoUAkDX3RQimEIFq14Ou+xm+DLMS2pFiXuam5ujCdASoZBnECVIIy8rqwsTAEHEmQAIAmhhc1E7ADqpU7wDiqpoRqH3QEqYpGp54rJfItChRl4FrRglCgGg+W7aVIN77/6n1qnbUi81KweHXnqjaWMTEdqypRW9veYEMzNN8Dgdk3t1Xl6+5cMzARCEnAmAIIAWNpdhBzBx4sToLQLlF6B4CbJLcfEYZGebd3oSkZeeAOgpwEklUQjA+nWVePWVN1BTU6s0/KOnzMI+PzvfNBnJz5/e/hOxZGfnRBOEWVmYAAiizQRAEEALm8uwA6DEPtnZ2VG3rLq6WumBR8gosLS01JbMifFU8cXiJ/HFS84KTON0AkBX/q+9+gY2rN8YTz1K/H36Icdg2rzvmSIL5TKh5GbhsPy7f7qGpwydFPCJbvroOn4gkQ/dOtD3nZ4eyCCTXA7NyC9AwdYKCkZZ+gzIBEBwqTIBEATQ4uai8QAogAelNqZCPwINDQ3SjZEoVPC4ceMs/SHQooa6NV9iyR3XaKmqTB0nEgBaVxT85/33Po5u/GZsNmYpaO5pF6Ng0nRTuqfQ5ZTZT2ahjZ6y9ulJ4Uv66O6m1MId6Ovrj5Yqq1BwMPIMsKowARBEmgmAIIAWNxe1A0hJ8WLixEnbSU1RyGgdyPyhLioqRE6O/YFCBk80FAzgP789FRQZ0CnFSQSAQnKTtf8H7y+PvnM7rbjcbhxx5e3w+PzSRafvVlMTnf5lrT1XNKwzbbYiKXvpSYKIiazvvttNOSVGC8mkB3wmAHrQilGXCYAggBY3l5EXgOwAKLvf4EL9ErmQZZlMTwETJ5Yp5xr40g2/Q8umDRZrzfhwqhMAsiNZt64Sn634EqvK14Jyczi15JaU4YCzrjBFfJlv/3TVnpeXKy13A4Uab23dKk13lELYquBgTAAElysTAEEALW4u0w5gqOj9JKBe2mmAjAHJKFCl8vETD+LrtxarJNKIsqhIADo7u7BubQXWfL0eq1evjb4rJ0Kh4D8UBMiMQm5/MoxuvV6yts+Vnq6cngJaW1ukhGwmGUeNssYjgAmA4GplAiAIoA3NZdoBDBWfgpMQCZBVJkyYEM26qErZ+Ol7ePvBW1URJ64cKhAAClpTU12HiooqrF2zAZs3002RfEO2uGCYXGHPn56FMbN2lz5Kb28ILS3Nwv3SyZ82VrpdM6PQ80RLS4uUmwCKCyA7u2SsOTMBEFwJTAAEAbShuRl2AIOnQW+V9EMgo6SlpUdDBatSulpb8PRVZ6oiTlw5rCYAbe3taG7agvq6RtRUb0Z1dS2amloScsMfCj75/1McANlFjvEfBdvJN31TpRvGlhaKEyJG8KJppzPNdwdmAiC4WpkACAJoQ3Oz7AAGT2Xz5lp0dMjxV6aEQRkZ6uQQf+5P56G9UW1/9AFdiBIAsvamEgwGoxbflHK2va0DnV1d6OwgA7BOtG1tj27yzc0tCXOdr/drmVFQjPnnm+MhQq5/5IYnUqyMuS/DXsGqZwAmACKrCohaf3NxFgJktLNhg1hegIF4AMPNnK54N27cGN04RAs9AdBTgCrFaXYAquCWyHJM3PdQzD7yx9KnGA73obGxSahfcvWjK3URa399ApDHQrPQUwDJWlBQYNpzxcB8mADo0+wOtZkACAJoU3PRvAAUtau4eOSwvWTctWnTRimBSyhPQHp6mk1obT/s5vIVWHb39UrIwkKogcCcUy9A4dSZ0oUJBHqiFvYihcJ3k6+/laWrqxvt7WJhs61IEsQEQHBVMAEQBNCm5mbbAQxMi/IGyFgjmZkZGDu2xCa0th82FAziid+dhr4Ei8euBLgOFMKT4sNhl98C+qfsIvr+Tyfp0aOt86sfmD8ZBJItkIixpxVBgZgACK5YGT/ugiJwcwMIWGEHQGKRsXdVVRXoJCNaysrK4PPJ/5E1IteyuxZh86rPjDTlNgmGQNH0XbD3yeeYMis6/Yt8d/z+VNBJ2o5CHkHkAWK00NMfJQgzszABEESXCYAggDY1t8IOYGBqPT2B6FOAqOdXXl5e9DSjQvn6zcX4+MkHVRCFZbAZgdnfOwET9znYFCnI/Y/cAI0WyttBYX7tKKLGgBRsLD/f3HgATAAEVwYTAEEAbWxuhR3AwPQoeyDdOogUMmaaNGmShcZMw0vb3tSA5/54tsh0uG2CILDgwkVIzzeHmNI1ukh0RNpAh0bttAr2fpdA4+7AHo87GhbYzMIEQBBdJgCCANrY3IgdAP2Y0ImC/PMzMtJA7jpaCt04VFRUCr0J0jhkB0D2ACoUJ7kDqoBXIsqQWVCEg8+/1rSpNTRQZE3j3dMGShupHYXcRpuajHuJUV6A0aMLTRWdCYAgvEwABAG0sbkWO4DBGz5Z4YucJoZgAz0AACAASURBVChzICUOEikUHGTsWDXCA694/lGsfO05kelwW4cjMPWgI7HToT8wbRb0nRExpCsqGtlTxzTBB2ULFRnDbPmZAIhoh+MACKJnb/NYdgAUfjM1NS3qNpSenhrNES6ryLA7IKvmKVMmw+Wy51QzGIuW6gq89JdLZcHD/TgQgYPO/gOyi82LVCkaVruwsNDWJzMR+em7TvKbWZgACKLLNwCCANrcfNOmalCKX7rSFz3ha5lKbe1mtLd3aKk6bJ2SkhJLc4aPJOzz116AtvoaoflwY2cikFlQjINNiv43gIjoDQAZzZoV+z+e1sgVUGR/ILnNNvplAhBPi3H+LqJgwaGHbd7WtjUaR9quhT9UMPoiUFhcCp6T7KW7uwtEOkRKbm6u6ScDrfJ9/uJ/8OXLT2mtzvUSCIHp84/GtPnfN3VG9IZOb+lGS15ePnw+bXY6RscYrp24EaAnGg3QzMIEQBBd1QgApc2kT1paKkpKxtlOAuj9rqamGhQZiyxyzV7Qguq0pLloNkK6sZg4cZIlssYbZGv9Zrxw7fnxqvHfExCBeef+CVmF5tqjONkNsLu7W8jzh90ANXxpGhvrBWxENQzgoBuAgc1/QGS7ScDgzX9AJiYBiEYIE3EPIizJHdCKdKFaviH/W3QxWmurtFTlOgmCQM6YcTjwN38wfTaiwXScHAjICtn5BkBwCatyAzB087ebBMTa/JkE9CNAOQI2bqwUWnljxowBxThXoXz5ylP4/H//UUEUlsEiBGZ894eYcuARpo8mGgoYIEM660MB0+8f7Q0iHgwcCljD8uIbAESv/OkzXLH6JmCkzZ9JQD8ClI2QvAKMFpWiArY31uH5a84T+rEzigO3sx4Bsk6fT8F/8sx9n+4nywFh19msrGzLE2mJXv/T3MnWx++X54UUa6XwDYDg98fuG4B4m7/VNwFaNn8mAYCRIESDl6pqKYJfu+NPqF/zleC3iZs7AYHRU2Zin59dYImoctIBmx9RbygYohEMqT8rPBiYAAguYzsJgNbN3yoSoGfzT3YS0N7ejtraWsOrj05hU6dONdxedsPK5e/inYduk90t96cgAnse/yuMmb2nZZLJ2EytTAnc2dkJeroQKWTfM2rUKJEuNLVlAqAJpuEr2UUA9G7+ZpMAI5t/MpOAUCiEDRs2CK2+iRMnCkUmFBp8SONwXwhPXXkmAh1i+Q5kysR9yUfAl5GJQy/5K9wer/zOh+lR3A4A0WBA+fl5mkN3G51cMNiL1tYtws9hGRkZIBsAswsTAEGE7SAARjd/s0iAyOafzCRg/foN6OsznumspGQsMjLM/5HQ+hVZ/uwjWLX0Ba3VuZ4DEZhywOGYcdhxlkou6k8/ICwl0yIvJLPio1DSIvLuobgnoiU/f1Q0QJnZhQmAIMJWEwDRzV82CZCx+ScrCaip2YzOTuNXhfRGSMaAqpS2BooJcIHw6UeV+bAc2yNAp+h5510DSgBkdZHxDEAye70eUHAg2SSANn/K80E3e6LFqut/kpMJgKC2rCQAsjZ/WSRA5uafjCRANB5ATk4OzE4Wovfr8drtV6N+bbneZlzfAQgUTN4Jc39+kS2SynhXH3wTkJOTK+2ETdf+W7e2Sjn5k4xW2iswARBczlYRAC2Z64xMhVLbUmx5vYyYrrlqampA7i6yS3FxMbKzs2V3q1x/ra1bQelOjRa6/qdnAJVK5Sfv4p2H2RhQJZ3IkmX3H5+Okl32ltWdrn7osEGEWcb1ev/ALmRlZW5zD3TpkmVwZSIm9BHx9x/cH/0OU7RUum2xojABEETZKgJgxmnb6E2AubIYIySCarSleVdXJ6qrjSfSoUhhpaUTbJF9uEHDfX147k/norPFeB50pSbEwkQRSMvJi/r+W2n8NxR6GcaAQ/sku4D09Aykpvo1H4Lo96+npye68dPVv8xiRfCfwfIyARDUnlUEgMQ0d+PVljvAXBmSZ/MnfZJxU0VFheEVSLHCyRNAtbL6jZfwyVMPqSYWyyOAwM7fOwFl+xws0IN40/5bgEaEw/Kjv9OJm4Lu0HeKPm63B263K3oSp1sH2uh7e0Po7Q0iEOhBRL4IUQJi5emfNMIEQHBdWkkA7CYBvPkLLpYhzemHZd26dYY7VS0WwMBEQsEAnv3Db9DDLoGGdatSQ39mNhZcdD08KT7bxaKkYu3tielqmpOTjdTUNEsxZgIgCLfVBMAuEsCbv+BCGab52rVrhd4PKRiQVe+FehD4+s2X8fGTD+hpwnUVRWCXY05C6V4HKSNdS8uW6Ek8kQqlLCbvBKsLEwBBxO0gAFaTAN78BRfJCM3Xr18v9I44efJk0DumaiUSDuPFP1/CWQJVU4xOeSjd70FnXw2X262zpXnV+/rCaG5uEiLO5kmnv2ci8KNG5cNjYXClASmZAOjX13Yt7CIAVpEAWpw1NdWgqzfZxagHgmw57OyvsrIC5EZktKiUFnjoHDav+hzL7rrO6NS4nc0I0Hd/n5+dj4LJM22WZMfhyQiPUgUnQiF3XsrtYUdhAiCIup0EgEQ30x2PNmgqZrj68ebfv/AqKiqFrjNVJgA0v/cfvQvrP3hD8FvGze1AoHTPA7DLsafYMbSmMSmfRldXl6a6qlayKuTvcPNnAiC4MuwmACS+mVf0gvDEbM6b/7ewVFZWIhg0/p6pUj6AWMoOdnfhf4suQlfr8OmqzVhj3KcYAqnZeTj43D/Ca7FRml6pKZYGWeU7sZDrYXZ2jq02PEwABFeOCgTASSSAN//tF9zGjRujOc+NlokTy5CigHX2SPJTmuCld14rMYiLUbS4nRYE6L1/7mkXYlTZdC3Vba1Dhx+KwhcIGCfRdkyAXA7p6t9uA14mAILaV4UAOIEE8Oa/42ITfQIoKyuDz2e/e1a8r9HK157DiucfjVeN/64AAjMPX4jJ+39XAUm0idBPAtoccxNA7/20+atQmAAIakElAqAyCeDNP/ZCo5TAIglEVLcBGJg1/Ui//cAtqPrsA8FvHDc3E4Exs/fEHj85w/aTqZE5OsEmgN786WP3yX8AXyYARlbaoDaqEQAVSQBv/sMvsvXr14HcmoyWKVOmaA5hanQMWe1CwWDUK6Bh/SpZXXI/EhHIL5uGuT87H25visRere2qp6cbbW3tyrkI0oZP7/307q9SYQIgqA0VCYBKJIA3/5EX2Jo1awyvQPpRIQKgymlCy0SCXZ149dY/cHwALWBZWCe7eBz2++Ulyhv9aYEkFOpDe/tWIfdaLeNorUNBfmjzVzFeBxMArVocpp6qBEAFEsCb/8iLi+KLUyAgo4VihxMBcFoJdLRhyd+uwZaajU4TPSHlzS4ej7mnXQBfelbCzG8gYQ8lEJKXQVAfPPT9pOQ+A+7U+lpbU5sJgCDOKhMAO0kAb/7xFxa5/5EboNHi9XpBNgBOLL3dXVh61yI0VRq/AXHivFWTObekFHNOPR++9EzVRJMiDxEBihUgM2VvPMHoRi49PV2pt/7hZGYCEE+bcf6uOgGwgwTw5q9tUVF0xerqTdoqx6hFrkSlpaWG29vdsLenG5/fcxlWr99styhJOf6MKeMw8YTfweNT613aDGUQEeju7ooGNaMnAjMKEXL67aOPU57lmAAIrgQnEAArSQBv/toXVFtbG+rq6rQ3GFIzIyMTJSVjDbdXoeH0ymew7P2v8Pp7X6ogTtLIMHf36Thy/u74KHd+0sx5YKKU1peCB9FHlAzQpu/3+6KhfL0ONJ5kAiC4/J1CAKwgAbz561tMzc3NoI/Rkpubg8LCIqPNlWi308Zno3KsXLMJz776Ibp7nBXQRQkQdQiRnubHsYfNwcwp46KtPsw9WEfrxKtK9gGUWZBIQV8ffcLRTyRCn0h0wnSad7ncUW8br9cD2vTpk5LihdutXiIuPVpiAqAHrRh1mQB8C0paWipKSsY5xi1NUPXCzen0T7cARktBQQHy861PIWpU3ljtBggA/a2towtPvvQ+NlTVyxyC+9qGwOQJxTjuyH2QnZn+DSbJTgCSfXEwARBcAU4hAFblC2ASoH1BbdpUhe5u43HMi4vHIDvb2ZbbgwkAIUfr9LNVFXj5jRXo7DIeIlm7FhK/ZlqqDwfP3Rlz95gGF1zbTZgJQOLrf6QZMgEQ1L8TCIBVm/8AlEwCtC0qcgEkV0CjZdy48UhP78/Y6NQylAAMzIOeApa9+wU+/mI9QgIYORUXGXJ7PR7sveuU6OZPJCBWYQIgA2nn9sEEQFB3qhMAqzd/JgHaFhSF/6UwwCLFKWGAR5rjcARgoE1rWyfe+GAlVqzcIBQxUQRnp7X1eNzYfeZEzNt3Z+RkfXvdzwTAaZo0X14mAIIYq0wA7Nr8mQTEX1SdnR2oqTHu/ubUIEBDkYlHAAbqt3f2REnAB5+uidoKcNkRgcyMVOw+axLm7DYt7sY/0JpvAJJ7JTEBENS/qgTA7s2fScDIC6ulpQVNTU2GVx95XIwfP95we1UaaiUAA/LSc8CaDZvx5eoqrF5fjV6TfLpVwSeeHCleD3aaPA47zyjF9Elj4XG74zXZ7u9MAHTBlXCVmQAIqlRFAqDK5s8kYPjFRdHJyAOAfJEpIuA2jyPNqzERXABpsnoJwGCAgsEQNmyqx/qNdVhfVYfG5jblksBoVqjGiuSSVjgqB5NLizBpQjEmTSiCL8WrsfWO1ZgAGIYuIRoyARBUo2oEQLXNn0lA/AU2ELc8EAigp6cn+unt7R1xMysqKlImp3j8GQ5fQ4QADO01EOxFbcMW1DW0onlLG1rbu6LPBeRNQH8LhcLoDYVExDW9bUrUx9wNvy8FGWl+ZGelIzcrHaPysjGmKA/Fo3Ojf5NVmADIQtKZ/TABENSbSgRA1c2fSYD+RUYBSogQDCYFdFMwUOj6X+UkI1pnLJMAaB2T632LABOA5F4NTAAE9a8KAVB982cSILjQAJDnQE8PkYIe5OXlJUTAJSYA4utCpAcmACLoOb8tEwBBHapAAJyy+TMJEFxsCdicCYC9SmUCYC/+do/OBEBQA3YTALoqrqmpiWa5kl0GrpjN6rukpCQhTrGycU+m/pgA2KttJgD24m/36EwABDVgJwEw8+Q/kNiHrI5raqpBqWtlF44YKBtR5/XHBMBenTEBsBd/u0dnAiCoAbsIgBWbPwWboWLuWJxASHAJOrr5TrWvAkEO7GOLEn3p+DB9ji1D86BqIMAEQFAPdhAAczfkNMS6mjd3TCYBgsvQsc13al8BdLcBPVuA/uyrXKxAIC0bSM3Dh5FJVozGYyiKABMAQcVYTQDM3Yhjb/4DEJk7NpMAwaXoyOZRAkCltxvoaAYixpMjORIAq4V2uYGMAsDXn0TqwzATAKtVoNJ4TAAEtWElATB3Ax5582cSILhQuHlMBL4hAPRX2vw7WoBefhIwZbmkpAOZeYDr28iBTABMQdoxnTIBEFSVVQRAhc2fSYDgYuHmOyCwHQEY+GuwE+hqAcJhRkwGAmTLk5YP+DN26I0JgAyAndsHEwBB3VlFAChufF1dnaC0OzYfsPYfMPjTOoCZ7ofFxcXIzs7WKgrXczACMQlAdD5hoLsD6GklK1QHz9BG0V0uIDUL8OcAwyQJYgJgo34UGJoJgKASrCIAJKZoBrmhUzW6+Zt5EzBq1CjQh0tyIDA8Adg2/0gI6GoDgu1sJKh5Sbj6T/tpuYDbM2IrJgCaQU3IikwABNVqJQGQSQJEN38zSABv/oKL0WHNKcDUbqHV2qSm54BABxBoA8JsKBgTNLcHEX8mXP7sYU/8Q9sxAdC2/BK1FhMAQc1aTQBkkABZm79MEsCbv+BCdFBzsmehwFKhUC/muDfol5ziBpChYLAbiCS5nQBZ9ZNFPxn4+dJ1Y8kEQDdkCdWACYCgOu0gACIkQPbmL4ME8OYvuAgd1Dwcps2/E319/ad4QwTgm0VHGZK6gWAP0BcAQpQtMdHtBVyA1wd4/UBKKuBNA1zGFwATAOPYJUJLJgCCWrSLABghAWZt/iIkgDd/wQXooObhcB86OjqjkSUHihABGDp36peIQF8v0BcCwiEgSjT6gHBkmzGh6jcGboCM99y0q3sAjwdwewGPF3DTxu/r/7ukwgRAEpAO7YYJgKDi7CQAekiA2Zu/ERLAm7/g4nNQc0pl3NXVhc11zfhs1Qas31iHrZ09+OMFJ6O3uxOpXXXYJbvHQTNyrqhr21PQnFIIT1oWrrn9MaT5UzBhbAF2nz0FkyYUOXdiLLluBJgA6IZs+wZ2EwAtJMCqzV8PCeDNX3DhOaR59eZGfLCiHF+vr45u+EPvq8866SjMmj4xOptgMIiWxkYmAybodmDTzy8qRmpqanSEr1ZtwD2PvbT9aJEIEwIT8Fe1SyYAgppRgQCMRAKs3vy1kADe/AUXncLNacP/6IuvsWb9JrS0UUS/ka+r5+4+HSf+4NAdZsRkQFzJsTb9wb0++vQSvL8ijhcGEwJxRSjcAxMAQeWoQgBikQC7Nv+RSABv/oILTrHmejf8oeJnpvvx58tOH3FWTAa0Kz3epj+4p8v+/A+0R29ldBQmBDrAUr8qEwBBHalEAAaTALs3/1gkgDd/wcWmQHPRDT/WFK6/9DRkZWpzYWMysCOCejb9gdbt7V247IYHxFcUEwJxDG3sgQmAIPiqEQCaTlvbVmRmZkFveF9BKIZtTmGDOzrakZ2dY9YQ3K9JCJix4Q8V9bSFh2L3XabrnkEykwEjm/5ggJd/vhoPPrlEN+ZxGzAhiAuRShWYAAhqQ0UCIDglbp7ECFix4Q+Fd/dZk3Ha8UcIoZ4MZEB00x8M8P3/fgkrVhoIwqRXS0wI9CJmaX0mAIJwMwEQBJCb24qAHRv+0An7U7y48aozpbm3JxIZkLnpD+BO4RIuue5edAd6rV97TAisx3yEEZkACKqDCYAggNzcUgRat7ZjbUU1yr+uQPmajYhQRDkFyjUXnYK8XPkZIJ1IBszY9AeruGXLVvz+5kcU0DqiMSDKxhVi2uTxmDZpPAry5a8BJSaqqBBMAAQVwwRAEEBubioCgzf8NRs2YXNd0zfjZeXkIjUtzdTxtXZ+wtHzsO9es7VWN1RPZTJg9qY/GLB3P/4Sjz//piEMZTcK9HSjrbX1m25zstIxccJYJgSygR6mPyYAgkAzARAEkJtLRWCkDX/wQGQgml9YCJdIIHmJks+cOg6/PuVYiT2O3JUKZMDKTX8wGnc+9AxWra+xDOsRB4oAzU0NCG/LDTG0LhMCc9XEBEAQXyYAggBycyEEtG74QwdJz8xERmaW0NgyG6d43Ljp92fa4rliJRmwa9Mf0BXlYbjgmnsQ6lUnpXJnRzu6Ojo0LScmBJpg0lyJCYBmqGJXZAIgCCA314WA0Q1/8CB06s8fPRpuSjSjULnq3BNQNDrfVonMIAN2b/qDAa1raMa1dzxuK8ZDByc34ebGhm3JmvSJxoRAH15DazMBEMMPTAAEAeTmIyIgY8MfOoA/LQ3ZObnKIf/Dw+Zi/v57KCOXCBlQadMfDOjSd5bjmVfeVwbjAUHIDoDsAUQLEwJ9CDIB0IfXDrWZAAgCyM23Q8CMDX8oxHmjCuBNSVEO+Unji3DhGQuVk4sE0kIGVN30BwN6071PoKK6XjmMQ7292NL8rYGqLAGZEIyMJBMAwZXGBEAQwCRv3tTSitXrqvD12o3Rf9J/m1lSUlKQO6rAzCEM9+12u3DL78+ER7GniaETCgQC2NrUiJxgI9DXG02tOzjLnmEATG7Y1xfGhdfchWHs7UwePX73W5qbEeoNxq8oUCM/NxtTysZiyqRx0X/SfydzYQIgqH0mAIIAJllzK074I0GqkutfLDkvPXMhxpeon5OejOk2fPA6wr0BTDngcLhcI2c9VGGZV1XX4YZ7n1RBlJgyDHUJtELQZL8hYAIguMqYAAgCmODN7d7wB8OrmutfLNUfdfAeOGL+XKVXBV1Xf/7U/ahb8U5UzsLZe2G348+CN8WntNwvLn0fi99Yrq6McVwCrRA82QgBEwDBVcUEQBDABGuu0oY/FFrVXP9iqb6kOB+X/eYEZVdFV3sbPrpvETobqreTMW1UEeb86kpk5OQpK/t1t/8LtY3mPjGJTl6PS6DoWFraJzohYAKgZRWMUIcJgCCADm+u8oY/GFpVXf+Gqp+u0m++6gyQrYJqpalqfXTzj/QGYormSfHiO6dcjDHTzI1oaASXUCiEC/50L+jpQuUi4hJoxbwSjRAwARBcNUwABAF0WHOnbPhDYVXV9S+W+s//xbGYUjZOmZUx8N6/+tkHNMk07agTlbMLWFdRjVsfeFaT/HZXkuUSaMU8nE4ImAAIrhImAIIAKt7cqRv+UFhVdf2Lpf6D990Zxx1xkBIrY+h7v1ahVLMLeOrFN/H6B19qFd/Wema5BFoxKacRAiYAgquCCYAggIo1T5QNfzCsKrv+xVJ/Xk4Grrn457avjOHe+7UKppJdwO9vehgtre1aRbe9nhUugVZMUnVCwARAcBUwARAE0ObmibjhD4VUdde/WEvgxitOR2qqfamK4733a122KtgFdPf04LfX/UOryErUs8Ml0IqJq0YImAAIap0JgCCAFjfv6g5g5er1+GLVeqxea37gHYunt8NwTnD9i4XRWScdhVnTJ1oOn973fq0C2mkX8NWqDbjnsZe0iqpGPQVcAq0AIhqYaOJYzJxahulTJiAt1VpXUiYAglpmAiAIoAXNadP/8NOV0c/aDdUgS+NkKU5w/Yuli7m7T8eJPzjUUjUZfe/XKqRddgGPPr0E769YrVVMZeqp5hJoNjBE1ieVjsHuO0/F7jtPQ6rffDLABEBQq0wABAE0sXlFVS2Wvv0xPl6xGsHeXhNHUrNrp7j+xUIvM92PP192umXAir73axXUDruAy/78D7R39mgVUZl6qrsEmgmULyUFu86ajAPn7oJxYwpNG4oJgCC0TAAEATSh+bqKGrz42jv4vHy98n7PJkz/my6d5PoXC4frLz0NWZnpZkIU7VvWe79WQa20C2hv78JlN2hzX9Qqv5X1nOQSaBYu0yaPx5Hz90HZePkhspkACGqNCYAggBKbNzZvxWNPv4rPvlojsVfnduUk179YKP984SHYY5edTFOAWe/9WgWe9v1TMGW/Q03NI7D889V48MklWkVSrp6TXQJlg7nLjMn4wRH7Iy83S1rXTAAEoWQCIAighOahvj68+Np7eGnpewgGQxJ6dH4XTnP9i4X47rMm47TjjzBFGRQZr6GhEStu+60p/WvtdLfz/oLCwiJ4vV6tTXTVu//fL2HFyg262qhWOVFcAmXgSk8Dhxy4O+bvvzu8ErJmMgEQ1AoTAEEABZvX1jfj3n8+h43VtYI9JVZzJ7r+DdWAP8WLG686E7IT7fX0BNDQUI++vj6U33OVrYqfeeY1IOOvoqJCpKamSZWFov5ect296A442/4lUV0CRZQ9fuxonPyjw1BYkCvSDZgACMEHMAEQBFCg+VsffI7HnnoFgaCzf+AEIIjZ1Kmuf7Emc81FpyBPYs72trZ2tLQ0f2MbogIBoHkTycnNzUNurtgP+mAMW7Zsxe9vfkT28rK+vyRxCdQLrN/nxXFHzcPeuxl/JmMCoBf1IfWdTgDoKrS7uwfBYACBQAD03/QhC1z6UHIW+ng8brjdXvj9KUhJ8cHn8yMtLQ1er0cQQf3Nw+EInnrxdby05H39jZOghVNd/2Kp5oSj52HfvcST69B7P238RAAGF1UIwIBMWVmZGDWqQIpdwLsff4nHn38zIVZ8srkE6lHagft8J2obQL/TegsTAL2IJQAB6OnpQXt7Ozo7OxEMBoUQ8Pt9yMjIBP1w+f2pQn1paUyn/XseehqfrVynpXrS1XGy618sZc2cOg6/PuVYIT0OvPcHAju6wqlGAGii9J2SYRdw50PPYNX6GiHsVGmczC6BWnQwe6eJOPlH34Xfpy+LJhMALeiOUMcpNwB9fWG0tW1Fa2srek3yiff7/cjOzkZOTk70XVN2oc3/tvv+g1VrN8ruOmH6c7rr31BFpHjcuOn3ZxpeT4Pf+2MpWUUCQHKK2gXQjccF19yDUG9fwqxtdgkcWZUUROjMk4+GTwcJYAIg+PVQnQAQc25paYlu/FZFwPN4PNG3zLy8PMM/3EPVQpv/rff9B6t58x9xxTrd9S/W5K469wQUjc7X/U0d+t7vJAJAsorYBdQ1NOPaOx7XjZnKDdglML529JIAJgDxMR2xhqoEgE4AbW1tUSNFqzb+oUARERg9enT0VkCkkPw33/NvrPy6QqSbhG+bCK5/sZT0w8PmYv7+e2jW33Dv/U4jAAPyGrELWPrOcjzzSuLZyLBLYPyvwU5TS3HGiUdpOnwxAYiPp+MIAF3x19XVRo37VChpaekoLi5GSooxX+dHnngZy95ZrsJUlJYhEVz/YgE8aXwRLjxjoSbsR3rvdyoBILn12gXcdO8TqKiu14SZkyqxS6A2be2zx0wcf8z8uJWZAMSFaOQKqt0A0Km/oaHBtlP/cGjRmyaRgMzMTF2IL3nrYzz61Ku62iRj5URy/RuqP7fbhVt+fyboRmmkEu+938kEgGTXahdA9j4XXnMX+hLn+f9b1bFLoOaft+OOOhAHzNllxPpMADTDGbuiKgSAgn40NTViy5YtgjMyt3l+fj4KCgo0DULBfa69+WFQpD8uIyOQSK5/sWZ66ZkLMb5k+FjoWt77nU4ASH4tdgFV1XW44d4nE/Yrwy6B2lRLhPnCM36EkjGjh23ABEAblsPWUoEA0JtnbW0tOjo6BGdjTXOyCaDbgJEKGf398cb7QZH+uIyMQKK5/sWa7VEH74Ej5s/d4U963vsTgQAMzGEku4AXl76PxW8k7pMZuwRq/0Uk49mLzlwICiEcqzAB0I5lzJp2E4BIJIyamlp0dXUKzsTa5hQ7oKRk7LCD/uvJV7D07U+sFcqhoyWa618sNZQUptVzgAAAIABJREFU5eGys0/c7k963/sTiQDQXIazC7ju9n+htrHVoatZm9jsEqgNJ6p10Nxdo4GCmABox0xzTTsJAJ1+yNivvd0ZJ/+hoGZlZWPMmB1vAujq/083PQiK+MclPgKJ6Po3dNYU5ezmq84AeTpQMfLen2gEgOYz1C6ASNEFf7o34dNgs0tg/N+FgRr03bn4rJ+gpHjHp1e+AdCOo3I3AGTsR/79Ti5DbQLCkQiuv+1hrKtIjAhmZusmUV3/YuF2/i+OxZSycdFwvoPj+YtgrGogID1zGmwXsK6iGrc+8Kye5o6tyy6B2lU3ccIYnPuLH+4QLpgJgHYMlSIA9CNIp/9EKGPHjv3GO+CjFeW4+6FnEmFalswhUV3/YoF34N6zsGDfnXeI5y8CdCIQgIH5Z2dnYel7X+Ktj1aKQOKYtuwSqE9Vpx1/JHaZOWm7RkwA9GG4Q207ngAofv/GjRsT5pqPrjFLS0ujOdF/f8PfUb25UVArydE8kV3/YmmQ7F0u/sX3pSo3kQgAAXPj/S/A5ZIfhlsq6LI6Y5dAXUjSEwA9BQxOGsQEQBeEO1a2mgDQu391dTW6u7sFJVereXp6GmqbOnDXg0+rJZjC0iS6618s6BceNgcTSrS5kWpRXSIRgKqaRjzxykdapp0wddglUJ8qf/HTo7DzjInfNGICoA8/228A6M2f3v4Tsfz7hbdRUVWXiFOTPqdkcP2LBdq00kJ8f8Fe0vBMJALwwpKPsaYqMX8bhlM4uwTq+ypMLivBOaf9gAmAPtiGr23lDQBF+KqsrECfCYFx6Do5PT0dGRkZ8Pn80bC9FEiCbhzoQ88O9KEUwuRyKNtCv3lLO+577GVZakn4fpLB9S+WEtP8Hvz6xMOl6TeRCMBd/3oZ3cHkC5rFLoH6vg6XnfNtci2+AdCHna03AE1NTdHMfjILWZFT1j5K4Tv4bWikMYh1D1hik9uRjLLknc/w8edrZXSVFH0kg+tfLEWSHcCFP9eW6ETLQkgUAhBNmPXgi8nz/j9IuewSqGWlf1tn/v674+jv7hv9H0wA9GFnGwGgL3hFxQbQLYCMQoZC+fl5IDc8rRv/0HHpZoBCDzc3NwsZJJK3/98eegEdnWokL5KBr5l9JJPrXywcj5r3Hew0aZwUiBOFAKxeV4MX3/pMCiZO7IRdArVrLTsrA3+8+GfR330mANpxi1nTqicA2mhljeX1pqCkpCQaSUxGCQR6sHlzLSgLoZFSU9eMfz61zEjTpGyTTK5/sRQ8cWwefnh4/wlGtCQKAXjypfexsU7u7aAotla2Z5dAfWhf+KuFmFBSxARAH2w71pa1KceTo7KyMvoGL1r8fn908yeXO5mFngLIO8GIjG9+8BXeW75KpjgJ21eyuf7FUqTP68Y5pxwhRceJQgDu+OdiBENybgelAGt1J+wSqAvxw+bthSPmz2ECoAu1GJWtIAA9PT2oqqoSFRV08p8wYbz0zX9AMDJOJDn13gQ8+N8lqGtUO4uhMPiSOkhG178doPv/p6fzTj0CXu/I6YG1QJ4IBCAU6sNtDy/uTxWYxIVdArUrn07/dAvATwDaMYtZ0woCQGOIpvmlN/8JEyZIu/YfDjYiK5s2VYOMtbQU+vG66e/PSPcq0DK20+okq+tfLD0t2Gcmdp35rT+zUV0mAgH4bOUGLP2Qb9DYJVD7t8Dr8eAvV56B/fc/0FTWaGrnNN3GxnpbM8ZYQQBkXP+PGjUK9LGikKcCeSxoKdW1zXjkaX7/14JVsrr+xcJmbEEOfnp07AxnWrAcqJMIBODx59/G5qY2PdNO2LrsEqhdtRecsRDHL/yhqXu0qZ0nAwGgt/UNGzZo12qMmmQ1XlZWZtjaX+/gdPqvrNyo6Slg+Rfr8OrbK/QOkZT1k9X1L5ay6fb/vFOPEl4HiUAAbn3oRUhyDhLG0+4O2CVQuwaOO+pAXHL+Wabu0aZ2ngwEoKOjA5s3b9au1Rg1CwsLkZubK9SH3satrVvR0FAftxn7/8eFKFoh2V3/dkApEsGvTzgUaf/X3rlA2VWVef5/7q13JalU5UUSSEhCItA8IglWIHGMQgCNMGp3pgkiNkFwhlkOSjM9q2d62ThrtNsnKo7dIAWKKN2GpTRFCKEFogkkJUSQPAkGSMz7UUm9H/dxZvat3JBHVd1zzz77de7/aK0qUvv5+/ap/b97f/vb1ZXBAA6RynUB0NuXwg9+tgpie4jPAAEeCQw2EhZeORtf/8r/UDpwlBZeCgJANviP8BqfMWOGtk//+aEn4hW8/faOgvEBnnjmJbz1jpzACTbc3U5V6kf/BrPegstmonH2LCnDui4A1v1+G15+fYcUg7hl5pHAYBa95IIZ+NH3/4/SOVpp4aUgAMT5+s7OjmAWHSTViBEjIK7bNfEEaXvTvz6Hg4fbTDTPmTp59G9wU42rr8Utn1woZUfXBcCjv1qNQ0e7pBjELjOPBAYyqbgd8Jc/vV/pHK208FIQALt27URvb18ggw6WaMKECbkwvyaeIBcX/eDHT6OjK143G0bNmkf/Biea8Hx86daPS+F2XQDc9/DTyHL5/4wxwCOBhV+L+rqRePaJB5XO0UoLLwUBIBwAZeLtn3POFFRXVxUeDQpS9Pb2YNeuPw1b8n0P/Rt6++QDHClovhVF8ujfcGbw8bklH0HdyJrQtnJZALR1dOOh5eIEjfI/s6H5msrII4GFydfWVOGFf3tE6eBRWngpCIC33nqr4D76cKaePn26ssA/hYZYkBMM3/jnXyq53bBQ21z5PY/+DW+puRdOxYfmXRTanC4LgNXrN2HDlp2h+x73jDwSOLyFRSCtl1Y+pnSOVlo4BUDhV3jmzJnaHQDzrRKXBQkBM9zzD/93eeFOlHAKHv0b3vj1IyuxbMnVoUeIywKg6RfP41gnL9Aayvg8Elj4tWj598eVztFKCy8FAbB9+/bCVhwmBQWAFD7jmUUEx7LyslwY59z38gpjKzrGYQzSAA8+7l4W3g/AZQHw7aZmwEvYaBYjbRLL/iIMeTrVDzH5iy/xb3yGJkABIDk6VEcClN0CEEcAk0n5mOlhMIm7AXbsGP6IElcAiidLUXAqs5tvmI8JY8PFuXBVABxubcdPnlxT/OCJSQ5O9tEYkgJAkqNqASDvBHgOqqurJXsZLntPj7gXYPhLjCgAwrE9PVcpi4KLZk7GtR+cHQqkqwJg1W9ew6YdpRE/g5N9qKEdKBMFQCBMQydSLQBcPgbY1taGAweGjwZIASA5AIfJXiqiYERNOT5/4zWhQLoqAB54/Dl09qRC9dnmTJzs9VqHAkCSt2oBECSYznBdsD0QEAWA5AAsMnscRYG4e+Ke264vksRAclcFwLeamiFs6fLDyd689SgAJG2gWgAcOXIE4ivsI/5IzJgxHSKanM5HnAAQ+/+FnHAoAHRaZfC64iAKllzbiCmTxxYN00UBsGvPISxf9bui+2oyAyd7k/SHrpsCQNIuqgVANJcBTcDo0XqjAQZZ/hfoKQAkB6Ci7K6JgllTx+P6qy4vmoaLAqD5169g+66DRfdVVwZO9rpIy9dDASDJULUAyGTS2LFD7jrgsrIyTJs2TVs8APHp/9133w10HTAFgOQA1JjdZlFQXZnEnZ++rmgaLgqAHz72LHr6M0X3VUUGTvYqqOorkwJAkrVqASCa9+6776C/X87hZ+zYsWhoaJDsbbDsra2tELcYBnkoAIJQsjONOF7aMG68FY0TfgB337q46K0u1wSAmHC/88gKa/b/Ww8dZCRPK96AcI2gAAjH7UQuHQJA1HH06FGplnqehylTzkFlpdp7AXp6erB79+7A4YspAKTMajRzVXU1xDXFtjyLF16K86efXVRzXBMA2/64Byt++3pRfVSZuKPtGHp7eJmXSsYqy6YAkKSrQwAEOU8fpBvl5eU455xzlEWSE1G4du3aVdQnAgqAIJazM42Y/IUIsOWZNqken7ruyqKa45oAeOKZddi5v7WoPqpMLCZ/IQL4uEmAAkDSbjoEgGhiFNsAopyKioqcCIg6OqCY/Pfs2Yv+/uKuLqYAkByABrOL5f+ox5FMdyrKEvjCLR8tqgjXBMD9j65Ef9qe8LYi2qfYBuDjJgEKAEm76RIAYgsgqrrESsDEiZNQVVUp2fuB7GLZf+/evUV98s9XTAEQiQm0F2LT/v+Jzvs+7vrsRyFuOQv6uCQA0ukMvveTlYCn/IqVoPhy6egHUBQuqxJTAEiaI6pJuVAzhPPPO++8jUwmGvUvPLrHjGlAff3o0A5FwttfCBMRp0D8HOahAAhDzXwe2/b/80SumnchZl84LTAglwTA65vfxvMtWwP3TVdC+gHoIh19PRQAkkx1CQDRTOFZLzzso3zEakB9fQNGjhyJZDJYsCAhRjo6OnJtEUv/Mg8FgAw9c3lt2//Pk5g0tg5Lb1gQGIxLAuDxp9Zg7+H2wH3TlZB+ALpIR18PBYAkU50CYGAV4J1QS+2FuilOCdTWjkBNTXVua0BcP5vf3x0469uP3t5+dHd3o6urM/Qn/tPbQQFQyDJ2/t62/f88JbH6f9dnFweG5pIA+O6PVyCiBcDAfIIkpB9AEEp2pqEAkLSLTgEgmnrsWBsOHhz+gh3JLmnNTgGgFXcklVm5/5/vme/jzpsWobo6mH+LKwKgty+FH/xsFTzYtf+fx04/gEheLe2FUABIItctAMRW++7df8o53sXhoQBwz4q27v/nSS64bCYaZ88KBNYVAbDu99vw8us7AvXJRCL6AZigLl8nBYAkQ90CQDQ3lUpj5853C160I9k1LdkpALRgjrQSW/f/850cV1+LWz65MFCfXREAj/5qNQ4d7QrUJxOJ6Adggrp8nRQAkgxNCADR5I6Oduzbt1+y9eazUwCYt0GxLbB1/z/fj4Tn40u3fjxQt1wRAPc9/DSyli7/C9D0Awg03KxLRAEgaRJTAkA0O4oQwZLdl85OASCNUGsBVu//nyDh43NLPoK6kTUF2bggANo6uvHQ8hcAiwWAAE0/gILDzboEFACSJjEpAIQ/wL59+9DZ2SHZCzPZR44cgf/5j4+YqZy1hiJg+/5/vlNzL5yKD827qGAfXRAAq9dvwoYtOwv2xXQC+gGYtkDx9VMAFM/slBwmBYBoiAjAI6LwdXXZuz84GGJx5HDSpIlY9sWvSVqA2XUSsH3/P8+ifmQlli25uiAaFwRA0y+ex7HO3oJ9MZ2AfgCmLVB8/RQAxTOzSgDkRYDwB3BlJUAEHTrrrLMgYg/cetdXJS3A7DoJ2L7/n2fhwcfdywr7AbggAL7d1Ax4wYJ06RwLp9dFPwCT9MPVTQEQjtuJXKZXAPINEdsBhw/LXxssiaNg9oaGBowZMyY3+YuHAqAgMmsSuLH//x6um2+Yjwljh7+u2HYBcLi1HT95co01Y6BQQ+gHUIiQXb+nAJC0hy0CIN+N9vZ2HDx40LojgolEAhMmTMiFHD75oQCQHIAas7uy/59HctHMybj2g7OHJWS7AFj1m9ewacdejVaWq4p+AHL8dOemAJAkbpsAEN3p70/hwIH91gQLEuGFJ0w4C+LegdMfCgDJAagxuyv7/3kkI2rK8fkbr3FaADzw+HPo7JG7b0PjEAH9AHTSlq+LAkCSoY0CQHRJOAeK1YAjRw5DXCNq4hFLxmPHjkVdXd2Q1VMAmLBMuDpd2f/P9873s7jntuudFgDfamoOfVtnOCvL5aIfgBw/3bkpACSJ2yoA8t0SF/mIK3vFl/hZxyOW++vr63Nf4ufhHgoAHRaRr8O1/f98j5dc24gpk8cOCcDmLYBdew5h+arfyRtPcwn0A9AMXKI6CgAJeCKr7QLgZCHQ1tYG8dXf3y/Z68GzV1RU5D7ti69CE3++BAoAJaaIvFDX9v/zAGZNHY/rr7rcSQHQ/OtXsH3XwchtqbpA+gGoJhxd+RQAkixdEQAnd7O3txednZ25L1kxUFlZgdra2pxzX2VlVdE0KQCKRmYkg2v7/3lI1ZVJ3Pnp65wUAD987Fn09JvZvpMZZPQDkKGnNy8FgCRvFwXAyV0We3biZsG+vj709/chlcognU4jm82c2DIQn+YTiSTEMnBFRTnEJ/2qqkpUVVUhmSyTIkgBIIVPW2bX9v/zYIQfwN23Lh5yRcrWLQCxXfedR1Y4tf+fZ04/AG2vpXRFFACSCF0XAJLdl85e6gLg0KHdUgzHjTtbKn+QzK7u/+f7tnjhpTh/+uCcbBUA2/64Byt++3oQ81iZRpcfgAvvj5UGOt4oCgBJ61AAyAGkALBfALi6/58fmdMm1eNT11056EC1VQA88cw67NzfKvdyGcytyw+AAkDOyBQAcvyccQKU7Kay7BQA9gsAV/f/84O2oiyBL9zyUacEwP2PrkR/Ws+pHRUvty4/AAoAOetRAMjxowCQ5EcBYL8AcHX//8TQ9H3c9dmPoqwsecZotXEFQMTt+N5PVgLHw2VLvmJGsuvyA6AAkDMvBYAcPwoASX4UAHYLANf3//PD86p5F2L2hdOcEACvb34bz7dslXyzzGfX4QdAASBnZwoAOX4UAJL8KADsFgCu7//nh+eksXVYesMCJwTA40+twd7D7ZJvlvnsOvwAKADk7EwBIMePAkCSHwWA3QLA9f3//PAUq/93fXaxEwLguz9egYy72/8nGOvwA6AAkPsDTAEgx48CQJIfBYDdAsD5/f/8+PR93HnTIlRXV54yYm3zAejtS+EHP1sFDwPXZbv86PADoACQGyEUAAX4iYAcqVQKYjCLADniezbri+t2chfuiC8+4QlQANgtAEaMHIXq2trwBrYo54LLZqJx9iyrBcC632/Dy6/vsIha+KZ0d3Wiq6MjfAEBclIABIA0TBIKgEHgpFJp9PX1IpXqN3aTnpxZ3clNAWC3ABAjKS7bAOPqa3HLJxdaLQAe/dVqHDra5c4LPERLe3t70HnsGFR/PKIAkBsqFADH+YlP8gMhcXs56cuNqcC50+kUbv/rbwROH8eETvwB84C60Q2oqDx1+dw1eyQ8H1+69eNWC4D7Hn4aWceX/0VI8bajR8Wd5MqHiBPvj3IK4SsoeQEglvN7erohLsjRdV1ueHPFJ6e4hEgIri9++Qfx6VSInrjyB8zzPNQ1jEF5eXmIXtqSxcfnlnwEdSNrTjTIJh+Ato5uPLT8BcBhAZBOpXCs9Yi2rVFX3h9b3oDT21HSAmDgVrwuiAtD+OgjICb+/C2EFAD2bwHkR4a4FGp0wxgky+QugNI30s6sae6FU/GheRdZKQBWr9+EDVt2msQjVbfwjzp25LDWD1IUAFImQ0kKADFQ29s7IJag+egjILZZurt7TuFOAeCOABAjRQQGEiIgkTwzqp6+kRS+pvqRlVi25GorBUDTL57Hsc7e8J0zmNPPZnG09Qgy6bTWVlAAyOEuOQEgrr3t7OzUqlLlTBSP3GKrpbu7K3eK4uSHAsAtASBsV1ZejtENDU5eVevBx93L3vMDsGkL4DsPN8NHwrkXXgh7sewvlv91PxQAcsRLSgCIiV8sP/PRS0BM+l1dYqvlTKcgCgD3BIAYPeUVFRhd3+BkvPqbb5iPCWNH514CWwTA4dZ2/OTJNXpfzChq84G2Y63o7+uLorSiy6AAKBrZKRlKQgCIeaejox3i0z8fvQREDIXu7u4hK21MvK23QRHX9sbOo3joxe145Y9HQpXs8h+wyqoqjBxd75zL2kUzJ+PaD862SgCs+s1r2LRjb6gxZDKTjnC/w/XP1Ptz6dR63PbhWbj8vDEm8UvXnWj8jNKIU0oLF70/dOjAsGdNxOTf3t52wulMmhgLCEwg7+k/XAbXBUC+b2GFgKk/YIGNWCBhdU0tRowaFVVxWsoZUVOOz994jVUC4IHHn0Nnj/4ldBngnR3t6OkyG7NA9/sTl4k/b/fYC4COjo7cET8++ggI0SXiKQRZcYmLAAgrBHT/AVMxClyLFihO/dxz2/VWCYBvNTU75VOhI8pfkLGq6/2J28RfEgKAe/5BXqFo0+QDKoml/yBP3ARAsUJA1x+wILaQSeNatMAl1zZiyuSxVvgA7NpzCMtX/U4Gv9a8uqL8BemU6vcnrhN/7AWA+PTZ3u7+lZpBXgJb0ohASmK//3RP/1LYAhiqj4W2BlT/AdM2NhyLFjhr6nhcf9XlVgiA5l+/gu27DmozlUxFOqP8BWmnqvcn7hN/rAWAmICOHj3GAD9B3qCI0mQyYvLvKvp4ZVxXAE7HOpQQUPUHLCKzFlWMS9ECqyuTuPPT11khAH742LPo6T/1eGxR4DUl1h3lL0i3on5/SmXij7UAEJM/g/wEeX2iSSNuSRSf/MPcjFgqAmCorYGo/4BFY9HwpbgSLVD4Adx962Jse/Dvw3c2gpzn3/EVfOeRFdbv/5uI8hcEb1TvT6lN/LEVAMLhTzj+8dFDIIinfylvARTaGnhm3R+kDDVu3NlS+VVkdiVa4OKFlyL73AMqEAQuM3H1f8aK374eOL2JhKai/AXpq6wAuHruxbE4zheE1WBpYnUKQESba9V4EUVY6HHJJ/wsZE9YlNoKwOm23/DH/fj+0xvw0tY9oYaFjQJAdMSFaIHTJtXj/HdXhuIeVaYtUz6Gnftboyou8nJMRvkL0pmwAmDueWfhCx+fg/kXTA5STWzTxEoAiGhzwwWdia0VNXesWE9/rgAUNlBYIWCrABA9tj1aYEVZAld1v1zYOApTPF9zJfrTll5GZjjKXxDsxQoATvynUo2NABCTUmtra9FOaEEGGdO8R0BwFkKrGE9/CoDgI6hYIWCzABC9tjpaoO/jo5lXgawhB7xEEiuTc60Np2w6yl+QtyaoAODEPzjN2AgA8clfTEx81BHIZkVM/+5IRVapbwEMZa2gQsB2ASD6Z3O0wPnV+zCqzcwVvO2jpuKl3onqXliJkm2I8hek+YUEACf+4SnGRgAcPdqKdNqQkg8yUh1PI+PpzxWA8MYvJARcEACi97ZGCzy3qhcXtJtxwts6ajbe7a0KPzgU5bQlyl+Q7g0lADjxB6EHxEIApFJpHDt2NFiPmapoAqlUP7q71dyiyBWAYOYYSgi4IgBEL22MFljlZfDhvleCGSHiVC9UzkWfXxZxqXLF2RTlL0hPThcAnPiDUHsvTSwEAEP+Fmf0YlJH4enPFYBiiA+f9nQh4JIAENcG1o1uQEVlZXRAZEsSfgD+60Ba702h2WQFnk2+H55FdynaFuUviGnzAoATfxBaZ6aJhQDg8n844w+Xa8DTvxfi07/KhysA4ejmhcD2w8ov3AzXwCFy2RgtsLH6EBradkTaz0KFtdbNQEvPuELJtP3exih/QTo/tS7N43xBQA2RxnkBcODAPv/IkXB3sUtwi3VWMfkLp0qx76/6oQCQI1zorgG50tXkti1a4NmVfbi44zU1nR2i1I2j3o/dvXashNga5W84g5Rq5L6oB6nzAmD37l0+L/2JblgMXOgjjvnpOZtMARCN7VwTAjZFCyz3Mrhasx/ArysuRwrJaIwvUYrNUf4G6xYnfgljD5LVeQGwc+c7Po//RTMoxCmKnh5xoY8fTYEBSqEACACpiCQuCQF7ogX6uAabkOzXc4w4U1GL53ARYHj/3/YofycPe078RfwRKCKp8wJgx463fOGoxkeOQCqVQk9PT6gLfWRqpgCQoTd0XleEgC3RAufUHMH4Y2+pMcZppR6om4Xf9zRoqWvIShyI8ifazolf7TBxXgBs3/6mz5v/5AaJ7IU+MrVTAMjQK5zXBSFgQ7TACZX9uKzj94WBRpBiw4g5ONhfHkFJ4YuwPcofJ/7wti0mp/MC4M03t/i69quLAetK2p6ebvT3p4w1lwJAD3rbhYDpaIFJZHBNv554AM9VXI6Mwf1/m6P8ceLX8/cgX4vzAmDbts2+zj1rveZRV5tOT//hekEBoM7Gg5VssxAwHS1wUXIbynqOKTVIpqoOz2UvUFrHcIXbGuWPE7+ZIeG8ANi6dZOYy/gUQUB4+gvHSfHd9EMBYMYCtgoBk9ECL61pw6RjW5UaZO/oC/GH7lFK6xiqcBuj/HHiNzIUTlTqvADYsmWT8ACsMIvRndozmXTuQh9bVBMFgLmx09bno23KAohQ2p3dPejq6kFXd+/xn7vR1d2Dzq4edPf0nvhZ/JtI19ndm9s6Ev8d6WMwWuCY8hQ+0LUh0u6cXlhL7Ry0pvTv/6uM8ldRUY7ammqMqKlCbW31wM/Hv9dUV534uba2BiNqxO8H0omfx+5bj7pKt4JZKR0gmguPgwAQUYAMu9RqtlrI6oSnvwjwY9NDAWDOGluPArXnz5duQNQCwlS0QM/P4LqUWj+AZ8svh+/pPf9fKMqfzAReXi53l0H31pdwPv96S7+DYQuIgwB4F8DUsABKJZ9JT//hGFMAmBuB6w4kMfmSeeYaAOSiTYpVh66e3tyFU8faOnHfj34Bzwcqq6uRSCQhBIGX8HLf4XlIiAj6CfGz+H+0nx4/Ur4DlV2HlDDpqxmHF9Izoi3b93NbeWJFLyv2QrNZZP3sQCwP30c6k0bf8eO9t9/8CZw75SyIT+XiS3xSl53AZTuzd2ML5o1XH3FUtp1xzR8HAfAqgDlxNZBsv8TfBLH3JwSAjQ8FgDmrvHiwFjMunm2uAYPUfORoO7745fuLa5MQCAASXgJeQmgEIRYSQisMfE+I4s78N5ErJypOev6sphNTjm0qrv6AqXfWXYQtPSPOSC0mb//4pC0i8+Um89z3LPzsexO8n83kJvf8v+Um/CIcoG69cTGuu+rKgK3Vk2zHptfx4XF6AjDp6ZFbtcRBAPwcwFK3sOtprS2e/lwB0GPvYmt58dg4zHjfrGKzKU2/a89+/K9/bFJaxxmFnyQgyhI+xvhtqPCyqPAyqMDA93JkBv77pH9Lws/9d8b30O8n0Ocnct9zP2eT7/18/N8OePXoz/qhJ3BZKFdefgnuuuMvZYsMb3YBAAATvUlEQVSJNP+ON7fjw6PVrLhE2tCYFua8ANi6dfPf//+J7t6Y2id0t8QS4EBM/0zoMnRk5AqADsqD17E+Mx2TJk0014BBat6y/R38w/1C07v15Jxqc6eR/Nz/Bj6Zi0/2x/8t9yl/4OeB/7+XXldPp0w+C9+89wu6qgtUz549+3BF2duB0jJR9ARiIAA2/bnv44no0bhbogiM1NXVaY2n/3AkKQDMjbOtIy/L7QPb9Pzuta24/+Ff2tQkLW3RISBqaqrxyPf+Tkt/glYiTpFcoCkCY9A2lVI65wXAH/7wh/Hl5cn9xm/WsGTUCKcq4elvyzG/QlgoAAoRUvP7/BFANaWHL/WFtRvwyL8+G76AEs0ZREAIP4h7//vncqKvtqYSFeXi+F6VcWJ1u9byKKAhKzgvAAS3LVs2bgQ8cb1WST+2evpzBcC+YRnVEcCoe/bUqjVY/vRvoy6W5Q1DQJwEqD1+KkAIg9w5/fx5/Zpq1FRXnjg18N7vohMQPApobnjGRABs+g6AL5nDaLZm2z39KQDMjo/Bal93sAyTL260rmGP/+rf8cwLv7OuXWzQ0ARkBQSPApobXbEQANu2bZybzXpqI3iYs1GBmv1cZDZXb0TkFoCZgWXjEUBB4qGfNeM3698wA4W1GiFQVpZAXVUZRlaVY2S1+H78q7oMI47/24jKk38v0iVRWZbMpeUTnkAsBECpbgOIc8IirK/tnv5cAQj/gqrKaeMRQNHX7z74C2zY+JaqbrPcGBKoKEscFw0UEMWaNzYCYPPmjfd4nvfNYgG4ml5M+sLZz4YLfWQYcgVAhl74vDYeARS9+ep3H8W2HX8K3zHmJIEiCZSygIiNANi2bdvIbDa9E0B9kfZ3LvmAp39XMUHArO0jBYAZ09h4BFCQ+NuvPYjd+xgYxsyoYK1hCLgsIGIjAIThNm/e9BXPw5fDGNGVPC56+nMLwK7RZesRQEHprr/7PlrbOuwCxtaQgEICJgVErATAG2+8UV9WlngTwDiF9jJWdF9fH3p7e43Vr6JirgCooDp8mbYeARStvu1L30B/OqUfCmskAUcJyAiIug/dGu1tWqcxVFr4YPbavHnjMs/zNAcTVztyRJCPgQt94veHkQJA7dgZrHRbjwCK8X3bX39DPxDWSAIlSmBNc5PSOVpp4YPZzPd9b8uWzWs8D/IXnVswKMTkP+DpH88rMykA9A8yW48AhroJUD8+1kgCsSEQOwEgLLNx48YZyaS3AUCdy5YSHv5dXV3Oe/oPZwMKAP0j1NYjgEZuAtSPnzWSgDUEYikABN1Nmzb9RSKB5daQLrIh6fTAMT9x1j/ODwWAfuvaegTQ1ZsA9VuQNZJANARiKwAEns2bN33b83B3NKj0lRI3T3+uAOgbO0FqsvUIYKneBBjEZkxDAioIxFoAHPcHeNjz8Fcq4KkoM46e/hQAKkZKuDJtPgLImwDD2ZS5SCAsgVgLAAHl1VdfLa+pqXwS8D4WFpKOfMLZr6enB6lU/Dz9KQB0jKBgddh8BJA3AQazIVORQFQEYi8ABKgXX3yxbMKE8Q8A/rKowEVZjpj8RWQ/se9fag99APRa3NYjgILCvzz5PFY8v14vENZGAiVMoCQEgLCv2A7Ytm3LN3zfv8cmewtPfzH5ZzLxdvYbijkFgN7RaOsRQEGBNwHqHQusjQRKRgDkTb1ly5ZPANmHbbgzQJztF2f8xQpAqT4UAHotb+sRQEGBNwHqHQusjQRKTgAIk2/f/sb0dDrxYwAfNDUE0unU8WN+plpgR70UAHrtYOsRQEGBNwHqHQusjQRKUgDktwS2bt38Gc/DN30f43UOhVI65leIKwVAIULR/t7WI4Cil7wJMFpbszQSKESgZAVAHsxrr702uqqq4r/5vn8XgIZCwGR/Lzz9hQDgM0CAAkDfSLD5CKCgwJsA9Y0F1kQCgkDJC4D8MNi0adOIZBJ3+D7ESYE/i3p4DHj690As/fN5jwAFgL7RYPMRQEGBNwHqGwusiQQoAIYYA5s3b35/IoGbAH+R7+NiAAmZ4ZLNigt9REz/0jvmV4gbBUAhQtH93uYjgKlUGsvu/np0nWVJJEACBQlwBaAAojfffHNsNtv/H3zfu9D3cYHnYZbvo8HzMBrACAAVwxWRyWRyk38pe/oPx4cCoOA7GlkCm48Ath5tx11fvj+yvrIgEiCBwgQoAAozYgqFBLItPy3dM5AKuQ5WtM1HAHkToObBwOpIgD4AHAOmCVAA6LOAzUcAeROgvnHAmkggT4ArABwLRglQAOjDb/MRQN4EqG8csCYSoADgGLCCAAWAHjPYfgSQNwHqGQeshQROJsAVAI4HowQoAPTgt/0IIG8C1DMOWAsJUABwDFhDgAJAjylsPgIoCPAmQD3jgLWQAAUAx4A1BCgA9JjC5iOAggBvAtQzDlgLCVAAcAxYQ4ACQI8pbD4CKAjwJkA944C1kAAFAMeANQQoAPSYwuYjgIKAqZsA9/xpu5QBJp8zSyq/6fqlGs/MzhOgE6DzJnS7AxQAeuxn8xFAQcDUTYCmJ2DT9esZfazFVgIUALZapkTaRQGg3tC2HwEUBEzdBGh6AjZdv/rRxxpsJkABYLN1SqBtFADqjWz7EUBBwNRNgKYnYNP1qx99rMFmAhQANlunBNpGAaDeyLYfATR5E6DpCdh0/epHH2uwmQAFgM3WKYG2UQCoN7LtRwBN3gRoegI2Xb/60ccabCZAAWCzdUqgbRQA6o1s+xFAkzcBmp6ATdevfvSxBpsJUADYbJ0SaBsFgHoj234E0ORNgKYnYNP1qx99rMFmAhQANlunBNrWuGipb3M3R1aVY3JDDSY3VGNSQw0mNdRi8mjxvTr37y48th8BNHkToOkJ2HT9LoxftlEdAQoAdWxZcgACtguA4brggjhw4QigyZsATU/ApusP8IoySYwJUADE2LgudM1lAeCCOHDhCKDJmwBNT8Cm63fhbwTbqI4ABYA6tiw5AIG4CgBbxIHtRwAFJ5M3AZqegE3XH+AVZZIYE6AAiLFxXehaKQoAneLA9iOAgoXJmwBNT8Cm63fhbwTbqI4ABYA6tiw5AAEKgACQjicJ43Ng+xFA0TWTNwGanoBN1x989DFlHAlQAMTRqg71iQIgGmONqq7A2WNqcM6Y2lO+Hx5zMaadOyWaShSV8rXv/RRb/7hLUenDF2t6AjZdvxHorNQaAhQA1piiNBtCAaDe7vWjR2H61EmYNmUSpp97Ns4/bwpqa6rVVxywhr/96gPYvf9wwNTRJjM9AZuuP1qaLM01AhQArlksZu2lADBjUCEKhBB433lTMX3q2Th3ylmorKgw0hhTNwEa6SwrJQGLCFAAWGSMUmwKBYAdVk8kEph81lhMP3fywErB1LMxbcpEVFSUK2+gqZsAlXeMFZCA5QQoACw3UNybRwFgr4WTyQQmTThVFIithPLyssgabfImwMg6wYJIwFECFACOGi4uzaYAcMuSg4mCGedOQllZOFFg8iZAt8iztSQQPQEKgOiZssQiCFAAFAHL0qSDioJpk1GWTBZsscmbAAs2jglIIOYEKABibmDbu0cBYLuFwrWvqrIC506ZiOlT8z4FkzFp4jgkPO+UAk3eBBiuZ8xFAvEhQAEQH1s62RMKACfNFqrRVVUVOPecU0XB3v2Hcf8jvwpVHjORAAnIEaAAkOPH3JIEKAAkATqevSyZQNb34CUSA19eEqctEjjeQzafBOwlQAFgr21KomUUACVh5uI66XkQxxLFV04QJMS2walbB8UVyNQkQAKDEaAA4LgwSoACwCh+Nyr3xPSfQCIpBMHJosCN5rOVJGArAQoAWy1TIu2iACgRQ0fcTU/sE3jHVwm4dRAxXRZXKgQoAErF0pb2kwLAUsM42Kzc6kBCbB8IP4L81oGDHWGTSUATAQoATaBZzeAEKAA4MlQSyDsXClEgfAroS6CSNst2jQAFgGsWi1l7KQBiZlDbu0MHQ9stxPZpJEABoBE2qzqTAAUAR4VRAnQwNIqflZslQAFgln/J104BUPJDwDoAdDC0ziRskCICFACKwLLYYAQaFy3tA2DmIvpgTWQqEhg4fkgHQ46EeBHoW9PcVKWyS4zeoZJuDMpuXLT0CICGGHSFXSgdAu2At8VLJnYkk2XphJeYCM97P4BxpYOAPY0BgcNrmpuUjlkKgBiMEpVdaFx041uAd57KOlg2CUgQSMP33gD89T68lmxZouXVZx/bDsA/vcwFH7t9FpLZRnh+o+d78+DjEngol6ibWUlAJYG31jQ3zVJZAQWASroxKLtx0dJnAVwbg66wC/EgsM/z/Q1IJDYgg7Wpmo6XNzQ3d4fp2pw77iiv3pO9JJH0F/g+5gC5rwvDlMU8JKCAwDNrmpsWKyj3RJEUACrpxqDsxkVLvwvgrhh0hV1wjoDXjdxk77V4WazzsqmWdS8s36OyG1d8/JbJ5YmKRh+YB99vBDAXQI3KOlk2CQxB4L41zU13q6RDAaCSbgzKbrzmphvh+4/HoCvsgv0E9nnw1/pIvCQm/obyY6+sXLlSOKEae5YsWZLc2zv6fM/PzEl4mO/DWwDgfAAiahEfElBGwPfwn9Y+1bRcWQUMu6USbTzKvvKaz4zP+On9HCvxsKdFvWgH/I0+sDbheS+l+rFuw+rHD1vUviGbMv+GZSORxaWe58334C8APLFSoNRZywUubGOkBHyksxPWrHzkUKSlnlYYVwBU0o1J2Y2LlrYA+EBMusNu6CcQ2FFPf9MiqdFb8LHbZwoHwwQwzweEILgUQFkkpbOQUiSwbk1z05WqO04BoJpwDMqfd/XSL/gevh+DrrALeghE5qinp7nR10IHw+iZllSJnnfnmqce+ifVfaYAUE04BuV/4KpbxniJ1E4AtTHoDrsQKQH9jnqRNl9jYSc7GPrw53kDJw/oYKjRBo5U1Znux9R1q5paVbeXAkA14ZiU33jN0vvg44sx6Q67EZ6AdY564btiNicdDM3yt7Z2z/vmmqce+hsd7aMA0EE5BnXMX3TjpDQ8EWCFqwAxsGfALrQCXovvZ1uSvteSrPJa1q74+dGAeZksBIEFi/9LPZL9jcj6jQnPE8cRhT8BI3GGYOlolo5kJjNr9TM/Fo7Xyh8KAOWI41PBBxYt/RsP+Hp8esSenEQgA+BNwNsAD2uznv/SK1e8byvuvTdLSmYJzL9h2SQP3vyE7y/w4YltAxGboNJsq1i7IgJ3r2luuk9R2WcUSwGgi3QM6pkz547yZENHiweIuOp83CawGx5akPXX+0m0ZCq6NoSNqOc2BvdaP+f6O2qq/PRlSc8TJw7mwUMjfJztXk/Y4tMIbEh2nDNv9ep707rIUADoIh2Teq649ubzstnMBgCjYtKlUuhGCsAbgPeS72ND1sfaV5//+dul0PFS6eMHP3XHRL8/MzeR8Ob4WcyH54sjZHQwdGcAdPiZxNy1z/xIbLNqeygAtKGOT0UfuGbpJzwfTwBIxqdXsemJDx/bkYCI3dCSyPrrKtP7N65evVrbp4rYkHS4IwsX3luWHfWni32IS49yIY3nARAXy/Bvvn12Tfs+PrX26aZm3U3jYNBNPCb1zbv6xtt9z3uAf1CMG/Qo4K2no55xO1jfADoYWmki34N/+2+bH24y0ToKABPUY1LnvEU3/ZUP/0eMeKbNoHTU04a6NCqig6FRO2d8eHeubX7oQVOtoAAwRT4m9TZefdN/hOc/Sp8AJQalo54SrCx0KALCwXBENjvHT/gDNyLSwVDNYPHR5gOfMbHsf3KHKADUmLekSm1cdNNM+PgXeP5lJdXxSDv7XkQ94ZmfyKbXq776NtLms7DYEjgRwdD3r/A9NDKCobSpN2SSyb98+ckHd0iXJFkABYAkQGYfILBw4cKynvJJ/xXw/zdXAwKNCkbUC4SJiWwjwAiGoS3S5Xnetw5Xtn1ty/Ll/aFLiTAjBUCEMFkUMOfamycms5l7PODzjBp4YkQc9Y+fuWdEPb4lcSQwiIOhOHVQH8e+huhTJ4B/7ve8b7U89dCBEPmVZaEAUIa2tAu+4tolDdlscimAm4/fl14qYy3uV9+W9sBm74MS8ObfsGyWl8XxkMbePMC/pIQchn0A633gMWQrHl+74p+sDKFdKn+Ugw5aplNA4MprPjM+m00vBLx5vofz4fvT4WEsgJEAKhRUqbNIOurppM26nCUQUwdDsZTfAeCwB7zte9jq+X6Ln/ZfXLPykUO2G4sCwHYLsX0kQAIkQAIkoIAABYACqCySBEiABEiABGwnQAFgu4XYPhIgARIgARJQQIACQAFUFkkCJEACJEACthOgALDdQmwfCZAACZAACSggQAGgACqLJAESIAESIAHbCVAA2G4hto8ESIAESIAEFBCgAFAAlUWSAAmQAAmQgO0EKABstxDbRwIkQAIkQAIKCFAAKIDKIkmABEiABEjAdgIUALZbiO0jARIgARIgAQUEKAAUQGWRJEACJEACJGA7AQoA2y3E9pEACZAACZCAAgIUAAqgskgSIAESIAESsJ0ABYDtFmL7SIAESIAESEABAQoABVBZJAmQAAmQAAnYToACwHYLsX0kQAIkQAIkoIAABYACqCySBEiABEiABGwnQAFgu4XYPhIgARIgARJQQIACQAFUFkkCJEACJEACthOgALDdQmwfCZAACZAACSggQAGgACqLJAESIAESIAHbCVAA2G4hto8ESIAESIAEFBCgAFAAlUWSAAmQAAmQgO0E/h+DXw/usBLI8gAAAABJRU5ErkJggg==", + "created": 1750418333517, + "lastRetrieved": 1763130743829 + }, + "708df2cd28b89e43cd6bf026b73c84d2b1680761": { + "mimeType": "image/png", + "id": "708df2cd28b89e43cd6bf026b73c84d2b1680761", + "dataURL": "data:image/png;base64,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", + "created": 1750418322932, + "lastRetrieved": 1763130743829 + }, + "421878bc33eecd83135e6a41f4df0e9e94b9b17f": { + "mimeType": "image/png", + "id": "421878bc33eecd83135e6a41f4df0e9e94b9b17f", + "dataURL": "data:image/png;base64,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", + "created": 1750417950735, + "lastRetrieved": 1763130743829 + } + } +} \ No newline at end of file diff --git a/structurizr/IAM/images/keycloak-ips.png b/structurizr/IAM/images/keycloak-ips.png new file mode 100644 index 0000000..232a50c Binary files /dev/null and b/structurizr/IAM/images/keycloak-ips.png differ diff --git a/structurizr/css/bootstrap-5.3.7.min.css b/structurizr/css/bootstrap-5.3.7.min.css new file mode 100644 index 0000000..955575a --- /dev/null +++ b/structurizr/css/bootstrap-5.3.7.min.css @@ -0,0 +1,6 @@ +@charset "UTF-8";/*! + * Bootstrap v5.3.7 (https://getbootstrap.com/) + * Copyright 2011-2025 The Bootstrap Authors + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) + */:root,[data-bs-theme=light]{--bs-blue:#0d6efd;--bs-indigo:#6610f2;--bs-purple:#6f42c1;--bs-pink:#d63384;--bs-red:#dc3545;--bs-orange:#fd7e14;--bs-yellow:#ffc107;--bs-green:#198754;--bs-teal:#20c997;--bs-cyan:#0dcaf0;--bs-black:#000;--bs-white:#fff;--bs-gray:#6c757d;--bs-gray-dark:#343a40;--bs-gray-100:#f8f9fa;--bs-gray-200:#e9ecef;--bs-gray-300:#dee2e6;--bs-gray-400:#ced4da;--bs-gray-500:#adb5bd;--bs-gray-600:#6c757d;--bs-gray-700:#495057;--bs-gray-800:#343a40;--bs-gray-900:#212529;--bs-primary:#0d6efd;--bs-secondary:#6c757d;--bs-success:#198754;--bs-info:#0dcaf0;--bs-warning:#ffc107;--bs-danger:#dc3545;--bs-light:#f8f9fa;--bs-dark:#212529;--bs-primary-rgb:13,110,253;--bs-secondary-rgb:108,117,125;--bs-success-rgb:25,135,84;--bs-info-rgb:13,202,240;--bs-warning-rgb:255,193,7;--bs-danger-rgb:220,53,69;--bs-light-rgb:248,249,250;--bs-dark-rgb:33,37,41;--bs-primary-text-emphasis:#052c65;--bs-secondary-text-emphasis:#2b2f32;--bs-success-text-emphasis:#0a3622;--bs-info-text-emphasis:#055160;--bs-warning-text-emphasis:#664d03;--bs-danger-text-emphasis:#58151c;--bs-light-text-emphasis:#495057;--bs-dark-text-emphasis:#495057;--bs-primary-bg-subtle:#cfe2ff;--bs-secondary-bg-subtle:#e2e3e5;--bs-success-bg-subtle:#d1e7dd;--bs-info-bg-subtle:#cff4fc;--bs-warning-bg-subtle:#fff3cd;--bs-danger-bg-subtle:#f8d7da;--bs-light-bg-subtle:#fcfcfd;--bs-dark-bg-subtle:#ced4da;--bs-primary-border-subtle:#9ec5fe;--bs-secondary-border-subtle:#c4c8cb;--bs-success-border-subtle:#a3cfbb;--bs-info-border-subtle:#9eeaf9;--bs-warning-border-subtle:#ffe69c;--bs-danger-border-subtle:#f1aeb5;--bs-light-border-subtle:#e9ecef;--bs-dark-border-subtle:#adb5bd;--bs-white-rgb:255,255,255;--bs-black-rgb:0,0,0;--bs-font-sans-serif:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue","Noto Sans","Liberation Sans",Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--bs-font-monospace:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--bs-gradient:linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));--bs-body-font-family:var(--bs-font-sans-serif);--bs-body-font-size:1rem;--bs-body-font-weight:400;--bs-body-line-height:1.5;--bs-body-color:#212529;--bs-body-color-rgb:33,37,41;--bs-body-bg:#fff;--bs-body-bg-rgb:255,255,255;--bs-emphasis-color:#000;--bs-emphasis-color-rgb:0,0,0;--bs-secondary-color:rgba(33, 37, 41, 0.75);--bs-secondary-color-rgb:33,37,41;--bs-secondary-bg:#e9ecef;--bs-secondary-bg-rgb:233,236,239;--bs-tertiary-color:rgba(33, 37, 41, 0.5);--bs-tertiary-color-rgb:33,37,41;--bs-tertiary-bg:#f8f9fa;--bs-tertiary-bg-rgb:248,249,250;--bs-heading-color:inherit;--bs-link-color:#0d6efd;--bs-link-color-rgb:13,110,253;--bs-link-decoration:underline;--bs-link-hover-color:#0a58ca;--bs-link-hover-color-rgb:10,88,202;--bs-code-color:#d63384;--bs-highlight-color:#212529;--bs-highlight-bg:#fff3cd;--bs-border-width:1px;--bs-border-style:solid;--bs-border-color:#dee2e6;--bs-border-color-translucent:rgba(0, 0, 0, 0.175);--bs-border-radius:0.375rem;--bs-border-radius-sm:0.25rem;--bs-border-radius-lg:0.5rem;--bs-border-radius-xl:1rem;--bs-border-radius-xxl:2rem;--bs-border-radius-2xl:var(--bs-border-radius-xxl);--bs-border-radius-pill:50rem;--bs-box-shadow:0 0.5rem 1rem rgba(0, 0, 0, 0.15);--bs-box-shadow-sm:0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);--bs-box-shadow-lg:0 1rem 3rem rgba(0, 0, 0, 0.175);--bs-box-shadow-inset:inset 0 1px 2px rgba(0, 0, 0, 0.075);--bs-focus-ring-width:0.25rem;--bs-focus-ring-opacity:0.25;--bs-focus-ring-color:rgba(13, 110, 253, 0.25);--bs-form-valid-color:#198754;--bs-form-valid-border-color:#198754;--bs-form-invalid-color:#dc3545;--bs-form-invalid-border-color:#dc3545}[data-bs-theme=dark]{color-scheme:dark;--bs-body-color:#dee2e6;--bs-body-color-rgb:222,226,230;--bs-body-bg:#212529;--bs-body-bg-rgb:33,37,41;--bs-emphasis-color:#fff;--bs-emphasis-color-rgb:255,255,255;--bs-secondary-color:rgba(222, 226, 230, 0.75);--bs-secondary-color-rgb:222,226,230;--bs-secondary-bg:#343a40;--bs-secondary-bg-rgb:52,58,64;--bs-tertiary-color:rgba(222, 226, 230, 0.5);--bs-tertiary-color-rgb:222,226,230;--bs-tertiary-bg:#2b3035;--bs-tertiary-bg-rgb:43,48,53;--bs-primary-text-emphasis:#6ea8fe;--bs-secondary-text-emphasis:#a7acb1;--bs-success-text-emphasis:#75b798;--bs-info-text-emphasis:#6edff6;--bs-warning-text-emphasis:#ffda6a;--bs-danger-text-emphasis:#ea868f;--bs-light-text-emphasis:#f8f9fa;--bs-dark-text-emphasis:#dee2e6;--bs-primary-bg-subtle:#031633;--bs-secondary-bg-subtle:#161719;--bs-success-bg-subtle:#051b11;--bs-info-bg-subtle:#032830;--bs-warning-bg-subtle:#332701;--bs-danger-bg-subtle:#2c0b0e;--bs-light-bg-subtle:#343a40;--bs-dark-bg-subtle:#1a1d20;--bs-primary-border-subtle:#084298;--bs-secondary-border-subtle:#41464b;--bs-success-border-subtle:#0f5132;--bs-info-border-subtle:#087990;--bs-warning-border-subtle:#997404;--bs-danger-border-subtle:#842029;--bs-light-border-subtle:#495057;--bs-dark-border-subtle:#343a40;--bs-heading-color:inherit;--bs-link-color:#6ea8fe;--bs-link-hover-color:#8bb9fe;--bs-link-color-rgb:110,168,254;--bs-link-hover-color-rgb:139,185,254;--bs-code-color:#e685b5;--bs-highlight-color:#dee2e6;--bs-highlight-bg:#664d03;--bs-border-color:#495057;--bs-border-color-translucent:rgba(255, 255, 255, 0.15);--bs-form-valid-color:#75b798;--bs-form-valid-border-color:#75b798;--bs-form-invalid-color:#ea868f;--bs-form-invalid-border-color:#ea868f}*,::after,::before{box-sizing:border-box}@media (prefers-reduced-motion:no-preference){:root{scroll-behavior:smooth}}body{margin:0;font-family:var(--bs-body-font-family);font-size:var(--bs-body-font-size);font-weight:var(--bs-body-font-weight);line-height:var(--bs-body-line-height);color:var(--bs-body-color);text-align:var(--bs-body-text-align);background-color:var(--bs-body-bg);-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}hr{margin:1rem 0;color:inherit;border:0;border-top:var(--bs-border-width) solid;opacity:.25}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{margin-top:0;margin-bottom:.5rem;font-weight:500;line-height:1.2;color:var(--bs-heading-color)}.h1,h1{font-size:calc(1.375rem + 1.5vw)}@media (min-width:1200px){.h1,h1{font-size:2.5rem}}.h2,h2{font-size:calc(1.325rem + .9vw)}@media (min-width:1200px){.h2,h2{font-size:2rem}}.h3,h3{font-size:calc(1.3rem + .6vw)}@media (min-width:1200px){.h3,h3{font-size:1.75rem}}.h4,h4{font-size:calc(1.275rem + .3vw)}@media (min-width:1200px){.h4,h4{font-size:1.5rem}}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}p{margin-top:0;margin-bottom:1rem}abbr[title]{-webkit-text-decoration:underline dotted;text-decoration:underline dotted;cursor:help;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none}address{margin-bottom:1rem;font-style:normal;line-height:inherit}ol,ul{padding-left:2rem}dl,ol,ul{margin-top:0;margin-bottom:1rem}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}.small,small{font-size:.875em}.mark,mark{padding:.1875em;color:var(--bs-highlight-color);background-color:var(--bs-highlight-bg)}sub,sup{position:relative;font-size:.75em;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:rgba(var(--bs-link-color-rgb),var(--bs-link-opacity,1));text-decoration:underline}a:hover{--bs-link-color-rgb:var(--bs-link-hover-color-rgb)}a:not([href]):not([class]),a:not([href]):not([class]):hover{color:inherit;text-decoration:none}code,kbd,pre,samp{font-family:var(--bs-font-monospace);font-size:1em}pre{display:block;margin-top:0;margin-bottom:1rem;overflow:auto;font-size:.875em}pre code{font-size:inherit;color:inherit;word-break:normal}code{font-size:.875em;color:var(--bs-code-color);word-wrap:break-word}a>code{color:inherit}kbd{padding:.1875rem .375rem;font-size:.875em;color:var(--bs-body-bg);background-color:var(--bs-body-color);border-radius:.25rem}kbd kbd{padding:0;font-size:1em}figure{margin:0 0 1rem}img,svg{vertical-align:middle}table{caption-side:bottom;border-collapse:collapse}caption{padding-top:.5rem;padding-bottom:.5rem;color:var(--bs-secondary-color);text-align:left}th{text-align:inherit;text-align:-webkit-match-parent}tbody,td,tfoot,th,thead,tr{border-color:inherit;border-style:solid;border-width:0}label{display:inline-block}button{border-radius:0}button:focus:not(:focus-visible){outline:0}button,input,optgroup,select,textarea{margin:0;font-family:inherit;font-size:inherit;line-height:inherit}button,select{text-transform:none}[role=button]{cursor:pointer}select{word-wrap:normal}select:disabled{opacity:1}[list]:not([type=date]):not([type=datetime-local]):not([type=month]):not([type=week]):not([type=time])::-webkit-calendar-picker-indicator{display:none!important}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]:not(:disabled),[type=reset]:not(:disabled),[type=submit]:not(:disabled),button:not(:disabled){cursor:pointer}::-moz-focus-inner{padding:0;border-style:none}textarea{resize:vertical}fieldset{min-width:0;padding:0;margin:0;border:0}legend{float:left;width:100%;padding:0;margin-bottom:.5rem;line-height:inherit;font-size:calc(1.275rem + .3vw)}@media (min-width:1200px){legend{font-size:1.5rem}}legend+*{clear:left}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-fields-wrapper,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-text,::-webkit-datetime-edit-year-field{padding:0}::-webkit-inner-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-color-swatch-wrapper{padding:0}::-webkit-file-upload-button{font:inherit;-webkit-appearance:button}::file-selector-button{font:inherit;-webkit-appearance:button}output{display:inline-block}iframe{border:0}summary{display:list-item;cursor:pointer}progress{vertical-align:baseline}[hidden]{display:none!important}.lead{font-size:1.25rem;font-weight:300}.display-1{font-weight:300;line-height:1.2;font-size:calc(1.625rem + 4.5vw)}@media (min-width:1200px){.display-1{font-size:5rem}}.display-2{font-weight:300;line-height:1.2;font-size:calc(1.575rem + 3.9vw)}@media (min-width:1200px){.display-2{font-size:4.5rem}}.display-3{font-weight:300;line-height:1.2;font-size:calc(1.525rem + 3.3vw)}@media (min-width:1200px){.display-3{font-size:4rem}}.display-4{font-weight:300;line-height:1.2;font-size:calc(1.475rem + 2.7vw)}@media (min-width:1200px){.display-4{font-size:3.5rem}}.display-5{font-weight:300;line-height:1.2;font-size:calc(1.425rem + 2.1vw)}@media (min-width:1200px){.display-5{font-size:3rem}}.display-6{font-weight:300;line-height:1.2;font-size:calc(1.375rem + 1.5vw)}@media (min-width:1200px){.display-6{font-size:2.5rem}}.list-unstyled{padding-left:0;list-style:none}.list-inline{padding-left:0;list-style:none}.list-inline-item{display:inline-block}.list-inline-item:not(:last-child){margin-right:.5rem}.initialism{font-size:.875em;text-transform:uppercase}.blockquote{margin-bottom:1rem;font-size:1.25rem}.blockquote>:last-child{margin-bottom:0}.blockquote-footer{margin-top:-1rem;margin-bottom:1rem;font-size:.875em;color:#6c757d}.blockquote-footer::before{content:"— "}.img-fluid{max-width:100%;height:auto}.img-thumbnail{padding:.25rem;background-color:var(--bs-body-bg);border:var(--bs-border-width) solid var(--bs-border-color);border-radius:var(--bs-border-radius);max-width:100%;height:auto}.figure{display:inline-block}.figure-img{margin-bottom:.5rem;line-height:1}.figure-caption{font-size:.875em;color:var(--bs-secondary-color)}.container,.container-fluid,.container-lg,.container-md,.container-sm,.container-xl,.container-xxl{--bs-gutter-x:1.5rem;--bs-gutter-y:0;width:100%;padding-right:calc(var(--bs-gutter-x) * .5);padding-left:calc(var(--bs-gutter-x) * .5);margin-right:auto;margin-left:auto}@media (min-width:576px){.container,.container-sm{max-width:540px}}@media (min-width:768px){.container,.container-md,.container-sm{max-width:720px}}@media (min-width:992px){.container,.container-lg,.container-md,.container-sm{max-width:960px}}@media (min-width:1200px){.container,.container-lg,.container-md,.container-sm,.container-xl{max-width:1140px}}@media (min-width:1400px){.container,.container-lg,.container-md,.container-sm,.container-xl,.container-xxl{max-width:1320px}}:root{--bs-breakpoint-xs:0;--bs-breakpoint-sm:576px;--bs-breakpoint-md:768px;--bs-breakpoint-lg:992px;--bs-breakpoint-xl:1200px;--bs-breakpoint-xxl:1400px}.row{--bs-gutter-x:1.5rem;--bs-gutter-y:0;display:flex;flex-wrap:wrap;margin-top:calc(-1 * var(--bs-gutter-y));margin-right:calc(-.5 * var(--bs-gutter-x));margin-left:calc(-.5 * var(--bs-gutter-x))}.row>*{flex-shrink:0;width:100%;max-width:100%;padding-right:calc(var(--bs-gutter-x) * .5);padding-left:calc(var(--bs-gutter-x) * .5);margin-top:var(--bs-gutter-y)}.col{flex:1 0 0}.row-cols-auto>*{flex:0 0 auto;width:auto}.row-cols-1>*{flex:0 0 auto;width:100%}.row-cols-2>*{flex:0 0 auto;width:50%}.row-cols-3>*{flex:0 0 auto;width:33.33333333%}.row-cols-4>*{flex:0 0 auto;width:25%}.row-cols-5>*{flex:0 0 auto;width:20%}.row-cols-6>*{flex:0 0 auto;width:16.66666667%}.col-auto{flex:0 0 auto;width:auto}.col-1{flex:0 0 auto;width:8.33333333%}.col-2{flex:0 0 auto;width:16.66666667%}.col-3{flex:0 0 auto;width:25%}.col-4{flex:0 0 auto;width:33.33333333%}.col-5{flex:0 0 auto;width:41.66666667%}.col-6{flex:0 0 auto;width:50%}.col-7{flex:0 0 auto;width:58.33333333%}.col-8{flex:0 0 auto;width:66.66666667%}.col-9{flex:0 0 auto;width:75%}.col-10{flex:0 0 auto;width:83.33333333%}.col-11{flex:0 0 auto;width:91.66666667%}.col-12{flex:0 0 auto;width:100%}.offset-1{margin-left:8.33333333%}.offset-2{margin-left:16.66666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.33333333%}.offset-5{margin-left:41.66666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.33333333%}.offset-8{margin-left:66.66666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.33333333%}.offset-11{margin-left:91.66666667%}.g-0,.gx-0{--bs-gutter-x:0}.g-0,.gy-0{--bs-gutter-y:0}.g-1,.gx-1{--bs-gutter-x:0.25rem}.g-1,.gy-1{--bs-gutter-y:0.25rem}.g-2,.gx-2{--bs-gutter-x:0.5rem}.g-2,.gy-2{--bs-gutter-y:0.5rem}.g-3,.gx-3{--bs-gutter-x:1rem}.g-3,.gy-3{--bs-gutter-y:1rem}.g-4,.gx-4{--bs-gutter-x:1.5rem}.g-4,.gy-4{--bs-gutter-y:1.5rem}.g-5,.gx-5{--bs-gutter-x:3rem}.g-5,.gy-5{--bs-gutter-y:3rem}@media (min-width:576px){.col-sm{flex:1 0 0}.row-cols-sm-auto>*{flex:0 0 auto;width:auto}.row-cols-sm-1>*{flex:0 0 auto;width:100%}.row-cols-sm-2>*{flex:0 0 auto;width:50%}.row-cols-sm-3>*{flex:0 0 auto;width:33.33333333%}.row-cols-sm-4>*{flex:0 0 auto;width:25%}.row-cols-sm-5>*{flex:0 0 auto;width:20%}.row-cols-sm-6>*{flex:0 0 auto;width:16.66666667%}.col-sm-auto{flex:0 0 auto;width:auto}.col-sm-1{flex:0 0 auto;width:8.33333333%}.col-sm-2{flex:0 0 auto;width:16.66666667%}.col-sm-3{flex:0 0 auto;width:25%}.col-sm-4{flex:0 0 auto;width:33.33333333%}.col-sm-5{flex:0 0 auto;width:41.66666667%}.col-sm-6{flex:0 0 auto;width:50%}.col-sm-7{flex:0 0 auto;width:58.33333333%}.col-sm-8{flex:0 0 auto;width:66.66666667%}.col-sm-9{flex:0 0 auto;width:75%}.col-sm-10{flex:0 0 auto;width:83.33333333%}.col-sm-11{flex:0 0 auto;width:91.66666667%}.col-sm-12{flex:0 0 auto;width:100%}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.33333333%}.offset-sm-2{margin-left:16.66666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.33333333%}.offset-sm-5{margin-left:41.66666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.33333333%}.offset-sm-8{margin-left:66.66666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.33333333%}.offset-sm-11{margin-left:91.66666667%}.g-sm-0,.gx-sm-0{--bs-gutter-x:0}.g-sm-0,.gy-sm-0{--bs-gutter-y:0}.g-sm-1,.gx-sm-1{--bs-gutter-x:0.25rem}.g-sm-1,.gy-sm-1{--bs-gutter-y:0.25rem}.g-sm-2,.gx-sm-2{--bs-gutter-x:0.5rem}.g-sm-2,.gy-sm-2{--bs-gutter-y:0.5rem}.g-sm-3,.gx-sm-3{--bs-gutter-x:1rem}.g-sm-3,.gy-sm-3{--bs-gutter-y:1rem}.g-sm-4,.gx-sm-4{--bs-gutter-x:1.5rem}.g-sm-4,.gy-sm-4{--bs-gutter-y:1.5rem}.g-sm-5,.gx-sm-5{--bs-gutter-x:3rem}.g-sm-5,.gy-sm-5{--bs-gutter-y:3rem}}@media (min-width:768px){.col-md{flex:1 0 0}.row-cols-md-auto>*{flex:0 0 auto;width:auto}.row-cols-md-1>*{flex:0 0 auto;width:100%}.row-cols-md-2>*{flex:0 0 auto;width:50%}.row-cols-md-3>*{flex:0 0 auto;width:33.33333333%}.row-cols-md-4>*{flex:0 0 auto;width:25%}.row-cols-md-5>*{flex:0 0 auto;width:20%}.row-cols-md-6>*{flex:0 0 auto;width:16.66666667%}.col-md-auto{flex:0 0 auto;width:auto}.col-md-1{flex:0 0 auto;width:8.33333333%}.col-md-2{flex:0 0 auto;width:16.66666667%}.col-md-3{flex:0 0 auto;width:25%}.col-md-4{flex:0 0 auto;width:33.33333333%}.col-md-5{flex:0 0 auto;width:41.66666667%}.col-md-6{flex:0 0 auto;width:50%}.col-md-7{flex:0 0 auto;width:58.33333333%}.col-md-8{flex:0 0 auto;width:66.66666667%}.col-md-9{flex:0 0 auto;width:75%}.col-md-10{flex:0 0 auto;width:83.33333333%}.col-md-11{flex:0 0 auto;width:91.66666667%}.col-md-12{flex:0 0 auto;width:100%}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.33333333%}.offset-md-2{margin-left:16.66666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.33333333%}.offset-md-5{margin-left:41.66666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.33333333%}.offset-md-8{margin-left:66.66666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.33333333%}.offset-md-11{margin-left:91.66666667%}.g-md-0,.gx-md-0{--bs-gutter-x:0}.g-md-0,.gy-md-0{--bs-gutter-y:0}.g-md-1,.gx-md-1{--bs-gutter-x:0.25rem}.g-md-1,.gy-md-1{--bs-gutter-y:0.25rem}.g-md-2,.gx-md-2{--bs-gutter-x:0.5rem}.g-md-2,.gy-md-2{--bs-gutter-y:0.5rem}.g-md-3,.gx-md-3{--bs-gutter-x:1rem}.g-md-3,.gy-md-3{--bs-gutter-y:1rem}.g-md-4,.gx-md-4{--bs-gutter-x:1.5rem}.g-md-4,.gy-md-4{--bs-gutter-y:1.5rem}.g-md-5,.gx-md-5{--bs-gutter-x:3rem}.g-md-5,.gy-md-5{--bs-gutter-y:3rem}}@media (min-width:992px){.col-lg{flex:1 0 0}.row-cols-lg-auto>*{flex:0 0 auto;width:auto}.row-cols-lg-1>*{flex:0 0 auto;width:100%}.row-cols-lg-2>*{flex:0 0 auto;width:50%}.row-cols-lg-3>*{flex:0 0 auto;width:33.33333333%}.row-cols-lg-4>*{flex:0 0 auto;width:25%}.row-cols-lg-5>*{flex:0 0 auto;width:20%}.row-cols-lg-6>*{flex:0 0 auto;width:16.66666667%}.col-lg-auto{flex:0 0 auto;width:auto}.col-lg-1{flex:0 0 auto;width:8.33333333%}.col-lg-2{flex:0 0 auto;width:16.66666667%}.col-lg-3{flex:0 0 auto;width:25%}.col-lg-4{flex:0 0 auto;width:33.33333333%}.col-lg-5{flex:0 0 auto;width:41.66666667%}.col-lg-6{flex:0 0 auto;width:50%}.col-lg-7{flex:0 0 auto;width:58.33333333%}.col-lg-8{flex:0 0 auto;width:66.66666667%}.col-lg-9{flex:0 0 auto;width:75%}.col-lg-10{flex:0 0 auto;width:83.33333333%}.col-lg-11{flex:0 0 auto;width:91.66666667%}.col-lg-12{flex:0 0 auto;width:100%}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.33333333%}.offset-lg-2{margin-left:16.66666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.33333333%}.offset-lg-5{margin-left:41.66666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.33333333%}.offset-lg-8{margin-left:66.66666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.33333333%}.offset-lg-11{margin-left:91.66666667%}.g-lg-0,.gx-lg-0{--bs-gutter-x:0}.g-lg-0,.gy-lg-0{--bs-gutter-y:0}.g-lg-1,.gx-lg-1{--bs-gutter-x:0.25rem}.g-lg-1,.gy-lg-1{--bs-gutter-y:0.25rem}.g-lg-2,.gx-lg-2{--bs-gutter-x:0.5rem}.g-lg-2,.gy-lg-2{--bs-gutter-y:0.5rem}.g-lg-3,.gx-lg-3{--bs-gutter-x:1rem}.g-lg-3,.gy-lg-3{--bs-gutter-y:1rem}.g-lg-4,.gx-lg-4{--bs-gutter-x:1.5rem}.g-lg-4,.gy-lg-4{--bs-gutter-y:1.5rem}.g-lg-5,.gx-lg-5{--bs-gutter-x:3rem}.g-lg-5,.gy-lg-5{--bs-gutter-y:3rem}}@media (min-width:1200px){.col-xl{flex:1 0 0}.row-cols-xl-auto>*{flex:0 0 auto;width:auto}.row-cols-xl-1>*{flex:0 0 auto;width:100%}.row-cols-xl-2>*{flex:0 0 auto;width:50%}.row-cols-xl-3>*{flex:0 0 auto;width:33.33333333%}.row-cols-xl-4>*{flex:0 0 auto;width:25%}.row-cols-xl-5>*{flex:0 0 auto;width:20%}.row-cols-xl-6>*{flex:0 0 auto;width:16.66666667%}.col-xl-auto{flex:0 0 auto;width:auto}.col-xl-1{flex:0 0 auto;width:8.33333333%}.col-xl-2{flex:0 0 auto;width:16.66666667%}.col-xl-3{flex:0 0 auto;width:25%}.col-xl-4{flex:0 0 auto;width:33.33333333%}.col-xl-5{flex:0 0 auto;width:41.66666667%}.col-xl-6{flex:0 0 auto;width:50%}.col-xl-7{flex:0 0 auto;width:58.33333333%}.col-xl-8{flex:0 0 auto;width:66.66666667%}.col-xl-9{flex:0 0 auto;width:75%}.col-xl-10{flex:0 0 auto;width:83.33333333%}.col-xl-11{flex:0 0 auto;width:91.66666667%}.col-xl-12{flex:0 0 auto;width:100%}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.33333333%}.offset-xl-2{margin-left:16.66666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.33333333%}.offset-xl-5{margin-left:41.66666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.33333333%}.offset-xl-8{margin-left:66.66666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.33333333%}.offset-xl-11{margin-left:91.66666667%}.g-xl-0,.gx-xl-0{--bs-gutter-x:0}.g-xl-0,.gy-xl-0{--bs-gutter-y:0}.g-xl-1,.gx-xl-1{--bs-gutter-x:0.25rem}.g-xl-1,.gy-xl-1{--bs-gutter-y:0.25rem}.g-xl-2,.gx-xl-2{--bs-gutter-x:0.5rem}.g-xl-2,.gy-xl-2{--bs-gutter-y:0.5rem}.g-xl-3,.gx-xl-3{--bs-gutter-x:1rem}.g-xl-3,.gy-xl-3{--bs-gutter-y:1rem}.g-xl-4,.gx-xl-4{--bs-gutter-x:1.5rem}.g-xl-4,.gy-xl-4{--bs-gutter-y:1.5rem}.g-xl-5,.gx-xl-5{--bs-gutter-x:3rem}.g-xl-5,.gy-xl-5{--bs-gutter-y:3rem}}@media (min-width:1400px){.col-xxl{flex:1 0 0}.row-cols-xxl-auto>*{flex:0 0 auto;width:auto}.row-cols-xxl-1>*{flex:0 0 auto;width:100%}.row-cols-xxl-2>*{flex:0 0 auto;width:50%}.row-cols-xxl-3>*{flex:0 0 auto;width:33.33333333%}.row-cols-xxl-4>*{flex:0 0 auto;width:25%}.row-cols-xxl-5>*{flex:0 0 auto;width:20%}.row-cols-xxl-6>*{flex:0 0 auto;width:16.66666667%}.col-xxl-auto{flex:0 0 auto;width:auto}.col-xxl-1{flex:0 0 auto;width:8.33333333%}.col-xxl-2{flex:0 0 auto;width:16.66666667%}.col-xxl-3{flex:0 0 auto;width:25%}.col-xxl-4{flex:0 0 auto;width:33.33333333%}.col-xxl-5{flex:0 0 auto;width:41.66666667%}.col-xxl-6{flex:0 0 auto;width:50%}.col-xxl-7{flex:0 0 auto;width:58.33333333%}.col-xxl-8{flex:0 0 auto;width:66.66666667%}.col-xxl-9{flex:0 0 auto;width:75%}.col-xxl-10{flex:0 0 auto;width:83.33333333%}.col-xxl-11{flex:0 0 auto;width:91.66666667%}.col-xxl-12{flex:0 0 auto;width:100%}.offset-xxl-0{margin-left:0}.offset-xxl-1{margin-left:8.33333333%}.offset-xxl-2{margin-left:16.66666667%}.offset-xxl-3{margin-left:25%}.offset-xxl-4{margin-left:33.33333333%}.offset-xxl-5{margin-left:41.66666667%}.offset-xxl-6{margin-left:50%}.offset-xxl-7{margin-left:58.33333333%}.offset-xxl-8{margin-left:66.66666667%}.offset-xxl-9{margin-left:75%}.offset-xxl-10{margin-left:83.33333333%}.offset-xxl-11{margin-left:91.66666667%}.g-xxl-0,.gx-xxl-0{--bs-gutter-x:0}.g-xxl-0,.gy-xxl-0{--bs-gutter-y:0}.g-xxl-1,.gx-xxl-1{--bs-gutter-x:0.25rem}.g-xxl-1,.gy-xxl-1{--bs-gutter-y:0.25rem}.g-xxl-2,.gx-xxl-2{--bs-gutter-x:0.5rem}.g-xxl-2,.gy-xxl-2{--bs-gutter-y:0.5rem}.g-xxl-3,.gx-xxl-3{--bs-gutter-x:1rem}.g-xxl-3,.gy-xxl-3{--bs-gutter-y:1rem}.g-xxl-4,.gx-xxl-4{--bs-gutter-x:1.5rem}.g-xxl-4,.gy-xxl-4{--bs-gutter-y:1.5rem}.g-xxl-5,.gx-xxl-5{--bs-gutter-x:3rem}.g-xxl-5,.gy-xxl-5{--bs-gutter-y:3rem}}.table{--bs-table-color-type:initial;--bs-table-bg-type:initial;--bs-table-color-state:initial;--bs-table-bg-state:initial;--bs-table-color:var(--bs-emphasis-color);--bs-table-bg:var(--bs-body-bg);--bs-table-border-color:var(--bs-border-color);--bs-table-accent-bg:transparent;--bs-table-striped-color:var(--bs-emphasis-color);--bs-table-striped-bg:rgba(var(--bs-emphasis-color-rgb), 0.05);--bs-table-active-color:var(--bs-emphasis-color);--bs-table-active-bg:rgba(var(--bs-emphasis-color-rgb), 0.1);--bs-table-hover-color:var(--bs-emphasis-color);--bs-table-hover-bg:rgba(var(--bs-emphasis-color-rgb), 0.075);width:100%;margin-bottom:1rem;vertical-align:top;border-color:var(--bs-table-border-color)}.table>:not(caption)>*>*{padding:.5rem .5rem;color:var(--bs-table-color-state,var(--bs-table-color-type,var(--bs-table-color)));background-color:var(--bs-table-bg);border-bottom-width:var(--bs-border-width);box-shadow:inset 0 0 0 9999px var(--bs-table-bg-state,var(--bs-table-bg-type,var(--bs-table-accent-bg)))}.table>tbody{vertical-align:inherit}.table>thead{vertical-align:bottom}.table-group-divider{border-top:calc(var(--bs-border-width) * 2) solid currentcolor}.caption-top{caption-side:top}.table-sm>:not(caption)>*>*{padding:.25rem .25rem}.table-bordered>:not(caption)>*{border-width:var(--bs-border-width) 0}.table-bordered>:not(caption)>*>*{border-width:0 var(--bs-border-width)}.table-borderless>:not(caption)>*>*{border-bottom-width:0}.table-borderless>:not(:first-child){border-top-width:0}.table-striped>tbody>tr:nth-of-type(odd)>*{--bs-table-color-type:var(--bs-table-striped-color);--bs-table-bg-type:var(--bs-table-striped-bg)}.table-striped-columns>:not(caption)>tr>:nth-child(2n){--bs-table-color-type:var(--bs-table-striped-color);--bs-table-bg-type:var(--bs-table-striped-bg)}.table-active{--bs-table-color-state:var(--bs-table-active-color);--bs-table-bg-state:var(--bs-table-active-bg)}.table-hover>tbody>tr:hover>*{--bs-table-color-state:var(--bs-table-hover-color);--bs-table-bg-state:var(--bs-table-hover-bg)}.table-primary{--bs-table-color:#000;--bs-table-bg:#cfe2ff;--bs-table-border-color:#a6b5cc;--bs-table-striped-bg:#c5d7f2;--bs-table-striped-color:#000;--bs-table-active-bg:#bacbe6;--bs-table-active-color:#000;--bs-table-hover-bg:#bfd1ec;--bs-table-hover-color:#000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-secondary{--bs-table-color:#000;--bs-table-bg:#e2e3e5;--bs-table-border-color:#b5b6b7;--bs-table-striped-bg:#d7d8da;--bs-table-striped-color:#000;--bs-table-active-bg:#cbccce;--bs-table-active-color:#000;--bs-table-hover-bg:#d1d2d4;--bs-table-hover-color:#000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-success{--bs-table-color:#000;--bs-table-bg:#d1e7dd;--bs-table-border-color:#a7b9b1;--bs-table-striped-bg:#c7dbd2;--bs-table-striped-color:#000;--bs-table-active-bg:#bcd0c7;--bs-table-active-color:#000;--bs-table-hover-bg:#c1d6cc;--bs-table-hover-color:#000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-info{--bs-table-color:#000;--bs-table-bg:#cff4fc;--bs-table-border-color:#a6c3ca;--bs-table-striped-bg:#c5e8ef;--bs-table-striped-color:#000;--bs-table-active-bg:#badce3;--bs-table-active-color:#000;--bs-table-hover-bg:#bfe2e9;--bs-table-hover-color:#000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-warning{--bs-table-color:#000;--bs-table-bg:#fff3cd;--bs-table-border-color:#ccc2a4;--bs-table-striped-bg:#f2e7c3;--bs-table-striped-color:#000;--bs-table-active-bg:#e6dbb9;--bs-table-active-color:#000;--bs-table-hover-bg:#ece1be;--bs-table-hover-color:#000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-danger{--bs-table-color:#000;--bs-table-bg:#f8d7da;--bs-table-border-color:#c6acae;--bs-table-striped-bg:#eccccf;--bs-table-striped-color:#000;--bs-table-active-bg:#dfc2c4;--bs-table-active-color:#000;--bs-table-hover-bg:#e5c7ca;--bs-table-hover-color:#000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-light{--bs-table-color:#000;--bs-table-bg:#f8f9fa;--bs-table-border-color:#c6c7c8;--bs-table-striped-bg:#ecedee;--bs-table-striped-color:#000;--bs-table-active-bg:#dfe0e1;--bs-table-active-color:#000;--bs-table-hover-bg:#e5e6e7;--bs-table-hover-color:#000;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-dark{--bs-table-color:#fff;--bs-table-bg:#212529;--bs-table-border-color:#4d5154;--bs-table-striped-bg:#2c3034;--bs-table-striped-color:#fff;--bs-table-active-bg:#373b3e;--bs-table-active-color:#fff;--bs-table-hover-bg:#323539;--bs-table-hover-color:#fff;color:var(--bs-table-color);border-color:var(--bs-table-border-color)}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}@media (max-width:575.98px){.table-responsive-sm{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width:767.98px){.table-responsive-md{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width:991.98px){.table-responsive-lg{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width:1199.98px){.table-responsive-xl{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width:1399.98px){.table-responsive-xxl{overflow-x:auto;-webkit-overflow-scrolling:touch}}.form-label{margin-bottom:.5rem}.col-form-label{padding-top:calc(.375rem + var(--bs-border-width));padding-bottom:calc(.375rem + var(--bs-border-width));margin-bottom:0;font-size:inherit;line-height:1.5}.col-form-label-lg{padding-top:calc(.5rem + var(--bs-border-width));padding-bottom:calc(.5rem + var(--bs-border-width));font-size:1.25rem}.col-form-label-sm{padding-top:calc(.25rem + var(--bs-border-width));padding-bottom:calc(.25rem + var(--bs-border-width));font-size:.875rem}.form-text{margin-top:.25rem;font-size:.875em;color:var(--bs-secondary-color)}.form-control{display:block;width:100%;padding:.375rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;color:var(--bs-body-color);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--bs-body-bg);background-clip:padding-box;border:var(--bs-border-width) solid var(--bs-border-color);border-radius:var(--bs-border-radius);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.form-control{transition:none}}.form-control[type=file]{overflow:hidden}.form-control[type=file]:not(:disabled):not([readonly]){cursor:pointer}.form-control:focus{color:var(--bs-body-color);background-color:var(--bs-body-bg);border-color:#86b7fe;outline:0;box-shadow:0 0 0 .25rem rgba(13,110,253,.25)}.form-control::-webkit-date-and-time-value{min-width:85px;height:1.5em;margin:0}.form-control::-webkit-datetime-edit{display:block;padding:0}.form-control::placeholder{color:var(--bs-secondary-color);opacity:1}.form-control:disabled{background-color:var(--bs-secondary-bg);opacity:1}.form-control::-webkit-file-upload-button{padding:.375rem .75rem;margin:-.375rem -.75rem;-webkit-margin-end:.75rem;margin-inline-end:.75rem;color:var(--bs-body-color);background-color:var(--bs-tertiary-bg);pointer-events:none;border-color:inherit;border-style:solid;border-width:0;border-inline-end-width:var(--bs-border-width);border-radius:0;-webkit-transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}.form-control::file-selector-button{padding:.375rem .75rem;margin:-.375rem -.75rem;-webkit-margin-end:.75rem;margin-inline-end:.75rem;color:var(--bs-body-color);background-color:var(--bs-tertiary-bg);pointer-events:none;border-color:inherit;border-style:solid;border-width:0;border-inline-end-width:var(--bs-border-width);border-radius:0;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.form-control::-webkit-file-upload-button{-webkit-transition:none;transition:none}.form-control::file-selector-button{transition:none}}.form-control:hover:not(:disabled):not([readonly])::-webkit-file-upload-button{background-color:var(--bs-secondary-bg)}.form-control:hover:not(:disabled):not([readonly])::file-selector-button{background-color:var(--bs-secondary-bg)}.form-control-plaintext{display:block;width:100%;padding:.375rem 0;margin-bottom:0;line-height:1.5;color:var(--bs-body-color);background-color:transparent;border:solid transparent;border-width:var(--bs-border-width) 0}.form-control-plaintext:focus{outline:0}.form-control-plaintext.form-control-lg,.form-control-plaintext.form-control-sm{padding-right:0;padding-left:0}.form-control-sm{min-height:calc(1.5em + .5rem + calc(var(--bs-border-width) * 2));padding:.25rem .5rem;font-size:.875rem;border-radius:var(--bs-border-radius-sm)}.form-control-sm::-webkit-file-upload-button{padding:.25rem .5rem;margin:-.25rem -.5rem;-webkit-margin-end:.5rem;margin-inline-end:.5rem}.form-control-sm::file-selector-button{padding:.25rem .5rem;margin:-.25rem -.5rem;-webkit-margin-end:.5rem;margin-inline-end:.5rem}.form-control-lg{min-height:calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));padding:.5rem 1rem;font-size:1.25rem;border-radius:var(--bs-border-radius-lg)}.form-control-lg::-webkit-file-upload-button{padding:.5rem 1rem;margin:-.5rem -1rem;-webkit-margin-end:1rem;margin-inline-end:1rem}.form-control-lg::file-selector-button{padding:.5rem 1rem;margin:-.5rem -1rem;-webkit-margin-end:1rem;margin-inline-end:1rem}textarea.form-control{min-height:calc(1.5em + .75rem + calc(var(--bs-border-width) * 2))}textarea.form-control-sm{min-height:calc(1.5em + .5rem + calc(var(--bs-border-width) * 2))}textarea.form-control-lg{min-height:calc(1.5em + 1rem + calc(var(--bs-border-width) * 2))}.form-control-color{width:3rem;height:calc(1.5em + .75rem + calc(var(--bs-border-width) * 2));padding:.375rem}.form-control-color:not(:disabled):not([readonly]){cursor:pointer}.form-control-color::-moz-color-swatch{border:0!important;border-radius:var(--bs-border-radius)}.form-control-color::-webkit-color-swatch{border:0!important;border-radius:var(--bs-border-radius)}.form-control-color.form-control-sm{height:calc(1.5em + .5rem + calc(var(--bs-border-width) * 2))}.form-control-color.form-control-lg{height:calc(1.5em + 1rem + calc(var(--bs-border-width) * 2))}.form-select{--bs-form-select-bg-img:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");display:block;width:100%;padding:.375rem 2.25rem .375rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;color:var(--bs-body-color);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--bs-body-bg);background-image:var(--bs-form-select-bg-img),var(--bs-form-select-bg-icon,none);background-repeat:no-repeat;background-position:right .75rem center;background-size:16px 12px;border:var(--bs-border-width) solid var(--bs-border-color);border-radius:var(--bs-border-radius);transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.form-select{transition:none}}.form-select:focus{border-color:#86b7fe;outline:0;box-shadow:0 0 0 .25rem rgba(13,110,253,.25)}.form-select[multiple],.form-select[size]:not([size="1"]){padding-right:.75rem;background-image:none}.form-select:disabled{background-color:var(--bs-secondary-bg)}.form-select:-moz-focusring{color:transparent;text-shadow:0 0 0 var(--bs-body-color)}.form-select-sm{padding-top:.25rem;padding-bottom:.25rem;padding-left:.5rem;font-size:.875rem;border-radius:var(--bs-border-radius-sm)}.form-select-lg{padding-top:.5rem;padding-bottom:.5rem;padding-left:1rem;font-size:1.25rem;border-radius:var(--bs-border-radius-lg)}[data-bs-theme=dark] .form-select{--bs-form-select-bg-img:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23dee2e6' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e")}.form-check{display:block;min-height:1.5rem;padding-left:1.5em;margin-bottom:.125rem}.form-check .form-check-input{float:left;margin-left:-1.5em}.form-check-reverse{padding-right:1.5em;padding-left:0;text-align:right}.form-check-reverse .form-check-input{float:right;margin-right:-1.5em;margin-left:0}.form-check-input{--bs-form-check-bg:var(--bs-body-bg);flex-shrink:0;width:1em;height:1em;margin-top:.25em;vertical-align:top;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--bs-form-check-bg);background-image:var(--bs-form-check-bg-image);background-repeat:no-repeat;background-position:center;background-size:contain;border:var(--bs-border-width) solid var(--bs-border-color);-webkit-print-color-adjust:exact;color-adjust:exact;print-color-adjust:exact}.form-check-input[type=checkbox]{border-radius:.25em}.form-check-input[type=radio]{border-radius:50%}.form-check-input:active{filter:brightness(90%)}.form-check-input:focus{border-color:#86b7fe;outline:0;box-shadow:0 0 0 .25rem rgba(13,110,253,.25)}.form-check-input:checked{background-color:#0d6efd;border-color:#0d6efd}.form-check-input:checked[type=checkbox]{--bs-form-check-bg-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e")}.form-check-input:checked[type=radio]{--bs-form-check-bg-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23fff'/%3e%3c/svg%3e")}.form-check-input[type=checkbox]:indeterminate{background-color:#0d6efd;border-color:#0d6efd;--bs-form-check-bg-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10h8'/%3e%3c/svg%3e")}.form-check-input:disabled{pointer-events:none;filter:none;opacity:.5}.form-check-input:disabled~.form-check-label,.form-check-input[disabled]~.form-check-label{cursor:default;opacity:.5}.form-switch{padding-left:2.5em}.form-switch .form-check-input{--bs-form-switch-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%280, 0, 0, 0.25%29'/%3e%3c/svg%3e");width:2em;margin-left:-2.5em;background-image:var(--bs-form-switch-bg);background-position:left center;border-radius:2em;transition:background-position .15s ease-in-out}@media (prefers-reduced-motion:reduce){.form-switch .form-check-input{transition:none}}.form-switch .form-check-input:focus{--bs-form-switch-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%2386b7fe'/%3e%3c/svg%3e")}.form-switch .form-check-input:checked{background-position:right center;--bs-form-switch-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e")}.form-switch.form-check-reverse{padding-right:2.5em;padding-left:0}.form-switch.form-check-reverse .form-check-input{margin-right:-2.5em;margin-left:0}.form-check-inline{display:inline-block;margin-right:1rem}.btn-check{position:absolute;clip:rect(0,0,0,0);pointer-events:none}.btn-check:disabled+.btn,.btn-check[disabled]+.btn{pointer-events:none;filter:none;opacity:.65}[data-bs-theme=dark] .form-switch .form-check-input:not(:checked):not(:focus){--bs-form-switch-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%28255, 255, 255, 0.25%29'/%3e%3c/svg%3e")}.form-range{width:100%;height:1.5rem;padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:transparent}.form-range:focus{outline:0}.form-range:focus::-webkit-slider-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .25rem rgba(13,110,253,.25)}.form-range:focus::-moz-range-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .25rem rgba(13,110,253,.25)}.form-range::-moz-focus-outer{border:0}.form-range::-webkit-slider-thumb{width:1rem;height:1rem;margin-top:-.25rem;-webkit-appearance:none;appearance:none;background-color:#0d6efd;border:0;border-radius:1rem;-webkit-transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.form-range::-webkit-slider-thumb{-webkit-transition:none;transition:none}}.form-range::-webkit-slider-thumb:active{background-color:#b6d4fe}.form-range::-webkit-slider-runnable-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:var(--bs-secondary-bg);border-color:transparent;border-radius:1rem}.form-range::-moz-range-thumb{width:1rem;height:1rem;-moz-appearance:none;appearance:none;background-color:#0d6efd;border:0;border-radius:1rem;-moz-transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.form-range::-moz-range-thumb{-moz-transition:none;transition:none}}.form-range::-moz-range-thumb:active{background-color:#b6d4fe}.form-range::-moz-range-track{width:100%;height:.5rem;color:transparent;cursor:pointer;background-color:var(--bs-secondary-bg);border-color:transparent;border-radius:1rem}.form-range:disabled{pointer-events:none}.form-range:disabled::-webkit-slider-thumb{background-color:var(--bs-secondary-color)}.form-range:disabled::-moz-range-thumb{background-color:var(--bs-secondary-color)}.form-floating{position:relative}.form-floating>.form-control,.form-floating>.form-control-plaintext,.form-floating>.form-select{height:calc(3.5rem + calc(var(--bs-border-width) * 2));min-height:calc(3.5rem + calc(var(--bs-border-width) * 2));line-height:1.25}.form-floating>label{position:absolute;top:0;left:0;z-index:2;max-width:100%;height:100%;padding:1rem .75rem;overflow:hidden;color:rgba(var(--bs-body-color-rgb),.65);text-align:start;text-overflow:ellipsis;white-space:nowrap;pointer-events:none;border:var(--bs-border-width) solid transparent;transform-origin:0 0;transition:opacity .1s ease-in-out,transform .1s ease-in-out}@media (prefers-reduced-motion:reduce){.form-floating>label{transition:none}}.form-floating>.form-control,.form-floating>.form-control-plaintext{padding:1rem .75rem}.form-floating>.form-control-plaintext::placeholder,.form-floating>.form-control::placeholder{color:transparent}.form-floating>.form-control-plaintext:focus,.form-floating>.form-control-plaintext:not(:placeholder-shown),.form-floating>.form-control:focus,.form-floating>.form-control:not(:placeholder-shown){padding-top:1.625rem;padding-bottom:.625rem}.form-floating>.form-control-plaintext:-webkit-autofill,.form-floating>.form-control:-webkit-autofill{padding-top:1.625rem;padding-bottom:.625rem}.form-floating>.form-select{padding-top:1.625rem;padding-bottom:.625rem;padding-left:.75rem}.form-floating>.form-control-plaintext~label,.form-floating>.form-control:focus~label,.form-floating>.form-control:not(:placeholder-shown)~label,.form-floating>.form-select~label{transform:scale(.85) translateY(-.5rem) translateX(.15rem)}.form-floating>.form-control:-webkit-autofill~label{transform:scale(.85) translateY(-.5rem) translateX(.15rem)}.form-floating>textarea:focus~label::after,.form-floating>textarea:not(:placeholder-shown)~label::after{position:absolute;inset:1rem 0.375rem;z-index:-1;height:1.5em;content:"";background-color:var(--bs-body-bg);border-radius:var(--bs-border-radius)}.form-floating>textarea:disabled~label::after{background-color:var(--bs-secondary-bg)}.form-floating>.form-control-plaintext~label{border-width:var(--bs-border-width) 0}.form-floating>.form-control:disabled~label,.form-floating>:disabled~label{color:#6c757d}.input-group{position:relative;display:flex;flex-wrap:wrap;align-items:stretch;width:100%}.input-group>.form-control,.input-group>.form-floating,.input-group>.form-select{position:relative;flex:1 1 auto;width:1%;min-width:0}.input-group>.form-control:focus,.input-group>.form-floating:focus-within,.input-group>.form-select:focus{z-index:5}.input-group .btn{position:relative;z-index:2}.input-group .btn:focus{z-index:5}.input-group-text{display:flex;align-items:center;padding:.375rem .75rem;font-size:1rem;font-weight:400;line-height:1.5;color:var(--bs-body-color);text-align:center;white-space:nowrap;background-color:var(--bs-tertiary-bg);border:var(--bs-border-width) solid var(--bs-border-color);border-radius:var(--bs-border-radius)}.input-group-lg>.btn,.input-group-lg>.form-control,.input-group-lg>.form-select,.input-group-lg>.input-group-text{padding:.5rem 1rem;font-size:1.25rem;border-radius:var(--bs-border-radius-lg)}.input-group-sm>.btn,.input-group-sm>.form-control,.input-group-sm>.form-select,.input-group-sm>.input-group-text{padding:.25rem .5rem;font-size:.875rem;border-radius:var(--bs-border-radius-sm)}.input-group-lg>.form-select,.input-group-sm>.form-select{padding-right:3rem}.input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n+3),.input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-control,.input-group:not(.has-validation)>.form-floating:not(:last-child)>.form-select,.input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating){border-top-right-radius:0;border-bottom-right-radius:0}.input-group.has-validation>.dropdown-toggle:nth-last-child(n+4),.input-group.has-validation>.form-floating:nth-last-child(n+3)>.form-control,.input-group.has-validation>.form-floating:nth-last-child(n+3)>.form-select,.input-group.has-validation>:nth-last-child(n+3):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating){border-top-right-radius:0;border-bottom-right-radius:0}.input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback){margin-left:calc(-1 * var(--bs-border-width));border-top-left-radius:0;border-bottom-left-radius:0}.input-group>.form-floating:not(:first-child)>.form-control,.input-group>.form-floating:not(:first-child)>.form-select{border-top-left-radius:0;border-bottom-left-radius:0}.valid-feedback{display:none;width:100%;margin-top:.25rem;font-size:.875em;color:var(--bs-form-valid-color)}.valid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.25rem .5rem;margin-top:.1rem;font-size:.875rem;color:#fff;background-color:var(--bs-success);border-radius:var(--bs-border-radius)}.is-valid~.valid-feedback,.is-valid~.valid-tooltip,.was-validated :valid~.valid-feedback,.was-validated :valid~.valid-tooltip{display:block}.form-control.is-valid,.was-validated .form-control:valid{border-color:var(--bs-form-valid-border-color);padding-right:calc(1.5em + .75rem);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23198754' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right calc(.375em + .1875rem) center;background-size:calc(.75em + .375rem) calc(.75em + .375rem)}.form-control.is-valid:focus,.was-validated .form-control:valid:focus{border-color:var(--bs-form-valid-border-color);box-shadow:0 0 0 .25rem rgba(var(--bs-success-rgb),.25)}.was-validated textarea.form-control:valid,textarea.form-control.is-valid{padding-right:calc(1.5em + .75rem);background-position:top calc(.375em + .1875rem) right calc(.375em + .1875rem)}.form-select.is-valid,.was-validated .form-select:valid{border-color:var(--bs-form-valid-border-color)}.form-select.is-valid:not([multiple]):not([size]),.form-select.is-valid:not([multiple])[size="1"],.was-validated .form-select:valid:not([multiple]):not([size]),.was-validated .form-select:valid:not([multiple])[size="1"]{--bs-form-select-bg-icon:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23198754' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1'/%3e%3c/svg%3e");padding-right:4.125rem;background-position:right .75rem center,center right 2.25rem;background-size:16px 12px,calc(.75em + .375rem) calc(.75em + .375rem)}.form-select.is-valid:focus,.was-validated .form-select:valid:focus{border-color:var(--bs-form-valid-border-color);box-shadow:0 0 0 .25rem rgba(var(--bs-success-rgb),.25)}.form-control-color.is-valid,.was-validated .form-control-color:valid{width:calc(3rem + calc(1.5em + .75rem))}.form-check-input.is-valid,.was-validated .form-check-input:valid{border-color:var(--bs-form-valid-border-color)}.form-check-input.is-valid:checked,.was-validated .form-check-input:valid:checked{background-color:var(--bs-form-valid-color)}.form-check-input.is-valid:focus,.was-validated .form-check-input:valid:focus{box-shadow:0 0 0 .25rem rgba(var(--bs-success-rgb),.25)}.form-check-input.is-valid~.form-check-label,.was-validated .form-check-input:valid~.form-check-label{color:var(--bs-form-valid-color)}.form-check-inline .form-check-input~.valid-feedback{margin-left:.5em}.input-group>.form-control:not(:focus).is-valid,.input-group>.form-floating:not(:focus-within).is-valid,.input-group>.form-select:not(:focus).is-valid,.was-validated .input-group>.form-control:not(:focus):valid,.was-validated .input-group>.form-floating:not(:focus-within):valid,.was-validated .input-group>.form-select:not(:focus):valid{z-index:3}.invalid-feedback{display:none;width:100%;margin-top:.25rem;font-size:.875em;color:var(--bs-form-invalid-color)}.invalid-tooltip{position:absolute;top:100%;z-index:5;display:none;max-width:100%;padding:.25rem .5rem;margin-top:.1rem;font-size:.875rem;color:#fff;background-color:var(--bs-danger);border-radius:var(--bs-border-radius)}.is-invalid~.invalid-feedback,.is-invalid~.invalid-tooltip,.was-validated :invalid~.invalid-feedback,.was-validated :invalid~.invalid-tooltip{display:block}.form-control.is-invalid,.was-validated .form-control:invalid{border-color:var(--bs-form-invalid-border-color);padding-right:calc(1.5em + .75rem);background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right calc(.375em + .1875rem) center;background-size:calc(.75em + .375rem) calc(.75em + .375rem)}.form-control.is-invalid:focus,.was-validated .form-control:invalid:focus{border-color:var(--bs-form-invalid-border-color);box-shadow:0 0 0 .25rem rgba(var(--bs-danger-rgb),.25)}.was-validated textarea.form-control:invalid,textarea.form-control.is-invalid{padding-right:calc(1.5em + .75rem);background-position:top calc(.375em + .1875rem) right calc(.375em + .1875rem)}.form-select.is-invalid,.was-validated .form-select:invalid{border-color:var(--bs-form-invalid-border-color)}.form-select.is-invalid:not([multiple]):not([size]),.form-select.is-invalid:not([multiple])[size="1"],.was-validated .form-select:invalid:not([multiple]):not([size]),.was-validated .form-select:invalid:not([multiple])[size="1"]{--bs-form-select-bg-icon:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");padding-right:4.125rem;background-position:right .75rem center,center right 2.25rem;background-size:16px 12px,calc(.75em + .375rem) calc(.75em + .375rem)}.form-select.is-invalid:focus,.was-validated .form-select:invalid:focus{border-color:var(--bs-form-invalid-border-color);box-shadow:0 0 0 .25rem rgba(var(--bs-danger-rgb),.25)}.form-control-color.is-invalid,.was-validated .form-control-color:invalid{width:calc(3rem + calc(1.5em + .75rem))}.form-check-input.is-invalid,.was-validated .form-check-input:invalid{border-color:var(--bs-form-invalid-border-color)}.form-check-input.is-invalid:checked,.was-validated .form-check-input:invalid:checked{background-color:var(--bs-form-invalid-color)}.form-check-input.is-invalid:focus,.was-validated .form-check-input:invalid:focus{box-shadow:0 0 0 .25rem rgba(var(--bs-danger-rgb),.25)}.form-check-input.is-invalid~.form-check-label,.was-validated .form-check-input:invalid~.form-check-label{color:var(--bs-form-invalid-color)}.form-check-inline .form-check-input~.invalid-feedback{margin-left:.5em}.input-group>.form-control:not(:focus).is-invalid,.input-group>.form-floating:not(:focus-within).is-invalid,.input-group>.form-select:not(:focus).is-invalid,.was-validated .input-group>.form-control:not(:focus):invalid,.was-validated .input-group>.form-floating:not(:focus-within):invalid,.was-validated .input-group>.form-select:not(:focus):invalid{z-index:4}.btn{--bs-btn-padding-x:0.75rem;--bs-btn-padding-y:0.375rem;--bs-btn-font-family: ;--bs-btn-font-size:1rem;--bs-btn-font-weight:400;--bs-btn-line-height:1.5;--bs-btn-color:var(--bs-body-color);--bs-btn-bg:transparent;--bs-btn-border-width:var(--bs-border-width);--bs-btn-border-color:transparent;--bs-btn-border-radius:var(--bs-border-radius);--bs-btn-hover-border-color:transparent;--bs-btn-box-shadow:inset 0 1px 0 rgba(255, 255, 255, 0.15),0 1px 1px rgba(0, 0, 0, 0.075);--bs-btn-disabled-opacity:0.65;--bs-btn-focus-box-shadow:0 0 0 0.25rem rgba(var(--bs-btn-focus-shadow-rgb), .5);display:inline-block;padding:var(--bs-btn-padding-y) var(--bs-btn-padding-x);font-family:var(--bs-btn-font-family);font-size:var(--bs-btn-font-size);font-weight:var(--bs-btn-font-weight);line-height:var(--bs-btn-line-height);color:var(--bs-btn-color);text-align:center;text-decoration:none;vertical-align:middle;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;border:var(--bs-btn-border-width) solid var(--bs-btn-border-color);border-radius:var(--bs-btn-border-radius);background-color:var(--bs-btn-bg);transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.btn{transition:none}}.btn:hover{color:var(--bs-btn-hover-color);background-color:var(--bs-btn-hover-bg);border-color:var(--bs-btn-hover-border-color)}.btn-check+.btn:hover{color:var(--bs-btn-color);background-color:var(--bs-btn-bg);border-color:var(--bs-btn-border-color)}.btn:focus-visible{color:var(--bs-btn-hover-color);background-color:var(--bs-btn-hover-bg);border-color:var(--bs-btn-hover-border-color);outline:0;box-shadow:var(--bs-btn-focus-box-shadow)}.btn-check:focus-visible+.btn{border-color:var(--bs-btn-hover-border-color);outline:0;box-shadow:var(--bs-btn-focus-box-shadow)}.btn-check:checked+.btn,.btn.active,.btn.show,.btn:first-child:active,:not(.btn-check)+.btn:active{color:var(--bs-btn-active-color);background-color:var(--bs-btn-active-bg);border-color:var(--bs-btn-active-border-color)}.btn-check:checked+.btn:focus-visible,.btn.active:focus-visible,.btn.show:focus-visible,.btn:first-child:active:focus-visible,:not(.btn-check)+.btn:active:focus-visible{box-shadow:var(--bs-btn-focus-box-shadow)}.btn-check:checked:focus-visible+.btn{box-shadow:var(--bs-btn-focus-box-shadow)}.btn.disabled,.btn:disabled,fieldset:disabled .btn{color:var(--bs-btn-disabled-color);pointer-events:none;background-color:var(--bs-btn-disabled-bg);border-color:var(--bs-btn-disabled-border-color);opacity:var(--bs-btn-disabled-opacity)}.btn-primary{--bs-btn-color:#fff;--bs-btn-bg:#0d6efd;--bs-btn-border-color:#0d6efd;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#0b5ed7;--bs-btn-hover-border-color:#0a58ca;--bs-btn-focus-shadow-rgb:49,132,253;--bs-btn-active-color:#fff;--bs-btn-active-bg:#0a58ca;--bs-btn-active-border-color:#0a53be;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#fff;--bs-btn-disabled-bg:#0d6efd;--bs-btn-disabled-border-color:#0d6efd}.btn-secondary{--bs-btn-color:#fff;--bs-btn-bg:#6c757d;--bs-btn-border-color:#6c757d;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#5c636a;--bs-btn-hover-border-color:#565e64;--bs-btn-focus-shadow-rgb:130,138,145;--bs-btn-active-color:#fff;--bs-btn-active-bg:#565e64;--bs-btn-active-border-color:#51585e;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#fff;--bs-btn-disabled-bg:#6c757d;--bs-btn-disabled-border-color:#6c757d}.btn-success{--bs-btn-color:#fff;--bs-btn-bg:#198754;--bs-btn-border-color:#198754;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#157347;--bs-btn-hover-border-color:#146c43;--bs-btn-focus-shadow-rgb:60,153,110;--bs-btn-active-color:#fff;--bs-btn-active-bg:#146c43;--bs-btn-active-border-color:#13653f;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#fff;--bs-btn-disabled-bg:#198754;--bs-btn-disabled-border-color:#198754}.btn-info{--bs-btn-color:#000;--bs-btn-bg:#0dcaf0;--bs-btn-border-color:#0dcaf0;--bs-btn-hover-color:#000;--bs-btn-hover-bg:#31d2f2;--bs-btn-hover-border-color:#25cff2;--bs-btn-focus-shadow-rgb:11,172,204;--bs-btn-active-color:#000;--bs-btn-active-bg:#3dd5f3;--bs-btn-active-border-color:#25cff2;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#000;--bs-btn-disabled-bg:#0dcaf0;--bs-btn-disabled-border-color:#0dcaf0}.btn-warning{--bs-btn-color:#000;--bs-btn-bg:#ffc107;--bs-btn-border-color:#ffc107;--bs-btn-hover-color:#000;--bs-btn-hover-bg:#ffca2c;--bs-btn-hover-border-color:#ffc720;--bs-btn-focus-shadow-rgb:217,164,6;--bs-btn-active-color:#000;--bs-btn-active-bg:#ffcd39;--bs-btn-active-border-color:#ffc720;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#000;--bs-btn-disabled-bg:#ffc107;--bs-btn-disabled-border-color:#ffc107}.btn-danger{--bs-btn-color:#fff;--bs-btn-bg:#dc3545;--bs-btn-border-color:#dc3545;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#bb2d3b;--bs-btn-hover-border-color:#b02a37;--bs-btn-focus-shadow-rgb:225,83,97;--bs-btn-active-color:#fff;--bs-btn-active-bg:#b02a37;--bs-btn-active-border-color:#a52834;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#fff;--bs-btn-disabled-bg:#dc3545;--bs-btn-disabled-border-color:#dc3545}.btn-light{--bs-btn-color:#000;--bs-btn-bg:#f8f9fa;--bs-btn-border-color:#f8f9fa;--bs-btn-hover-color:#000;--bs-btn-hover-bg:#d3d4d5;--bs-btn-hover-border-color:#c6c7c8;--bs-btn-focus-shadow-rgb:211,212,213;--bs-btn-active-color:#000;--bs-btn-active-bg:#c6c7c8;--bs-btn-active-border-color:#babbbc;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#000;--bs-btn-disabled-bg:#f8f9fa;--bs-btn-disabled-border-color:#f8f9fa}.btn-dark{--bs-btn-color:#fff;--bs-btn-bg:#212529;--bs-btn-border-color:#212529;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#424649;--bs-btn-hover-border-color:#373b3e;--bs-btn-focus-shadow-rgb:66,70,73;--bs-btn-active-color:#fff;--bs-btn-active-bg:#4d5154;--bs-btn-active-border-color:#373b3e;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#fff;--bs-btn-disabled-bg:#212529;--bs-btn-disabled-border-color:#212529}.btn-outline-primary{--bs-btn-color:#0d6efd;--bs-btn-border-color:#0d6efd;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#0d6efd;--bs-btn-hover-border-color:#0d6efd;--bs-btn-focus-shadow-rgb:13,110,253;--bs-btn-active-color:#fff;--bs-btn-active-bg:#0d6efd;--bs-btn-active-border-color:#0d6efd;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#0d6efd;--bs-btn-disabled-bg:transparent;--bs-btn-disabled-border-color:#0d6efd;--bs-gradient:none}.btn-outline-secondary{--bs-btn-color:#6c757d;--bs-btn-border-color:#6c757d;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#6c757d;--bs-btn-hover-border-color:#6c757d;--bs-btn-focus-shadow-rgb:108,117,125;--bs-btn-active-color:#fff;--bs-btn-active-bg:#6c757d;--bs-btn-active-border-color:#6c757d;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#6c757d;--bs-btn-disabled-bg:transparent;--bs-btn-disabled-border-color:#6c757d;--bs-gradient:none}.btn-outline-success{--bs-btn-color:#198754;--bs-btn-border-color:#198754;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#198754;--bs-btn-hover-border-color:#198754;--bs-btn-focus-shadow-rgb:25,135,84;--bs-btn-active-color:#fff;--bs-btn-active-bg:#198754;--bs-btn-active-border-color:#198754;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#198754;--bs-btn-disabled-bg:transparent;--bs-btn-disabled-border-color:#198754;--bs-gradient:none}.btn-outline-info{--bs-btn-color:#0dcaf0;--bs-btn-border-color:#0dcaf0;--bs-btn-hover-color:#000;--bs-btn-hover-bg:#0dcaf0;--bs-btn-hover-border-color:#0dcaf0;--bs-btn-focus-shadow-rgb:13,202,240;--bs-btn-active-color:#000;--bs-btn-active-bg:#0dcaf0;--bs-btn-active-border-color:#0dcaf0;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#0dcaf0;--bs-btn-disabled-bg:transparent;--bs-btn-disabled-border-color:#0dcaf0;--bs-gradient:none}.btn-outline-warning{--bs-btn-color:#ffc107;--bs-btn-border-color:#ffc107;--bs-btn-hover-color:#000;--bs-btn-hover-bg:#ffc107;--bs-btn-hover-border-color:#ffc107;--bs-btn-focus-shadow-rgb:255,193,7;--bs-btn-active-color:#000;--bs-btn-active-bg:#ffc107;--bs-btn-active-border-color:#ffc107;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#ffc107;--bs-btn-disabled-bg:transparent;--bs-btn-disabled-border-color:#ffc107;--bs-gradient:none}.btn-outline-danger{--bs-btn-color:#dc3545;--bs-btn-border-color:#dc3545;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#dc3545;--bs-btn-hover-border-color:#dc3545;--bs-btn-focus-shadow-rgb:220,53,69;--bs-btn-active-color:#fff;--bs-btn-active-bg:#dc3545;--bs-btn-active-border-color:#dc3545;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#dc3545;--bs-btn-disabled-bg:transparent;--bs-btn-disabled-border-color:#dc3545;--bs-gradient:none}.btn-outline-light{--bs-btn-color:#f8f9fa;--bs-btn-border-color:#f8f9fa;--bs-btn-hover-color:#000;--bs-btn-hover-bg:#f8f9fa;--bs-btn-hover-border-color:#f8f9fa;--bs-btn-focus-shadow-rgb:248,249,250;--bs-btn-active-color:#000;--bs-btn-active-bg:#f8f9fa;--bs-btn-active-border-color:#f8f9fa;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#f8f9fa;--bs-btn-disabled-bg:transparent;--bs-btn-disabled-border-color:#f8f9fa;--bs-gradient:none}.btn-outline-dark{--bs-btn-color:#212529;--bs-btn-border-color:#212529;--bs-btn-hover-color:#fff;--bs-btn-hover-bg:#212529;--bs-btn-hover-border-color:#212529;--bs-btn-focus-shadow-rgb:33,37,41;--bs-btn-active-color:#fff;--bs-btn-active-bg:#212529;--bs-btn-active-border-color:#212529;--bs-btn-active-shadow:inset 0 3px 5px rgba(0, 0, 0, 0.125);--bs-btn-disabled-color:#212529;--bs-btn-disabled-bg:transparent;--bs-btn-disabled-border-color:#212529;--bs-gradient:none}.btn-link{--bs-btn-font-weight:400;--bs-btn-color:var(--bs-link-color);--bs-btn-bg:transparent;--bs-btn-border-color:transparent;--bs-btn-hover-color:var(--bs-link-hover-color);--bs-btn-hover-border-color:transparent;--bs-btn-active-color:var(--bs-link-hover-color);--bs-btn-active-border-color:transparent;--bs-btn-disabled-color:#6c757d;--bs-btn-disabled-border-color:transparent;--bs-btn-box-shadow:0 0 0 #000;--bs-btn-focus-shadow-rgb:49,132,253;text-decoration:underline}.btn-link:focus-visible{color:var(--bs-btn-color)}.btn-link:hover{color:var(--bs-btn-hover-color)}.btn-group-lg>.btn,.btn-lg{--bs-btn-padding-y:0.5rem;--bs-btn-padding-x:1rem;--bs-btn-font-size:1.25rem;--bs-btn-border-radius:var(--bs-border-radius-lg)}.btn-group-sm>.btn,.btn-sm{--bs-btn-padding-y:0.25rem;--bs-btn-padding-x:0.5rem;--bs-btn-font-size:0.875rem;--bs-btn-border-radius:var(--bs-border-radius-sm)}.fade{transition:opacity .15s linear}@media (prefers-reduced-motion:reduce){.fade{transition:none}}.fade:not(.show){opacity:0}.collapse:not(.show){display:none}.collapsing{height:0;overflow:hidden;transition:height .35s ease}@media (prefers-reduced-motion:reduce){.collapsing{transition:none}}.collapsing.collapse-horizontal{width:0;height:auto;transition:width .35s ease}@media (prefers-reduced-motion:reduce){.collapsing.collapse-horizontal{transition:none}}.dropdown,.dropdown-center,.dropend,.dropstart,.dropup,.dropup-center{position:relative}.dropdown-toggle{white-space:nowrap}.dropdown-toggle::after{display:inline-block;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid;border-right:.3em solid transparent;border-bottom:0;border-left:.3em solid transparent}.dropdown-toggle:empty::after{margin-left:0}.dropdown-menu{--bs-dropdown-zindex:1000;--bs-dropdown-min-width:10rem;--bs-dropdown-padding-x:0;--bs-dropdown-padding-y:0.5rem;--bs-dropdown-spacer:0.125rem;--bs-dropdown-font-size:1rem;--bs-dropdown-color:var(--bs-body-color);--bs-dropdown-bg:var(--bs-body-bg);--bs-dropdown-border-color:var(--bs-border-color-translucent);--bs-dropdown-border-radius:var(--bs-border-radius);--bs-dropdown-border-width:var(--bs-border-width);--bs-dropdown-inner-border-radius:calc(var(--bs-border-radius) - var(--bs-border-width));--bs-dropdown-divider-bg:var(--bs-border-color-translucent);--bs-dropdown-divider-margin-y:0.5rem;--bs-dropdown-box-shadow:var(--bs-box-shadow);--bs-dropdown-link-color:var(--bs-body-color);--bs-dropdown-link-hover-color:var(--bs-body-color);--bs-dropdown-link-hover-bg:var(--bs-tertiary-bg);--bs-dropdown-link-active-color:#fff;--bs-dropdown-link-active-bg:#0d6efd;--bs-dropdown-link-disabled-color:var(--bs-tertiary-color);--bs-dropdown-item-padding-x:1rem;--bs-dropdown-item-padding-y:0.25rem;--bs-dropdown-header-color:#6c757d;--bs-dropdown-header-padding-x:1rem;--bs-dropdown-header-padding-y:0.5rem;position:absolute;z-index:var(--bs-dropdown-zindex);display:none;min-width:var(--bs-dropdown-min-width);padding:var(--bs-dropdown-padding-y) var(--bs-dropdown-padding-x);margin:0;font-size:var(--bs-dropdown-font-size);color:var(--bs-dropdown-color);text-align:left;list-style:none;background-color:var(--bs-dropdown-bg);background-clip:padding-box;border:var(--bs-dropdown-border-width) solid var(--bs-dropdown-border-color);border-radius:var(--bs-dropdown-border-radius)}.dropdown-menu[data-bs-popper]{top:100%;left:0;margin-top:var(--bs-dropdown-spacer)}.dropdown-menu-start{--bs-position:start}.dropdown-menu-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-end{--bs-position:end}.dropdown-menu-end[data-bs-popper]{right:0;left:auto}@media (min-width:576px){.dropdown-menu-sm-start{--bs-position:start}.dropdown-menu-sm-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-sm-end{--bs-position:end}.dropdown-menu-sm-end[data-bs-popper]{right:0;left:auto}}@media (min-width:768px){.dropdown-menu-md-start{--bs-position:start}.dropdown-menu-md-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-md-end{--bs-position:end}.dropdown-menu-md-end[data-bs-popper]{right:0;left:auto}}@media (min-width:992px){.dropdown-menu-lg-start{--bs-position:start}.dropdown-menu-lg-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-lg-end{--bs-position:end}.dropdown-menu-lg-end[data-bs-popper]{right:0;left:auto}}@media (min-width:1200px){.dropdown-menu-xl-start{--bs-position:start}.dropdown-menu-xl-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-xl-end{--bs-position:end}.dropdown-menu-xl-end[data-bs-popper]{right:0;left:auto}}@media (min-width:1400px){.dropdown-menu-xxl-start{--bs-position:start}.dropdown-menu-xxl-start[data-bs-popper]{right:auto;left:0}.dropdown-menu-xxl-end{--bs-position:end}.dropdown-menu-xxl-end[data-bs-popper]{right:0;left:auto}}.dropup .dropdown-menu[data-bs-popper]{top:auto;bottom:100%;margin-top:0;margin-bottom:var(--bs-dropdown-spacer)}.dropup .dropdown-toggle::after{display:inline-block;margin-left:.255em;vertical-align:.255em;content:"";border-top:0;border-right:.3em solid transparent;border-bottom:.3em solid;border-left:.3em solid transparent}.dropup .dropdown-toggle:empty::after{margin-left:0}.dropend .dropdown-menu[data-bs-popper]{top:0;right:auto;left:100%;margin-top:0;margin-left:var(--bs-dropdown-spacer)}.dropend .dropdown-toggle::after{display:inline-block;margin-left:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-right:0;border-bottom:.3em solid transparent;border-left:.3em solid}.dropend .dropdown-toggle:empty::after{margin-left:0}.dropend .dropdown-toggle::after{vertical-align:0}.dropstart .dropdown-menu[data-bs-popper]{top:0;right:100%;left:auto;margin-top:0;margin-right:var(--bs-dropdown-spacer)}.dropstart .dropdown-toggle::after{display:inline-block;margin-left:.255em;vertical-align:.255em;content:""}.dropstart .dropdown-toggle::after{display:none}.dropstart .dropdown-toggle::before{display:inline-block;margin-right:.255em;vertical-align:.255em;content:"";border-top:.3em solid transparent;border-right:.3em solid;border-bottom:.3em solid transparent}.dropstart .dropdown-toggle:empty::after{margin-left:0}.dropstart .dropdown-toggle::before{vertical-align:0}.dropdown-divider{height:0;margin:var(--bs-dropdown-divider-margin-y) 0;overflow:hidden;border-top:1px solid var(--bs-dropdown-divider-bg);opacity:1}.dropdown-item{display:block;width:100%;padding:var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);clear:both;font-weight:400;color:var(--bs-dropdown-link-color);text-align:inherit;text-decoration:none;white-space:nowrap;background-color:transparent;border:0;border-radius:var(--bs-dropdown-item-border-radius,0)}.dropdown-item:focus,.dropdown-item:hover{color:var(--bs-dropdown-link-hover-color);background-color:var(--bs-dropdown-link-hover-bg)}.dropdown-item.active,.dropdown-item:active{color:var(--bs-dropdown-link-active-color);text-decoration:none;background-color:var(--bs-dropdown-link-active-bg)}.dropdown-item.disabled,.dropdown-item:disabled{color:var(--bs-dropdown-link-disabled-color);pointer-events:none;background-color:transparent}.dropdown-menu.show{display:block}.dropdown-header{display:block;padding:var(--bs-dropdown-header-padding-y) var(--bs-dropdown-header-padding-x);margin-bottom:0;font-size:.875rem;color:var(--bs-dropdown-header-color);white-space:nowrap}.dropdown-item-text{display:block;padding:var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);color:var(--bs-dropdown-link-color)}.dropdown-menu-dark{--bs-dropdown-color:#dee2e6;--bs-dropdown-bg:#343a40;--bs-dropdown-border-color:var(--bs-border-color-translucent);--bs-dropdown-box-shadow: ;--bs-dropdown-link-color:#dee2e6;--bs-dropdown-link-hover-color:#fff;--bs-dropdown-divider-bg:var(--bs-border-color-translucent);--bs-dropdown-link-hover-bg:rgba(255, 255, 255, 0.15);--bs-dropdown-link-active-color:#fff;--bs-dropdown-link-active-bg:#0d6efd;--bs-dropdown-link-disabled-color:#adb5bd;--bs-dropdown-header-color:#adb5bd}.btn-group,.btn-group-vertical{position:relative;display:inline-flex;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{position:relative;flex:1 1 auto}.btn-group-vertical>.btn-check:checked+.btn,.btn-group-vertical>.btn-check:focus+.btn,.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:hover,.btn-group>.btn-check:checked+.btn,.btn-group>.btn-check:focus+.btn,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus,.btn-group>.btn:hover{z-index:1}.btn-toolbar{display:flex;flex-wrap:wrap;justify-content:flex-start}.btn-toolbar .input-group{width:auto}.btn-group{border-radius:var(--bs-border-radius)}.btn-group>.btn-group:not(:first-child),.btn-group>:not(.btn-check:first-child)+.btn{margin-left:calc(-1 * var(--bs-border-width))}.btn-group>.btn-group:not(:last-child)>.btn,.btn-group>.btn.dropdown-toggle-split:first-child,.btn-group>.btn:not(:last-child):not(.dropdown-toggle){border-top-right-radius:0;border-bottom-right-radius:0}.btn-group>.btn-group:not(:first-child)>.btn,.btn-group>.btn:nth-child(n+3),.btn-group>:not(.btn-check)+.btn{border-top-left-radius:0;border-bottom-left-radius:0}.dropdown-toggle-split{padding-right:.5625rem;padding-left:.5625rem}.dropdown-toggle-split::after,.dropend .dropdown-toggle-split::after,.dropup .dropdown-toggle-split::after{margin-left:0}.dropstart .dropdown-toggle-split::before{margin-right:0}.btn-group-sm>.btn+.dropdown-toggle-split,.btn-sm+.dropdown-toggle-split{padding-right:.375rem;padding-left:.375rem}.btn-group-lg>.btn+.dropdown-toggle-split,.btn-lg+.dropdown-toggle-split{padding-right:.75rem;padding-left:.75rem}.btn-group-vertical{flex-direction:column;align-items:flex-start;justify-content:center}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group{width:100%}.btn-group-vertical>.btn-group:not(:first-child),.btn-group-vertical>.btn:not(:first-child){margin-top:calc(-1 * var(--bs-border-width))}.btn-group-vertical>.btn-group:not(:last-child)>.btn,.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle){border-bottom-right-radius:0;border-bottom-left-radius:0}.btn-group-vertical>.btn-group:not(:first-child)>.btn,.btn-group-vertical>.btn:nth-child(n+3),.btn-group-vertical>:not(.btn-check)+.btn{border-top-left-radius:0;border-top-right-radius:0}.nav{--bs-nav-link-padding-x:1rem;--bs-nav-link-padding-y:0.5rem;--bs-nav-link-font-weight: ;--bs-nav-link-color:var(--bs-link-color);--bs-nav-link-hover-color:var(--bs-link-hover-color);--bs-nav-link-disabled-color:var(--bs-secondary-color);display:flex;flex-wrap:wrap;padding-left:0;margin-bottom:0;list-style:none}.nav-link{display:block;padding:var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);font-size:var(--bs-nav-link-font-size);font-weight:var(--bs-nav-link-font-weight);color:var(--bs-nav-link-color);text-decoration:none;background:0 0;border:0;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out}@media (prefers-reduced-motion:reduce){.nav-link{transition:none}}.nav-link:focus,.nav-link:hover{color:var(--bs-nav-link-hover-color)}.nav-link:focus-visible{outline:0;box-shadow:0 0 0 .25rem rgba(13,110,253,.25)}.nav-link.disabled,.nav-link:disabled{color:var(--bs-nav-link-disabled-color);pointer-events:none;cursor:default}.nav-tabs{--bs-nav-tabs-border-width:var(--bs-border-width);--bs-nav-tabs-border-color:var(--bs-border-color);--bs-nav-tabs-border-radius:var(--bs-border-radius);--bs-nav-tabs-link-hover-border-color:var(--bs-secondary-bg) var(--bs-secondary-bg) var(--bs-border-color);--bs-nav-tabs-link-active-color:var(--bs-emphasis-color);--bs-nav-tabs-link-active-bg:var(--bs-body-bg);--bs-nav-tabs-link-active-border-color:var(--bs-border-color) var(--bs-border-color) var(--bs-body-bg);border-bottom:var(--bs-nav-tabs-border-width) solid var(--bs-nav-tabs-border-color)}.nav-tabs .nav-link{margin-bottom:calc(-1 * var(--bs-nav-tabs-border-width));border:var(--bs-nav-tabs-border-width) solid transparent;border-top-left-radius:var(--bs-nav-tabs-border-radius);border-top-right-radius:var(--bs-nav-tabs-border-radius)}.nav-tabs .nav-link:focus,.nav-tabs .nav-link:hover{isolation:isolate;border-color:var(--bs-nav-tabs-link-hover-border-color)}.nav-tabs .nav-item.show .nav-link,.nav-tabs .nav-link.active{color:var(--bs-nav-tabs-link-active-color);background-color:var(--bs-nav-tabs-link-active-bg);border-color:var(--bs-nav-tabs-link-active-border-color)}.nav-tabs .dropdown-menu{margin-top:calc(-1 * var(--bs-nav-tabs-border-width));border-top-left-radius:0;border-top-right-radius:0}.nav-pills{--bs-nav-pills-border-radius:var(--bs-border-radius);--bs-nav-pills-link-active-color:#fff;--bs-nav-pills-link-active-bg:#0d6efd}.nav-pills .nav-link{border-radius:var(--bs-nav-pills-border-radius)}.nav-pills .nav-link.active,.nav-pills .show>.nav-link{color:var(--bs-nav-pills-link-active-color);background-color:var(--bs-nav-pills-link-active-bg)}.nav-underline{--bs-nav-underline-gap:1rem;--bs-nav-underline-border-width:0.125rem;--bs-nav-underline-link-active-color:var(--bs-emphasis-color);gap:var(--bs-nav-underline-gap)}.nav-underline .nav-link{padding-right:0;padding-left:0;border-bottom:var(--bs-nav-underline-border-width) solid transparent}.nav-underline .nav-link:focus,.nav-underline .nav-link:hover{border-bottom-color:currentcolor}.nav-underline .nav-link.active,.nav-underline .show>.nav-link{font-weight:700;color:var(--bs-nav-underline-link-active-color);border-bottom-color:currentcolor}.nav-fill .nav-item,.nav-fill>.nav-link{flex:1 1 auto;text-align:center}.nav-justified .nav-item,.nav-justified>.nav-link{flex-grow:1;flex-basis:0;text-align:center}.nav-fill .nav-item .nav-link,.nav-justified .nav-item .nav-link{width:100%}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.navbar{--bs-navbar-padding-x:0;--bs-navbar-padding-y:0.5rem;--bs-navbar-color:rgba(var(--bs-emphasis-color-rgb), 0.65);--bs-navbar-hover-color:rgba(var(--bs-emphasis-color-rgb), 0.8);--bs-navbar-disabled-color:rgba(var(--bs-emphasis-color-rgb), 0.3);--bs-navbar-active-color:rgba(var(--bs-emphasis-color-rgb), 1);--bs-navbar-brand-padding-y:0.3125rem;--bs-navbar-brand-margin-end:1rem;--bs-navbar-brand-font-size:1.25rem;--bs-navbar-brand-color:rgba(var(--bs-emphasis-color-rgb), 1);--bs-navbar-brand-hover-color:rgba(var(--bs-emphasis-color-rgb), 1);--bs-navbar-nav-link-padding-x:0.5rem;--bs-navbar-toggler-padding-y:0.25rem;--bs-navbar-toggler-padding-x:0.75rem;--bs-navbar-toggler-font-size:1.25rem;--bs-navbar-toggler-icon-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2833, 37, 41, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");--bs-navbar-toggler-border-color:rgba(var(--bs-emphasis-color-rgb), 0.15);--bs-navbar-toggler-border-radius:var(--bs-border-radius);--bs-navbar-toggler-focus-width:0.25rem;--bs-navbar-toggler-transition:box-shadow 0.15s ease-in-out;position:relative;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:var(--bs-navbar-padding-y) var(--bs-navbar-padding-x)}.navbar>.container,.navbar>.container-fluid,.navbar>.container-lg,.navbar>.container-md,.navbar>.container-sm,.navbar>.container-xl,.navbar>.container-xxl{display:flex;flex-wrap:inherit;align-items:center;justify-content:space-between}.navbar-brand{padding-top:var(--bs-navbar-brand-padding-y);padding-bottom:var(--bs-navbar-brand-padding-y);margin-right:var(--bs-navbar-brand-margin-end);font-size:var(--bs-navbar-brand-font-size);color:var(--bs-navbar-brand-color);text-decoration:none;white-space:nowrap}.navbar-brand:focus,.navbar-brand:hover{color:var(--bs-navbar-brand-hover-color)}.navbar-nav{--bs-nav-link-padding-x:0;--bs-nav-link-padding-y:0.5rem;--bs-nav-link-font-weight: ;--bs-nav-link-color:var(--bs-navbar-color);--bs-nav-link-hover-color:var(--bs-navbar-hover-color);--bs-nav-link-disabled-color:var(--bs-navbar-disabled-color);display:flex;flex-direction:column;padding-left:0;margin-bottom:0;list-style:none}.navbar-nav .nav-link.active,.navbar-nav .nav-link.show{color:var(--bs-navbar-active-color)}.navbar-nav .dropdown-menu{position:static}.navbar-text{padding-top:.5rem;padding-bottom:.5rem;color:var(--bs-navbar-color)}.navbar-text a,.navbar-text a:focus,.navbar-text a:hover{color:var(--bs-navbar-active-color)}.navbar-collapse{flex-grow:1;flex-basis:100%;align-items:center}.navbar-toggler{padding:var(--bs-navbar-toggler-padding-y) var(--bs-navbar-toggler-padding-x);font-size:var(--bs-navbar-toggler-font-size);line-height:1;color:var(--bs-navbar-color);background-color:transparent;border:var(--bs-border-width) solid var(--bs-navbar-toggler-border-color);border-radius:var(--bs-navbar-toggler-border-radius);transition:var(--bs-navbar-toggler-transition)}@media (prefers-reduced-motion:reduce){.navbar-toggler{transition:none}}.navbar-toggler:hover{text-decoration:none}.navbar-toggler:focus{text-decoration:none;outline:0;box-shadow:0 0 0 var(--bs-navbar-toggler-focus-width)}.navbar-toggler-icon{display:inline-block;width:1.5em;height:1.5em;vertical-align:middle;background-image:var(--bs-navbar-toggler-icon-bg);background-repeat:no-repeat;background-position:center;background-size:100%}.navbar-nav-scroll{max-height:var(--bs-scroll-height,75vh);overflow-y:auto}@media (min-width:576px){.navbar-expand-sm{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-sm .navbar-nav{flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .nav-link{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-sm .navbar-nav-scroll{overflow:visible}.navbar-expand-sm .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-sm .navbar-toggler{display:none}.navbar-expand-sm .offcanvas{position:static;z-index:auto;flex-grow:1;width:auto!important;height:auto!important;visibility:visible!important;background-color:transparent!important;border:0!important;transform:none!important;transition:none}.navbar-expand-sm .offcanvas .offcanvas-header{display:none}.navbar-expand-sm .offcanvas .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible}}@media (min-width:768px){.navbar-expand-md{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-md .navbar-nav{flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .nav-link{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-md .navbar-nav-scroll{overflow:visible}.navbar-expand-md .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-md .navbar-toggler{display:none}.navbar-expand-md .offcanvas{position:static;z-index:auto;flex-grow:1;width:auto!important;height:auto!important;visibility:visible!important;background-color:transparent!important;border:0!important;transform:none!important;transition:none}.navbar-expand-md .offcanvas .offcanvas-header{display:none}.navbar-expand-md .offcanvas .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible}}@media (min-width:992px){.navbar-expand-lg{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-lg .navbar-nav{flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .nav-link{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-lg .navbar-nav-scroll{overflow:visible}.navbar-expand-lg .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-lg .navbar-toggler{display:none}.navbar-expand-lg .offcanvas{position:static;z-index:auto;flex-grow:1;width:auto!important;height:auto!important;visibility:visible!important;background-color:transparent!important;border:0!important;transform:none!important;transition:none}.navbar-expand-lg .offcanvas .offcanvas-header{display:none}.navbar-expand-lg .offcanvas .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible}}@media (min-width:1200px){.navbar-expand-xl{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-xl .navbar-nav{flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .nav-link{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-xl .navbar-nav-scroll{overflow:visible}.navbar-expand-xl .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-xl .navbar-toggler{display:none}.navbar-expand-xl .offcanvas{position:static;z-index:auto;flex-grow:1;width:auto!important;height:auto!important;visibility:visible!important;background-color:transparent!important;border:0!important;transform:none!important;transition:none}.navbar-expand-xl .offcanvas .offcanvas-header{display:none}.navbar-expand-xl .offcanvas .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible}}@media (min-width:1400px){.navbar-expand-xxl{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-xxl .navbar-nav{flex-direction:row}.navbar-expand-xxl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xxl .navbar-nav .nav-link{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand-xxl .navbar-nav-scroll{overflow:visible}.navbar-expand-xxl .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-xxl .navbar-toggler{display:none}.navbar-expand-xxl .offcanvas{position:static;z-index:auto;flex-grow:1;width:auto!important;height:auto!important;visibility:visible!important;background-color:transparent!important;border:0!important;transform:none!important;transition:none}.navbar-expand-xxl .offcanvas .offcanvas-header{display:none}.navbar-expand-xxl .offcanvas .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible}}.navbar-expand{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand .navbar-nav{flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .nav-link{padding-right:var(--bs-navbar-nav-link-padding-x);padding-left:var(--bs-navbar-nav-link-padding-x)}.navbar-expand .navbar-nav-scroll{overflow:visible}.navbar-expand .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand .navbar-toggler{display:none}.navbar-expand .offcanvas{position:static;z-index:auto;flex-grow:1;width:auto!important;height:auto!important;visibility:visible!important;background-color:transparent!important;border:0!important;transform:none!important;transition:none}.navbar-expand .offcanvas .offcanvas-header{display:none}.navbar-expand .offcanvas .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible}.navbar-dark,.navbar[data-bs-theme=dark]{--bs-navbar-color:rgba(255, 255, 255, 0.55);--bs-navbar-hover-color:rgba(255, 255, 255, 0.75);--bs-navbar-disabled-color:rgba(255, 255, 255, 0.25);--bs-navbar-active-color:#fff;--bs-navbar-brand-color:#fff;--bs-navbar-brand-hover-color:#fff;--bs-navbar-toggler-border-color:rgba(255, 255, 255, 0.1);--bs-navbar-toggler-icon-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}[data-bs-theme=dark] .navbar-toggler-icon{--bs-navbar-toggler-icon-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}.card{--bs-card-spacer-y:1rem;--bs-card-spacer-x:1rem;--bs-card-title-spacer-y:0.5rem;--bs-card-title-color: ;--bs-card-subtitle-color: ;--bs-card-border-width:var(--bs-border-width);--bs-card-border-color:var(--bs-border-color-translucent);--bs-card-border-radius:var(--bs-border-radius);--bs-card-box-shadow: ;--bs-card-inner-border-radius:calc(var(--bs-border-radius) - (var(--bs-border-width)));--bs-card-cap-padding-y:0.5rem;--bs-card-cap-padding-x:1rem;--bs-card-cap-bg:rgba(var(--bs-body-color-rgb), 0.03);--bs-card-cap-color: ;--bs-card-height: ;--bs-card-color: ;--bs-card-bg:var(--bs-body-bg);--bs-card-img-overlay-padding:1rem;--bs-card-group-margin:0.75rem;position:relative;display:flex;flex-direction:column;min-width:0;height:var(--bs-card-height);color:var(--bs-body-color);word-wrap:break-word;background-color:var(--bs-card-bg);background-clip:border-box;border:var(--bs-card-border-width) solid var(--bs-card-border-color);border-radius:var(--bs-card-border-radius)}.card>hr{margin-right:0;margin-left:0}.card>.list-group{border-top:inherit;border-bottom:inherit}.card>.list-group:first-child{border-top-width:0;border-top-left-radius:var(--bs-card-inner-border-radius);border-top-right-radius:var(--bs-card-inner-border-radius)}.card>.list-group:last-child{border-bottom-width:0;border-bottom-right-radius:var(--bs-card-inner-border-radius);border-bottom-left-radius:var(--bs-card-inner-border-radius)}.card>.card-header+.list-group,.card>.list-group+.card-footer{border-top:0}.card-body{flex:1 1 auto;padding:var(--bs-card-spacer-y) var(--bs-card-spacer-x);color:var(--bs-card-color)}.card-title{margin-bottom:var(--bs-card-title-spacer-y);color:var(--bs-card-title-color)}.card-subtitle{margin-top:calc(-.5 * var(--bs-card-title-spacer-y));margin-bottom:0;color:var(--bs-card-subtitle-color)}.card-text:last-child{margin-bottom:0}.card-link+.card-link{margin-left:var(--bs-card-spacer-x)}.card-header{padding:var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);margin-bottom:0;color:var(--bs-card-cap-color);background-color:var(--bs-card-cap-bg);border-bottom:var(--bs-card-border-width) solid var(--bs-card-border-color)}.card-header:first-child{border-radius:var(--bs-card-inner-border-radius) var(--bs-card-inner-border-radius) 0 0}.card-footer{padding:var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);color:var(--bs-card-cap-color);background-color:var(--bs-card-cap-bg);border-top:var(--bs-card-border-width) solid var(--bs-card-border-color)}.card-footer:last-child{border-radius:0 0 var(--bs-card-inner-border-radius) var(--bs-card-inner-border-radius)}.card-header-tabs{margin-right:calc(-.5 * var(--bs-card-cap-padding-x));margin-bottom:calc(-1 * var(--bs-card-cap-padding-y));margin-left:calc(-.5 * var(--bs-card-cap-padding-x));border-bottom:0}.card-header-tabs .nav-link.active{background-color:var(--bs-card-bg);border-bottom-color:var(--bs-card-bg)}.card-header-pills{margin-right:calc(-.5 * var(--bs-card-cap-padding-x));margin-left:calc(-.5 * var(--bs-card-cap-padding-x))}.card-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;padding:var(--bs-card-img-overlay-padding);border-radius:var(--bs-card-inner-border-radius)}.card-img,.card-img-bottom,.card-img-top{width:100%}.card-img,.card-img-top{border-top-left-radius:var(--bs-card-inner-border-radius);border-top-right-radius:var(--bs-card-inner-border-radius)}.card-img,.card-img-bottom{border-bottom-right-radius:var(--bs-card-inner-border-radius);border-bottom-left-radius:var(--bs-card-inner-border-radius)}.card-group>.card{margin-bottom:var(--bs-card-group-margin)}@media (min-width:576px){.card-group{display:flex;flex-flow:row wrap}.card-group>.card{flex:1 0 0;margin-bottom:0}.card-group>.card+.card{margin-left:0;border-left:0}.card-group>.card:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.card-group>.card:not(:last-child)>.card-header,.card-group>.card:not(:last-child)>.card-img-top{border-top-right-radius:0}.card-group>.card:not(:last-child)>.card-footer,.card-group>.card:not(:last-child)>.card-img-bottom{border-bottom-right-radius:0}.card-group>.card:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.card-group>.card:not(:first-child)>.card-header,.card-group>.card:not(:first-child)>.card-img-top{border-top-left-radius:0}.card-group>.card:not(:first-child)>.card-footer,.card-group>.card:not(:first-child)>.card-img-bottom{border-bottom-left-radius:0}}.accordion{--bs-accordion-color:var(--bs-body-color);--bs-accordion-bg:var(--bs-body-bg);--bs-accordion-transition:color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,border-radius 0.15s ease;--bs-accordion-border-color:var(--bs-border-color);--bs-accordion-border-width:var(--bs-border-width);--bs-accordion-border-radius:var(--bs-border-radius);--bs-accordion-inner-border-radius:calc(var(--bs-border-radius) - (var(--bs-border-width)));--bs-accordion-btn-padding-x:1.25rem;--bs-accordion-btn-padding-y:1rem;--bs-accordion-btn-color:var(--bs-body-color);--bs-accordion-btn-bg:var(--bs-accordion-bg);--bs-accordion-btn-icon:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23212529' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m2 5 6 6 6-6'/%3e%3c/svg%3e");--bs-accordion-btn-icon-width:1.25rem;--bs-accordion-btn-icon-transform:rotate(-180deg);--bs-accordion-btn-icon-transition:transform 0.2s ease-in-out;--bs-accordion-btn-active-icon:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23052c65' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m2 5 6 6 6-6'/%3e%3c/svg%3e");--bs-accordion-btn-focus-box-shadow:0 0 0 0.25rem rgba(13, 110, 253, 0.25);--bs-accordion-body-padding-x:1.25rem;--bs-accordion-body-padding-y:1rem;--bs-accordion-active-color:var(--bs-primary-text-emphasis);--bs-accordion-active-bg:var(--bs-primary-bg-subtle)}.accordion-button{position:relative;display:flex;align-items:center;width:100%;padding:var(--bs-accordion-btn-padding-y) var(--bs-accordion-btn-padding-x);font-size:1rem;color:var(--bs-accordion-btn-color);text-align:left;background-color:var(--bs-accordion-btn-bg);border:0;border-radius:0;overflow-anchor:none;transition:var(--bs-accordion-transition)}@media (prefers-reduced-motion:reduce){.accordion-button{transition:none}}.accordion-button:not(.collapsed){color:var(--bs-accordion-active-color);background-color:var(--bs-accordion-active-bg);box-shadow:inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 var(--bs-accordion-border-color)}.accordion-button:not(.collapsed)::after{background-image:var(--bs-accordion-btn-active-icon);transform:var(--bs-accordion-btn-icon-transform)}.accordion-button::after{flex-shrink:0;width:var(--bs-accordion-btn-icon-width);height:var(--bs-accordion-btn-icon-width);margin-left:auto;content:"";background-image:var(--bs-accordion-btn-icon);background-repeat:no-repeat;background-size:var(--bs-accordion-btn-icon-width);transition:var(--bs-accordion-btn-icon-transition)}@media (prefers-reduced-motion:reduce){.accordion-button::after{transition:none}}.accordion-button:hover{z-index:2}.accordion-button:focus{z-index:3;outline:0;box-shadow:var(--bs-accordion-btn-focus-box-shadow)}.accordion-header{margin-bottom:0}.accordion-item{color:var(--bs-accordion-color);background-color:var(--bs-accordion-bg);border:var(--bs-accordion-border-width) solid var(--bs-accordion-border-color)}.accordion-item:first-of-type{border-top-left-radius:var(--bs-accordion-border-radius);border-top-right-radius:var(--bs-accordion-border-radius)}.accordion-item:first-of-type>.accordion-header .accordion-button{border-top-left-radius:var(--bs-accordion-inner-border-radius);border-top-right-radius:var(--bs-accordion-inner-border-radius)}.accordion-item:not(:first-of-type){border-top:0}.accordion-item:last-of-type{border-bottom-right-radius:var(--bs-accordion-border-radius);border-bottom-left-radius:var(--bs-accordion-border-radius)}.accordion-item:last-of-type>.accordion-header .accordion-button.collapsed{border-bottom-right-radius:var(--bs-accordion-inner-border-radius);border-bottom-left-radius:var(--bs-accordion-inner-border-radius)}.accordion-item:last-of-type>.accordion-collapse{border-bottom-right-radius:var(--bs-accordion-border-radius);border-bottom-left-radius:var(--bs-accordion-border-radius)}.accordion-body{padding:var(--bs-accordion-body-padding-y) var(--bs-accordion-body-padding-x)}.accordion-flush>.accordion-item{border-right:0;border-left:0;border-radius:0}.accordion-flush>.accordion-item:first-child{border-top:0}.accordion-flush>.accordion-item:last-child{border-bottom:0}.accordion-flush>.accordion-item>.accordion-collapse,.accordion-flush>.accordion-item>.accordion-header .accordion-button,.accordion-flush>.accordion-item>.accordion-header .accordion-button.collapsed{border-radius:0}[data-bs-theme=dark] .accordion-button::after{--bs-accordion-btn-icon:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236ea8fe'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708'/%3e%3c/svg%3e");--bs-accordion-btn-active-icon:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236ea8fe'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708'/%3e%3c/svg%3e")}.breadcrumb{--bs-breadcrumb-padding-x:0;--bs-breadcrumb-padding-y:0;--bs-breadcrumb-margin-bottom:1rem;--bs-breadcrumb-bg: ;--bs-breadcrumb-border-radius: ;--bs-breadcrumb-divider-color:var(--bs-secondary-color);--bs-breadcrumb-item-padding-x:0.5rem;--bs-breadcrumb-item-active-color:var(--bs-secondary-color);display:flex;flex-wrap:wrap;padding:var(--bs-breadcrumb-padding-y) var(--bs-breadcrumb-padding-x);margin-bottom:var(--bs-breadcrumb-margin-bottom);font-size:var(--bs-breadcrumb-font-size);list-style:none;background-color:var(--bs-breadcrumb-bg);border-radius:var(--bs-breadcrumb-border-radius)}.breadcrumb-item+.breadcrumb-item{padding-left:var(--bs-breadcrumb-item-padding-x)}.breadcrumb-item+.breadcrumb-item::before{float:left;padding-right:var(--bs-breadcrumb-item-padding-x);color:var(--bs-breadcrumb-divider-color);content:var(--bs-breadcrumb-divider, "/")}.breadcrumb-item.active{color:var(--bs-breadcrumb-item-active-color)}.pagination{--bs-pagination-padding-x:0.75rem;--bs-pagination-padding-y:0.375rem;--bs-pagination-font-size:1rem;--bs-pagination-color:var(--bs-link-color);--bs-pagination-bg:var(--bs-body-bg);--bs-pagination-border-width:var(--bs-border-width);--bs-pagination-border-color:var(--bs-border-color);--bs-pagination-border-radius:var(--bs-border-radius);--bs-pagination-hover-color:var(--bs-link-hover-color);--bs-pagination-hover-bg:var(--bs-tertiary-bg);--bs-pagination-hover-border-color:var(--bs-border-color);--bs-pagination-focus-color:var(--bs-link-hover-color);--bs-pagination-focus-bg:var(--bs-secondary-bg);--bs-pagination-focus-box-shadow:0 0 0 0.25rem rgba(13, 110, 253, 0.25);--bs-pagination-active-color:#fff;--bs-pagination-active-bg:#0d6efd;--bs-pagination-active-border-color:#0d6efd;--bs-pagination-disabled-color:var(--bs-secondary-color);--bs-pagination-disabled-bg:var(--bs-secondary-bg);--bs-pagination-disabled-border-color:var(--bs-border-color);display:flex;padding-left:0;list-style:none}.page-link{position:relative;display:block;padding:var(--bs-pagination-padding-y) var(--bs-pagination-padding-x);font-size:var(--bs-pagination-font-size);color:var(--bs-pagination-color);text-decoration:none;background-color:var(--bs-pagination-bg);border:var(--bs-pagination-border-width) solid var(--bs-pagination-border-color);transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.page-link{transition:none}}.page-link:hover{z-index:2;color:var(--bs-pagination-hover-color);background-color:var(--bs-pagination-hover-bg);border-color:var(--bs-pagination-hover-border-color)}.page-link:focus{z-index:3;color:var(--bs-pagination-focus-color);background-color:var(--bs-pagination-focus-bg);outline:0;box-shadow:var(--bs-pagination-focus-box-shadow)}.active>.page-link,.page-link.active{z-index:3;color:var(--bs-pagination-active-color);background-color:var(--bs-pagination-active-bg);border-color:var(--bs-pagination-active-border-color)}.disabled>.page-link,.page-link.disabled{color:var(--bs-pagination-disabled-color);pointer-events:none;background-color:var(--bs-pagination-disabled-bg);border-color:var(--bs-pagination-disabled-border-color)}.page-item:not(:first-child) .page-link{margin-left:calc(-1 * var(--bs-border-width))}.page-item:first-child .page-link{border-top-left-radius:var(--bs-pagination-border-radius);border-bottom-left-radius:var(--bs-pagination-border-radius)}.page-item:last-child .page-link{border-top-right-radius:var(--bs-pagination-border-radius);border-bottom-right-radius:var(--bs-pagination-border-radius)}.pagination-lg{--bs-pagination-padding-x:1.5rem;--bs-pagination-padding-y:0.75rem;--bs-pagination-font-size:1.25rem;--bs-pagination-border-radius:var(--bs-border-radius-lg)}.pagination-sm{--bs-pagination-padding-x:0.5rem;--bs-pagination-padding-y:0.25rem;--bs-pagination-font-size:0.875rem;--bs-pagination-border-radius:var(--bs-border-radius-sm)}.badge{--bs-badge-padding-x:0.65em;--bs-badge-padding-y:0.35em;--bs-badge-font-size:0.75em;--bs-badge-font-weight:700;--bs-badge-color:#fff;--bs-badge-border-radius:var(--bs-border-radius);display:inline-block;padding:var(--bs-badge-padding-y) var(--bs-badge-padding-x);font-size:var(--bs-badge-font-size);font-weight:var(--bs-badge-font-weight);line-height:1;color:var(--bs-badge-color);text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:var(--bs-badge-border-radius)}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.alert{--bs-alert-bg:transparent;--bs-alert-padding-x:1rem;--bs-alert-padding-y:1rem;--bs-alert-margin-bottom:1rem;--bs-alert-color:inherit;--bs-alert-border-color:transparent;--bs-alert-border:var(--bs-border-width) solid var(--bs-alert-border-color);--bs-alert-border-radius:var(--bs-border-radius);--bs-alert-link-color:inherit;position:relative;padding:var(--bs-alert-padding-y) var(--bs-alert-padding-x);margin-bottom:var(--bs-alert-margin-bottom);color:var(--bs-alert-color);background-color:var(--bs-alert-bg);border:var(--bs-alert-border);border-radius:var(--bs-alert-border-radius)}.alert-heading{color:inherit}.alert-link{font-weight:700;color:var(--bs-alert-link-color)}.alert-dismissible{padding-right:3rem}.alert-dismissible .btn-close{position:absolute;top:0;right:0;z-index:2;padding:1.25rem 1rem}.alert-primary{--bs-alert-color:var(--bs-primary-text-emphasis);--bs-alert-bg:var(--bs-primary-bg-subtle);--bs-alert-border-color:var(--bs-primary-border-subtle);--bs-alert-link-color:var(--bs-primary-text-emphasis)}.alert-secondary{--bs-alert-color:var(--bs-secondary-text-emphasis);--bs-alert-bg:var(--bs-secondary-bg-subtle);--bs-alert-border-color:var(--bs-secondary-border-subtle);--bs-alert-link-color:var(--bs-secondary-text-emphasis)}.alert-success{--bs-alert-color:var(--bs-success-text-emphasis);--bs-alert-bg:var(--bs-success-bg-subtle);--bs-alert-border-color:var(--bs-success-border-subtle);--bs-alert-link-color:var(--bs-success-text-emphasis)}.alert-info{--bs-alert-color:var(--bs-info-text-emphasis);--bs-alert-bg:var(--bs-info-bg-subtle);--bs-alert-border-color:var(--bs-info-border-subtle);--bs-alert-link-color:var(--bs-info-text-emphasis)}.alert-warning{--bs-alert-color:var(--bs-warning-text-emphasis);--bs-alert-bg:var(--bs-warning-bg-subtle);--bs-alert-border-color:var(--bs-warning-border-subtle);--bs-alert-link-color:var(--bs-warning-text-emphasis)}.alert-danger{--bs-alert-color:var(--bs-danger-text-emphasis);--bs-alert-bg:var(--bs-danger-bg-subtle);--bs-alert-border-color:var(--bs-danger-border-subtle);--bs-alert-link-color:var(--bs-danger-text-emphasis)}.alert-light{--bs-alert-color:var(--bs-light-text-emphasis);--bs-alert-bg:var(--bs-light-bg-subtle);--bs-alert-border-color:var(--bs-light-border-subtle);--bs-alert-link-color:var(--bs-light-text-emphasis)}.alert-dark{--bs-alert-color:var(--bs-dark-text-emphasis);--bs-alert-bg:var(--bs-dark-bg-subtle);--bs-alert-border-color:var(--bs-dark-border-subtle);--bs-alert-link-color:var(--bs-dark-text-emphasis)}@keyframes progress-bar-stripes{0%{background-position-x:var(--bs-progress-height)}}.progress,.progress-stacked{--bs-progress-height:1rem;--bs-progress-font-size:0.75rem;--bs-progress-bg:var(--bs-secondary-bg);--bs-progress-border-radius:var(--bs-border-radius);--bs-progress-box-shadow:var(--bs-box-shadow-inset);--bs-progress-bar-color:#fff;--bs-progress-bar-bg:#0d6efd;--bs-progress-bar-transition:width 0.6s ease;display:flex;height:var(--bs-progress-height);overflow:hidden;font-size:var(--bs-progress-font-size);background-color:var(--bs-progress-bg);border-radius:var(--bs-progress-border-radius)}.progress-bar{display:flex;flex-direction:column;justify-content:center;overflow:hidden;color:var(--bs-progress-bar-color);text-align:center;white-space:nowrap;background-color:var(--bs-progress-bar-bg);transition:var(--bs-progress-bar-transition)}@media (prefers-reduced-motion:reduce){.progress-bar{transition:none}}.progress-bar-striped{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:var(--bs-progress-height) var(--bs-progress-height)}.progress-stacked>.progress{overflow:visible}.progress-stacked>.progress>.progress-bar{width:100%}.progress-bar-animated{animation:1s linear infinite progress-bar-stripes}@media (prefers-reduced-motion:reduce){.progress-bar-animated{animation:none}}.list-group{--bs-list-group-color:var(--bs-body-color);--bs-list-group-bg:var(--bs-body-bg);--bs-list-group-border-color:var(--bs-border-color);--bs-list-group-border-width:var(--bs-border-width);--bs-list-group-border-radius:var(--bs-border-radius);--bs-list-group-item-padding-x:1rem;--bs-list-group-item-padding-y:0.5rem;--bs-list-group-action-color:var(--bs-secondary-color);--bs-list-group-action-hover-color:var(--bs-emphasis-color);--bs-list-group-action-hover-bg:var(--bs-tertiary-bg);--bs-list-group-action-active-color:var(--bs-body-color);--bs-list-group-action-active-bg:var(--bs-secondary-bg);--bs-list-group-disabled-color:var(--bs-secondary-color);--bs-list-group-disabled-bg:var(--bs-body-bg);--bs-list-group-active-color:#fff;--bs-list-group-active-bg:#0d6efd;--bs-list-group-active-border-color:#0d6efd;display:flex;flex-direction:column;padding-left:0;margin-bottom:0;border-radius:var(--bs-list-group-border-radius)}.list-group-numbered{list-style-type:none;counter-reset:section}.list-group-numbered>.list-group-item::before{content:counters(section, ".") ". ";counter-increment:section}.list-group-item{position:relative;display:block;padding:var(--bs-list-group-item-padding-y) var(--bs-list-group-item-padding-x);color:var(--bs-list-group-color);text-decoration:none;background-color:var(--bs-list-group-bg);border:var(--bs-list-group-border-width) solid var(--bs-list-group-border-color)}.list-group-item:first-child{border-top-left-radius:inherit;border-top-right-radius:inherit}.list-group-item:last-child{border-bottom-right-radius:inherit;border-bottom-left-radius:inherit}.list-group-item.disabled,.list-group-item:disabled{color:var(--bs-list-group-disabled-color);pointer-events:none;background-color:var(--bs-list-group-disabled-bg)}.list-group-item.active{z-index:2;color:var(--bs-list-group-active-color);background-color:var(--bs-list-group-active-bg);border-color:var(--bs-list-group-active-border-color)}.list-group-item+.list-group-item{border-top-width:0}.list-group-item+.list-group-item.active{margin-top:calc(-1 * var(--bs-list-group-border-width));border-top-width:var(--bs-list-group-border-width)}.list-group-item-action{width:100%;color:var(--bs-list-group-action-color);text-align:inherit}.list-group-item-action:not(.active):focus,.list-group-item-action:not(.active):hover{z-index:1;color:var(--bs-list-group-action-hover-color);text-decoration:none;background-color:var(--bs-list-group-action-hover-bg)}.list-group-item-action:not(.active):active{color:var(--bs-list-group-action-active-color);background-color:var(--bs-list-group-action-active-bg)}.list-group-horizontal{flex-direction:row}.list-group-horizontal>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal>.list-group-item.active{margin-top:0}.list-group-horizontal>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}@media (min-width:576px){.list-group-horizontal-sm{flex-direction:row}.list-group-horizontal-sm>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-sm>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-sm>.list-group-item.active{margin-top:0}.list-group-horizontal-sm>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-sm>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}@media (min-width:768px){.list-group-horizontal-md{flex-direction:row}.list-group-horizontal-md>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-md>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-md>.list-group-item.active{margin-top:0}.list-group-horizontal-md>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-md>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}@media (min-width:992px){.list-group-horizontal-lg{flex-direction:row}.list-group-horizontal-lg>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-lg>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-lg>.list-group-item.active{margin-top:0}.list-group-horizontal-lg>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-lg>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}@media (min-width:1200px){.list-group-horizontal-xl{flex-direction:row}.list-group-horizontal-xl>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-xl>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-xl>.list-group-item.active{margin-top:0}.list-group-horizontal-xl>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-xl>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}@media (min-width:1400px){.list-group-horizontal-xxl{flex-direction:row}.list-group-horizontal-xxl>.list-group-item:first-child:not(:last-child){border-bottom-left-radius:var(--bs-list-group-border-radius);border-top-right-radius:0}.list-group-horizontal-xxl>.list-group-item:last-child:not(:first-child){border-top-right-radius:var(--bs-list-group-border-radius);border-bottom-left-radius:0}.list-group-horizontal-xxl>.list-group-item.active{margin-top:0}.list-group-horizontal-xxl>.list-group-item+.list-group-item{border-top-width:var(--bs-list-group-border-width);border-left-width:0}.list-group-horizontal-xxl>.list-group-item+.list-group-item.active{margin-left:calc(-1 * var(--bs-list-group-border-width));border-left-width:var(--bs-list-group-border-width)}}.list-group-flush{border-radius:0}.list-group-flush>.list-group-item{border-width:0 0 var(--bs-list-group-border-width)}.list-group-flush>.list-group-item:last-child{border-bottom-width:0}.list-group-item-primary{--bs-list-group-color:var(--bs-primary-text-emphasis);--bs-list-group-bg:var(--bs-primary-bg-subtle);--bs-list-group-border-color:var(--bs-primary-border-subtle);--bs-list-group-action-hover-color:var(--bs-emphasis-color);--bs-list-group-action-hover-bg:var(--bs-primary-border-subtle);--bs-list-group-action-active-color:var(--bs-emphasis-color);--bs-list-group-action-active-bg:var(--bs-primary-border-subtle);--bs-list-group-active-color:var(--bs-primary-bg-subtle);--bs-list-group-active-bg:var(--bs-primary-text-emphasis);--bs-list-group-active-border-color:var(--bs-primary-text-emphasis)}.list-group-item-secondary{--bs-list-group-color:var(--bs-secondary-text-emphasis);--bs-list-group-bg:var(--bs-secondary-bg-subtle);--bs-list-group-border-color:var(--bs-secondary-border-subtle);--bs-list-group-action-hover-color:var(--bs-emphasis-color);--bs-list-group-action-hover-bg:var(--bs-secondary-border-subtle);--bs-list-group-action-active-color:var(--bs-emphasis-color);--bs-list-group-action-active-bg:var(--bs-secondary-border-subtle);--bs-list-group-active-color:var(--bs-secondary-bg-subtle);--bs-list-group-active-bg:var(--bs-secondary-text-emphasis);--bs-list-group-active-border-color:var(--bs-secondary-text-emphasis)}.list-group-item-success{--bs-list-group-color:var(--bs-success-text-emphasis);--bs-list-group-bg:var(--bs-success-bg-subtle);--bs-list-group-border-color:var(--bs-success-border-subtle);--bs-list-group-action-hover-color:var(--bs-emphasis-color);--bs-list-group-action-hover-bg:var(--bs-success-border-subtle);--bs-list-group-action-active-color:var(--bs-emphasis-color);--bs-list-group-action-active-bg:var(--bs-success-border-subtle);--bs-list-group-active-color:var(--bs-success-bg-subtle);--bs-list-group-active-bg:var(--bs-success-text-emphasis);--bs-list-group-active-border-color:var(--bs-success-text-emphasis)}.list-group-item-info{--bs-list-group-color:var(--bs-info-text-emphasis);--bs-list-group-bg:var(--bs-info-bg-subtle);--bs-list-group-border-color:var(--bs-info-border-subtle);--bs-list-group-action-hover-color:var(--bs-emphasis-color);--bs-list-group-action-hover-bg:var(--bs-info-border-subtle);--bs-list-group-action-active-color:var(--bs-emphasis-color);--bs-list-group-action-active-bg:var(--bs-info-border-subtle);--bs-list-group-active-color:var(--bs-info-bg-subtle);--bs-list-group-active-bg:var(--bs-info-text-emphasis);--bs-list-group-active-border-color:var(--bs-info-text-emphasis)}.list-group-item-warning{--bs-list-group-color:var(--bs-warning-text-emphasis);--bs-list-group-bg:var(--bs-warning-bg-subtle);--bs-list-group-border-color:var(--bs-warning-border-subtle);--bs-list-group-action-hover-color:var(--bs-emphasis-color);--bs-list-group-action-hover-bg:var(--bs-warning-border-subtle);--bs-list-group-action-active-color:var(--bs-emphasis-color);--bs-list-group-action-active-bg:var(--bs-warning-border-subtle);--bs-list-group-active-color:var(--bs-warning-bg-subtle);--bs-list-group-active-bg:var(--bs-warning-text-emphasis);--bs-list-group-active-border-color:var(--bs-warning-text-emphasis)}.list-group-item-danger{--bs-list-group-color:var(--bs-danger-text-emphasis);--bs-list-group-bg:var(--bs-danger-bg-subtle);--bs-list-group-border-color:var(--bs-danger-border-subtle);--bs-list-group-action-hover-color:var(--bs-emphasis-color);--bs-list-group-action-hover-bg:var(--bs-danger-border-subtle);--bs-list-group-action-active-color:var(--bs-emphasis-color);--bs-list-group-action-active-bg:var(--bs-danger-border-subtle);--bs-list-group-active-color:var(--bs-danger-bg-subtle);--bs-list-group-active-bg:var(--bs-danger-text-emphasis);--bs-list-group-active-border-color:var(--bs-danger-text-emphasis)}.list-group-item-light{--bs-list-group-color:var(--bs-light-text-emphasis);--bs-list-group-bg:var(--bs-light-bg-subtle);--bs-list-group-border-color:var(--bs-light-border-subtle);--bs-list-group-action-hover-color:var(--bs-emphasis-color);--bs-list-group-action-hover-bg:var(--bs-light-border-subtle);--bs-list-group-action-active-color:var(--bs-emphasis-color);--bs-list-group-action-active-bg:var(--bs-light-border-subtle);--bs-list-group-active-color:var(--bs-light-bg-subtle);--bs-list-group-active-bg:var(--bs-light-text-emphasis);--bs-list-group-active-border-color:var(--bs-light-text-emphasis)}.list-group-item-dark{--bs-list-group-color:var(--bs-dark-text-emphasis);--bs-list-group-bg:var(--bs-dark-bg-subtle);--bs-list-group-border-color:var(--bs-dark-border-subtle);--bs-list-group-action-hover-color:var(--bs-emphasis-color);--bs-list-group-action-hover-bg:var(--bs-dark-border-subtle);--bs-list-group-action-active-color:var(--bs-emphasis-color);--bs-list-group-action-active-bg:var(--bs-dark-border-subtle);--bs-list-group-active-color:var(--bs-dark-bg-subtle);--bs-list-group-active-bg:var(--bs-dark-text-emphasis);--bs-list-group-active-border-color:var(--bs-dark-text-emphasis)}.btn-close{--bs-btn-close-color:#000;--bs-btn-close-bg:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414'/%3e%3c/svg%3e");--bs-btn-close-opacity:0.5;--bs-btn-close-hover-opacity:0.75;--bs-btn-close-focus-shadow:0 0 0 0.25rem rgba(13, 110, 253, 0.25);--bs-btn-close-focus-opacity:1;--bs-btn-close-disabled-opacity:0.25;box-sizing:content-box;width:1em;height:1em;padding:.25em .25em;color:var(--bs-btn-close-color);background:transparent var(--bs-btn-close-bg) center/1em auto no-repeat;filter:var(--bs-btn-close-filter);border:0;border-radius:.375rem;opacity:var(--bs-btn-close-opacity)}.btn-close:hover{color:var(--bs-btn-close-color);text-decoration:none;opacity:var(--bs-btn-close-hover-opacity)}.btn-close:focus{outline:0;box-shadow:var(--bs-btn-close-focus-shadow);opacity:var(--bs-btn-close-focus-opacity)}.btn-close.disabled,.btn-close:disabled{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;opacity:var(--bs-btn-close-disabled-opacity)}.btn-close-white{--bs-btn-close-filter:invert(1) grayscale(100%) brightness(200%)}:root,[data-bs-theme=light]{--bs-btn-close-filter: }[data-bs-theme=dark]{--bs-btn-close-filter:invert(1) grayscale(100%) brightness(200%)}.toast{--bs-toast-zindex:1090;--bs-toast-padding-x:0.75rem;--bs-toast-padding-y:0.5rem;--bs-toast-spacing:1.5rem;--bs-toast-max-width:350px;--bs-toast-font-size:0.875rem;--bs-toast-color: ;--bs-toast-bg:rgba(var(--bs-body-bg-rgb), 0.85);--bs-toast-border-width:var(--bs-border-width);--bs-toast-border-color:var(--bs-border-color-translucent);--bs-toast-border-radius:var(--bs-border-radius);--bs-toast-box-shadow:var(--bs-box-shadow);--bs-toast-header-color:var(--bs-secondary-color);--bs-toast-header-bg:rgba(var(--bs-body-bg-rgb), 0.85);--bs-toast-header-border-color:var(--bs-border-color-translucent);width:var(--bs-toast-max-width);max-width:100%;font-size:var(--bs-toast-font-size);color:var(--bs-toast-color);pointer-events:auto;background-color:var(--bs-toast-bg);background-clip:padding-box;border:var(--bs-toast-border-width) solid var(--bs-toast-border-color);box-shadow:var(--bs-toast-box-shadow);border-radius:var(--bs-toast-border-radius)}.toast.showing{opacity:0}.toast:not(.show){display:none}.toast-container{--bs-toast-zindex:1090;position:absolute;z-index:var(--bs-toast-zindex);width:-webkit-max-content;width:-moz-max-content;width:max-content;max-width:100%;pointer-events:none}.toast-container>:not(:last-child){margin-bottom:var(--bs-toast-spacing)}.toast-header{display:flex;align-items:center;padding:var(--bs-toast-padding-y) var(--bs-toast-padding-x);color:var(--bs-toast-header-color);background-color:var(--bs-toast-header-bg);background-clip:padding-box;border-bottom:var(--bs-toast-border-width) solid var(--bs-toast-header-border-color);border-top-left-radius:calc(var(--bs-toast-border-radius) - var(--bs-toast-border-width));border-top-right-radius:calc(var(--bs-toast-border-radius) - var(--bs-toast-border-width))}.toast-header .btn-close{margin-right:calc(-.5 * var(--bs-toast-padding-x));margin-left:var(--bs-toast-padding-x)}.toast-body{padding:var(--bs-toast-padding-x);word-wrap:break-word}.modal{--bs-modal-zindex:1055;--bs-modal-width:500px;--bs-modal-padding:1rem;--bs-modal-margin:0.5rem;--bs-modal-color:var(--bs-body-color);--bs-modal-bg:var(--bs-body-bg);--bs-modal-border-color:var(--bs-border-color-translucent);--bs-modal-border-width:var(--bs-border-width);--bs-modal-border-radius:var(--bs-border-radius-lg);--bs-modal-box-shadow:var(--bs-box-shadow-sm);--bs-modal-inner-border-radius:calc(var(--bs-border-radius-lg) - (var(--bs-border-width)));--bs-modal-header-padding-x:1rem;--bs-modal-header-padding-y:1rem;--bs-modal-header-padding:1rem 1rem;--bs-modal-header-border-color:var(--bs-border-color);--bs-modal-header-border-width:var(--bs-border-width);--bs-modal-title-line-height:1.5;--bs-modal-footer-gap:0.5rem;--bs-modal-footer-bg: ;--bs-modal-footer-border-color:var(--bs-border-color);--bs-modal-footer-border-width:var(--bs-border-width);position:fixed;top:0;left:0;z-index:var(--bs-modal-zindex);display:none;width:100%;height:100%;overflow-x:hidden;overflow-y:auto;outline:0}.modal-dialog{position:relative;width:auto;margin:var(--bs-modal-margin);pointer-events:none}.modal.fade .modal-dialog{transform:translate(0,-50px);transition:transform .3s ease-out}@media (prefers-reduced-motion:reduce){.modal.fade .modal-dialog{transition:none}}.modal.show .modal-dialog{transform:none}.modal.modal-static .modal-dialog{transform:scale(1.02)}.modal-dialog-scrollable{height:calc(100% - var(--bs-modal-margin) * 2)}.modal-dialog-scrollable .modal-content{max-height:100%;overflow:hidden}.modal-dialog-scrollable .modal-body{overflow-y:auto}.modal-dialog-centered{display:flex;align-items:center;min-height:calc(100% - var(--bs-modal-margin) * 2)}.modal-content{position:relative;display:flex;flex-direction:column;width:100%;color:var(--bs-modal-color);pointer-events:auto;background-color:var(--bs-modal-bg);background-clip:padding-box;border:var(--bs-modal-border-width) solid var(--bs-modal-border-color);border-radius:var(--bs-modal-border-radius);outline:0}.modal-backdrop{--bs-backdrop-zindex:1050;--bs-backdrop-bg:#000;--bs-backdrop-opacity:0.5;position:fixed;top:0;left:0;z-index:var(--bs-backdrop-zindex);width:100vw;height:100vh;background-color:var(--bs-backdrop-bg)}.modal-backdrop.fade{opacity:0}.modal-backdrop.show{opacity:var(--bs-backdrop-opacity)}.modal-header{display:flex;flex-shrink:0;align-items:center;padding:var(--bs-modal-header-padding);border-bottom:var(--bs-modal-header-border-width) solid var(--bs-modal-header-border-color);border-top-left-radius:var(--bs-modal-inner-border-radius);border-top-right-radius:var(--bs-modal-inner-border-radius)}.modal-header .btn-close{padding:calc(var(--bs-modal-header-padding-y) * .5) calc(var(--bs-modal-header-padding-x) * .5);margin-top:calc(-.5 * var(--bs-modal-header-padding-y));margin-right:calc(-.5 * var(--bs-modal-header-padding-x));margin-bottom:calc(-.5 * var(--bs-modal-header-padding-y));margin-left:auto}.modal-title{margin-bottom:0;line-height:var(--bs-modal-title-line-height)}.modal-body{position:relative;flex:1 1 auto;padding:var(--bs-modal-padding)}.modal-footer{display:flex;flex-shrink:0;flex-wrap:wrap;align-items:center;justify-content:flex-end;padding:calc(var(--bs-modal-padding) - var(--bs-modal-footer-gap) * .5);background-color:var(--bs-modal-footer-bg);border-top:var(--bs-modal-footer-border-width) solid var(--bs-modal-footer-border-color);border-bottom-right-radius:var(--bs-modal-inner-border-radius);border-bottom-left-radius:var(--bs-modal-inner-border-radius)}.modal-footer>*{margin:calc(var(--bs-modal-footer-gap) * .5)}@media (min-width:576px){.modal{--bs-modal-margin:1.75rem;--bs-modal-box-shadow:var(--bs-box-shadow)}.modal-dialog{max-width:var(--bs-modal-width);margin-right:auto;margin-left:auto}.modal-sm{--bs-modal-width:300px}}@media (min-width:992px){.modal-lg,.modal-xl{--bs-modal-width:800px}}@media (min-width:1200px){.modal-xl{--bs-modal-width:1140px}}.modal-fullscreen{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen .modal-footer,.modal-fullscreen .modal-header{border-radius:0}.modal-fullscreen .modal-body{overflow-y:auto}@media (max-width:575.98px){.modal-fullscreen-sm-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-sm-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-sm-down .modal-footer,.modal-fullscreen-sm-down .modal-header{border-radius:0}.modal-fullscreen-sm-down .modal-body{overflow-y:auto}}@media (max-width:767.98px){.modal-fullscreen-md-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-md-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-md-down .modal-footer,.modal-fullscreen-md-down .modal-header{border-radius:0}.modal-fullscreen-md-down .modal-body{overflow-y:auto}}@media (max-width:991.98px){.modal-fullscreen-lg-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-lg-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-lg-down .modal-footer,.modal-fullscreen-lg-down .modal-header{border-radius:0}.modal-fullscreen-lg-down .modal-body{overflow-y:auto}}@media (max-width:1199.98px){.modal-fullscreen-xl-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-xl-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-xl-down .modal-footer,.modal-fullscreen-xl-down .modal-header{border-radius:0}.modal-fullscreen-xl-down .modal-body{overflow-y:auto}}@media (max-width:1399.98px){.modal-fullscreen-xxl-down{width:100vw;max-width:none;height:100%;margin:0}.modal-fullscreen-xxl-down .modal-content{height:100%;border:0;border-radius:0}.modal-fullscreen-xxl-down .modal-footer,.modal-fullscreen-xxl-down .modal-header{border-radius:0}.modal-fullscreen-xxl-down .modal-body{overflow-y:auto}}.tooltip{--bs-tooltip-zindex:1080;--bs-tooltip-max-width:200px;--bs-tooltip-padding-x:0.5rem;--bs-tooltip-padding-y:0.25rem;--bs-tooltip-margin: ;--bs-tooltip-font-size:0.875rem;--bs-tooltip-color:var(--bs-body-bg);--bs-tooltip-bg:var(--bs-emphasis-color);--bs-tooltip-border-radius:var(--bs-border-radius);--bs-tooltip-opacity:0.9;--bs-tooltip-arrow-width:0.8rem;--bs-tooltip-arrow-height:0.4rem;z-index:var(--bs-tooltip-zindex);display:block;margin:var(--bs-tooltip-margin);font-family:var(--bs-font-sans-serif);font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;white-space:normal;word-spacing:normal;line-break:auto;font-size:var(--bs-tooltip-font-size);word-wrap:break-word;opacity:0}.tooltip.show{opacity:var(--bs-tooltip-opacity)}.tooltip .tooltip-arrow{display:block;width:var(--bs-tooltip-arrow-width);height:var(--bs-tooltip-arrow-height)}.tooltip .tooltip-arrow::before{position:absolute;content:"";border-color:transparent;border-style:solid}.bs-tooltip-auto[data-popper-placement^=top] .tooltip-arrow,.bs-tooltip-top .tooltip-arrow{bottom:calc(-1 * var(--bs-tooltip-arrow-height))}.bs-tooltip-auto[data-popper-placement^=top] .tooltip-arrow::before,.bs-tooltip-top .tooltip-arrow::before{top:-1px;border-width:var(--bs-tooltip-arrow-height) calc(var(--bs-tooltip-arrow-width) * .5) 0;border-top-color:var(--bs-tooltip-bg)}.bs-tooltip-auto[data-popper-placement^=right] .tooltip-arrow,.bs-tooltip-end .tooltip-arrow{left:calc(-1 * var(--bs-tooltip-arrow-height));width:var(--bs-tooltip-arrow-height);height:var(--bs-tooltip-arrow-width)}.bs-tooltip-auto[data-popper-placement^=right] .tooltip-arrow::before,.bs-tooltip-end .tooltip-arrow::before{right:-1px;border-width:calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height) calc(var(--bs-tooltip-arrow-width) * .5) 0;border-right-color:var(--bs-tooltip-bg)}.bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow,.bs-tooltip-bottom .tooltip-arrow{top:calc(-1 * var(--bs-tooltip-arrow-height))}.bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow::before,.bs-tooltip-bottom .tooltip-arrow::before{bottom:-1px;border-width:0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height);border-bottom-color:var(--bs-tooltip-bg)}.bs-tooltip-auto[data-popper-placement^=left] .tooltip-arrow,.bs-tooltip-start .tooltip-arrow{right:calc(-1 * var(--bs-tooltip-arrow-height));width:var(--bs-tooltip-arrow-height);height:var(--bs-tooltip-arrow-width)}.bs-tooltip-auto[data-popper-placement^=left] .tooltip-arrow::before,.bs-tooltip-start .tooltip-arrow::before{left:-1px;border-width:calc(var(--bs-tooltip-arrow-width) * .5) 0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height);border-left-color:var(--bs-tooltip-bg)}.tooltip-inner{max-width:var(--bs-tooltip-max-width);padding:var(--bs-tooltip-padding-y) var(--bs-tooltip-padding-x);color:var(--bs-tooltip-color);text-align:center;background-color:var(--bs-tooltip-bg);border-radius:var(--bs-tooltip-border-radius)}.popover{--bs-popover-zindex:1070;--bs-popover-max-width:276px;--bs-popover-font-size:0.875rem;--bs-popover-bg:var(--bs-body-bg);--bs-popover-border-width:var(--bs-border-width);--bs-popover-border-color:var(--bs-border-color-translucent);--bs-popover-border-radius:var(--bs-border-radius-lg);--bs-popover-inner-border-radius:calc(var(--bs-border-radius-lg) - var(--bs-border-width));--bs-popover-box-shadow:var(--bs-box-shadow);--bs-popover-header-padding-x:1rem;--bs-popover-header-padding-y:0.5rem;--bs-popover-header-font-size:1rem;--bs-popover-header-color:inherit;--bs-popover-header-bg:var(--bs-secondary-bg);--bs-popover-body-padding-x:1rem;--bs-popover-body-padding-y:1rem;--bs-popover-body-color:var(--bs-body-color);--bs-popover-arrow-width:1rem;--bs-popover-arrow-height:0.5rem;--bs-popover-arrow-border:var(--bs-popover-border-color);z-index:var(--bs-popover-zindex);display:block;max-width:var(--bs-popover-max-width);font-family:var(--bs-font-sans-serif);font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;white-space:normal;word-spacing:normal;line-break:auto;font-size:var(--bs-popover-font-size);word-wrap:break-word;background-color:var(--bs-popover-bg);background-clip:padding-box;border:var(--bs-popover-border-width) solid var(--bs-popover-border-color);border-radius:var(--bs-popover-border-radius)}.popover .popover-arrow{display:block;width:var(--bs-popover-arrow-width);height:var(--bs-popover-arrow-height)}.popover .popover-arrow::after,.popover .popover-arrow::before{position:absolute;display:block;content:"";border-color:transparent;border-style:solid;border-width:0}.bs-popover-auto[data-popper-placement^=top]>.popover-arrow,.bs-popover-top>.popover-arrow{bottom:calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width))}.bs-popover-auto[data-popper-placement^=top]>.popover-arrow::after,.bs-popover-auto[data-popper-placement^=top]>.popover-arrow::before,.bs-popover-top>.popover-arrow::after,.bs-popover-top>.popover-arrow::before{border-width:var(--bs-popover-arrow-height) calc(var(--bs-popover-arrow-width) * .5) 0}.bs-popover-auto[data-popper-placement^=top]>.popover-arrow::before,.bs-popover-top>.popover-arrow::before{bottom:0;border-top-color:var(--bs-popover-arrow-border)}.bs-popover-auto[data-popper-placement^=top]>.popover-arrow::after,.bs-popover-top>.popover-arrow::after{bottom:var(--bs-popover-border-width);border-top-color:var(--bs-popover-bg)}.bs-popover-auto[data-popper-placement^=right]>.popover-arrow,.bs-popover-end>.popover-arrow{left:calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));width:var(--bs-popover-arrow-height);height:var(--bs-popover-arrow-width)}.bs-popover-auto[data-popper-placement^=right]>.popover-arrow::after,.bs-popover-auto[data-popper-placement^=right]>.popover-arrow::before,.bs-popover-end>.popover-arrow::after,.bs-popover-end>.popover-arrow::before{border-width:calc(var(--bs-popover-arrow-width) * .5) var(--bs-popover-arrow-height) calc(var(--bs-popover-arrow-width) * .5) 0}.bs-popover-auto[data-popper-placement^=right]>.popover-arrow::before,.bs-popover-end>.popover-arrow::before{left:0;border-right-color:var(--bs-popover-arrow-border)}.bs-popover-auto[data-popper-placement^=right]>.popover-arrow::after,.bs-popover-end>.popover-arrow::after{left:var(--bs-popover-border-width);border-right-color:var(--bs-popover-bg)}.bs-popover-auto[data-popper-placement^=bottom]>.popover-arrow,.bs-popover-bottom>.popover-arrow{top:calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width))}.bs-popover-auto[data-popper-placement^=bottom]>.popover-arrow::after,.bs-popover-auto[data-popper-placement^=bottom]>.popover-arrow::before,.bs-popover-bottom>.popover-arrow::after,.bs-popover-bottom>.popover-arrow::before{border-width:0 calc(var(--bs-popover-arrow-width) * .5) var(--bs-popover-arrow-height)}.bs-popover-auto[data-popper-placement^=bottom]>.popover-arrow::before,.bs-popover-bottom>.popover-arrow::before{top:0;border-bottom-color:var(--bs-popover-arrow-border)}.bs-popover-auto[data-popper-placement^=bottom]>.popover-arrow::after,.bs-popover-bottom>.popover-arrow::after{top:var(--bs-popover-border-width);border-bottom-color:var(--bs-popover-bg)}.bs-popover-auto[data-popper-placement^=bottom] .popover-header::before,.bs-popover-bottom .popover-header::before{position:absolute;top:0;left:50%;display:block;width:var(--bs-popover-arrow-width);margin-left:calc(-.5 * var(--bs-popover-arrow-width));content:"";border-bottom:var(--bs-popover-border-width) solid var(--bs-popover-header-bg)}.bs-popover-auto[data-popper-placement^=left]>.popover-arrow,.bs-popover-start>.popover-arrow{right:calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));width:var(--bs-popover-arrow-height);height:var(--bs-popover-arrow-width)}.bs-popover-auto[data-popper-placement^=left]>.popover-arrow::after,.bs-popover-auto[data-popper-placement^=left]>.popover-arrow::before,.bs-popover-start>.popover-arrow::after,.bs-popover-start>.popover-arrow::before{border-width:calc(var(--bs-popover-arrow-width) * .5) 0 calc(var(--bs-popover-arrow-width) * .5) var(--bs-popover-arrow-height)}.bs-popover-auto[data-popper-placement^=left]>.popover-arrow::before,.bs-popover-start>.popover-arrow::before{right:0;border-left-color:var(--bs-popover-arrow-border)}.bs-popover-auto[data-popper-placement^=left]>.popover-arrow::after,.bs-popover-start>.popover-arrow::after{right:var(--bs-popover-border-width);border-left-color:var(--bs-popover-bg)}.popover-header{padding:var(--bs-popover-header-padding-y) var(--bs-popover-header-padding-x);margin-bottom:0;font-size:var(--bs-popover-header-font-size);color:var(--bs-popover-header-color);background-color:var(--bs-popover-header-bg);border-bottom:var(--bs-popover-border-width) solid var(--bs-popover-border-color);border-top-left-radius:var(--bs-popover-inner-border-radius);border-top-right-radius:var(--bs-popover-inner-border-radius)}.popover-header:empty{display:none}.popover-body{padding:var(--bs-popover-body-padding-y) var(--bs-popover-body-padding-x);color:var(--bs-popover-body-color)}.carousel{position:relative}.carousel.pointer-event{touch-action:pan-y}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel-inner::after{display:block;clear:both;content:""}.carousel-item{position:relative;display:none;float:left;width:100%;margin-right:-100%;-webkit-backface-visibility:hidden;backface-visibility:hidden;transition:transform .6s ease-in-out}@media (prefers-reduced-motion:reduce){.carousel-item{transition:none}}.carousel-item-next,.carousel-item-prev,.carousel-item.active{display:block}.active.carousel-item-end,.carousel-item-next:not(.carousel-item-start){transform:translateX(100%)}.active.carousel-item-start,.carousel-item-prev:not(.carousel-item-end){transform:translateX(-100%)}.carousel-fade .carousel-item{opacity:0;transition-property:opacity;transform:none}.carousel-fade .carousel-item-next.carousel-item-start,.carousel-fade .carousel-item-prev.carousel-item-end,.carousel-fade .carousel-item.active{z-index:1;opacity:1}.carousel-fade .active.carousel-item-end,.carousel-fade .active.carousel-item-start{z-index:0;opacity:0;transition:opacity 0s .6s}@media (prefers-reduced-motion:reduce){.carousel-fade .active.carousel-item-end,.carousel-fade .active.carousel-item-start{transition:none}}.carousel-control-next,.carousel-control-prev{position:absolute;top:0;bottom:0;z-index:1;display:flex;align-items:center;justify-content:center;width:15%;padding:0;color:#fff;text-align:center;background:0 0;filter:var(--bs-carousel-control-icon-filter);border:0;opacity:.5;transition:opacity .15s ease}@media (prefers-reduced-motion:reduce){.carousel-control-next,.carousel-control-prev{transition:none}}.carousel-control-next:focus,.carousel-control-next:hover,.carousel-control-prev:focus,.carousel-control-prev:hover{color:#fff;text-decoration:none;outline:0;opacity:.9}.carousel-control-prev{left:0}.carousel-control-next{right:0}.carousel-control-next-icon,.carousel-control-prev-icon{display:inline-block;width:2rem;height:2rem;background-repeat:no-repeat;background-position:50%;background-size:100% 100%}.carousel-control-prev-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0'/%3e%3c/svg%3e")}.carousel-control-next-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708'/%3e%3c/svg%3e")}.carousel-indicators{position:absolute;right:0;bottom:0;left:0;z-index:2;display:flex;justify-content:center;padding:0;margin-right:15%;margin-bottom:1rem;margin-left:15%}.carousel-indicators [data-bs-target]{box-sizing:content-box;flex:0 1 auto;width:30px;height:3px;padding:0;margin-right:3px;margin-left:3px;text-indent:-999px;cursor:pointer;background-color:var(--bs-carousel-indicator-active-bg);background-clip:padding-box;border:0;border-top:10px solid transparent;border-bottom:10px solid transparent;opacity:.5;transition:opacity .6s ease}@media (prefers-reduced-motion:reduce){.carousel-indicators [data-bs-target]{transition:none}}.carousel-indicators .active{opacity:1}.carousel-caption{position:absolute;right:15%;bottom:1.25rem;left:15%;padding-top:1.25rem;padding-bottom:1.25rem;color:var(--bs-carousel-caption-color);text-align:center}.carousel-dark{--bs-carousel-indicator-active-bg:#000;--bs-carousel-caption-color:#000;--bs-carousel-control-icon-filter:invert(1) grayscale(100)}:root,[data-bs-theme=light]{--bs-carousel-indicator-active-bg:#fff;--bs-carousel-caption-color:#fff;--bs-carousel-control-icon-filter: }[data-bs-theme=dark]{--bs-carousel-indicator-active-bg:#000;--bs-carousel-caption-color:#000;--bs-carousel-control-icon-filter:invert(1) grayscale(100)}.spinner-border,.spinner-grow{display:inline-block;width:var(--bs-spinner-width);height:var(--bs-spinner-height);vertical-align:var(--bs-spinner-vertical-align);border-radius:50%;animation:var(--bs-spinner-animation-speed) linear infinite var(--bs-spinner-animation-name)}@keyframes spinner-border{to{transform:rotate(360deg)}}.spinner-border{--bs-spinner-width:2rem;--bs-spinner-height:2rem;--bs-spinner-vertical-align:-0.125em;--bs-spinner-border-width:0.25em;--bs-spinner-animation-speed:0.75s;--bs-spinner-animation-name:spinner-border;border:var(--bs-spinner-border-width) solid currentcolor;border-right-color:transparent}.spinner-border-sm{--bs-spinner-width:1rem;--bs-spinner-height:1rem;--bs-spinner-border-width:0.2em}@keyframes spinner-grow{0%{transform:scale(0)}50%{opacity:1;transform:none}}.spinner-grow{--bs-spinner-width:2rem;--bs-spinner-height:2rem;--bs-spinner-vertical-align:-0.125em;--bs-spinner-animation-speed:0.75s;--bs-spinner-animation-name:spinner-grow;background-color:currentcolor;opacity:0}.spinner-grow-sm{--bs-spinner-width:1rem;--bs-spinner-height:1rem}@media (prefers-reduced-motion:reduce){.spinner-border,.spinner-grow{--bs-spinner-animation-speed:1.5s}}.offcanvas,.offcanvas-lg,.offcanvas-md,.offcanvas-sm,.offcanvas-xl,.offcanvas-xxl{--bs-offcanvas-zindex:1045;--bs-offcanvas-width:400px;--bs-offcanvas-height:30vh;--bs-offcanvas-padding-x:1rem;--bs-offcanvas-padding-y:1rem;--bs-offcanvas-color:var(--bs-body-color);--bs-offcanvas-bg:var(--bs-body-bg);--bs-offcanvas-border-width:var(--bs-border-width);--bs-offcanvas-border-color:var(--bs-border-color-translucent);--bs-offcanvas-box-shadow:var(--bs-box-shadow-sm);--bs-offcanvas-transition:transform 0.3s ease-in-out;--bs-offcanvas-title-line-height:1.5}@media (max-width:575.98px){.offcanvas-sm{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width:575.98px) and (prefers-reduced-motion:reduce){.offcanvas-sm{transition:none}}@media (max-width:575.98px){.offcanvas-sm.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-sm.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-sm.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-sm.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-sm.show:not(.hiding),.offcanvas-sm.showing{transform:none}.offcanvas-sm.hiding,.offcanvas-sm.show,.offcanvas-sm.showing{visibility:visible}}@media (min-width:576px){.offcanvas-sm{--bs-offcanvas-height:auto;--bs-offcanvas-border-width:0;background-color:transparent!important}.offcanvas-sm .offcanvas-header{display:none}.offcanvas-sm .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible;background-color:transparent!important}}@media (max-width:767.98px){.offcanvas-md{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width:767.98px) and (prefers-reduced-motion:reduce){.offcanvas-md{transition:none}}@media (max-width:767.98px){.offcanvas-md.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-md.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-md.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-md.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-md.show:not(.hiding),.offcanvas-md.showing{transform:none}.offcanvas-md.hiding,.offcanvas-md.show,.offcanvas-md.showing{visibility:visible}}@media (min-width:768px){.offcanvas-md{--bs-offcanvas-height:auto;--bs-offcanvas-border-width:0;background-color:transparent!important}.offcanvas-md .offcanvas-header{display:none}.offcanvas-md .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible;background-color:transparent!important}}@media (max-width:991.98px){.offcanvas-lg{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width:991.98px) and (prefers-reduced-motion:reduce){.offcanvas-lg{transition:none}}@media (max-width:991.98px){.offcanvas-lg.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-lg.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-lg.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-lg.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-lg.show:not(.hiding),.offcanvas-lg.showing{transform:none}.offcanvas-lg.hiding,.offcanvas-lg.show,.offcanvas-lg.showing{visibility:visible}}@media (min-width:992px){.offcanvas-lg{--bs-offcanvas-height:auto;--bs-offcanvas-border-width:0;background-color:transparent!important}.offcanvas-lg .offcanvas-header{display:none}.offcanvas-lg .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible;background-color:transparent!important}}@media (max-width:1199.98px){.offcanvas-xl{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width:1199.98px) and (prefers-reduced-motion:reduce){.offcanvas-xl{transition:none}}@media (max-width:1199.98px){.offcanvas-xl.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-xl.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-xl.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-xl.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-xl.show:not(.hiding),.offcanvas-xl.showing{transform:none}.offcanvas-xl.hiding,.offcanvas-xl.show,.offcanvas-xl.showing{visibility:visible}}@media (min-width:1200px){.offcanvas-xl{--bs-offcanvas-height:auto;--bs-offcanvas-border-width:0;background-color:transparent!important}.offcanvas-xl .offcanvas-header{display:none}.offcanvas-xl .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible;background-color:transparent!important}}@media (max-width:1399.98px){.offcanvas-xxl{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}}@media (max-width:1399.98px) and (prefers-reduced-motion:reduce){.offcanvas-xxl{transition:none}}@media (max-width:1399.98px){.offcanvas-xxl.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas-xxl.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas-xxl.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas-xxl.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas-xxl.show:not(.hiding),.offcanvas-xxl.showing{transform:none}.offcanvas-xxl.hiding,.offcanvas-xxl.show,.offcanvas-xxl.showing{visibility:visible}}@media (min-width:1400px){.offcanvas-xxl{--bs-offcanvas-height:auto;--bs-offcanvas-border-width:0;background-color:transparent!important}.offcanvas-xxl .offcanvas-header{display:none}.offcanvas-xxl .offcanvas-body{display:flex;flex-grow:0;padding:0;overflow-y:visible;background-color:transparent!important}}.offcanvas{position:fixed;bottom:0;z-index:var(--bs-offcanvas-zindex);display:flex;flex-direction:column;max-width:100%;color:var(--bs-offcanvas-color);visibility:hidden;background-color:var(--bs-offcanvas-bg);background-clip:padding-box;outline:0;transition:var(--bs-offcanvas-transition)}@media (prefers-reduced-motion:reduce){.offcanvas{transition:none}}.offcanvas.offcanvas-start{top:0;left:0;width:var(--bs-offcanvas-width);border-right:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(-100%)}.offcanvas.offcanvas-end{top:0;right:0;width:var(--bs-offcanvas-width);border-left:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateX(100%)}.offcanvas.offcanvas-top{top:0;right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-bottom:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(-100%)}.offcanvas.offcanvas-bottom{right:0;left:0;height:var(--bs-offcanvas-height);max-height:100%;border-top:var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);transform:translateY(100%)}.offcanvas.show:not(.hiding),.offcanvas.showing{transform:none}.offcanvas.hiding,.offcanvas.show,.offcanvas.showing{visibility:visible}.offcanvas-backdrop{position:fixed;top:0;left:0;z-index:1040;width:100vw;height:100vh;background-color:#000}.offcanvas-backdrop.fade{opacity:0}.offcanvas-backdrop.show{opacity:.5}.offcanvas-header{display:flex;align-items:center;padding:var(--bs-offcanvas-padding-y) var(--bs-offcanvas-padding-x)}.offcanvas-header .btn-close{padding:calc(var(--bs-offcanvas-padding-y) * .5) calc(var(--bs-offcanvas-padding-x) * .5);margin-top:calc(-.5 * var(--bs-offcanvas-padding-y));margin-right:calc(-.5 * var(--bs-offcanvas-padding-x));margin-bottom:calc(-.5 * var(--bs-offcanvas-padding-y));margin-left:auto}.offcanvas-title{margin-bottom:0;line-height:var(--bs-offcanvas-title-line-height)}.offcanvas-body{flex-grow:1;padding:var(--bs-offcanvas-padding-y) var(--bs-offcanvas-padding-x);overflow-y:auto}.placeholder{display:inline-block;min-height:1em;vertical-align:middle;cursor:wait;background-color:currentcolor;opacity:.5}.placeholder.btn::before{display:inline-block;content:""}.placeholder-xs{min-height:.6em}.placeholder-sm{min-height:.8em}.placeholder-lg{min-height:1.2em}.placeholder-glow .placeholder{animation:placeholder-glow 2s ease-in-out infinite}@keyframes placeholder-glow{50%{opacity:.2}}.placeholder-wave{-webkit-mask-image:linear-gradient(130deg,#000 55%,rgba(0,0,0,0.8) 75%,#000 95%);mask-image:linear-gradient(130deg,#000 55%,rgba(0,0,0,0.8) 75%,#000 95%);-webkit-mask-size:200% 100%;mask-size:200% 100%;animation:placeholder-wave 2s linear infinite}@keyframes placeholder-wave{100%{-webkit-mask-position:-200% 0%;mask-position:-200% 0%}}.clearfix::after{display:block;clear:both;content:""}.text-bg-primary{color:#fff!important;background-color:RGBA(var(--bs-primary-rgb),var(--bs-bg-opacity,1))!important}.text-bg-secondary{color:#fff!important;background-color:RGBA(var(--bs-secondary-rgb),var(--bs-bg-opacity,1))!important}.text-bg-success{color:#fff!important;background-color:RGBA(var(--bs-success-rgb),var(--bs-bg-opacity,1))!important}.text-bg-info{color:#000!important;background-color:RGBA(var(--bs-info-rgb),var(--bs-bg-opacity,1))!important}.text-bg-warning{color:#000!important;background-color:RGBA(var(--bs-warning-rgb),var(--bs-bg-opacity,1))!important}.text-bg-danger{color:#fff!important;background-color:RGBA(var(--bs-danger-rgb),var(--bs-bg-opacity,1))!important}.text-bg-light{color:#000!important;background-color:RGBA(var(--bs-light-rgb),var(--bs-bg-opacity,1))!important}.text-bg-dark{color:#fff!important;background-color:RGBA(var(--bs-dark-rgb),var(--bs-bg-opacity,1))!important}.link-primary{color:RGBA(var(--bs-primary-rgb),var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(var(--bs-primary-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(var(--bs-primary-rgb),var(--bs-link-underline-opacity,1))!important}.link-primary:focus,.link-primary:hover{color:RGBA(10,88,202,var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(10,88,202,var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(10,88,202,var(--bs-link-underline-opacity,1))!important}.link-secondary{color:RGBA(var(--bs-secondary-rgb),var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(var(--bs-secondary-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(var(--bs-secondary-rgb),var(--bs-link-underline-opacity,1))!important}.link-secondary:focus,.link-secondary:hover{color:RGBA(86,94,100,var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(86,94,100,var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(86,94,100,var(--bs-link-underline-opacity,1))!important}.link-success{color:RGBA(var(--bs-success-rgb),var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(var(--bs-success-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(var(--bs-success-rgb),var(--bs-link-underline-opacity,1))!important}.link-success:focus,.link-success:hover{color:RGBA(20,108,67,var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(20,108,67,var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(20,108,67,var(--bs-link-underline-opacity,1))!important}.link-info{color:RGBA(var(--bs-info-rgb),var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(var(--bs-info-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(var(--bs-info-rgb),var(--bs-link-underline-opacity,1))!important}.link-info:focus,.link-info:hover{color:RGBA(61,213,243,var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(61,213,243,var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(61,213,243,var(--bs-link-underline-opacity,1))!important}.link-warning{color:RGBA(var(--bs-warning-rgb),var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(var(--bs-warning-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(var(--bs-warning-rgb),var(--bs-link-underline-opacity,1))!important}.link-warning:focus,.link-warning:hover{color:RGBA(255,205,57,var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(255,205,57,var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(255,205,57,var(--bs-link-underline-opacity,1))!important}.link-danger{color:RGBA(var(--bs-danger-rgb),var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(var(--bs-danger-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(var(--bs-danger-rgb),var(--bs-link-underline-opacity,1))!important}.link-danger:focus,.link-danger:hover{color:RGBA(176,42,55,var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(176,42,55,var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(176,42,55,var(--bs-link-underline-opacity,1))!important}.link-light{color:RGBA(var(--bs-light-rgb),var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(var(--bs-light-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(var(--bs-light-rgb),var(--bs-link-underline-opacity,1))!important}.link-light:focus,.link-light:hover{color:RGBA(249,250,251,var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(249,250,251,var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(249,250,251,var(--bs-link-underline-opacity,1))!important}.link-dark{color:RGBA(var(--bs-dark-rgb),var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(var(--bs-dark-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(var(--bs-dark-rgb),var(--bs-link-underline-opacity,1))!important}.link-dark:focus,.link-dark:hover{color:RGBA(26,30,33,var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(26,30,33,var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(26,30,33,var(--bs-link-underline-opacity,1))!important}.link-body-emphasis{color:RGBA(var(--bs-emphasis-color-rgb),var(--bs-link-opacity,1))!important;-webkit-text-decoration-color:RGBA(var(--bs-emphasis-color-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:RGBA(var(--bs-emphasis-color-rgb),var(--bs-link-underline-opacity,1))!important}.link-body-emphasis:focus,.link-body-emphasis:hover{color:RGBA(var(--bs-emphasis-color-rgb),var(--bs-link-opacity,.75))!important;-webkit-text-decoration-color:RGBA(var(--bs-emphasis-color-rgb),var(--bs-link-underline-opacity,0.75))!important;text-decoration-color:RGBA(var(--bs-emphasis-color-rgb),var(--bs-link-underline-opacity,0.75))!important}.focus-ring:focus{outline:0;box-shadow:var(--bs-focus-ring-x,0) var(--bs-focus-ring-y,0) var(--bs-focus-ring-blur,0) var(--bs-focus-ring-width) var(--bs-focus-ring-color)}.icon-link{display:inline-flex;gap:.375rem;align-items:center;-webkit-text-decoration-color:rgba(var(--bs-link-color-rgb),var(--bs-link-opacity,0.5));text-decoration-color:rgba(var(--bs-link-color-rgb),var(--bs-link-opacity,0.5));text-underline-offset:0.25em;-webkit-backface-visibility:hidden;backface-visibility:hidden}.icon-link>.bi{flex-shrink:0;width:1em;height:1em;fill:currentcolor;transition:.2s ease-in-out transform}@media (prefers-reduced-motion:reduce){.icon-link>.bi{transition:none}}.icon-link-hover:focus-visible>.bi,.icon-link-hover:hover>.bi{transform:var(--bs-icon-link-transform,translate3d(.25em,0,0))}.ratio{position:relative;width:100%}.ratio::before{display:block;padding-top:var(--bs-aspect-ratio);content:""}.ratio>*{position:absolute;top:0;left:0;width:100%;height:100%}.ratio-1x1{--bs-aspect-ratio:100%}.ratio-4x3{--bs-aspect-ratio:75%}.ratio-16x9{--bs-aspect-ratio:56.25%}.ratio-21x9{--bs-aspect-ratio:42.8571428571%}.fixed-top{position:fixed;top:0;right:0;left:0;z-index:1030}.fixed-bottom{position:fixed;right:0;bottom:0;left:0;z-index:1030}.sticky-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}.sticky-bottom{position:-webkit-sticky;position:sticky;bottom:0;z-index:1020}@media (min-width:576px){.sticky-sm-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}.sticky-sm-bottom{position:-webkit-sticky;position:sticky;bottom:0;z-index:1020}}@media (min-width:768px){.sticky-md-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}.sticky-md-bottom{position:-webkit-sticky;position:sticky;bottom:0;z-index:1020}}@media (min-width:992px){.sticky-lg-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}.sticky-lg-bottom{position:-webkit-sticky;position:sticky;bottom:0;z-index:1020}}@media (min-width:1200px){.sticky-xl-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}.sticky-xl-bottom{position:-webkit-sticky;position:sticky;bottom:0;z-index:1020}}@media (min-width:1400px){.sticky-xxl-top{position:-webkit-sticky;position:sticky;top:0;z-index:1020}.sticky-xxl-bottom{position:-webkit-sticky;position:sticky;bottom:0;z-index:1020}}.hstack{display:flex;flex-direction:row;align-items:center;align-self:stretch}.vstack{display:flex;flex:1 1 auto;flex-direction:column;align-self:stretch}.visually-hidden,.visually-hidden-focusable:not(:focus):not(:focus-within){width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}.visually-hidden-focusable:not(:focus):not(:focus-within):not(caption),.visually-hidden:not(caption){position:absolute!important}.visually-hidden *,.visually-hidden-focusable:not(:focus):not(:focus-within) *{overflow:hidden!important}.stretched-link::after{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;content:""}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vr{display:inline-block;align-self:stretch;width:var(--bs-border-width);min-height:1em;background-color:currentcolor;opacity:.25}.align-baseline{vertical-align:baseline!important}.align-top{vertical-align:top!important}.align-middle{vertical-align:middle!important}.align-bottom{vertical-align:bottom!important}.align-text-bottom{vertical-align:text-bottom!important}.align-text-top{vertical-align:text-top!important}.float-start{float:left!important}.float-end{float:right!important}.float-none{float:none!important}.object-fit-contain{-o-object-fit:contain!important;object-fit:contain!important}.object-fit-cover{-o-object-fit:cover!important;object-fit:cover!important}.object-fit-fill{-o-object-fit:fill!important;object-fit:fill!important}.object-fit-scale{-o-object-fit:scale-down!important;object-fit:scale-down!important}.object-fit-none{-o-object-fit:none!important;object-fit:none!important}.opacity-0{opacity:0!important}.opacity-25{opacity:.25!important}.opacity-50{opacity:.5!important}.opacity-75{opacity:.75!important}.opacity-100{opacity:1!important}.overflow-auto{overflow:auto!important}.overflow-hidden{overflow:hidden!important}.overflow-visible{overflow:visible!important}.overflow-scroll{overflow:scroll!important}.overflow-x-auto{overflow-x:auto!important}.overflow-x-hidden{overflow-x:hidden!important}.overflow-x-visible{overflow-x:visible!important}.overflow-x-scroll{overflow-x:scroll!important}.overflow-y-auto{overflow-y:auto!important}.overflow-y-hidden{overflow-y:hidden!important}.overflow-y-visible{overflow-y:visible!important}.overflow-y-scroll{overflow-y:scroll!important}.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-block{display:block!important}.d-grid{display:grid!important}.d-inline-grid{display:inline-grid!important}.d-table{display:table!important}.d-table-row{display:table-row!important}.d-table-cell{display:table-cell!important}.d-flex{display:flex!important}.d-inline-flex{display:inline-flex!important}.d-none{display:none!important}.shadow{box-shadow:var(--bs-box-shadow)!important}.shadow-sm{box-shadow:var(--bs-box-shadow-sm)!important}.shadow-lg{box-shadow:var(--bs-box-shadow-lg)!important}.shadow-none{box-shadow:none!important}.focus-ring-primary{--bs-focus-ring-color:rgba(var(--bs-primary-rgb), var(--bs-focus-ring-opacity))}.focus-ring-secondary{--bs-focus-ring-color:rgba(var(--bs-secondary-rgb), var(--bs-focus-ring-opacity))}.focus-ring-success{--bs-focus-ring-color:rgba(var(--bs-success-rgb), var(--bs-focus-ring-opacity))}.focus-ring-info{--bs-focus-ring-color:rgba(var(--bs-info-rgb), var(--bs-focus-ring-opacity))}.focus-ring-warning{--bs-focus-ring-color:rgba(var(--bs-warning-rgb), var(--bs-focus-ring-opacity))}.focus-ring-danger{--bs-focus-ring-color:rgba(var(--bs-danger-rgb), var(--bs-focus-ring-opacity))}.focus-ring-light{--bs-focus-ring-color:rgba(var(--bs-light-rgb), var(--bs-focus-ring-opacity))}.focus-ring-dark{--bs-focus-ring-color:rgba(var(--bs-dark-rgb), var(--bs-focus-ring-opacity))}.position-static{position:static!important}.position-relative{position:relative!important}.position-absolute{position:absolute!important}.position-fixed{position:fixed!important}.position-sticky{position:-webkit-sticky!important;position:sticky!important}.top-0{top:0!important}.top-50{top:50%!important}.top-100{top:100%!important}.bottom-0{bottom:0!important}.bottom-50{bottom:50%!important}.bottom-100{bottom:100%!important}.start-0{left:0!important}.start-50{left:50%!important}.start-100{left:100%!important}.end-0{right:0!important}.end-50{right:50%!important}.end-100{right:100%!important}.translate-middle{transform:translate(-50%,-50%)!important}.translate-middle-x{transform:translateX(-50%)!important}.translate-middle-y{transform:translateY(-50%)!important}.border{border:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color)!important}.border-0{border:0!important}.border-top{border-top:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color)!important}.border-top-0{border-top:0!important}.border-end{border-right:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color)!important}.border-end-0{border-right:0!important}.border-bottom{border-bottom:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color)!important}.border-bottom-0{border-bottom:0!important}.border-start{border-left:var(--bs-border-width) var(--bs-border-style) var(--bs-border-color)!important}.border-start-0{border-left:0!important}.border-primary{--bs-border-opacity:1;border-color:rgba(var(--bs-primary-rgb),var(--bs-border-opacity))!important}.border-secondary{--bs-border-opacity:1;border-color:rgba(var(--bs-secondary-rgb),var(--bs-border-opacity))!important}.border-success{--bs-border-opacity:1;border-color:rgba(var(--bs-success-rgb),var(--bs-border-opacity))!important}.border-info{--bs-border-opacity:1;border-color:rgba(var(--bs-info-rgb),var(--bs-border-opacity))!important}.border-warning{--bs-border-opacity:1;border-color:rgba(var(--bs-warning-rgb),var(--bs-border-opacity))!important}.border-danger{--bs-border-opacity:1;border-color:rgba(var(--bs-danger-rgb),var(--bs-border-opacity))!important}.border-light{--bs-border-opacity:1;border-color:rgba(var(--bs-light-rgb),var(--bs-border-opacity))!important}.border-dark{--bs-border-opacity:1;border-color:rgba(var(--bs-dark-rgb),var(--bs-border-opacity))!important}.border-black{--bs-border-opacity:1;border-color:rgba(var(--bs-black-rgb),var(--bs-border-opacity))!important}.border-white{--bs-border-opacity:1;border-color:rgba(var(--bs-white-rgb),var(--bs-border-opacity))!important}.border-primary-subtle{border-color:var(--bs-primary-border-subtle)!important}.border-secondary-subtle{border-color:var(--bs-secondary-border-subtle)!important}.border-success-subtle{border-color:var(--bs-success-border-subtle)!important}.border-info-subtle{border-color:var(--bs-info-border-subtle)!important}.border-warning-subtle{border-color:var(--bs-warning-border-subtle)!important}.border-danger-subtle{border-color:var(--bs-danger-border-subtle)!important}.border-light-subtle{border-color:var(--bs-light-border-subtle)!important}.border-dark-subtle{border-color:var(--bs-dark-border-subtle)!important}.border-1{border-width:1px!important}.border-2{border-width:2px!important}.border-3{border-width:3px!important}.border-4{border-width:4px!important}.border-5{border-width:5px!important}.border-opacity-10{--bs-border-opacity:0.1}.border-opacity-25{--bs-border-opacity:0.25}.border-opacity-50{--bs-border-opacity:0.5}.border-opacity-75{--bs-border-opacity:0.75}.border-opacity-100{--bs-border-opacity:1}.w-25{width:25%!important}.w-50{width:50%!important}.w-75{width:75%!important}.w-100{width:100%!important}.w-auto{width:auto!important}.mw-100{max-width:100%!important}.vw-100{width:100vw!important}.min-vw-100{min-width:100vw!important}.h-25{height:25%!important}.h-50{height:50%!important}.h-75{height:75%!important}.h-100{height:100%!important}.h-auto{height:auto!important}.mh-100{max-height:100%!important}.vh-100{height:100vh!important}.min-vh-100{min-height:100vh!important}.flex-fill{flex:1 1 auto!important}.flex-row{flex-direction:row!important}.flex-column{flex-direction:column!important}.flex-row-reverse{flex-direction:row-reverse!important}.flex-column-reverse{flex-direction:column-reverse!important}.flex-grow-0{flex-grow:0!important}.flex-grow-1{flex-grow:1!important}.flex-shrink-0{flex-shrink:0!important}.flex-shrink-1{flex-shrink:1!important}.flex-wrap{flex-wrap:wrap!important}.flex-nowrap{flex-wrap:nowrap!important}.flex-wrap-reverse{flex-wrap:wrap-reverse!important}.justify-content-start{justify-content:flex-start!important}.justify-content-end{justify-content:flex-end!important}.justify-content-center{justify-content:center!important}.justify-content-between{justify-content:space-between!important}.justify-content-around{justify-content:space-around!important}.justify-content-evenly{justify-content:space-evenly!important}.align-items-start{align-items:flex-start!important}.align-items-end{align-items:flex-end!important}.align-items-center{align-items:center!important}.align-items-baseline{align-items:baseline!important}.align-items-stretch{align-items:stretch!important}.align-content-start{align-content:flex-start!important}.align-content-end{align-content:flex-end!important}.align-content-center{align-content:center!important}.align-content-between{align-content:space-between!important}.align-content-around{align-content:space-around!important}.align-content-stretch{align-content:stretch!important}.align-self-auto{align-self:auto!important}.align-self-start{align-self:flex-start!important}.align-self-end{align-self:flex-end!important}.align-self-center{align-self:center!important}.align-self-baseline{align-self:baseline!important}.align-self-stretch{align-self:stretch!important}.order-first{order:-1!important}.order-0{order:0!important}.order-1{order:1!important}.order-2{order:2!important}.order-3{order:3!important}.order-4{order:4!important}.order-5{order:5!important}.order-last{order:6!important}.m-0{margin:0!important}.m-1{margin:.25rem!important}.m-2{margin:.5rem!important}.m-3{margin:1rem!important}.m-4{margin:1.5rem!important}.m-5{margin:3rem!important}.m-auto{margin:auto!important}.mx-0{margin-right:0!important;margin-left:0!important}.mx-1{margin-right:.25rem!important;margin-left:.25rem!important}.mx-2{margin-right:.5rem!important;margin-left:.5rem!important}.mx-3{margin-right:1rem!important;margin-left:1rem!important}.mx-4{margin-right:1.5rem!important;margin-left:1.5rem!important}.mx-5{margin-right:3rem!important;margin-left:3rem!important}.mx-auto{margin-right:auto!important;margin-left:auto!important}.my-0{margin-top:0!important;margin-bottom:0!important}.my-1{margin-top:.25rem!important;margin-bottom:.25rem!important}.my-2{margin-top:.5rem!important;margin-bottom:.5rem!important}.my-3{margin-top:1rem!important;margin-bottom:1rem!important}.my-4{margin-top:1.5rem!important;margin-bottom:1.5rem!important}.my-5{margin-top:3rem!important;margin-bottom:3rem!important}.my-auto{margin-top:auto!important;margin-bottom:auto!important}.mt-0{margin-top:0!important}.mt-1{margin-top:.25rem!important}.mt-2{margin-top:.5rem!important}.mt-3{margin-top:1rem!important}.mt-4{margin-top:1.5rem!important}.mt-5{margin-top:3rem!important}.mt-auto{margin-top:auto!important}.me-0{margin-right:0!important}.me-1{margin-right:.25rem!important}.me-2{margin-right:.5rem!important}.me-3{margin-right:1rem!important}.me-4{margin-right:1.5rem!important}.me-5{margin-right:3rem!important}.me-auto{margin-right:auto!important}.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:.25rem!important}.mb-2{margin-bottom:.5rem!important}.mb-3{margin-bottom:1rem!important}.mb-4{margin-bottom:1.5rem!important}.mb-5{margin-bottom:3rem!important}.mb-auto{margin-bottom:auto!important}.ms-0{margin-left:0!important}.ms-1{margin-left:.25rem!important}.ms-2{margin-left:.5rem!important}.ms-3{margin-left:1rem!important}.ms-4{margin-left:1.5rem!important}.ms-5{margin-left:3rem!important}.ms-auto{margin-left:auto!important}.p-0{padding:0!important}.p-1{padding:.25rem!important}.p-2{padding:.5rem!important}.p-3{padding:1rem!important}.p-4{padding:1.5rem!important}.p-5{padding:3rem!important}.px-0{padding-right:0!important;padding-left:0!important}.px-1{padding-right:.25rem!important;padding-left:.25rem!important}.px-2{padding-right:.5rem!important;padding-left:.5rem!important}.px-3{padding-right:1rem!important;padding-left:1rem!important}.px-4{padding-right:1.5rem!important;padding-left:1.5rem!important}.px-5{padding-right:3rem!important;padding-left:3rem!important}.py-0{padding-top:0!important;padding-bottom:0!important}.py-1{padding-top:.25rem!important;padding-bottom:.25rem!important}.py-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.py-3{padding-top:1rem!important;padding-bottom:1rem!important}.py-4{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.py-5{padding-top:3rem!important;padding-bottom:3rem!important}.pt-0{padding-top:0!important}.pt-1{padding-top:.25rem!important}.pt-2{padding-top:.5rem!important}.pt-3{padding-top:1rem!important}.pt-4{padding-top:1.5rem!important}.pt-5{padding-top:3rem!important}.pe-0{padding-right:0!important}.pe-1{padding-right:.25rem!important}.pe-2{padding-right:.5rem!important}.pe-3{padding-right:1rem!important}.pe-4{padding-right:1.5rem!important}.pe-5{padding-right:3rem!important}.pb-0{padding-bottom:0!important}.pb-1{padding-bottom:.25rem!important}.pb-2{padding-bottom:.5rem!important}.pb-3{padding-bottom:1rem!important}.pb-4{padding-bottom:1.5rem!important}.pb-5{padding-bottom:3rem!important}.ps-0{padding-left:0!important}.ps-1{padding-left:.25rem!important}.ps-2{padding-left:.5rem!important}.ps-3{padding-left:1rem!important}.ps-4{padding-left:1.5rem!important}.ps-5{padding-left:3rem!important}.gap-0{gap:0!important}.gap-1{gap:.25rem!important}.gap-2{gap:.5rem!important}.gap-3{gap:1rem!important}.gap-4{gap:1.5rem!important}.gap-5{gap:3rem!important}.row-gap-0{row-gap:0!important}.row-gap-1{row-gap:.25rem!important}.row-gap-2{row-gap:.5rem!important}.row-gap-3{row-gap:1rem!important}.row-gap-4{row-gap:1.5rem!important}.row-gap-5{row-gap:3rem!important}.column-gap-0{-moz-column-gap:0!important;column-gap:0!important}.column-gap-1{-moz-column-gap:0.25rem!important;column-gap:.25rem!important}.column-gap-2{-moz-column-gap:0.5rem!important;column-gap:.5rem!important}.column-gap-3{-moz-column-gap:1rem!important;column-gap:1rem!important}.column-gap-4{-moz-column-gap:1.5rem!important;column-gap:1.5rem!important}.column-gap-5{-moz-column-gap:3rem!important;column-gap:3rem!important}.font-monospace{font-family:var(--bs-font-monospace)!important}.fs-1{font-size:calc(1.375rem + 1.5vw)!important}.fs-2{font-size:calc(1.325rem + .9vw)!important}.fs-3{font-size:calc(1.3rem + .6vw)!important}.fs-4{font-size:calc(1.275rem + .3vw)!important}.fs-5{font-size:1.25rem!important}.fs-6{font-size:1rem!important}.fst-italic{font-style:italic!important}.fst-normal{font-style:normal!important}.fw-lighter{font-weight:lighter!important}.fw-light{font-weight:300!important}.fw-normal{font-weight:400!important}.fw-medium{font-weight:500!important}.fw-semibold{font-weight:600!important}.fw-bold{font-weight:700!important}.fw-bolder{font-weight:bolder!important}.lh-1{line-height:1!important}.lh-sm{line-height:1.25!important}.lh-base{line-height:1.5!important}.lh-lg{line-height:2!important}.text-start{text-align:left!important}.text-end{text-align:right!important}.text-center{text-align:center!important}.text-decoration-none{text-decoration:none!important}.text-decoration-underline{text-decoration:underline!important}.text-decoration-line-through{text-decoration:line-through!important}.text-lowercase{text-transform:lowercase!important}.text-uppercase{text-transform:uppercase!important}.text-capitalize{text-transform:capitalize!important}.text-wrap{white-space:normal!important}.text-nowrap{white-space:nowrap!important}.text-break{word-wrap:break-word!important;word-break:break-word!important}.text-primary{--bs-text-opacity:1;color:rgba(var(--bs-primary-rgb),var(--bs-text-opacity))!important}.text-secondary{--bs-text-opacity:1;color:rgba(var(--bs-secondary-rgb),var(--bs-text-opacity))!important}.text-success{--bs-text-opacity:1;color:rgba(var(--bs-success-rgb),var(--bs-text-opacity))!important}.text-info{--bs-text-opacity:1;color:rgba(var(--bs-info-rgb),var(--bs-text-opacity))!important}.text-warning{--bs-text-opacity:1;color:rgba(var(--bs-warning-rgb),var(--bs-text-opacity))!important}.text-danger{--bs-text-opacity:1;color:rgba(var(--bs-danger-rgb),var(--bs-text-opacity))!important}.text-light{--bs-text-opacity:1;color:rgba(var(--bs-light-rgb),var(--bs-text-opacity))!important}.text-dark{--bs-text-opacity:1;color:rgba(var(--bs-dark-rgb),var(--bs-text-opacity))!important}.text-black{--bs-text-opacity:1;color:rgba(var(--bs-black-rgb),var(--bs-text-opacity))!important}.text-white{--bs-text-opacity:1;color:rgba(var(--bs-white-rgb),var(--bs-text-opacity))!important}.text-body{--bs-text-opacity:1;color:rgba(var(--bs-body-color-rgb),var(--bs-text-opacity))!important}.text-muted{--bs-text-opacity:1;color:var(--bs-secondary-color)!important}.text-black-50{--bs-text-opacity:1;color:rgba(0,0,0,.5)!important}.text-white-50{--bs-text-opacity:1;color:rgba(255,255,255,.5)!important}.text-body-secondary{--bs-text-opacity:1;color:var(--bs-secondary-color)!important}.text-body-tertiary{--bs-text-opacity:1;color:var(--bs-tertiary-color)!important}.text-body-emphasis{--bs-text-opacity:1;color:var(--bs-emphasis-color)!important}.text-reset{--bs-text-opacity:1;color:inherit!important}.text-opacity-25{--bs-text-opacity:0.25}.text-opacity-50{--bs-text-opacity:0.5}.text-opacity-75{--bs-text-opacity:0.75}.text-opacity-100{--bs-text-opacity:1}.text-primary-emphasis{color:var(--bs-primary-text-emphasis)!important}.text-secondary-emphasis{color:var(--bs-secondary-text-emphasis)!important}.text-success-emphasis{color:var(--bs-success-text-emphasis)!important}.text-info-emphasis{color:var(--bs-info-text-emphasis)!important}.text-warning-emphasis{color:var(--bs-warning-text-emphasis)!important}.text-danger-emphasis{color:var(--bs-danger-text-emphasis)!important}.text-light-emphasis{color:var(--bs-light-text-emphasis)!important}.text-dark-emphasis{color:var(--bs-dark-text-emphasis)!important}.link-opacity-10{--bs-link-opacity:0.1}.link-opacity-10-hover:hover{--bs-link-opacity:0.1}.link-opacity-25{--bs-link-opacity:0.25}.link-opacity-25-hover:hover{--bs-link-opacity:0.25}.link-opacity-50{--bs-link-opacity:0.5}.link-opacity-50-hover:hover{--bs-link-opacity:0.5}.link-opacity-75{--bs-link-opacity:0.75}.link-opacity-75-hover:hover{--bs-link-opacity:0.75}.link-opacity-100{--bs-link-opacity:1}.link-opacity-100-hover:hover{--bs-link-opacity:1}.link-offset-1{text-underline-offset:0.125em!important}.link-offset-1-hover:hover{text-underline-offset:0.125em!important}.link-offset-2{text-underline-offset:0.25em!important}.link-offset-2-hover:hover{text-underline-offset:0.25em!important}.link-offset-3{text-underline-offset:0.375em!important}.link-offset-3-hover:hover{text-underline-offset:0.375em!important}.link-underline-primary{--bs-link-underline-opacity:1;-webkit-text-decoration-color:rgba(var(--bs-primary-rgb),var(--bs-link-underline-opacity))!important;text-decoration-color:rgba(var(--bs-primary-rgb),var(--bs-link-underline-opacity))!important}.link-underline-secondary{--bs-link-underline-opacity:1;-webkit-text-decoration-color:rgba(var(--bs-secondary-rgb),var(--bs-link-underline-opacity))!important;text-decoration-color:rgba(var(--bs-secondary-rgb),var(--bs-link-underline-opacity))!important}.link-underline-success{--bs-link-underline-opacity:1;-webkit-text-decoration-color:rgba(var(--bs-success-rgb),var(--bs-link-underline-opacity))!important;text-decoration-color:rgba(var(--bs-success-rgb),var(--bs-link-underline-opacity))!important}.link-underline-info{--bs-link-underline-opacity:1;-webkit-text-decoration-color:rgba(var(--bs-info-rgb),var(--bs-link-underline-opacity))!important;text-decoration-color:rgba(var(--bs-info-rgb),var(--bs-link-underline-opacity))!important}.link-underline-warning{--bs-link-underline-opacity:1;-webkit-text-decoration-color:rgba(var(--bs-warning-rgb),var(--bs-link-underline-opacity))!important;text-decoration-color:rgba(var(--bs-warning-rgb),var(--bs-link-underline-opacity))!important}.link-underline-danger{--bs-link-underline-opacity:1;-webkit-text-decoration-color:rgba(var(--bs-danger-rgb),var(--bs-link-underline-opacity))!important;text-decoration-color:rgba(var(--bs-danger-rgb),var(--bs-link-underline-opacity))!important}.link-underline-light{--bs-link-underline-opacity:1;-webkit-text-decoration-color:rgba(var(--bs-light-rgb),var(--bs-link-underline-opacity))!important;text-decoration-color:rgba(var(--bs-light-rgb),var(--bs-link-underline-opacity))!important}.link-underline-dark{--bs-link-underline-opacity:1;-webkit-text-decoration-color:rgba(var(--bs-dark-rgb),var(--bs-link-underline-opacity))!important;text-decoration-color:rgba(var(--bs-dark-rgb),var(--bs-link-underline-opacity))!important}.link-underline{--bs-link-underline-opacity:1;-webkit-text-decoration-color:rgba(var(--bs-link-color-rgb),var(--bs-link-underline-opacity,1))!important;text-decoration-color:rgba(var(--bs-link-color-rgb),var(--bs-link-underline-opacity,1))!important}.link-underline-opacity-0{--bs-link-underline-opacity:0}.link-underline-opacity-0-hover:hover{--bs-link-underline-opacity:0}.link-underline-opacity-10{--bs-link-underline-opacity:0.1}.link-underline-opacity-10-hover:hover{--bs-link-underline-opacity:0.1}.link-underline-opacity-25{--bs-link-underline-opacity:0.25}.link-underline-opacity-25-hover:hover{--bs-link-underline-opacity:0.25}.link-underline-opacity-50{--bs-link-underline-opacity:0.5}.link-underline-opacity-50-hover:hover{--bs-link-underline-opacity:0.5}.link-underline-opacity-75{--bs-link-underline-opacity:0.75}.link-underline-opacity-75-hover:hover{--bs-link-underline-opacity:0.75}.link-underline-opacity-100{--bs-link-underline-opacity:1}.link-underline-opacity-100-hover:hover{--bs-link-underline-opacity:1}.bg-primary{--bs-bg-opacity:1;background-color:rgba(var(--bs-primary-rgb),var(--bs-bg-opacity))!important}.bg-secondary{--bs-bg-opacity:1;background-color:rgba(var(--bs-secondary-rgb),var(--bs-bg-opacity))!important}.bg-success{--bs-bg-opacity:1;background-color:rgba(var(--bs-success-rgb),var(--bs-bg-opacity))!important}.bg-info{--bs-bg-opacity:1;background-color:rgba(var(--bs-info-rgb),var(--bs-bg-opacity))!important}.bg-warning{--bs-bg-opacity:1;background-color:rgba(var(--bs-warning-rgb),var(--bs-bg-opacity))!important}.bg-danger{--bs-bg-opacity:1;background-color:rgba(var(--bs-danger-rgb),var(--bs-bg-opacity))!important}.bg-light{--bs-bg-opacity:1;background-color:rgba(var(--bs-light-rgb),var(--bs-bg-opacity))!important}.bg-dark{--bs-bg-opacity:1;background-color:rgba(var(--bs-dark-rgb),var(--bs-bg-opacity))!important}.bg-black{--bs-bg-opacity:1;background-color:rgba(var(--bs-black-rgb),var(--bs-bg-opacity))!important}.bg-white{--bs-bg-opacity:1;background-color:rgba(var(--bs-white-rgb),var(--bs-bg-opacity))!important}.bg-body{--bs-bg-opacity:1;background-color:rgba(var(--bs-body-bg-rgb),var(--bs-bg-opacity))!important}.bg-transparent{--bs-bg-opacity:1;background-color:transparent!important}.bg-body-secondary{--bs-bg-opacity:1;background-color:rgba(var(--bs-secondary-bg-rgb),var(--bs-bg-opacity))!important}.bg-body-tertiary{--bs-bg-opacity:1;background-color:rgba(var(--bs-tertiary-bg-rgb),var(--bs-bg-opacity))!important}.bg-opacity-10{--bs-bg-opacity:0.1}.bg-opacity-25{--bs-bg-opacity:0.25}.bg-opacity-50{--bs-bg-opacity:0.5}.bg-opacity-75{--bs-bg-opacity:0.75}.bg-opacity-100{--bs-bg-opacity:1}.bg-primary-subtle{background-color:var(--bs-primary-bg-subtle)!important}.bg-secondary-subtle{background-color:var(--bs-secondary-bg-subtle)!important}.bg-success-subtle{background-color:var(--bs-success-bg-subtle)!important}.bg-info-subtle{background-color:var(--bs-info-bg-subtle)!important}.bg-warning-subtle{background-color:var(--bs-warning-bg-subtle)!important}.bg-danger-subtle{background-color:var(--bs-danger-bg-subtle)!important}.bg-light-subtle{background-color:var(--bs-light-bg-subtle)!important}.bg-dark-subtle{background-color:var(--bs-dark-bg-subtle)!important}.bg-gradient{background-image:var(--bs-gradient)!important}.user-select-all{-webkit-user-select:all!important;-moz-user-select:all!important;user-select:all!important}.user-select-auto{-webkit-user-select:auto!important;-moz-user-select:auto!important;user-select:auto!important}.user-select-none{-webkit-user-select:none!important;-moz-user-select:none!important;user-select:none!important}.pe-none{pointer-events:none!important}.pe-auto{pointer-events:auto!important}.rounded{border-radius:var(--bs-border-radius)!important}.rounded-0{border-radius:0!important}.rounded-1{border-radius:var(--bs-border-radius-sm)!important}.rounded-2{border-radius:var(--bs-border-radius)!important}.rounded-3{border-radius:var(--bs-border-radius-lg)!important}.rounded-4{border-radius:var(--bs-border-radius-xl)!important}.rounded-5{border-radius:var(--bs-border-radius-xxl)!important}.rounded-circle{border-radius:50%!important}.rounded-pill{border-radius:var(--bs-border-radius-pill)!important}.rounded-top{border-top-left-radius:var(--bs-border-radius)!important;border-top-right-radius:var(--bs-border-radius)!important}.rounded-top-0{border-top-left-radius:0!important;border-top-right-radius:0!important}.rounded-top-1{border-top-left-radius:var(--bs-border-radius-sm)!important;border-top-right-radius:var(--bs-border-radius-sm)!important}.rounded-top-2{border-top-left-radius:var(--bs-border-radius)!important;border-top-right-radius:var(--bs-border-radius)!important}.rounded-top-3{border-top-left-radius:var(--bs-border-radius-lg)!important;border-top-right-radius:var(--bs-border-radius-lg)!important}.rounded-top-4{border-top-left-radius:var(--bs-border-radius-xl)!important;border-top-right-radius:var(--bs-border-radius-xl)!important}.rounded-top-5{border-top-left-radius:var(--bs-border-radius-xxl)!important;border-top-right-radius:var(--bs-border-radius-xxl)!important}.rounded-top-circle{border-top-left-radius:50%!important;border-top-right-radius:50%!important}.rounded-top-pill{border-top-left-radius:var(--bs-border-radius-pill)!important;border-top-right-radius:var(--bs-border-radius-pill)!important}.rounded-end{border-top-right-radius:var(--bs-border-radius)!important;border-bottom-right-radius:var(--bs-border-radius)!important}.rounded-end-0{border-top-right-radius:0!important;border-bottom-right-radius:0!important}.rounded-end-1{border-top-right-radius:var(--bs-border-radius-sm)!important;border-bottom-right-radius:var(--bs-border-radius-sm)!important}.rounded-end-2{border-top-right-radius:var(--bs-border-radius)!important;border-bottom-right-radius:var(--bs-border-radius)!important}.rounded-end-3{border-top-right-radius:var(--bs-border-radius-lg)!important;border-bottom-right-radius:var(--bs-border-radius-lg)!important}.rounded-end-4{border-top-right-radius:var(--bs-border-radius-xl)!important;border-bottom-right-radius:var(--bs-border-radius-xl)!important}.rounded-end-5{border-top-right-radius:var(--bs-border-radius-xxl)!important;border-bottom-right-radius:var(--bs-border-radius-xxl)!important}.rounded-end-circle{border-top-right-radius:50%!important;border-bottom-right-radius:50%!important}.rounded-end-pill{border-top-right-radius:var(--bs-border-radius-pill)!important;border-bottom-right-radius:var(--bs-border-radius-pill)!important}.rounded-bottom{border-bottom-right-radius:var(--bs-border-radius)!important;border-bottom-left-radius:var(--bs-border-radius)!important}.rounded-bottom-0{border-bottom-right-radius:0!important;border-bottom-left-radius:0!important}.rounded-bottom-1{border-bottom-right-radius:var(--bs-border-radius-sm)!important;border-bottom-left-radius:var(--bs-border-radius-sm)!important}.rounded-bottom-2{border-bottom-right-radius:var(--bs-border-radius)!important;border-bottom-left-radius:var(--bs-border-radius)!important}.rounded-bottom-3{border-bottom-right-radius:var(--bs-border-radius-lg)!important;border-bottom-left-radius:var(--bs-border-radius-lg)!important}.rounded-bottom-4{border-bottom-right-radius:var(--bs-border-radius-xl)!important;border-bottom-left-radius:var(--bs-border-radius-xl)!important}.rounded-bottom-5{border-bottom-right-radius:var(--bs-border-radius-xxl)!important;border-bottom-left-radius:var(--bs-border-radius-xxl)!important}.rounded-bottom-circle{border-bottom-right-radius:50%!important;border-bottom-left-radius:50%!important}.rounded-bottom-pill{border-bottom-right-radius:var(--bs-border-radius-pill)!important;border-bottom-left-radius:var(--bs-border-radius-pill)!important}.rounded-start{border-bottom-left-radius:var(--bs-border-radius)!important;border-top-left-radius:var(--bs-border-radius)!important}.rounded-start-0{border-bottom-left-radius:0!important;border-top-left-radius:0!important}.rounded-start-1{border-bottom-left-radius:var(--bs-border-radius-sm)!important;border-top-left-radius:var(--bs-border-radius-sm)!important}.rounded-start-2{border-bottom-left-radius:var(--bs-border-radius)!important;border-top-left-radius:var(--bs-border-radius)!important}.rounded-start-3{border-bottom-left-radius:var(--bs-border-radius-lg)!important;border-top-left-radius:var(--bs-border-radius-lg)!important}.rounded-start-4{border-bottom-left-radius:var(--bs-border-radius-xl)!important;border-top-left-radius:var(--bs-border-radius-xl)!important}.rounded-start-5{border-bottom-left-radius:var(--bs-border-radius-xxl)!important;border-top-left-radius:var(--bs-border-radius-xxl)!important}.rounded-start-circle{border-bottom-left-radius:50%!important;border-top-left-radius:50%!important}.rounded-start-pill{border-bottom-left-radius:var(--bs-border-radius-pill)!important;border-top-left-radius:var(--bs-border-radius-pill)!important}.visible{visibility:visible!important}.invisible{visibility:hidden!important}.z-n1{z-index:-1!important}.z-0{z-index:0!important}.z-1{z-index:1!important}.z-2{z-index:2!important}.z-3{z-index:3!important}@media (min-width:576px){.float-sm-start{float:left!important}.float-sm-end{float:right!important}.float-sm-none{float:none!important}.object-fit-sm-contain{-o-object-fit:contain!important;object-fit:contain!important}.object-fit-sm-cover{-o-object-fit:cover!important;object-fit:cover!important}.object-fit-sm-fill{-o-object-fit:fill!important;object-fit:fill!important}.object-fit-sm-scale{-o-object-fit:scale-down!important;object-fit:scale-down!important}.object-fit-sm-none{-o-object-fit:none!important;object-fit:none!important}.d-sm-inline{display:inline!important}.d-sm-inline-block{display:inline-block!important}.d-sm-block{display:block!important}.d-sm-grid{display:grid!important}.d-sm-inline-grid{display:inline-grid!important}.d-sm-table{display:table!important}.d-sm-table-row{display:table-row!important}.d-sm-table-cell{display:table-cell!important}.d-sm-flex{display:flex!important}.d-sm-inline-flex{display:inline-flex!important}.d-sm-none{display:none!important}.flex-sm-fill{flex:1 1 auto!important}.flex-sm-row{flex-direction:row!important}.flex-sm-column{flex-direction:column!important}.flex-sm-row-reverse{flex-direction:row-reverse!important}.flex-sm-column-reverse{flex-direction:column-reverse!important}.flex-sm-grow-0{flex-grow:0!important}.flex-sm-grow-1{flex-grow:1!important}.flex-sm-shrink-0{flex-shrink:0!important}.flex-sm-shrink-1{flex-shrink:1!important}.flex-sm-wrap{flex-wrap:wrap!important}.flex-sm-nowrap{flex-wrap:nowrap!important}.flex-sm-wrap-reverse{flex-wrap:wrap-reverse!important}.justify-content-sm-start{justify-content:flex-start!important}.justify-content-sm-end{justify-content:flex-end!important}.justify-content-sm-center{justify-content:center!important}.justify-content-sm-between{justify-content:space-between!important}.justify-content-sm-around{justify-content:space-around!important}.justify-content-sm-evenly{justify-content:space-evenly!important}.align-items-sm-start{align-items:flex-start!important}.align-items-sm-end{align-items:flex-end!important}.align-items-sm-center{align-items:center!important}.align-items-sm-baseline{align-items:baseline!important}.align-items-sm-stretch{align-items:stretch!important}.align-content-sm-start{align-content:flex-start!important}.align-content-sm-end{align-content:flex-end!important}.align-content-sm-center{align-content:center!important}.align-content-sm-between{align-content:space-between!important}.align-content-sm-around{align-content:space-around!important}.align-content-sm-stretch{align-content:stretch!important}.align-self-sm-auto{align-self:auto!important}.align-self-sm-start{align-self:flex-start!important}.align-self-sm-end{align-self:flex-end!important}.align-self-sm-center{align-self:center!important}.align-self-sm-baseline{align-self:baseline!important}.align-self-sm-stretch{align-self:stretch!important}.order-sm-first{order:-1!important}.order-sm-0{order:0!important}.order-sm-1{order:1!important}.order-sm-2{order:2!important}.order-sm-3{order:3!important}.order-sm-4{order:4!important}.order-sm-5{order:5!important}.order-sm-last{order:6!important}.m-sm-0{margin:0!important}.m-sm-1{margin:.25rem!important}.m-sm-2{margin:.5rem!important}.m-sm-3{margin:1rem!important}.m-sm-4{margin:1.5rem!important}.m-sm-5{margin:3rem!important}.m-sm-auto{margin:auto!important}.mx-sm-0{margin-right:0!important;margin-left:0!important}.mx-sm-1{margin-right:.25rem!important;margin-left:.25rem!important}.mx-sm-2{margin-right:.5rem!important;margin-left:.5rem!important}.mx-sm-3{margin-right:1rem!important;margin-left:1rem!important}.mx-sm-4{margin-right:1.5rem!important;margin-left:1.5rem!important}.mx-sm-5{margin-right:3rem!important;margin-left:3rem!important}.mx-sm-auto{margin-right:auto!important;margin-left:auto!important}.my-sm-0{margin-top:0!important;margin-bottom:0!important}.my-sm-1{margin-top:.25rem!important;margin-bottom:.25rem!important}.my-sm-2{margin-top:.5rem!important;margin-bottom:.5rem!important}.my-sm-3{margin-top:1rem!important;margin-bottom:1rem!important}.my-sm-4{margin-top:1.5rem!important;margin-bottom:1.5rem!important}.my-sm-5{margin-top:3rem!important;margin-bottom:3rem!important}.my-sm-auto{margin-top:auto!important;margin-bottom:auto!important}.mt-sm-0{margin-top:0!important}.mt-sm-1{margin-top:.25rem!important}.mt-sm-2{margin-top:.5rem!important}.mt-sm-3{margin-top:1rem!important}.mt-sm-4{margin-top:1.5rem!important}.mt-sm-5{margin-top:3rem!important}.mt-sm-auto{margin-top:auto!important}.me-sm-0{margin-right:0!important}.me-sm-1{margin-right:.25rem!important}.me-sm-2{margin-right:.5rem!important}.me-sm-3{margin-right:1rem!important}.me-sm-4{margin-right:1.5rem!important}.me-sm-5{margin-right:3rem!important}.me-sm-auto{margin-right:auto!important}.mb-sm-0{margin-bottom:0!important}.mb-sm-1{margin-bottom:.25rem!important}.mb-sm-2{margin-bottom:.5rem!important}.mb-sm-3{margin-bottom:1rem!important}.mb-sm-4{margin-bottom:1.5rem!important}.mb-sm-5{margin-bottom:3rem!important}.mb-sm-auto{margin-bottom:auto!important}.ms-sm-0{margin-left:0!important}.ms-sm-1{margin-left:.25rem!important}.ms-sm-2{margin-left:.5rem!important}.ms-sm-3{margin-left:1rem!important}.ms-sm-4{margin-left:1.5rem!important}.ms-sm-5{margin-left:3rem!important}.ms-sm-auto{margin-left:auto!important}.p-sm-0{padding:0!important}.p-sm-1{padding:.25rem!important}.p-sm-2{padding:.5rem!important}.p-sm-3{padding:1rem!important}.p-sm-4{padding:1.5rem!important}.p-sm-5{padding:3rem!important}.px-sm-0{padding-right:0!important;padding-left:0!important}.px-sm-1{padding-right:.25rem!important;padding-left:.25rem!important}.px-sm-2{padding-right:.5rem!important;padding-left:.5rem!important}.px-sm-3{padding-right:1rem!important;padding-left:1rem!important}.px-sm-4{padding-right:1.5rem!important;padding-left:1.5rem!important}.px-sm-5{padding-right:3rem!important;padding-left:3rem!important}.py-sm-0{padding-top:0!important;padding-bottom:0!important}.py-sm-1{padding-top:.25rem!important;padding-bottom:.25rem!important}.py-sm-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.py-sm-3{padding-top:1rem!important;padding-bottom:1rem!important}.py-sm-4{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.py-sm-5{padding-top:3rem!important;padding-bottom:3rem!important}.pt-sm-0{padding-top:0!important}.pt-sm-1{padding-top:.25rem!important}.pt-sm-2{padding-top:.5rem!important}.pt-sm-3{padding-top:1rem!important}.pt-sm-4{padding-top:1.5rem!important}.pt-sm-5{padding-top:3rem!important}.pe-sm-0{padding-right:0!important}.pe-sm-1{padding-right:.25rem!important}.pe-sm-2{padding-right:.5rem!important}.pe-sm-3{padding-right:1rem!important}.pe-sm-4{padding-right:1.5rem!important}.pe-sm-5{padding-right:3rem!important}.pb-sm-0{padding-bottom:0!important}.pb-sm-1{padding-bottom:.25rem!important}.pb-sm-2{padding-bottom:.5rem!important}.pb-sm-3{padding-bottom:1rem!important}.pb-sm-4{padding-bottom:1.5rem!important}.pb-sm-5{padding-bottom:3rem!important}.ps-sm-0{padding-left:0!important}.ps-sm-1{padding-left:.25rem!important}.ps-sm-2{padding-left:.5rem!important}.ps-sm-3{padding-left:1rem!important}.ps-sm-4{padding-left:1.5rem!important}.ps-sm-5{padding-left:3rem!important}.gap-sm-0{gap:0!important}.gap-sm-1{gap:.25rem!important}.gap-sm-2{gap:.5rem!important}.gap-sm-3{gap:1rem!important}.gap-sm-4{gap:1.5rem!important}.gap-sm-5{gap:3rem!important}.row-gap-sm-0{row-gap:0!important}.row-gap-sm-1{row-gap:.25rem!important}.row-gap-sm-2{row-gap:.5rem!important}.row-gap-sm-3{row-gap:1rem!important}.row-gap-sm-4{row-gap:1.5rem!important}.row-gap-sm-5{row-gap:3rem!important}.column-gap-sm-0{-moz-column-gap:0!important;column-gap:0!important}.column-gap-sm-1{-moz-column-gap:0.25rem!important;column-gap:.25rem!important}.column-gap-sm-2{-moz-column-gap:0.5rem!important;column-gap:.5rem!important}.column-gap-sm-3{-moz-column-gap:1rem!important;column-gap:1rem!important}.column-gap-sm-4{-moz-column-gap:1.5rem!important;column-gap:1.5rem!important}.column-gap-sm-5{-moz-column-gap:3rem!important;column-gap:3rem!important}.text-sm-start{text-align:left!important}.text-sm-end{text-align:right!important}.text-sm-center{text-align:center!important}}@media (min-width:768px){.float-md-start{float:left!important}.float-md-end{float:right!important}.float-md-none{float:none!important}.object-fit-md-contain{-o-object-fit:contain!important;object-fit:contain!important}.object-fit-md-cover{-o-object-fit:cover!important;object-fit:cover!important}.object-fit-md-fill{-o-object-fit:fill!important;object-fit:fill!important}.object-fit-md-scale{-o-object-fit:scale-down!important;object-fit:scale-down!important}.object-fit-md-none{-o-object-fit:none!important;object-fit:none!important}.d-md-inline{display:inline!important}.d-md-inline-block{display:inline-block!important}.d-md-block{display:block!important}.d-md-grid{display:grid!important}.d-md-inline-grid{display:inline-grid!important}.d-md-table{display:table!important}.d-md-table-row{display:table-row!important}.d-md-table-cell{display:table-cell!important}.d-md-flex{display:flex!important}.d-md-inline-flex{display:inline-flex!important}.d-md-none{display:none!important}.flex-md-fill{flex:1 1 auto!important}.flex-md-row{flex-direction:row!important}.flex-md-column{flex-direction:column!important}.flex-md-row-reverse{flex-direction:row-reverse!important}.flex-md-column-reverse{flex-direction:column-reverse!important}.flex-md-grow-0{flex-grow:0!important}.flex-md-grow-1{flex-grow:1!important}.flex-md-shrink-0{flex-shrink:0!important}.flex-md-shrink-1{flex-shrink:1!important}.flex-md-wrap{flex-wrap:wrap!important}.flex-md-nowrap{flex-wrap:nowrap!important}.flex-md-wrap-reverse{flex-wrap:wrap-reverse!important}.justify-content-md-start{justify-content:flex-start!important}.justify-content-md-end{justify-content:flex-end!important}.justify-content-md-center{justify-content:center!important}.justify-content-md-between{justify-content:space-between!important}.justify-content-md-around{justify-content:space-around!important}.justify-content-md-evenly{justify-content:space-evenly!important}.align-items-md-start{align-items:flex-start!important}.align-items-md-end{align-items:flex-end!important}.align-items-md-center{align-items:center!important}.align-items-md-baseline{align-items:baseline!important}.align-items-md-stretch{align-items:stretch!important}.align-content-md-start{align-content:flex-start!important}.align-content-md-end{align-content:flex-end!important}.align-content-md-center{align-content:center!important}.align-content-md-between{align-content:space-between!important}.align-content-md-around{align-content:space-around!important}.align-content-md-stretch{align-content:stretch!important}.align-self-md-auto{align-self:auto!important}.align-self-md-start{align-self:flex-start!important}.align-self-md-end{align-self:flex-end!important}.align-self-md-center{align-self:center!important}.align-self-md-baseline{align-self:baseline!important}.align-self-md-stretch{align-self:stretch!important}.order-md-first{order:-1!important}.order-md-0{order:0!important}.order-md-1{order:1!important}.order-md-2{order:2!important}.order-md-3{order:3!important}.order-md-4{order:4!important}.order-md-5{order:5!important}.order-md-last{order:6!important}.m-md-0{margin:0!important}.m-md-1{margin:.25rem!important}.m-md-2{margin:.5rem!important}.m-md-3{margin:1rem!important}.m-md-4{margin:1.5rem!important}.m-md-5{margin:3rem!important}.m-md-auto{margin:auto!important}.mx-md-0{margin-right:0!important;margin-left:0!important}.mx-md-1{margin-right:.25rem!important;margin-left:.25rem!important}.mx-md-2{margin-right:.5rem!important;margin-left:.5rem!important}.mx-md-3{margin-right:1rem!important;margin-left:1rem!important}.mx-md-4{margin-right:1.5rem!important;margin-left:1.5rem!important}.mx-md-5{margin-right:3rem!important;margin-left:3rem!important}.mx-md-auto{margin-right:auto!important;margin-left:auto!important}.my-md-0{margin-top:0!important;margin-bottom:0!important}.my-md-1{margin-top:.25rem!important;margin-bottom:.25rem!important}.my-md-2{margin-top:.5rem!important;margin-bottom:.5rem!important}.my-md-3{margin-top:1rem!important;margin-bottom:1rem!important}.my-md-4{margin-top:1.5rem!important;margin-bottom:1.5rem!important}.my-md-5{margin-top:3rem!important;margin-bottom:3rem!important}.my-md-auto{margin-top:auto!important;margin-bottom:auto!important}.mt-md-0{margin-top:0!important}.mt-md-1{margin-top:.25rem!important}.mt-md-2{margin-top:.5rem!important}.mt-md-3{margin-top:1rem!important}.mt-md-4{margin-top:1.5rem!important}.mt-md-5{margin-top:3rem!important}.mt-md-auto{margin-top:auto!important}.me-md-0{margin-right:0!important}.me-md-1{margin-right:.25rem!important}.me-md-2{margin-right:.5rem!important}.me-md-3{margin-right:1rem!important}.me-md-4{margin-right:1.5rem!important}.me-md-5{margin-right:3rem!important}.me-md-auto{margin-right:auto!important}.mb-md-0{margin-bottom:0!important}.mb-md-1{margin-bottom:.25rem!important}.mb-md-2{margin-bottom:.5rem!important}.mb-md-3{margin-bottom:1rem!important}.mb-md-4{margin-bottom:1.5rem!important}.mb-md-5{margin-bottom:3rem!important}.mb-md-auto{margin-bottom:auto!important}.ms-md-0{margin-left:0!important}.ms-md-1{margin-left:.25rem!important}.ms-md-2{margin-left:.5rem!important}.ms-md-3{margin-left:1rem!important}.ms-md-4{margin-left:1.5rem!important}.ms-md-5{margin-left:3rem!important}.ms-md-auto{margin-left:auto!important}.p-md-0{padding:0!important}.p-md-1{padding:.25rem!important}.p-md-2{padding:.5rem!important}.p-md-3{padding:1rem!important}.p-md-4{padding:1.5rem!important}.p-md-5{padding:3rem!important}.px-md-0{padding-right:0!important;padding-left:0!important}.px-md-1{padding-right:.25rem!important;padding-left:.25rem!important}.px-md-2{padding-right:.5rem!important;padding-left:.5rem!important}.px-md-3{padding-right:1rem!important;padding-left:1rem!important}.px-md-4{padding-right:1.5rem!important;padding-left:1.5rem!important}.px-md-5{padding-right:3rem!important;padding-left:3rem!important}.py-md-0{padding-top:0!important;padding-bottom:0!important}.py-md-1{padding-top:.25rem!important;padding-bottom:.25rem!important}.py-md-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.py-md-3{padding-top:1rem!important;padding-bottom:1rem!important}.py-md-4{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.py-md-5{padding-top:3rem!important;padding-bottom:3rem!important}.pt-md-0{padding-top:0!important}.pt-md-1{padding-top:.25rem!important}.pt-md-2{padding-top:.5rem!important}.pt-md-3{padding-top:1rem!important}.pt-md-4{padding-top:1.5rem!important}.pt-md-5{padding-top:3rem!important}.pe-md-0{padding-right:0!important}.pe-md-1{padding-right:.25rem!important}.pe-md-2{padding-right:.5rem!important}.pe-md-3{padding-right:1rem!important}.pe-md-4{padding-right:1.5rem!important}.pe-md-5{padding-right:3rem!important}.pb-md-0{padding-bottom:0!important}.pb-md-1{padding-bottom:.25rem!important}.pb-md-2{padding-bottom:.5rem!important}.pb-md-3{padding-bottom:1rem!important}.pb-md-4{padding-bottom:1.5rem!important}.pb-md-5{padding-bottom:3rem!important}.ps-md-0{padding-left:0!important}.ps-md-1{padding-left:.25rem!important}.ps-md-2{padding-left:.5rem!important}.ps-md-3{padding-left:1rem!important}.ps-md-4{padding-left:1.5rem!important}.ps-md-5{padding-left:3rem!important}.gap-md-0{gap:0!important}.gap-md-1{gap:.25rem!important}.gap-md-2{gap:.5rem!important}.gap-md-3{gap:1rem!important}.gap-md-4{gap:1.5rem!important}.gap-md-5{gap:3rem!important}.row-gap-md-0{row-gap:0!important}.row-gap-md-1{row-gap:.25rem!important}.row-gap-md-2{row-gap:.5rem!important}.row-gap-md-3{row-gap:1rem!important}.row-gap-md-4{row-gap:1.5rem!important}.row-gap-md-5{row-gap:3rem!important}.column-gap-md-0{-moz-column-gap:0!important;column-gap:0!important}.column-gap-md-1{-moz-column-gap:0.25rem!important;column-gap:.25rem!important}.column-gap-md-2{-moz-column-gap:0.5rem!important;column-gap:.5rem!important}.column-gap-md-3{-moz-column-gap:1rem!important;column-gap:1rem!important}.column-gap-md-4{-moz-column-gap:1.5rem!important;column-gap:1.5rem!important}.column-gap-md-5{-moz-column-gap:3rem!important;column-gap:3rem!important}.text-md-start{text-align:left!important}.text-md-end{text-align:right!important}.text-md-center{text-align:center!important}}@media (min-width:992px){.float-lg-start{float:left!important}.float-lg-end{float:right!important}.float-lg-none{float:none!important}.object-fit-lg-contain{-o-object-fit:contain!important;object-fit:contain!important}.object-fit-lg-cover{-o-object-fit:cover!important;object-fit:cover!important}.object-fit-lg-fill{-o-object-fit:fill!important;object-fit:fill!important}.object-fit-lg-scale{-o-object-fit:scale-down!important;object-fit:scale-down!important}.object-fit-lg-none{-o-object-fit:none!important;object-fit:none!important}.d-lg-inline{display:inline!important}.d-lg-inline-block{display:inline-block!important}.d-lg-block{display:block!important}.d-lg-grid{display:grid!important}.d-lg-inline-grid{display:inline-grid!important}.d-lg-table{display:table!important}.d-lg-table-row{display:table-row!important}.d-lg-table-cell{display:table-cell!important}.d-lg-flex{display:flex!important}.d-lg-inline-flex{display:inline-flex!important}.d-lg-none{display:none!important}.flex-lg-fill{flex:1 1 auto!important}.flex-lg-row{flex-direction:row!important}.flex-lg-column{flex-direction:column!important}.flex-lg-row-reverse{flex-direction:row-reverse!important}.flex-lg-column-reverse{flex-direction:column-reverse!important}.flex-lg-grow-0{flex-grow:0!important}.flex-lg-grow-1{flex-grow:1!important}.flex-lg-shrink-0{flex-shrink:0!important}.flex-lg-shrink-1{flex-shrink:1!important}.flex-lg-wrap{flex-wrap:wrap!important}.flex-lg-nowrap{flex-wrap:nowrap!important}.flex-lg-wrap-reverse{flex-wrap:wrap-reverse!important}.justify-content-lg-start{justify-content:flex-start!important}.justify-content-lg-end{justify-content:flex-end!important}.justify-content-lg-center{justify-content:center!important}.justify-content-lg-between{justify-content:space-between!important}.justify-content-lg-around{justify-content:space-around!important}.justify-content-lg-evenly{justify-content:space-evenly!important}.align-items-lg-start{align-items:flex-start!important}.align-items-lg-end{align-items:flex-end!important}.align-items-lg-center{align-items:center!important}.align-items-lg-baseline{align-items:baseline!important}.align-items-lg-stretch{align-items:stretch!important}.align-content-lg-start{align-content:flex-start!important}.align-content-lg-end{align-content:flex-end!important}.align-content-lg-center{align-content:center!important}.align-content-lg-between{align-content:space-between!important}.align-content-lg-around{align-content:space-around!important}.align-content-lg-stretch{align-content:stretch!important}.align-self-lg-auto{align-self:auto!important}.align-self-lg-start{align-self:flex-start!important}.align-self-lg-end{align-self:flex-end!important}.align-self-lg-center{align-self:center!important}.align-self-lg-baseline{align-self:baseline!important}.align-self-lg-stretch{align-self:stretch!important}.order-lg-first{order:-1!important}.order-lg-0{order:0!important}.order-lg-1{order:1!important}.order-lg-2{order:2!important}.order-lg-3{order:3!important}.order-lg-4{order:4!important}.order-lg-5{order:5!important}.order-lg-last{order:6!important}.m-lg-0{margin:0!important}.m-lg-1{margin:.25rem!important}.m-lg-2{margin:.5rem!important}.m-lg-3{margin:1rem!important}.m-lg-4{margin:1.5rem!important}.m-lg-5{margin:3rem!important}.m-lg-auto{margin:auto!important}.mx-lg-0{margin-right:0!important;margin-left:0!important}.mx-lg-1{margin-right:.25rem!important;margin-left:.25rem!important}.mx-lg-2{margin-right:.5rem!important;margin-left:.5rem!important}.mx-lg-3{margin-right:1rem!important;margin-left:1rem!important}.mx-lg-4{margin-right:1.5rem!important;margin-left:1.5rem!important}.mx-lg-5{margin-right:3rem!important;margin-left:3rem!important}.mx-lg-auto{margin-right:auto!important;margin-left:auto!important}.my-lg-0{margin-top:0!important;margin-bottom:0!important}.my-lg-1{margin-top:.25rem!important;margin-bottom:.25rem!important}.my-lg-2{margin-top:.5rem!important;margin-bottom:.5rem!important}.my-lg-3{margin-top:1rem!important;margin-bottom:1rem!important}.my-lg-4{margin-top:1.5rem!important;margin-bottom:1.5rem!important}.my-lg-5{margin-top:3rem!important;margin-bottom:3rem!important}.my-lg-auto{margin-top:auto!important;margin-bottom:auto!important}.mt-lg-0{margin-top:0!important}.mt-lg-1{margin-top:.25rem!important}.mt-lg-2{margin-top:.5rem!important}.mt-lg-3{margin-top:1rem!important}.mt-lg-4{margin-top:1.5rem!important}.mt-lg-5{margin-top:3rem!important}.mt-lg-auto{margin-top:auto!important}.me-lg-0{margin-right:0!important}.me-lg-1{margin-right:.25rem!important}.me-lg-2{margin-right:.5rem!important}.me-lg-3{margin-right:1rem!important}.me-lg-4{margin-right:1.5rem!important}.me-lg-5{margin-right:3rem!important}.me-lg-auto{margin-right:auto!important}.mb-lg-0{margin-bottom:0!important}.mb-lg-1{margin-bottom:.25rem!important}.mb-lg-2{margin-bottom:.5rem!important}.mb-lg-3{margin-bottom:1rem!important}.mb-lg-4{margin-bottom:1.5rem!important}.mb-lg-5{margin-bottom:3rem!important}.mb-lg-auto{margin-bottom:auto!important}.ms-lg-0{margin-left:0!important}.ms-lg-1{margin-left:.25rem!important}.ms-lg-2{margin-left:.5rem!important}.ms-lg-3{margin-left:1rem!important}.ms-lg-4{margin-left:1.5rem!important}.ms-lg-5{margin-left:3rem!important}.ms-lg-auto{margin-left:auto!important}.p-lg-0{padding:0!important}.p-lg-1{padding:.25rem!important}.p-lg-2{padding:.5rem!important}.p-lg-3{padding:1rem!important}.p-lg-4{padding:1.5rem!important}.p-lg-5{padding:3rem!important}.px-lg-0{padding-right:0!important;padding-left:0!important}.px-lg-1{padding-right:.25rem!important;padding-left:.25rem!important}.px-lg-2{padding-right:.5rem!important;padding-left:.5rem!important}.px-lg-3{padding-right:1rem!important;padding-left:1rem!important}.px-lg-4{padding-right:1.5rem!important;padding-left:1.5rem!important}.px-lg-5{padding-right:3rem!important;padding-left:3rem!important}.py-lg-0{padding-top:0!important;padding-bottom:0!important}.py-lg-1{padding-top:.25rem!important;padding-bottom:.25rem!important}.py-lg-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.py-lg-3{padding-top:1rem!important;padding-bottom:1rem!important}.py-lg-4{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.py-lg-5{padding-top:3rem!important;padding-bottom:3rem!important}.pt-lg-0{padding-top:0!important}.pt-lg-1{padding-top:.25rem!important}.pt-lg-2{padding-top:.5rem!important}.pt-lg-3{padding-top:1rem!important}.pt-lg-4{padding-top:1.5rem!important}.pt-lg-5{padding-top:3rem!important}.pe-lg-0{padding-right:0!important}.pe-lg-1{padding-right:.25rem!important}.pe-lg-2{padding-right:.5rem!important}.pe-lg-3{padding-right:1rem!important}.pe-lg-4{padding-right:1.5rem!important}.pe-lg-5{padding-right:3rem!important}.pb-lg-0{padding-bottom:0!important}.pb-lg-1{padding-bottom:.25rem!important}.pb-lg-2{padding-bottom:.5rem!important}.pb-lg-3{padding-bottom:1rem!important}.pb-lg-4{padding-bottom:1.5rem!important}.pb-lg-5{padding-bottom:3rem!important}.ps-lg-0{padding-left:0!important}.ps-lg-1{padding-left:.25rem!important}.ps-lg-2{padding-left:.5rem!important}.ps-lg-3{padding-left:1rem!important}.ps-lg-4{padding-left:1.5rem!important}.ps-lg-5{padding-left:3rem!important}.gap-lg-0{gap:0!important}.gap-lg-1{gap:.25rem!important}.gap-lg-2{gap:.5rem!important}.gap-lg-3{gap:1rem!important}.gap-lg-4{gap:1.5rem!important}.gap-lg-5{gap:3rem!important}.row-gap-lg-0{row-gap:0!important}.row-gap-lg-1{row-gap:.25rem!important}.row-gap-lg-2{row-gap:.5rem!important}.row-gap-lg-3{row-gap:1rem!important}.row-gap-lg-4{row-gap:1.5rem!important}.row-gap-lg-5{row-gap:3rem!important}.column-gap-lg-0{-moz-column-gap:0!important;column-gap:0!important}.column-gap-lg-1{-moz-column-gap:0.25rem!important;column-gap:.25rem!important}.column-gap-lg-2{-moz-column-gap:0.5rem!important;column-gap:.5rem!important}.column-gap-lg-3{-moz-column-gap:1rem!important;column-gap:1rem!important}.column-gap-lg-4{-moz-column-gap:1.5rem!important;column-gap:1.5rem!important}.column-gap-lg-5{-moz-column-gap:3rem!important;column-gap:3rem!important}.text-lg-start{text-align:left!important}.text-lg-end{text-align:right!important}.text-lg-center{text-align:center!important}}@media (min-width:1200px){.float-xl-start{float:left!important}.float-xl-end{float:right!important}.float-xl-none{float:none!important}.object-fit-xl-contain{-o-object-fit:contain!important;object-fit:contain!important}.object-fit-xl-cover{-o-object-fit:cover!important;object-fit:cover!important}.object-fit-xl-fill{-o-object-fit:fill!important;object-fit:fill!important}.object-fit-xl-scale{-o-object-fit:scale-down!important;object-fit:scale-down!important}.object-fit-xl-none{-o-object-fit:none!important;object-fit:none!important}.d-xl-inline{display:inline!important}.d-xl-inline-block{display:inline-block!important}.d-xl-block{display:block!important}.d-xl-grid{display:grid!important}.d-xl-inline-grid{display:inline-grid!important}.d-xl-table{display:table!important}.d-xl-table-row{display:table-row!important}.d-xl-table-cell{display:table-cell!important}.d-xl-flex{display:flex!important}.d-xl-inline-flex{display:inline-flex!important}.d-xl-none{display:none!important}.flex-xl-fill{flex:1 1 auto!important}.flex-xl-row{flex-direction:row!important}.flex-xl-column{flex-direction:column!important}.flex-xl-row-reverse{flex-direction:row-reverse!important}.flex-xl-column-reverse{flex-direction:column-reverse!important}.flex-xl-grow-0{flex-grow:0!important}.flex-xl-grow-1{flex-grow:1!important}.flex-xl-shrink-0{flex-shrink:0!important}.flex-xl-shrink-1{flex-shrink:1!important}.flex-xl-wrap{flex-wrap:wrap!important}.flex-xl-nowrap{flex-wrap:nowrap!important}.flex-xl-wrap-reverse{flex-wrap:wrap-reverse!important}.justify-content-xl-start{justify-content:flex-start!important}.justify-content-xl-end{justify-content:flex-end!important}.justify-content-xl-center{justify-content:center!important}.justify-content-xl-between{justify-content:space-between!important}.justify-content-xl-around{justify-content:space-around!important}.justify-content-xl-evenly{justify-content:space-evenly!important}.align-items-xl-start{align-items:flex-start!important}.align-items-xl-end{align-items:flex-end!important}.align-items-xl-center{align-items:center!important}.align-items-xl-baseline{align-items:baseline!important}.align-items-xl-stretch{align-items:stretch!important}.align-content-xl-start{align-content:flex-start!important}.align-content-xl-end{align-content:flex-end!important}.align-content-xl-center{align-content:center!important}.align-content-xl-between{align-content:space-between!important}.align-content-xl-around{align-content:space-around!important}.align-content-xl-stretch{align-content:stretch!important}.align-self-xl-auto{align-self:auto!important}.align-self-xl-start{align-self:flex-start!important}.align-self-xl-end{align-self:flex-end!important}.align-self-xl-center{align-self:center!important}.align-self-xl-baseline{align-self:baseline!important}.align-self-xl-stretch{align-self:stretch!important}.order-xl-first{order:-1!important}.order-xl-0{order:0!important}.order-xl-1{order:1!important}.order-xl-2{order:2!important}.order-xl-3{order:3!important}.order-xl-4{order:4!important}.order-xl-5{order:5!important}.order-xl-last{order:6!important}.m-xl-0{margin:0!important}.m-xl-1{margin:.25rem!important}.m-xl-2{margin:.5rem!important}.m-xl-3{margin:1rem!important}.m-xl-4{margin:1.5rem!important}.m-xl-5{margin:3rem!important}.m-xl-auto{margin:auto!important}.mx-xl-0{margin-right:0!important;margin-left:0!important}.mx-xl-1{margin-right:.25rem!important;margin-left:.25rem!important}.mx-xl-2{margin-right:.5rem!important;margin-left:.5rem!important}.mx-xl-3{margin-right:1rem!important;margin-left:1rem!important}.mx-xl-4{margin-right:1.5rem!important;margin-left:1.5rem!important}.mx-xl-5{margin-right:3rem!important;margin-left:3rem!important}.mx-xl-auto{margin-right:auto!important;margin-left:auto!important}.my-xl-0{margin-top:0!important;margin-bottom:0!important}.my-xl-1{margin-top:.25rem!important;margin-bottom:.25rem!important}.my-xl-2{margin-top:.5rem!important;margin-bottom:.5rem!important}.my-xl-3{margin-top:1rem!important;margin-bottom:1rem!important}.my-xl-4{margin-top:1.5rem!important;margin-bottom:1.5rem!important}.my-xl-5{margin-top:3rem!important;margin-bottom:3rem!important}.my-xl-auto{margin-top:auto!important;margin-bottom:auto!important}.mt-xl-0{margin-top:0!important}.mt-xl-1{margin-top:.25rem!important}.mt-xl-2{margin-top:.5rem!important}.mt-xl-3{margin-top:1rem!important}.mt-xl-4{margin-top:1.5rem!important}.mt-xl-5{margin-top:3rem!important}.mt-xl-auto{margin-top:auto!important}.me-xl-0{margin-right:0!important}.me-xl-1{margin-right:.25rem!important}.me-xl-2{margin-right:.5rem!important}.me-xl-3{margin-right:1rem!important}.me-xl-4{margin-right:1.5rem!important}.me-xl-5{margin-right:3rem!important}.me-xl-auto{margin-right:auto!important}.mb-xl-0{margin-bottom:0!important}.mb-xl-1{margin-bottom:.25rem!important}.mb-xl-2{margin-bottom:.5rem!important}.mb-xl-3{margin-bottom:1rem!important}.mb-xl-4{margin-bottom:1.5rem!important}.mb-xl-5{margin-bottom:3rem!important}.mb-xl-auto{margin-bottom:auto!important}.ms-xl-0{margin-left:0!important}.ms-xl-1{margin-left:.25rem!important}.ms-xl-2{margin-left:.5rem!important}.ms-xl-3{margin-left:1rem!important}.ms-xl-4{margin-left:1.5rem!important}.ms-xl-5{margin-left:3rem!important}.ms-xl-auto{margin-left:auto!important}.p-xl-0{padding:0!important}.p-xl-1{padding:.25rem!important}.p-xl-2{padding:.5rem!important}.p-xl-3{padding:1rem!important}.p-xl-4{padding:1.5rem!important}.p-xl-5{padding:3rem!important}.px-xl-0{padding-right:0!important;padding-left:0!important}.px-xl-1{padding-right:.25rem!important;padding-left:.25rem!important}.px-xl-2{padding-right:.5rem!important;padding-left:.5rem!important}.px-xl-3{padding-right:1rem!important;padding-left:1rem!important}.px-xl-4{padding-right:1.5rem!important;padding-left:1.5rem!important}.px-xl-5{padding-right:3rem!important;padding-left:3rem!important}.py-xl-0{padding-top:0!important;padding-bottom:0!important}.py-xl-1{padding-top:.25rem!important;padding-bottom:.25rem!important}.py-xl-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.py-xl-3{padding-top:1rem!important;padding-bottom:1rem!important}.py-xl-4{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.py-xl-5{padding-top:3rem!important;padding-bottom:3rem!important}.pt-xl-0{padding-top:0!important}.pt-xl-1{padding-top:.25rem!important}.pt-xl-2{padding-top:.5rem!important}.pt-xl-3{padding-top:1rem!important}.pt-xl-4{padding-top:1.5rem!important}.pt-xl-5{padding-top:3rem!important}.pe-xl-0{padding-right:0!important}.pe-xl-1{padding-right:.25rem!important}.pe-xl-2{padding-right:.5rem!important}.pe-xl-3{padding-right:1rem!important}.pe-xl-4{padding-right:1.5rem!important}.pe-xl-5{padding-right:3rem!important}.pb-xl-0{padding-bottom:0!important}.pb-xl-1{padding-bottom:.25rem!important}.pb-xl-2{padding-bottom:.5rem!important}.pb-xl-3{padding-bottom:1rem!important}.pb-xl-4{padding-bottom:1.5rem!important}.pb-xl-5{padding-bottom:3rem!important}.ps-xl-0{padding-left:0!important}.ps-xl-1{padding-left:.25rem!important}.ps-xl-2{padding-left:.5rem!important}.ps-xl-3{padding-left:1rem!important}.ps-xl-4{padding-left:1.5rem!important}.ps-xl-5{padding-left:3rem!important}.gap-xl-0{gap:0!important}.gap-xl-1{gap:.25rem!important}.gap-xl-2{gap:.5rem!important}.gap-xl-3{gap:1rem!important}.gap-xl-4{gap:1.5rem!important}.gap-xl-5{gap:3rem!important}.row-gap-xl-0{row-gap:0!important}.row-gap-xl-1{row-gap:.25rem!important}.row-gap-xl-2{row-gap:.5rem!important}.row-gap-xl-3{row-gap:1rem!important}.row-gap-xl-4{row-gap:1.5rem!important}.row-gap-xl-5{row-gap:3rem!important}.column-gap-xl-0{-moz-column-gap:0!important;column-gap:0!important}.column-gap-xl-1{-moz-column-gap:0.25rem!important;column-gap:.25rem!important}.column-gap-xl-2{-moz-column-gap:0.5rem!important;column-gap:.5rem!important}.column-gap-xl-3{-moz-column-gap:1rem!important;column-gap:1rem!important}.column-gap-xl-4{-moz-column-gap:1.5rem!important;column-gap:1.5rem!important}.column-gap-xl-5{-moz-column-gap:3rem!important;column-gap:3rem!important}.text-xl-start{text-align:left!important}.text-xl-end{text-align:right!important}.text-xl-center{text-align:center!important}}@media (min-width:1400px){.float-xxl-start{float:left!important}.float-xxl-end{float:right!important}.float-xxl-none{float:none!important}.object-fit-xxl-contain{-o-object-fit:contain!important;object-fit:contain!important}.object-fit-xxl-cover{-o-object-fit:cover!important;object-fit:cover!important}.object-fit-xxl-fill{-o-object-fit:fill!important;object-fit:fill!important}.object-fit-xxl-scale{-o-object-fit:scale-down!important;object-fit:scale-down!important}.object-fit-xxl-none{-o-object-fit:none!important;object-fit:none!important}.d-xxl-inline{display:inline!important}.d-xxl-inline-block{display:inline-block!important}.d-xxl-block{display:block!important}.d-xxl-grid{display:grid!important}.d-xxl-inline-grid{display:inline-grid!important}.d-xxl-table{display:table!important}.d-xxl-table-row{display:table-row!important}.d-xxl-table-cell{display:table-cell!important}.d-xxl-flex{display:flex!important}.d-xxl-inline-flex{display:inline-flex!important}.d-xxl-none{display:none!important}.flex-xxl-fill{flex:1 1 auto!important}.flex-xxl-row{flex-direction:row!important}.flex-xxl-column{flex-direction:column!important}.flex-xxl-row-reverse{flex-direction:row-reverse!important}.flex-xxl-column-reverse{flex-direction:column-reverse!important}.flex-xxl-grow-0{flex-grow:0!important}.flex-xxl-grow-1{flex-grow:1!important}.flex-xxl-shrink-0{flex-shrink:0!important}.flex-xxl-shrink-1{flex-shrink:1!important}.flex-xxl-wrap{flex-wrap:wrap!important}.flex-xxl-nowrap{flex-wrap:nowrap!important}.flex-xxl-wrap-reverse{flex-wrap:wrap-reverse!important}.justify-content-xxl-start{justify-content:flex-start!important}.justify-content-xxl-end{justify-content:flex-end!important}.justify-content-xxl-center{justify-content:center!important}.justify-content-xxl-between{justify-content:space-between!important}.justify-content-xxl-around{justify-content:space-around!important}.justify-content-xxl-evenly{justify-content:space-evenly!important}.align-items-xxl-start{align-items:flex-start!important}.align-items-xxl-end{align-items:flex-end!important}.align-items-xxl-center{align-items:center!important}.align-items-xxl-baseline{align-items:baseline!important}.align-items-xxl-stretch{align-items:stretch!important}.align-content-xxl-start{align-content:flex-start!important}.align-content-xxl-end{align-content:flex-end!important}.align-content-xxl-center{align-content:center!important}.align-content-xxl-between{align-content:space-between!important}.align-content-xxl-around{align-content:space-around!important}.align-content-xxl-stretch{align-content:stretch!important}.align-self-xxl-auto{align-self:auto!important}.align-self-xxl-start{align-self:flex-start!important}.align-self-xxl-end{align-self:flex-end!important}.align-self-xxl-center{align-self:center!important}.align-self-xxl-baseline{align-self:baseline!important}.align-self-xxl-stretch{align-self:stretch!important}.order-xxl-first{order:-1!important}.order-xxl-0{order:0!important}.order-xxl-1{order:1!important}.order-xxl-2{order:2!important}.order-xxl-3{order:3!important}.order-xxl-4{order:4!important}.order-xxl-5{order:5!important}.order-xxl-last{order:6!important}.m-xxl-0{margin:0!important}.m-xxl-1{margin:.25rem!important}.m-xxl-2{margin:.5rem!important}.m-xxl-3{margin:1rem!important}.m-xxl-4{margin:1.5rem!important}.m-xxl-5{margin:3rem!important}.m-xxl-auto{margin:auto!important}.mx-xxl-0{margin-right:0!important;margin-left:0!important}.mx-xxl-1{margin-right:.25rem!important;margin-left:.25rem!important}.mx-xxl-2{margin-right:.5rem!important;margin-left:.5rem!important}.mx-xxl-3{margin-right:1rem!important;margin-left:1rem!important}.mx-xxl-4{margin-right:1.5rem!important;margin-left:1.5rem!important}.mx-xxl-5{margin-right:3rem!important;margin-left:3rem!important}.mx-xxl-auto{margin-right:auto!important;margin-left:auto!important}.my-xxl-0{margin-top:0!important;margin-bottom:0!important}.my-xxl-1{margin-top:.25rem!important;margin-bottom:.25rem!important}.my-xxl-2{margin-top:.5rem!important;margin-bottom:.5rem!important}.my-xxl-3{margin-top:1rem!important;margin-bottom:1rem!important}.my-xxl-4{margin-top:1.5rem!important;margin-bottom:1.5rem!important}.my-xxl-5{margin-top:3rem!important;margin-bottom:3rem!important}.my-xxl-auto{margin-top:auto!important;margin-bottom:auto!important}.mt-xxl-0{margin-top:0!important}.mt-xxl-1{margin-top:.25rem!important}.mt-xxl-2{margin-top:.5rem!important}.mt-xxl-3{margin-top:1rem!important}.mt-xxl-4{margin-top:1.5rem!important}.mt-xxl-5{margin-top:3rem!important}.mt-xxl-auto{margin-top:auto!important}.me-xxl-0{margin-right:0!important}.me-xxl-1{margin-right:.25rem!important}.me-xxl-2{margin-right:.5rem!important}.me-xxl-3{margin-right:1rem!important}.me-xxl-4{margin-right:1.5rem!important}.me-xxl-5{margin-right:3rem!important}.me-xxl-auto{margin-right:auto!important}.mb-xxl-0{margin-bottom:0!important}.mb-xxl-1{margin-bottom:.25rem!important}.mb-xxl-2{margin-bottom:.5rem!important}.mb-xxl-3{margin-bottom:1rem!important}.mb-xxl-4{margin-bottom:1.5rem!important}.mb-xxl-5{margin-bottom:3rem!important}.mb-xxl-auto{margin-bottom:auto!important}.ms-xxl-0{margin-left:0!important}.ms-xxl-1{margin-left:.25rem!important}.ms-xxl-2{margin-left:.5rem!important}.ms-xxl-3{margin-left:1rem!important}.ms-xxl-4{margin-left:1.5rem!important}.ms-xxl-5{margin-left:3rem!important}.ms-xxl-auto{margin-left:auto!important}.p-xxl-0{padding:0!important}.p-xxl-1{padding:.25rem!important}.p-xxl-2{padding:.5rem!important}.p-xxl-3{padding:1rem!important}.p-xxl-4{padding:1.5rem!important}.p-xxl-5{padding:3rem!important}.px-xxl-0{padding-right:0!important;padding-left:0!important}.px-xxl-1{padding-right:.25rem!important;padding-left:.25rem!important}.px-xxl-2{padding-right:.5rem!important;padding-left:.5rem!important}.px-xxl-3{padding-right:1rem!important;padding-left:1rem!important}.px-xxl-4{padding-right:1.5rem!important;padding-left:1.5rem!important}.px-xxl-5{padding-right:3rem!important;padding-left:3rem!important}.py-xxl-0{padding-top:0!important;padding-bottom:0!important}.py-xxl-1{padding-top:.25rem!important;padding-bottom:.25rem!important}.py-xxl-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.py-xxl-3{padding-top:1rem!important;padding-bottom:1rem!important}.py-xxl-4{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.py-xxl-5{padding-top:3rem!important;padding-bottom:3rem!important}.pt-xxl-0{padding-top:0!important}.pt-xxl-1{padding-top:.25rem!important}.pt-xxl-2{padding-top:.5rem!important}.pt-xxl-3{padding-top:1rem!important}.pt-xxl-4{padding-top:1.5rem!important}.pt-xxl-5{padding-top:3rem!important}.pe-xxl-0{padding-right:0!important}.pe-xxl-1{padding-right:.25rem!important}.pe-xxl-2{padding-right:.5rem!important}.pe-xxl-3{padding-right:1rem!important}.pe-xxl-4{padding-right:1.5rem!important}.pe-xxl-5{padding-right:3rem!important}.pb-xxl-0{padding-bottom:0!important}.pb-xxl-1{padding-bottom:.25rem!important}.pb-xxl-2{padding-bottom:.5rem!important}.pb-xxl-3{padding-bottom:1rem!important}.pb-xxl-4{padding-bottom:1.5rem!important}.pb-xxl-5{padding-bottom:3rem!important}.ps-xxl-0{padding-left:0!important}.ps-xxl-1{padding-left:.25rem!important}.ps-xxl-2{padding-left:.5rem!important}.ps-xxl-3{padding-left:1rem!important}.ps-xxl-4{padding-left:1.5rem!important}.ps-xxl-5{padding-left:3rem!important}.gap-xxl-0{gap:0!important}.gap-xxl-1{gap:.25rem!important}.gap-xxl-2{gap:.5rem!important}.gap-xxl-3{gap:1rem!important}.gap-xxl-4{gap:1.5rem!important}.gap-xxl-5{gap:3rem!important}.row-gap-xxl-0{row-gap:0!important}.row-gap-xxl-1{row-gap:.25rem!important}.row-gap-xxl-2{row-gap:.5rem!important}.row-gap-xxl-3{row-gap:1rem!important}.row-gap-xxl-4{row-gap:1.5rem!important}.row-gap-xxl-5{row-gap:3rem!important}.column-gap-xxl-0{-moz-column-gap:0!important;column-gap:0!important}.column-gap-xxl-1{-moz-column-gap:0.25rem!important;column-gap:.25rem!important}.column-gap-xxl-2{-moz-column-gap:0.5rem!important;column-gap:.5rem!important}.column-gap-xxl-3{-moz-column-gap:1rem!important;column-gap:1rem!important}.column-gap-xxl-4{-moz-column-gap:1.5rem!important;column-gap:1.5rem!important}.column-gap-xxl-5{-moz-column-gap:3rem!important;column-gap:3rem!important}.text-xxl-start{text-align:left!important}.text-xxl-end{text-align:right!important}.text-xxl-center{text-align:center!important}}@media (min-width:1200px){.fs-1{font-size:2.5rem!important}.fs-2{font-size:2rem!important}.fs-3{font-size:1.75rem!important}.fs-4{font-size:1.5rem!important}}@media print{.d-print-inline{display:inline!important}.d-print-inline-block{display:inline-block!important}.d-print-block{display:block!important}.d-print-grid{display:grid!important}.d-print-inline-grid{display:inline-grid!important}.d-print-table{display:table!important}.d-print-table-row{display:table-row!important}.d-print-table-cell{display:table-cell!important}.d-print-flex{display:flex!important}.d-print-inline-flex{display:inline-flex!important}.d-print-none{display:none!important}} +/*# sourceMappingURL=bootstrap.min.css.map */ \ No newline at end of file diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS-mu0SC55I.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS-mu0SC55I.woff2 new file mode 100644 index 0000000..545243f Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS-mu0SC55I.woff2 differ diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS2mu0SC55K5gw.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS2mu0SC55K5gw.woff2 new file mode 100644 index 0000000..5331c21 Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS2mu0SC55K5gw.woff2 differ diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSCmu0SC55K5gw.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSCmu0SC55K5gw.woff2 new file mode 100644 index 0000000..e121d79 Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSCmu0SC55K5gw.woff2 differ diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSGmu0SC55K5gw.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSGmu0SC55K5gw.woff2 new file mode 100644 index 0000000..b1e8f1e Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSGmu0SC55K5gw.woff2 differ diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSKmu0SC55K5gw.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSKmu0SC55K5gw.woff2 new file mode 100644 index 0000000..2a73a33 Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSKmu0SC55K5gw.woff2 differ diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSOmu0SC55K5gw.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSOmu0SC55K5gw.woff2 new file mode 100644 index 0000000..1f8f90c Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSOmu0SC55K5gw.woff2 differ diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSumu0SC55K5gw.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSumu0SC55K5gw.woff2 new file mode 100644 index 0000000..1f9f9d4 Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSumu0SC55K5gw.woff2 differ diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSymu0SC55K5gw.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSymu0SC55K5gw.woff2 new file mode 100644 index 0000000..c59febe Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSymu0SC55K5gw.woff2 differ diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTUGmu0SC55K5gw.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTUGmu0SC55K5gw.woff2 new file mode 100644 index 0000000..36ca578 Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTUGmu0SC55K5gw.woff2 differ diff --git a/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTVOmu0SC55K5gw.woff2 b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTVOmu0SC55K5gw.woff2 new file mode 100644 index 0000000..59c9767 Binary files /dev/null and b/structurizr/css/fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTVOmu0SC55K5gw.woff2 differ diff --git a/structurizr/css/joint-3.6.5.css b/structurizr/css/joint-3.6.5.css new file mode 100644 index 0000000..633683e --- /dev/null +++ b/structurizr/css/joint-3.6.5.css @@ -0,0 +1,387 @@ +/*! JointJS v3.6.5 (2022-12-15) - JavaScript diagramming library + + +This Source Code Form is subject to the terms of the Mozilla Public +License, v. 2.0. If a copy of the MPL was not distributed with this +file, You can obtain one at http://mozilla.org/MPL/2.0/. +*/ +/* +A complete list of SVG properties that can be set through CSS is here: +http://www.w3.org/TR/SVG/styling.html + +Important note: Presentation attributes have a lower precedence over CSS style rules. +*/ + + +/* .viewport is a node wrapping all diagram elements in the paper */ +.joint-viewport { + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; +} + +.joint-paper > svg, +.joint-paper-background, +.joint-paper-grid { + position: absolute; + top: 0; + left: 0; + right: 0; + bottom: 0; +} + +/* +1. IE can't handle paths without the `d` attribute for bounding box calculation +2. IE can't even handle 'd' attribute as a css selector (e.g path[d]) so the following rule will + break the links rendering. + +path:not([d]) { + display: none; +} + +*/ + + +/* magnet is an element that can be either source or a target of a link */ +[magnet=true]:not(.joint-element) { + cursor: crosshair; +} +[magnet=true]:not(.joint-element):hover { + opacity: .7; +} + +/* + +Elements have CSS classes named by their types. E.g. type: basic.Rect has a CSS class "element basic Rect". +This makes it possible to easilly style elements in CSS and have generic CSS rules applying to +the whole group of elements. Each plugin can provide its own stylesheet. + +*/ + +.joint-element { + /* Give the user a hint that he can drag&drop the element. */ + cursor: move; +} + +.joint-element * { + -webkit-user-drag: none; +} + +.joint-element .scalable * { + /* The default behavior when scaling an element is not to scale the stroke in order to prevent the ugly effect of stroke with different proportions. */ + vector-effect: non-scaling-stroke; +} +/* + +connection-wrap is a element of the joint.dia.Link that follows the .connection of that link. +In other words, the `d` attribute of the .connection-wrap contains the same data as the `d` attribute of the +.connection . The advantage of using .connection-wrap is to be able to catch pointer events +in the neighborhood of the .connection . This is especially handy if the .connection is +very thin. + +*/ + +.marker-source, +.marker-target { + /* This makes the arrowheads point to the border of objects even though the transform: scale() is applied on them. */ + vector-effect: non-scaling-stroke; +} + +/* Paper */ +.joint-paper { + position: relative; +} +/* Paper */ + +/* Highlighting */ +.joint-highlight-opacity { + opacity: 0.3; +} +/* Highlighting */ + +/* + +Vertex markers are `` elements that appear at connection vertex positions. + +*/ + +.joint-link .connection-wrap, +.joint-link .connection { + fill: none; +} + +/* element wrapping .marker-vertex-group. */ +.marker-vertices { + opacity: 0; + cursor: move; +} +.marker-arrowheads { + opacity: 0; + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; +/* display: none; */ /* setting `display: none` on .marker-arrowheads effectivelly switches of links reconnecting */ +} +.link-tools { + opacity: 0; + cursor: pointer; +} +.link-tools .tool-options { + display: none; /* by default, we don't display link options tool */ +} +.joint-link:hover .marker-vertices, +.joint-link:hover .marker-arrowheads, +.joint-link:hover .link-tools { + opacity: 1; +} + +/* element used to remove a vertex */ +.marker-vertex-remove { + cursor: pointer; + opacity: .1; +} + +.marker-vertex-group:hover .marker-vertex-remove { + opacity: 1; +} + +.marker-vertex-remove-area { + opacity: .1; + cursor: pointer; +} +.marker-vertex-group:hover .marker-vertex-remove-area { + opacity: 1; +} + +/* +Example of custom changes (in pure CSS only!): + +Do not show marker vertices at all: .marker-vertices { display: none; } +Do not allow adding new vertices: .connection-wrap { pointer-events: none; } +*/ + +/* foreignObject inside the elements (i.e joint.shapes.basic.TextBlock) */ +.joint-element .fobj { + overflow: hidden; +} +.joint-element .fobj body { + background-color: transparent; + margin: 0px; + position: static; +} +.joint-element .fobj div { + text-align: center; + vertical-align: middle; + display: table-cell; + padding: 0px 5px 0px 5px; +} + +/* Paper */ +.joint-paper.joint-theme-dark { + background-color: #18191b; +} +/* Paper */ + +/* Links */ +.joint-link.joint-theme-dark .connection-wrap { + stroke: #8F8FF3; + stroke-width: 15; + stroke-linecap: round; + stroke-linejoin: round; + opacity: 0; + cursor: move; +} +.joint-link.joint-theme-dark .connection-wrap:hover { + opacity: .4; + stroke-opacity: .4; +} +.joint-link.joint-theme-dark .connection { + stroke-linejoin: round; +} +.joint-link.joint-theme-dark .link-tools .tool-remove circle { + fill: #F33636; +} +.joint-link.joint-theme-dark .link-tools .tool-remove path { + fill: white; +} +.joint-link.joint-theme-dark .link-tools [event="link:options"] circle { + fill: green; +} +/* element inside .marker-vertex-group element */ +.joint-link.joint-theme-dark .marker-vertex { + fill: #5652DB; +} +.joint-link.joint-theme-dark .marker-vertex:hover { + fill: #8E8CE1; + stroke: none; +} +.joint-link.joint-theme-dark .marker-arrowhead { + fill: #5652DB; +} +.joint-link.joint-theme-dark .marker-arrowhead:hover { + fill: #8E8CE1; + stroke: none; +} +/* element used to remove a vertex */ +.joint-link.joint-theme-dark .marker-vertex-remove-area { + fill: green; + stroke: darkgreen; +} +.joint-link.joint-theme-dark .marker-vertex-remove { + fill: white; + stroke: white; +} +/* Links */ +/* Paper */ +.joint-paper.joint-theme-default { + background-color: #FFFFFF; +} +/* Paper */ + +/* Links */ +.joint-link.joint-theme-default .connection-wrap { + stroke: #000000; + stroke-width: 15; + stroke-linecap: round; + stroke-linejoin: round; + opacity: 0; + cursor: move; +} +.joint-link.joint-theme-default .connection-wrap:hover { + opacity: .4; + stroke-opacity: .4; +} +.joint-link.joint-theme-default .connection { + stroke-linejoin: round; +} +.joint-link.joint-theme-default .link-tools .tool-remove circle { + fill: #FF0000; +} +.joint-link.joint-theme-default .link-tools .tool-remove path { + fill: #FFFFFF; +} + +/* element inside .marker-vertex-group element */ +.joint-link.joint-theme-default .marker-vertex { + fill: #1ABC9C; +} +.joint-link.joint-theme-default .marker-vertex:hover { + fill: #34495E; + stroke: none; +} + +.joint-link.joint-theme-default .marker-arrowhead { + fill: #1ABC9C; +} +.joint-link.joint-theme-default .marker-arrowhead:hover { + fill: #F39C12; + stroke: none; +} + +/* element used to remove a vertex */ +.joint-link.joint-theme-default .marker-vertex-remove { + fill: #FFFFFF; +} +/* Links */ + +@font-face { + font-family: 'lato-light'; + src: url(data:application/font-woff;charset=utf-8;base64,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) format('woff'); + font-weight: normal; + font-style: normal; +} + +/* Links */ +.joint-link.joint-theme-material .connection-wrap { + stroke: #000000; + stroke-width: 15; + stroke-linecap: round; + stroke-linejoin: round; + opacity: 0; + cursor: move; +} +.joint-link.joint-theme-material .connection-wrap:hover { + opacity: .4; + stroke-opacity: .4; +} +.joint-link.joint-theme-material .connection { + stroke-linejoin: round; +} +.joint-link.joint-theme-material .link-tools .tool-remove circle { + fill: #C64242; +} +.joint-link.joint-theme-material .link-tools .tool-remove path { + fill: #FFFFFF; +} + +/* element inside .marker-vertex-group element */ +.joint-link.joint-theme-material .marker-vertex { + fill: #d0d8e8; +} +.joint-link.joint-theme-material .marker-vertex:hover { + fill: #5fa9ee; + stroke: none; +} + +.joint-link.joint-theme-material .marker-arrowhead { + fill: #d0d8e8; +} +.joint-link.joint-theme-material .marker-arrowhead:hover { + fill: #5fa9ee; + stroke: none; +} + +/* element used to remove a vertex */ +.joint-link.joint-theme-material .marker-vertex-remove-area { + fill: #5fa9ee; +} +.joint-link.joint-theme-material .marker-vertex-remove { + fill: white; +} +/* Links */ + +/* Links */ +.joint-link.joint-theme-modern .connection-wrap { + stroke: #000000; + stroke-width: 15; + stroke-linecap: round; + stroke-linejoin: round; + opacity: 0; + cursor: move; +} +.joint-link.joint-theme-modern .connection-wrap:hover { + opacity: .4; + stroke-opacity: .4; +} +.joint-link.joint-theme-modern .connection { + stroke-linejoin: round; +} +.joint-link.joint-theme-modern .link-tools .tool-remove circle { + fill: #FF0000; +} +.joint-link.joint-theme-modern .link-tools .tool-remove path { + fill: #FFFFFF; +} + +/* element inside .marker-vertex-group element */ +.joint-link.joint-theme-modern .marker-vertex { + fill: #1ABC9C; +} +.joint-link.joint-theme-modern .marker-vertex:hover { + fill: #34495E; + stroke: none; +} + +.joint-link.joint-theme-modern .marker-arrowhead { + fill: #1ABC9C; +} +.joint-link.joint-theme-modern .marker-arrowhead:hover { + fill: #F39C12; + stroke: none; +} + +/* element used to remove a vertex */ +.joint-link.joint-theme-modern .marker-vertex-remove { + fill: white; +} +/* Links */ diff --git a/structurizr/css/open-sans.css b/structurizr/css/open-sans.css new file mode 100644 index 0000000..920f8a8 --- /dev/null +++ b/structurizr/css/open-sans.css @@ -0,0 +1,180 @@ +/* cyrillic-ext */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSKmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F; +} +/* cyrillic */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSumu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116; +} +/* greek-ext */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSOmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+1F00-1FFF; +} +/* greek */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSymu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF; +} +/* hebrew */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS2mu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F; +} +/* math */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTVOmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF; +} +/* symbols */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTUGmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF; +} +/* vietnamese */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSCmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB; +} +/* latin-ext */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSGmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; +} +/* latin */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 400; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS-mu0SC55I.woff2) format('woff2'); + unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; +} +/* cyrillic-ext */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSKmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F; +} +/* cyrillic */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSumu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116; +} +/* greek-ext */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSOmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+1F00-1FFF; +} +/* greek */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSymu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF; +} +/* hebrew */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS2mu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0307-0308, U+0590-05FF, U+200C-2010, U+20AA, U+25CC, U+FB1D-FB4F; +} +/* math */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTVOmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF; +} +/* symbols */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTUGmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF; +} +/* vietnamese */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSCmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB; +} +/* latin-ext */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSGmu0SC55K5gw.woff2) format('woff2'); + unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; +} +/* latin */ +@font-face { + font-family: 'Open Sans'; + font-style: normal; + font-weight: 700; + font-stretch: 100%; + src: url(./fonts/open-sans/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS-mu0SC55I.woff2) format('woff2'); + unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; +} \ No newline at end of file diff --git a/structurizr/css/structurizr-static-dark.css b/structurizr/css/structurizr-static-dark.css new file mode 100644 index 0000000..af4b163 --- /dev/null +++ b/structurizr/css/structurizr-static-dark.css @@ -0,0 +1,97 @@ +body { + background: #111111; + color: #dddddd; +} + +.icon-xs { + filter: invert(1.0); +} + +.icon-sm { + filter: invert(1.0); +} + +.icon-md { + filter: invert(1.0); +} + +.icon-lg { + filter: invert(1.0); +} + +.icon-xl { + filter: invert(1.0); +} + +.icon-xxl { + filter: invert(1.0); +} + +.icon-h1 { + filter: invert(1.0); +} + +.icon-h2 { + filter: invert(1.0); +} + +.modal-content { + background: #111111; + border: #dddddd 1px solid; + color: #dddddd; + font-size: 15px; +} + +.modal-header { + border-bottom: 1px solid #111111; +} + +.modal-header .btn-close { + filter: invert(1.0); +} + +.modal-footer { + border-top: 1px solid #333333; +} + +#diagramViewport { + background: #333333; +} + +.btn-default { + background-image: linear-gradient(to bottom, #ccc 0, #ddd 100%); +} + +.btn-default.disabled, .btn-default:disabled, .btn-default[disabled] { + background-color: #777777; + background-image: none; +} + +.structurizrDiagramViewport { + background: #111111; +} + +code { + color: #dddddd; + background: #111111; + font-weight: bold; +} + +.img-light { + display: none; +} +.img-dark { + display: block; +} + +.form-control { + background: #333333; + color: #cccccc; +} +.form-control::placeholder { + color: #cccccc; +} +.form-control:focus { + background: #333333; + color: #cccccc; +} \ No newline at end of file diff --git a/structurizr/css/structurizr-static.css b/structurizr/css/structurizr-static.css new file mode 100644 index 0000000..b03a2d4 --- /dev/null +++ b/structurizr/css/structurizr-static.css @@ -0,0 +1,153 @@ +body { + font-family: "Open Sans", sans-serif; + font-size: 14px; + padding-left: 0; + padding-right: 0; + line-height: 1.5; + margin: 0; +} +.centered { + text-align: center; +} +.btn { + text-shadow: none; +} +.icon-btn { + width: 18px; + height: 18px; + margin-bottom: 1px; + vertical-align: middle; +} +.icon-xs { + width: 12px; + height: 12px; + margin: 2px 2px 4px 0; +} +.icon-sm { + width: 18px; + height: 18px; + vertical-align: middle; + margin: 2px 2px 4px 0; +} +.icon-md { + width: 26px; + height: 26px; + margin: 2px 2px 4px 0; +} +.icon-lg { + width: 36px; + height: 36px; + margin: 2px 2px 4px 0; +} +.icon-xxl { + width: 50px; + height: 50px; + margin-bottom: 10px; +} +.icon-white { + filter: invert(1); +} +.icon-h1 { + width: 45px; + height: 45px; + vertical-align: bottom; + line-height: 1; + margin-bottom: 0; +} +.icon-h2 { + width: 32px; + height: 32px; + vertical-align: bottom; + margin-bottom: 4px; +} + +.modal-xl { + width: 95%; + max-width: 95%; +} +.modal-content { + font-size: 15px; +} + +.btn-active { + background: #999999; +} + +#quickFindModal .selected { + background: #85BBF0; + color: #ffffff; +} +#quickFindModal .quickNavigationItem { + padding: 4px; + border-radius: 2px; + cursor: pointer; +} + +#tooltip { + font-size: 14px; + color: #000000; + background: #eeeeee; + padding: 10px; + margin: 20px; + position: absolute; + z-index: 10; + opacity: 0.98; + border: 2px #666666 solid; + border-radius: 5px; + width: 33%; + max-width: 33%; + overflow: hidden; +} +#tooltipName { + font-size: 20px; + font-weight: normal; +} +#tooltipParent { + font-size: 8px; +} +#tooltipMetadata { + font-size: 10px; +} +#tooltipType { + font-size: 10px; +} +#tooltipDescription { + font-size: 12px; + margin-top: 10px; +} +#tooltipTags { + margin-top: 10px; + font-size: 10px; +} +#tooltipProperties { + margin-top: 15px; + font-size: 10px; +} +#tooltipUrl { + margin-top: 10px; + font-size: 10px; +} +#tooltip .tag { + border-width: 1px; + border-style: solid; + padding: 3px 3px 3px 3px; + margin: 3px 3px 3px 0; + border-radius: 6px; + white-space: nowrap; + display: inline-block; +} +.hidden { + display: none !important; +} + +code { + color: #000000; + font-weight: bold; +} + +.img-light { + display: block; +} +.img-dark { + display: none; +} diff --git a/structurizr/css/structurizr.css b/structurizr/css/structurizr.css new file mode 100644 index 0000000..e4de7d0 --- /dev/null +++ b/structurizr/css/structurizr.css @@ -0,0 +1,586 @@ +body { + font-family: "Open Sans", sans-serif; + padding-left: 0; + padding-right: 0; + line-height: 1.5; +} +.centered { + text-align: center; +} +#footer { + text-align: center; + padding-top: 20px; + padding-bottom: 20px; + padding-left: 0; + padding-right: 0; + font-size: 13px; +} +.container { + font-size: 18px; + padding-left: 10px; + padding-right: 10px; +} +.section { + margin-right: 0; + margin-left: 0; + padding-top: 40px; + padding-bottom: 100px; + padding-left: 10px; + padding-right: 10px; +} +.row { + padding-bottom: 20px; +} +h1 { + font-size: 50px; + font-weight: normal; + margin-top: 30px; +} +h2 { + font-size: 40px; + font-weight: normal; + margin-top: 30px; +} +h3 { + font-size: 30px; + font-weight: normal; + margin-top: 30px; +} +h4 { + font-size: 25px; + font-weight: normal; + margin-top: 30px; +} +h5 { + font-size: 16px; + font-weight: normal; +} +h6 { + font-size: 13px; + font-weight: normal; +} + +.form-signin { + max-width: 330px; + padding: 15px; + margin: 0 auto; +} + +#diagramDefinition { + padding: 0; + background: #dddddd; +} +.c4MetaModel td { + font-size: 13px; +} +.c4MetaModel td ul { + padding: 0 0 0 20px; +} +.dashboardMetaData { + font-size: 14px; +} +.workspaceMetaData { + font-size: 11px; + color: gray; +} +a:hover { + text-decoration: none; +} + +.hideHorizontalScrollbars { + overflow-x: hidden !important; +} +.hideVerticalScrollbars { + overflow-y: hidden !important; +} + +.panel-title { + font-size: 24px; +} +.table-vcenter td { + vertical-align: middle!important; +} +.pricingSmallPrint { + font-size: 13px; +} +#buildNumber { +} +.inactive { + opacity:0.4; + filter:alpha(opacity=40); +} +.pricingPagePrice { + font-size: 80px; + font-weight: bold; +} +.img-thumbnail { + color: #ddd; +} +label { + font-weight: normal; +} +.label { + font-weight: normal; +} +.imageTitle { + font-size: 13px; + font-weight: bold; + margin-top: 10px; + margin-bottom: 30px; + text-align: center; +} +.structurizrEmbed { + padding: 0; + overflow: hidden; + margin-left: auto; + margin-right: auto; +} +.embedCode { + font-size: 11px; +} +.codeSample { + font-size: 11px; +} + +a { + color: #1168BD; +} + +.structurizrBackgroundGray { + background: #777777; + color: #ffffff; +} +.structurizrBackgroundDarker { + background: #02172C; + color: #ffffff; +} +.structurizrBackgroundDark { + background: #08427B; + color: #ffffff; +} +.structurizrBackgroundBase { + background: #1168BD; + color: #ffffff; +} +.structurizrBackgroundLight { + background: #438DD5; + color: #ffffff; +} +.structurizrBackgroundLighter { + background: #85BBF0; + color: #ffffff; +} +.structurizrBackgroundDarker a, .structurizrBackgroundDark a, .structurizrBackgroundBase a, .structurizrBackgroundLight a { + color: #85BBF0; +} + +.label-primary { + background: #1168BD; +} +.label-branch { + background: #08427B; + font-size: 12px; +} +.label-version { + background: #85BBF0; + font-size: 12px; +} + +th { + font-weight: normal; +} + +.grayscale { + -webkit-filter: grayscale(100%); /* Chrome, Safari, Opera */ + filter: grayscale(100%); +} + +code { + color: #08427B; + background: #E9F4FE; +} +.marker-vertex { + fill: #dddddd; + r: 20; +} + +.marker-vertex:hover { + fill: #ff0000; +} + +.smaller { + font-size: 11px; +} + +.dashboardPublicWorkspace { + border-color: #d9534f; +} + +.dashboardPublicWorkspace a { + color: #d9534f; +} + +.dashboardPrivateWorkspace { + border-color: #337ab7; +} + +#documentationContent { + margin-bottom: 100px; +} + +#documentationContent img { + cursor: pointer; +} + +#documentationContent table th, #decisionLogContent table th { + padding: 5px 10px 5px 10px; + border: solid 1px gray; + font-weight: bold; + background: #eeeeee; +} + +#documentationContent table td, #decisionLogContent table td { + padding: 5px 10px 5px 10px; + border: solid 1px gray; +} + +#documentationNavigation { + padding: 0px 0px 20px 5px; + line-height: 200%; +} + +.documentationNavigationLink { + +} + +.documentationNavigationLinkActive { + font-weight: bold; +} + +.documentationNavigationHeading { + font-size: 20px; + margin-bottom: 0px; + margin-top: 20px; +} + +.documentationNavigationSection { + font-size: 12px; +} + +.documentationNavigationSubSection { + padding-left: 20px; + font-size: 11px; +} + +.documentationNavigationSubSubSection { + padding-left: 30px; + font-size: 10px; +} + +.documentationSection { + font-size: 18px; + padding-left: 10px; + padding-right: 30px; +} + +#documentationNavigationPanel { + overflow-y: scroll; +} +#documentationPanel { + overflow-y: scroll; + padding-top: 20px; + padding-bottom: 50px; +} + +#documentationMetadata { + font-size: 9px; + color: #777777; +} + +.decisionNavigationLink { + +} + +.decisionNavigationLinkActive { + font-weight: bold; +} + +.decisionNavigationHeading { + font-size: 20px; + margin-bottom: 0px; + margin-top: 20px; +} + +.decisionNavigationItem { + font-size: 12px; +} + +.decisionLogSummary { + font-size: 18px; +} + +.decisionLogSummary table td { + border-top: 1px solid #ddd !important; + border-bottom: none !important; + border-left: none !important; + border-right: none !important; +} + +.faded { + color: #aaaaaa; +} + +.btn { + text-shadow: none; +} + +.icon-btn { + width: 18px; + height: 18px; + margin-bottom: 1px; + vertical-align: middle; +} +.icon-xs { + width: 12px; + height: 12px; + margin: 2px 2px 4px 0; +} +.icon-sm { + width: 18px; + height: 18px; + vertical-align: middle; + margin: 2px 2px 4px 0; +} +.icon-md { + width: 26px; + height: 26px; + margin: 2px 2px 4px 0; +} +.icon-lg { + width: 36px; + height: 36px; + margin: 2px 2px 4px 0; +} +.icon-xxl { + width: 50px; + height: 50px; + margin-bottom: 10px; +} +.icon-white { + filter: invert(1); +} +.icon-h1 { + width: 45px; + height: 45px; + vertical-align: bottom; + line-height: 1; + margin-bottom: 0; +} +.icon-h2 { + width: 32px; + height: 32px; + vertical-align: bottom; + margin-bottom: 4px; +} + +hr { + border-top: 1px solid #ddd; +} +.modal-xl { + width: 95% +} + +.img-light { + display: block; +} +.img-dark { + display: none; +} + +#exploreGraphPanel, #exploreTreePanel { + background: #ffffff; +} + +#exploreGraph text, #exploreTree text { + fill: #000000; + stroke: #ffffff; + paint-order: stroke; +} + +#exploreGraph .nodeName { + font-size: 13px; + fill: #000000; + cursor: default; +} +#exploreGraph .nodeMetadata { + font-size: 8px; + fill: #444444; + cursor: default; +} +#exploreGraph .link { + fill: none; +} + +#topNavigation, #workspaceSummaryControls { + background: #ffffff; + border-bottom: solid 1px #dddddd; + box-shadow: 0px 0px 3px #dddddd; + font-size: 18px; + font-weight: normal; +} +.topNavigationItem { + margin-left: 20px; + margin-right: 20px; +} +#editorControls, #diagramControls, #explorationControls, #documentationControls, #decisionLogControls, #healthControls { + background: #ffffff; + border-bottom: solid 1px #dddddd; + box-shadow: 0px 0px 3px #dddddd; +} +#topNavigation .row, #workspaceSummaryControls .row, #diagramControls .row, #explorationControls .row, #documentationControls .row, #decisionLogControls .row, #healthControls .row { + margin-left: 0; + margin-right: 0; +} + +#diagramNavigationPanel { + background: #ffffff; + overflow-y: scroll; + border-right: solid 1px #dddddd; +} + +#diagram { + background: gray; + margin: 0; + padding: 0; + border-style: none; +} + +.diagramThumbnail { + cursor: pointer; + margin: 0 0 40px 0; + padding: 10px; + border-radius: 5px; +} + +.diagramThumbnail img { + max-height: 160px; + margin-left: auto; + margin-right: auto; + margin-bottom: 10px; +} + +.diagramThumbnailActive { + background: #aaaaaa; + color: #ffffff; +} + +.structurizrDiagramViewport { + text-align: center; + margin: 0 auto 0 auto; + padding: 0; + border-style: none; + overflow: scroll; +} + +.structurizrDiagramCanvas { + border-style: none; + background: white; + padding: 0; + margin: auto; +} + +.structurizrElement .highlightedElement { + stroke-width: 5px; + stroke: #777777; + stroke-dasharray: 10 10; +} + +.joint-element * { + vector-effect: none; +} + +.joint-link.joint-theme-default .marker-vertex { + fill: #1168BD; + r: 25px; +} + +.joint-link.joint-theme-default .marker-vertex:hover { + fill: #08427B; + r: 25px; +} + +.joint-link.joint-theme-default .connection-wrap:hover { + opacity: 0; + stroke-opacity: 0; +} + +#navigationModal option { + padding: 5px; +} + +#filterModal .tag { + padding: 5px 5px 5px 5px; + margin: 3px 3px 3px 3px; + border-radius: 7px; + font-size: 12px; + white-space: nowrap; + display: inline-block; + cursor: default; + user-select: none; + -webkit-user-select: none; +} +#filterModal .tagOn { + background: #aaaaaa; + color: #ffffff; + border: solid 1px #aaaaaa; +} +#filterModal .tagOff { + background: #ffffff; + color: #777777; + border: solid 1px #777777; +} + +#quickFindModal .viewKey { + font-size: 75%; +} + +#banner { + text-align: center; + font-size: 14px; +} + +.brandingLogo { + max-height: 35px; + margin-top: 5px; +} + +.btn { + cursor: default; +} +.btn-active { + background: #999999; +} + +#quickFindModal .selected { + background: #85BBF0; + color: #ffffff; +} +#quickFindModal .quickNavigationItem { + padding: 4px; + border-radius: 2px; + cursor: pointer; +} + +#progressMessage { + position: fixed; + z-index: 1000; + opacity: .90; + bottom: 10px; + right: 10px; + text-align: center; + font-size: 20px; + border-radius: 5px; + padding: 20px; + background: #999999; + max-width: 80%; +} \ No newline at end of file diff --git a/structurizr/decisions/0001-record-architecture-decisions.md b/structurizr/decisions/0001-record-architecture-decisions.md new file mode 100644 index 0000000..19c5166 --- /dev/null +++ b/structurizr/decisions/0001-record-architecture-decisions.md @@ -0,0 +1,29 @@ +# 1. Record architecture decisions + +Date: 2025-05-01 + +## Status + +Accepted + +## Context + +We moeten ontwerpbeslissingen bijhouden tijdens de ontwikkeling van dit project. Belangrijk is om daarvan een helder overzicht te hebben, zodat we deze later makkelijk kunnen terugvinden. Bijvoorbeeld keuzes voor bepaalde frameworks en packages. Zo kunnen nieuwe projectmedewerkers / developers ook snel zien waarom er bepaalde keuzes zijn gemaakt. + +## Decision + +We gaan gebruik maken van Architecture Decision Records, zoals [beschreven door Michael Nygard](http://thinkrelevance.com/blog/2011/11/15/documenting-architecture-decisions). + +Er is een ADR Tools CLI beschikbaar voor het snel kunnen aanmaken van nieuwe beslis-documenten. + +- [ADR Tools](https://github.com/npryce/adr-tools) + +Voorbeeld om een nieuw decision record aan te maken: + +``` +adr new Beslissing die genomen moet worden +``` + +## Consequences + +We moeten keuzes die we maken ook wel gaan bijhouden. Als we dat consequent doen, is dit een heel mooie manier om alle gemaakte beslissingen inzichtelijk te houden. diff --git a/structurizr/decisions/0002-notify-onderzoek.md b/structurizr/decisions/0002-notify-onderzoek.md new file mode 100644 index 0000000..90ba3bf --- /dev/null +++ b/structurizr/decisions/0002-notify-onderzoek.md @@ -0,0 +1,63 @@ +# 2. Notify Onderzoek + +Date: 2025-07-07 + +## Status + +Accepted + +## Context + +Tijdens onze gesprekken met verschillende organisaties (Belastingdienst, UWV en RDW) over aansluiten op MijnOverheidZakelijk kwam +een andere behoefte eigenlijk meer omhoog, een rijksbrede, goed werkende notificatie service. +Binnen Logius wordt hiervoor al gekeken naar NotifyNL, een fork van het project NotifyUK door het bedrijf Worth systems. +Vanuit het programma MijnOverheidZakelijk hadden we ook tijd om hier onderzoek naar te doen. Binnen dit onderzoek is er niet gekeken naar de functionele mogelijkheden maar alleen naar de technische keuzes (code, gebruikte third party systemen en architecturale beslissingen) en de verschillen tussen het base NotifyUK project en de Nederlandse fork. + +De code is op dit moment opgesplitst in meerdere afzonderlijke Flask (python) projecten. Er is een front-end applicatie, genaamd 'admin', Daarnaast is er een back-end, aangeduid als 'api', die verantwoordelijk is voor het verwerken en versturen van de notificaties. Beide projecten maken gebruik van een gedeeld utils-project, dat als PIP-package wordt geïmporteerd om herbruikbare functionaliteit te bieden. + +Voor veel van de kernfunctionaliteiten maakt Notify standaard gebruik van Amazon producten. Zo wordt Amazon SES (Simple Email Service) ingezet voor het versturen van e-mails, terwijl Amazon SQS (Simple Queue Service) wordt gebruikt voor het beheren van de queue. Voor het versturen van SMS-berichten wordt gebruikgemaakt van verschillende marktpartijen. Deze afhankelijkheid van externe cloud-diensten betekent dat het systeem sterk leunt op de infrastructuur van Amazon. + + +1. **Bestaande Notify-implementatie klonen zonder wijzigingen** + + Gebruik een directe fork van bijvoorbeeld de UK-versie, inclusief de bestaande e-mail- en sms-clients en bijbehorende afhankelijkheden, zoals AWS (Amazon Web Services). Dit is de snelste route naar een werkend systeem, maar biedt beperkte controle over toekomstige ontwikkeling. Er is een grotere afhankelijkheid van externe leveranciers, wat mogelijk minder wenselijk is vanuit het oogpunt van openheid en technologische onafhankelijkheid. Ook is het oplossen van technical debt lastig te realiseren omdat je sterk afhankelijk blijft van de upstream fork. + +2. **Bestaande Notify-implementatie klonen en alleen de clients aanpassen** + + Fork de UK-versie en implementeer eigen providers voor e-mail en sms. Dit biedt meer controle over kritieke afhankelijkheden (zoals het vermijden van AWS), terwijl je nog steeds kunt profiteren van functionele updates uit het originele project. Wel is er minder flexibiliteit om grote structurele aanpassingen in de code door te voeren, wat het oplossen van technical debt op termijn bemoeilijkt. + +3. **Bestaande Notify-implementatie klonen met structurele wijzigingen** + + Start met een fork van bijvoorbeeld de UK-versie, maar behandel deze slechts als initiële basis. Ontwikkel daarna zelfstandig verder zonder actief de upstream-code te volgen. Dit geeft maximale vrijheid in architectuurkeuzes en biedt de mogelijkheid om technical debt aan te pakken. Nadeel is dat je geen toekomstige verbeteringen uit de oorspronkelijke versie meer kunt overnemen. + +4. **Volledig eigen ontwikkeling met lessen uit bestaande Notify-implementaties** + + Bouw een nieuwe codebase vanaf nul, geïnspireerd op bestaande oplossingen zoals die van de UK, Canada, Nederland of de VS. Dit geeft volledige vrijheid in technologie (bijvoorbeeld keuze voor een ander framework dan Flask/Python) en architectuur. + +| Optie | Inspanning | Aanpasbaarheid | Vendor lock-in | Aansluitbaarheid | +| ----- | ---------- | --------------- | -------------- | ---------------- | +| 1 | Laag | Laag | Ja | Midden | +| 2 | Laag | Laag | Nee | Midden | +| 3 | Midden | Midden tot Hoog | Nee | Hoog | +| 4 | Hoog | Hoog | Nee | Hoog | + +## Decision + +Onze conclusie is dat dit project niet al te lastig is om zelf als overheid te gaan implementeren en door te ontwikkelen. De materie is niet al te lastig en er is bij de overheid intern genoeg kennis en ontwikkelkracht om dit zelf (open-source) te ontwikkelen. + +Wel moet er een keuze worden gemaakt tot hoever de upstream met de UK variant moet worden onderhouden, hoe meer je zelf gaat veranderen/verbeteren aan de Nederlandse versie, hoe lastiger veranderingen die de UK doet terug te brengen zijn in de code base. Canada heeft dit opgelost door NotifyUK als start punt te gebruiken en vanaf daar zelf door te gaan ontwikkelen. Onze suggestie is om ook te kiezen voor deze oplossing, dus optie 3. + +Wij zijn tot deze conclusie komen door de volgende overwegingen: + +- De code heeft in onze opinie wat verbeter mogelijkheden, zo is de back-end code soms onnodig verwarrend en ondersteunt de front-end sommige basale functionaliteiten niet, zoals i18n/meertaligheid. Ons advies zou dan ook zijn om goed te kijken of er tijd is om de front-end te herschrijven en deze in een moderner jasje te steken, bijvoorbeeld door gebruik te maken van React. Mocht hier geen tijd voor zijn, dan kan er met beperkte inspanning ook worden gekeken naar het toevoegen van de benodigde functionaliteiten aan de bestaande front-end. + Ook zal er wat tijd te gereserveerd moeten worden om technical debt van de back-end service aan te pakken. + +- Er zijn verschillende aanpassingen nodig om de afhankelijkheden van third-party software weg te halen. Zo moet de Amazon simple queue service worden vervangen met een zelf gehoste queue, hierbij kan gedacht worden aan RabbitMQ. De Amazon simple email service moet worden vervangen door de mail-relay van de overheid (Logius) zelf. Ook moet er worden nagedacht hoe de SMS berichten worden verstuurd, is er bij de overheid al een partij die dit voor je kan doen, of moet hier een markt partij voor worden verzonden. Onze suggestie zou zijn om vast met de queue/email te beginnen terwijl hier over na wordt gedacht. + +- Worth Systems heeft kleine aanpassingen gedaan op de UK versie van notify, zo hebben ze de telefoonnummer validatie aangepast naar een Nederlandse variant, een andere SMS provider toegevoegd en wat tekstuele aanpassingen gedaan, maar er moet nog heel veel gebeuren. Zo zijn alle templates nog in het Engels, linkt alles nog door naar de Engelse versie, is de website niet in de rijkshuisstijl, is er nog geen Nederlandse documentatie en zijn er nog geen grote code opschoon acties gedaan. +Er werd gecommuniceerd dat hier naar werd gekeken maar op het moment van schrijven is hier nog niks van terug te vinden op de productie omgeving, maar kijkend naar hun repository wordt er wel gewerkt aan een feature branch die misschien binnenkort gemerged kan worden. + +## Consequences +- Er moet worden bepaald onder welk programma dit project komt te draaien +- Er moeten een aantal developers / team worden gevonden +- Er moet een beheer club worden gezocht \ No newline at end of file diff --git a/structurizr/decisions/0003-scenario-bepaling.md b/structurizr/decisions/0003-scenario-bepaling.md new file mode 100644 index 0000000..1e8cd0b --- /dev/null +++ b/structurizr/decisions/0003-scenario-bepaling.md @@ -0,0 +1,118 @@ +# 3. Scenario bepaling + +Date: 2025-07-08 + +## Status + +Proposed + +## Context + +Vanuit de buisiness kregen we de vraag om scenarios op basis van architectuur vraagstukken van Paul Jansen uit te werken tot documenatie en ook prototypes. + +### Scenario 2 + +Bij scenario 2 maken alle (vak)applicaties van bijv. het UWV, de belastingdienst of RVO allemaal direct verbinding met de notificatie service (Of dit nou Notify of een alternatief is) + +#### Scenario 2 + +![Scenario 2 uitgetekend](./images/Scenario2.png "Scenario 2 uitgetekend") + +
    + Zie mermaid code + + sequenceDiagram + actor Medewerker + Medewerker->>Vakapplicatie: + activate Vakapplicatie + Vakapplicatie->>Notificatie service:Verstuur verzoek tot notificatie + activate Notificatie service + Notificatie service-->>Vakapplicatie: + deactivate Vakapplicatie + Notificatie service-->>Vakapplicatie:Notificatie status update callback + deactivate Notificatie service + activate Vakapplicatie + Vakapplicatie->>Vakapplicatie:Afhandeling callback + deactivate Vakapplicatie +
    + +Voordelen: + +- Geen ontwikkelwerk voor een generiek component + +Nadelen: + +- Elke overheids organisatie moet zelf connectie opzetten met de notificatie service die op dit moment niet al te best gedocumenteerd is +- Elke overheids organisatie moet zelf een implementatie verzinnen en opzetten om te voldoen aan de wet MEBV +- Geen centrale / federatieve opslag van alle contactmomenten mogelijk +- Organisatie moet zelf kanaal herstel inrichten + +### Scenario 8 + +Bij scenario 8 komt er een generiek component tussen de (vak)applicaties van alle organisaties en de notificatie service. Deze kan verschillende problemen wegnemen voor de organsaties, zoals het opslaan van alle contactmomenten, kanaal herstel en het eenduidig praten met de notificatie service. + +Dit component wordt ontwikkeld door het MijnOverheidZakelijk team maar komt wel bij de organisaties zelf te draaien. Het zelfde principe als dat de gemeentes nu doen met het OMC van worth systems + +**_OMC - is een placeholder term totdat we een goede benaming hebben voor deze service_** + +#### Scenario 8 + +![Scenario 8 uitgetekend](./images/Scenario8.png "Scenario 8 uitgetekend") + +
    + Zie mermaid code + + sequenceDiagram + actor Medewerker + Medewerker->>Vakapplicatie: + activate Vakapplicatie + Vakapplicatie->>OMC:Verstuur verzoek tot notificatie + deactivate Vakapplicatie + activate OMC + OMC->>Profiel service:Haal contact inforamtie op o.b.v. kvknummer + activate Profiel service + Profiel service-->>OMC: + deactivate Profiel service + OMC->>Notificatie service:Verstuur verzoek tot notificatie + activate Notificatie service + deactivate OMC + + Notificatie service-->>OMC:Notificatie status update callback + deactivate Notificatie service + activate OMC + alt status = mislukt + OMC->>Profiel service:Haal adres gegevens op o.b.v. kvknummer + activate Profiel service + Profiel service-->>OMC: + deactivate Profiel service + OMC->>Notificatie service:Stuur verzoek tot brief + activate Notificatie service + Notificatie service-->>OMC:Brief callback + deactivate Notificatie service + end + deactivate OMC + OMC-->>Vakapplicatie:Optionele callback + +
    + +Voordelen: + +- Elke overheids organisatie hoeft alleen eenduidig aan te sluiten op onze OMC, deze ingang kan samen met deze organisaties worden gespecificeerd en opgezet +- Wij ontzorgen de gebruikers als zei het Email-adres van de ontvanger niet weten, als input kan dan het KVK nummer worden gegeven en regelen wij de rest +- Wij geven een optie voor poging tot kanaalherstel, hierdoor wordt voldaan aan de wet MEBV + +Nadelen: + +- Organisaties moeten zelf de nieuwe versies uitrollen op het platform als deze gereleased worden door ons +- Moet nog ontwikkeld worden + +## Decision + +Wij hebben deze 2 scenario's uitgwerkt en zijn tot de conclussie komen hier een aantal dingen in te missen. + +- Om te verkomen dat een bedrijf meerdere brieven ontvangt moet hier een centrale service voor komen +- De contactmomenten moeten worden opgeslagen op een federatieve manier zodat een nog te ontwikkelen service deze kan uitlezen + +## Consequences + +Het gevolg is dat we de uitgewerkte scenario's 2 en 8 moeten gaan vervangen met een uitwerking die ook de bovenstaande punten implementeert diff --git a/structurizr/decisions/0004-OpenZaak-OpenKlant copy.md b/structurizr/decisions/0004-OpenZaak-OpenKlant copy.md new file mode 100644 index 0000000..bde50ee --- /dev/null +++ b/structurizr/decisions/0004-OpenZaak-OpenKlant copy.md @@ -0,0 +1,32 @@ +# 4. OpenKlant & OpenZaak voor fase 1 + +Date: 2025-07-15 + +## Status + +Accepted + +## Context + +1. **OpenKlant gebruiken i.p.v. een profiel service ontwikkelen** + + OpenKlant is op dit moment te uitgebreid voor de eerste fase; een nadere afweging is pas zinvol zodra de requirements concreter zijn. + Enkele voorbeelden: + Een partij kan meerdere digitale adressen hebben, waar wij e-mails naartoe kunnen sturen. Echter, er ontbreekt een mogelijkheid om aan te geven waarvoor een adres bedoeld is (bijv. voor financiële communicatie). + Daarnaast bevat OpenKlant meerdere velden (zoals rekeningnummer, actor en interne taak) die wij voorlopig niet zouden gebruiken. + +2. **OpenZaak inzetten voor zaak gericht werken (ZGW) aan de vakapplicatie kant** + + OpenZaak, eventueel in combinatie met OpenKlant en OpenNotificatie, zou een rol kunnen spelen binnen de dienstverlenende partijen (zoals UWV, Belastingdienst, etc.). + Voor de eerste fase is dit echter niet aan te raden, gezien de aanzienlijke tijdsinvestering die van deze partijen gevraagd zou worden om ZGW te implementeren. + In latere fases kan deze optie opnieuw worden overwogen. + Een belangrijke kanttekening hierbij is dat kanaalherstel momenteel is ingebouwd in de zelfontwikkelde OMC, en niet in het ZGW-ecosysteem. + +## Decision + +Geen gebruik van OpenZaak & OpenKlant in de eerste fase. + +## Consequences + +Voor de eerste fase maken we gebruik van de zelfontwikkelde profielservice en OMC. +In latere fases, en zodra de requirements duidelijker zijn, moet deze keuze opnieuw worden overwogen. diff --git a/structurizr/decisions/0005-AuditLog-EventSourcing.md b/structurizr/decisions/0005-AuditLog-EventSourcing.md new file mode 100644 index 0000000..f072026 --- /dev/null +++ b/structurizr/decisions/0005-AuditLog-EventSourcing.md @@ -0,0 +1,100 @@ +# 5. Event Sourcing + +Date: 2025-10-05 + +## Status + +Accepted + +## Context + +Vanuit de business kregen we de vraag om event sourcing te onderzoeken in de context van de Profiel Service, wat momenteel dus alleen een e-mailadres betreft maar in de toekomst meer zou kunnen bevatten. + +Hieronder een eenvoudig voorbeeld van hoe de tijdlijn van een profiel er uit zou kunnen zien: +![Profiel tijdlijn](./images/ProfielTijdlijn.png "Profiel tijdlijn") + +
    + Zie mermaid code + +``` +mermaid +flowchart TD + subgraph Profiel Tijdlijn + E[2025-01-01: ProfielCreated email=1]:::event --> D[2025-02-02: ProfielUpdated email=2]:::event --> C[2025-03-03: ProfielUpdated email=3]:::event --> B[2025-04-04: ProfielDeleted]:::event + end + + classDef event fill:#e3f2fd,stroke:#2196f3,color:#0d47a1; +``` + +
    + +### Event Sourcing + +Event sourcing is een manier van gegevensopslag waarbij niet de actuele state van een entiteit wordt opgeslagen, maar alle events die tot die state hebben geleid. +Elke wijziging aan een profiel, bijvoorbeeld het aanpassen van een e-mailadres of toevoegen van een telefoonnummer, wordt vastgelegd als een apart event. +De actuele state van een profiel wordt dan bepaald door alle events in chronologische volgorde opnieuw toe te passen. + +Onderstaande illustratie toont hoe een profiel vanuit de initiële state wordt opgebouwd door het herhalen van events tot de bevraagde versie is bereikt: +![Event Source Read](./images/EventSourceRead.png "Event Source Read") + +
    + Zie mermaid code + +``` +mermaid +flowchart TD + subgraph Event Sourced Voorbeeld + X[User Requests Profiel at=2025-02-15]:::action + A[Base Profiel email=1]:::current + X -->|Load base state| A + A -->|Apply event 2025-02-02: email updated to 2| B[Reconstructed Profiel email=2] + end + + classDef current fill:#c8e6c9,stroke:#2e7d32,color:#1b5e20; + classDef action fill:#fff9c4,stroke:#fbc02d,color:#f57f17; +``` + +
    + +### Audit Logging + +Audit logging daarentegen legt de wijzigingen vast ten opzichte van de huidige state, grootendeels voor audit- of compliance-doeleinden. +De primaire opslag blijft de actuele state van het profiel, terwijl de audit log enkel dient voor naspeurbaarheid en historische reconstructie wanneer nodig. + +Het verschil met event sourcing is dat audit logging niet bedoeld is om de actuele state telkens opnieuw op te bouwen, maar om een historische reconstructie mogelijk te maken wanneer dat gevraagd wordt. +Dit kan bijvoorbeeld door middel van een reverse delta read, zoals hieronder geïllustreerd: +![Reverse Read Voorbeeld](./images/ReverseDeltaRead.png "Reverse Read Voorbeeld") + +Een reverse delta read betekent het toepassen van de opgeslagen audit logs in volgorde van nieuwste eerst, tot aan de datum die de ondernemer of toezichthouder heeft opgegeven. +Hiermee kan de state van een profiel op een eerder moment worden herleid, zonder dat het volledige eventverloop hoeft te worden opgebouwd. + +
    + Zie mermaid code + +``` +mermaid +flowchart TD + subgraph Reverse Read Voorbeeld + X[User requests Profiel at=2025-02-15]:::action + A[Current Profiel email=3]:::current + X -->|Load current state| A + A -->|Apply reverse deltas: undo 2025-04-04 & 2025-03-03| Y[Reconstructed Profiel email=2] + end + + classDef current fill:#c8e6c9,stroke:#2e7d32,color:#1b5e20; + classDef action fill:#fff9c4,stroke:#fbc02d,color:#f57f17; +``` + +
    + +## Decision + +Na het afwegen van beide scenario’s hebben we geconcludeerd dat Audit Logging op dit moment geschikter is, maar we blijven de toekomst in het oog houden, waarin een uitgebreidere profielservice mogelijk meer voordeel haalt uit event sourcing. +De belangrijkste reden is dat bijna elke use case enkel de laatste versie van het profiel nodig heeft. +Bij Event Sourcing zou dan telkens opnieuw het hele profiel moeten worden opgebouwd, wat onnodige complexiteit en performancekosten met zich meebrengt voor de huidige schaal en scope. + +## Consequences + +- We implementeren Audit Logging als eerste stap, inclusief ondersteuning voor reverse reads, zodat historische reconstructie mogelijk blijft. +- De architectuur wordt zodanig opgezet dat een eventuele migratie naar Event Sourcing in de toekomst niet wordt uitgesloten. +- Voor nu blijft de Profiel Service state-based met audit trail. diff --git a/structurizr/decisions/0006-federatieve-authenticatie-en-autorisatie-op-basis-van-oidc-en-eidas.md b/structurizr/decisions/0006-federatieve-authenticatie-en-autorisatie-op-basis-van-oidc-en-eidas.md new file mode 100644 index 0000000..9e388a4 --- /dev/null +++ b/structurizr/decisions/0006-federatieve-authenticatie-en-autorisatie-op-basis-van-oidc-en-eidas.md @@ -0,0 +1,257 @@ +# 6. Federatieve Authenticatie en Autorisatie op basis van OpenID Connect en eIDAS 2.0 + +Date: 2025-10-27 + +## Status + +Proposed + +## Context + +### Doel + +Een federatieve architectuur voor authenticatie en autorisatie van gebruikers (DigiD / eHerkenning / eIDAS), waarmee rechtstreeks geauthenticeerd kan worden bij individuele services - zoals de Profiel Service, Berichten Services, MijnServices etc - met eenduidige trust- en token-flows die aansluiten op eIDAS 2.0 en OpenID Connect. + +Het document beschrijft: + +- Componenten en rollen +- Schematische architectuur (flowdiagram) +- Sequence diagram (met voorbeeld JWT-claims en HTTP-calls) +- Token- en trustmechanismen (OIDC, JWT, JWKS, aud, iss, acr) +- Security- en privacy-overwegingen +- Management-samenvatting (A4) + +## Kerncomponenten + +- **Gebruiker (Burger / Bedrijf)** – eindgebruiker die zich authenticeert met DigiD, eHerkenning of eIDAS. +- **Client (Portal / Mobile / SPA)** – applicatie die namens de gebruiker API-calls doet naar Berichten Services. +- **Identity Provider (IdP)** – OIDC en eIDAS-compatible of nationale IdP (DigiD/eHerkenning). Biedt ID Token, Access Token, JWKS. +- **Federation Trust Registry / Metadata Service** – centrale of federatieve trustlijst met IdP’s, clients en services. +- **Token Exchange / Gateway (optioneel)** – wisselt tokens om voor resource-specifieke tokens ([RFC 8693](https://www.rfc-editor.org/rfc/rfc8693.html)). +- **Berichten Service (Resource Server)** – valideert tokens en bepaalt autorisatie. +- **Policy Engine (OPA/XACML)** – beoordeelt toegangsregels. + +## Architectuurdiagram + +Er zijn verschillende mogelijkheden om op federatieve wijze toegang tot services te verlenen, waarvan twee hoofdopties (beiden eIDAS 2.0 compliant); + +### Optie 1: Resource Server vertrouwt direct op de IdP (klassieke OIDC) + +Klassieke OIDC validatie met trusts tussen elke Berichten Service en een centrale IdP. De *Token Exchange Service* (TE) vraagt een nieuw access token aan bij dezelfde IdP, maar dan met: + +- een andere `aud` (audience): de URI van de specifieke Berichten Service; +- een beperkte `scope` + +De Berichten Service (BSA / BSB) doet daarna: + +- Controleer de signature van het token via de JWKS van de IdP +- Controleer of `aud` overeenkomt met zijn eigen identifier +- Controleer `exp`, `iss` en optioneel `azp` (authorized party) +- Daarna autorisatie via de **Policy Engine** + +> **TLDR**; Dit is eenvoudig, omdat alle Resource Servers de centrale IdP vertrouwen + +```mermaid +flowchart LR + subgraph GebruikerSide["Gebruiker & Client"] + U[Gebruiker] + C[Client] + end + + subgraph IdP["Identity Provider"] + IdPMain["OpenID Connect IdP
    (DigiD/eHerkenning/eIDAS)"] + JWKS[(JWKS Endpoint)] + end + + subgraph Federation["Federation Layer"] + TE[Token Exchange Service] + PE[Policy Engine] + end + + subgraph Resources["Berichten Services"] + B1[Berichten Service A] + B2[Berichten Service B] + end + + %% --- Authentication & Token Issuance --- + U -->|Login via browser redirect| IdPMain + C -->|OIDC Auth Code Flow + PKCE| IdPMain + IdPMain -->|ID Token + Access Token| C + + %% --- Resource Access --- + C -->|Bearer Access Token| B1 + C -->|Bearer Access Token| B2 + + %% --- Optional Token Exchange --- + C -->|"Token Exchange Request (RFC 8693)"| TE + TE -->|Validate subject_token| IdPMain + TE -->|"Issue resource-scoped token (aud = BS-A/BS-B)"| C + + %% --- Validation & Authorization --- + B1 -->|Validate token via JWKS| IdPMain + B2 -->|Validate token via JWKS| IdPMain + B1 -->|Authorization decision| PE + B2 -->|Authorization decision| PE +``` + +### Optie 2: Federatieve validatie (trust via Trust Registry) + +In een meer *federatieve* opzet (zoals eIDAS 2.0 en conform GDI) is er geen directe koppeling tussen elke Berichten Service en een centrale IdP, maar een Trust Registry die de services vertrouwen: + +- De *Trust Registry* (TR) houdt biju welke issuers geldig zijn en hun JWKS locaties. +- Een Resource Server (zoals de Berichten Service) hoeft de IdP niet rechtstreeks te kennen; ze haalt de *issuer metadata* (inclusief JWKS URL) uit de Trust Registry +- Vervolgens valideert de Resource Server het token zelf (signature & claims) +- De *Trust Registry* kan optioneel caching en key rollover afhandelen + +> **TLDR**; Dit model maakt het mogelijk dat meerdere IdP's meedoen in de federatie, zonder centrale afhankelijkheid + + +```mermaid +flowchart LR + subgraph GebruikerSide["Gebruiker & Client"] + U[Gebruiker] + C[Client] + end + + subgraph IdP["Identity Provider"] + IdPMain["OpenID Connect IdP
    (DigiD/eHerkenning/eIDAS)"] + JWKS[(JWKS Endpoint)] + end + + subgraph Federation["Federation Layer"] + TR[Trust Registry / Metadata Service] + TE[Token Exchange Service] + PE[Policy Engine] + end + + subgraph Resources["Berichten Services"] + B1[Berichten Service A] + B2[Berichten Service B] + end + + %% --- Authentication & Token Issuance --- + U -->|Login via browser redirect| IdPMain + C -->|OIDC Auth Code Flow + PKCE| IdPMain + IdPMain -->|ID Token + Access Token| C + + %% --- Resource Access via Federation --- + C -->|"Token Exchange Request (RFC 8693)"| TE + TE -->|Validate subject_token| IdPMain + TE -->|"Issue resource-scoped token (aud = BS-A/BS-B)"| C + + %% --- Trust Registry Distribution --- + TR -->|Publishes issuer metadata + JWKS URLs| B1 + TR -->|Publishes issuer metadata + JWKS URLs| B2 + TR -->|Publishes issuer metadata + JWKS URLs| TE + + %% --- Token Validation --- + C -->|Bearer Resource Token| B1 + C -->|Bearer Resource Token| B2 + B1 -->|"Validate signature using JWKS (from TR)"| IdPMain + B2 -->|"Validate signature using JWKS (from TR)"| IdPMain + + %% --- Authorization --- + B1 -->|Authorization decision| PE + B2 -->|Authorization decision| PE + +``` + +## Sequence diagram (optie 2) + +```mermaid +sequenceDiagram + participant U as Gebruiker + participant C as Client (SPA / Portal) + participant IdP as Identity Provider (DigiD/eHerkenning/eIDAS) + participant FR as Trust Registry + participant BS as Berichten Service + + U->>C: Navigeert naar client + C->>IdP: Authorization Code Flow (OIDC + PKCE) + IdP->>C: Authorization Code + C->>IdP: Token Request (code, verifier) + IdP->>C: ID Token + Access Token (JWT) + C->>BS: GET /api/messages (Authorization: Bearer ) + BS->>FR: Vraag trusted issuers (metadata) + BS->>IdP: Haal JWKS en valideer handtekening + BS->>BS: Autorisatie via Policy Engine (OPA) + BS-->>C: JSON Response met berichtenlijst +``` + +**Voorbeeld Access Token (JWT payload):** + +```json +{ + "iss": "https://login.mijnoverheid.nl", + "aud": ["https://berichten.belastingdienst.nl"], + "sub": "urn:person:NL:BSN:999999999", + "acr": "urn:etoegang:core:assurance-class:loa4", + "scope": "messages.read", + "exp": 1730100000, + "iat": 1730096400, + "client_id": "mijnoverheid-app", + "consent": true +} +``` + +**Voorbeeld HTTP-aanroep:** + +```http +GET /api/messages HTTP/1.1 +Host: berichten.belastingdienst.nl +Authorization: Bearer eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9... +Accept: application/json +``` + +--- + +## Management-samenvatting (A4) + +### Doel + +Het federatief berichtenmagazijn maakt het mogelijk dat burgers en bedrijven **rechtstreeks** hun berichten kunnen ophalen bij overheidsorganisaties, zonder centrale bottleneck. De gebruiker logt veilig in via DigiD, eHerkenning of eIDAS, waarna zijn identiteit met beveiligde tokens wordt doorgegeven aan de afzonderlijke Berichten Services. + +### Waarom federatief? + +* **Schaalbaarheid:** geen centrale berichtenhub die alles aggregeert. +* **Autonomie:** elke organisatie behoudt beheer over eigen berichten en beleid. +* **Veiligheid:** tokens en trust worden cryptografisch gevalideerd via eIDAS-standaarden. +* **Europese interoperabiliteit:** sluit aan op eIDAS 2.0 en toekomstige European Digital Identity Wallets. + +### Hoe werkt het? + +1. De gebruiker logt in via een erkende IdP (DigiD, eHerkenning, eIDAS). +2. De applicatie ontvangt een digitaal ondertekend toegangstoken. +3. Dit token wordt gebruikt om direct de Berichten Services van deelnemende organisaties aan te roepen. +4. Elke service valideert de handtekening en controleert of de gebruiker bevoegd is. +5. De response (berichtenlijst of notificatie) wordt direct aan de gebruiker getoond. + +### Belangrijkste bouwstenen + +| Component | Beschrijving | +| --------------------------- | -------------------------------------------------------------------------------- | +| **Identity Provider (IdP)** | Zorgt voor betrouwbare inlog en identiteitsverklaring (DigiD/eHerkenning/eIDAS). | +| **Trust Registry** | Beheert welke IdP’s, clients en services elkaar vertrouwen. | +| **Berichten Service** | Verwerkt de berichtenaanvragen en valideert tokens. | +| **Policy Engine** | Past regels toe (wie mag wat zien). | +| **Token Exchange** | (Optioneel) maakt tokens geldig voor specifieke services. | + +### Veiligheidsprincipes + +* Alleen ondertekende tokens van erkende IdP’s. +* Geen centrale opslag van persoonsgegevens. +* Transparant en controleerbaar via federatief trustmodel. +* Aansluitend op eIDAS 2.0 LoA- en metadata-standaarden. + +### Conclusie + +Deze federatieve aanpak combineert **veiligheid**, **autonomie** en **interoperabiliteit**. Het is een toekomstvaste oplossing die volledig aansluit bij eIDAS 2.0 en de European Digital Identity-architectuur, zonder centrale kwetsbaarheden of schaalproblemen. + +--- + +## Mogelijke vervolgstappen + +* Definieer Trust Registry API en governance-model. +* Maak proof-of-concept met 2 Berichten Services, één IdP en tokenvalidatie. +* Test met eHerkenning LoA_HIGH en eIDAS cross-border login. +* Documenteer metadata-profielen volgens eIDAS 2.0 schema's. diff --git a/structurizr/decisions/0007-logboek-dataverwer.md b/structurizr/decisions/0007-logboek-dataverwer.md new file mode 100644 index 0000000..b94c539 --- /dev/null +++ b/structurizr/decisions/0007-logboek-dataverwer.md @@ -0,0 +1,61 @@ +# 7. Logboek dataverwerking + +Date: 2025-10-28 + +## Status + +Declined + +## Context + +### Bevindingen Logboek Dataverwerking Prototype + +#### Prototype Implementatie + +Als onderdeel van ons onderzoek hebben we een Java-package ontwikkeld die OpenTelemetry traces en spans omzet naar een vooraf gedefinieerd dataformat voor logboekverwerking. Deze data wordt vervolgens opgeslagen in een ClickHouse database. Tijdens de implementatie en het testen van deze standaard hebben we verschillende uitdagingen geïdentificeerd. + +#### Kritische Knelpunten bij Federatieve Implementatie + +Voor organisaties die procesflows willen koppelen over hun eigen systemen en externe partijen heen, is een federatieve architectuur noodzakelijk. Binnen dit domein hebben we significante uitdagingen geconstateerd waarvoor momenteel geen uitgewerkte standaard beschikbaar is: + +##### 1. Performance-uitdagingen bij het ophalen van span-hiërarchieën + +Bij het reconstrueren van een complete trace moet worden vastgesteld of een span child-spans heeft. Deze kunnen zich zowel intern binnen het eigen systeem bevinden als bij externe partijen. Om de aanwezigheid van child-spans te verifiëren, moet er bij alle mogelijke logboek-verwerkingsservices worden gecontroleerd of deze een span bevatten met het betreffende span-ID als parent-ID. +Dit proces moet recursief worden herhaald voor elke gevonden child-span, wat theoretisch kan resulteren in honderden niveaus diep. Bij elk niveau moeten opnieuw calls worden uitgevoerd naar alle potentiële dataverwerkingsservices, wat leidt tot onacceptabele performance-overhead. + +##### 2. Register LDV's + +Er moet een trust registry komen met welke organisatie er allemaal een LDV service heeft draaien zodat je weet welke organisaties je uberhaupt kan bevragen. + +##### 3. Inefficiënte datastructuur voor parent-referenties + +De foreign_span_id (parent-referentie) wordt momenteel opgeslagen als JSON-string binnen de attributes. Bij het doorzoeken van spans vereist dit telkens het parsen van JSON-data om toegang te krijgen tot deze enkele waarde. Dit leidt tot aanzienlijke performance-problemen, met name bij grootschalige implementaties. + +#### Conclusie en Aanbevelingen + +Op basis van bovenstaande bevindingen concluderen we dat een federatieve implementatie van logboek-dataverwerking conform de huidige standaard niet schaalbaar is vanuit performance-perspectief. + +##### Mogelijke oplossingen + +1. Een mogelijke optimalisatie zou zijn om in de span-metadata te registreren naar welke externe partij de communicatie plaatsvindt. Deze informatie maakt momenteel echter geen deel uit van de LDV-standaard, waardoor dit niet op uniforme wijze kan worden geïmplementeerd. + +2. Een overkoepelend parent trace id waarmee je alle foreign spans direct kan ophalen ipv het gebruik van een parent_span id in een json veld. dit voorkomt dat je recursief alle childs hoeft op te halen. + +##### Aanbevolen aanpak: + +###### Binnen eigen context (bijvoorbeeld MOZa): + +Gebruik de standaard OpenTelemetry-implementatie voor het visualiseren van flows binnen de eigen systeemgrenzen. + +###### Opslagoplossing: + +Kies voor een gevestigde, productie-klare oplossing zoals Elastic APM voor het opslaan en analyseren van telemetrie-data, in plaats van een custom-implementatie. +Voor cross-organisatie trace-analyse raden we aan te wachten tot er een uitgewerkte federatieve standaard beschikbaar komt die bovenstaande performance-uitdagingen adresseert. + +## Decision + +Na nader overleg met het team van LDV op het Fieldlab 2025 bestaanszekerheid bij levensgebeurtenissen hebben geconcludeerd dat sommige van onze conclusie incorrect waren, en andere hebben wij in samenwerking kunnen rechttrekken. Daarom hebben wij de beslissing genomen LDV te implementeren. Zie ADR 0010-LDV-Implementatie voor meer informatie. + +## Consequences + +ADR 0010-ldv-implementatie. diff --git a/structurizr/decisions/0008-Data Eigenaar.md b/structurizr/decisions/0008-Data Eigenaar.md new file mode 100644 index 0000000..0ad20e0 --- /dev/null +++ b/structurizr/decisions/0008-Data Eigenaar.md @@ -0,0 +1,141 @@ +# 8. Eigenaar van contactvoorkeur-data + +Date: 2025-11-13 + +## Status + +Accepted + +## Context + +Binnen de profielservice worden contactvoorkeuren vastgelegd, zoals e-mailadressen, telefoonnummers en (woon)adressen. +Deze gegevens kunnen persoonsgegevens bevatten en vallen daardoor onder de bescherming van de AVG. + +In de huidige modellering zijn er twee relevante rollen: + +- **Ontvangende Partij:** de partij (persoon of organisatie) die het contactmiddel beheert of bezit. +- **Betreffende Partij:** de partij (persoon of organisatie) waarop de communicatie betrekking heeft. + +De vraag is wie in juridisch en functioneel opzicht de ‘eigenaar’ is van de contactvoorkeur: +Is dat de Ontvangende Partij (die het contactmiddel beheert), of de Betreffende Partij (waarvoor de contactvoorkeur geldt)? + +## Scenario beschrijving + +De RVO wil contact opnemen met **HoutBv**, waarvan het KVK-nummer _123_ is. +In de profielservice staat bij HoutBv het e-mailadres **jan@gmail.com** als contactvoorkeur. +Jan Jansen is de persoon achter dit e-mailadres en werkt namens HoutBv. + +In dit scenario: + +- **Ontvangende Partij:** Jan Jansen (de partij die het e-mailadres beheert) +- **Betreffende Partij:** HoutBv (de partij waarvoor contact wordt opgenomen) + +De kernvraag is dus: + +- Is de contactvoorkeur van **Jan Jansen**, omdat het zijn e-mailadres is? (**Optie 1**) +- Of is de contactvoorkeur van **HoutBv**, omdat het de organisatie is waarmee contact moet worden opgenomen? (**Optie 2**) + +> Een kanttekening is hier dat kijkend naar de profielservice voor burgers personen en organisaties beide rollen kunnen vervullen. + +### Architectuurdiagram + +#### Optie 1 - Ontvangende Partij is eigenaar. + +_(de persoon of organisatie die het contactmiddel bezit is eigenaar)_ + +![OntvangendePartijEigenaar](./images/OntvangendePartijEigenaar.png "OntvangendePartijEigenaar") + +
    + Zie mermaid code + ```mermaid + graph TD + %% Personen / Bedrijven + P0["PARTIJ ID 0
    Persoon: Hans Eigenaar
    Identificatie: BSN-456789"] + P1["PARTIJ ID 1
    Persoon: Jan Jansen
    Identificatie: BSN-123456789"] + P2["PARTIJ ID 2
    Bedrijf: Steen BV
    Identificatie: KVK-112233"] + P3["PARTIJ ID 3
    Bedrijf: Hout Bv NV
    Identificatie: KVK-445566"] + + %% Contactvoorkeuren van Jan + C0["CONTACTVOORKEUR ID 0
    Scope: Alles
    Type: EMAIL
    Waarde: hans@SteenBv.nl"] + C1["CONTACTVOORKEUR ID 1
    Scope: Belasting
    Type: EMAIL
    Waarde: jan@SteenBv.nl"] + C2["CONTACTVOORKEUR ID 2
    Scope: Alles
    Type: EMAIL
    Waarde: jan@gmail.com"] + C3["CONTACTVOORKEUR ID 3
    Scope: Belasting
    Type: EMAIL
    Waarde: jan@HoutBv.nl"] + + %% Contactvoorkeur van bedrijf + C4["CONTACTVOORKEUR ID 4
    Scope: Alles
    Type: EMAIL
    Waarde: info@HoutBv.com"] + + %% Relaties van Jan + P0 -->|Eigenaar van| C0 + P1 -->|Eigenaar van| C1 + C0 -->|Betreffend Partij| P2 + C1 -->|Betreffend Partij| P2 + + P1 -->|Eigenaar van| C2 + + P1 -->|Eigenaar van| C3 + C3 -->|Betreffend Partij| P3 + + + %% Relatie van Hout Bv zelf + P3 -->|Eigenaar van| C4 + ``` + +
    + +#### Optie 2 - Betreffende Partij is eigenaar. + +_(de persoon of organisatie waar het contactmiddel betrekking op heeft is eigenaar)_ + +![BetreffendePartijEigenaar](./images/BetreffendePartijEigenaar.png "BetreffendePartijEigenaar") + +
    + Zie mermaid code + + ```mermaid + graph TD + %% Personen / Bedrijven + P1["PARTIJ ID 1
    Persoon: Jan Jansen
    Identificatie: BSN-123456789"] + P2["PARTIJ ID 2
    Bedrijf: Hout Bv NV
    Identificatie: KVK-445566"] + + %% Contactvoorkeuren van Jan + C1["CONTACTVOORKEUR ID 1
    Scope: Belasting
    Type: EMAIL
    Waarde: jan_BD@gmail.nl"] + C2["CONTACTVOORKEUR ID 2
    Scope: Alles
    Type: EMAIL
    Waarde: jan@gmail.com"] + + %% Contactvoorkeur van bedrijf + C3["CONTACTVOORKEUR ID 3
    Scope: Alles
    Type: EMAIL
    Waarde: info@HoutBv.nl"] + C4["CONTACTVOORKEUR ID 4
    Scope: Belasting
    Type: EMAIL
    Waarde: BD@HoutBv.nl"] + C5["CONTACTVOORKEUR ID 5
    Scope: Belasting
    Type: EMAIL
    Waarde: jan_BD@gmail.nl"] + + %% Relaties van Jan + P1 -->|Eigenaar van| C1 + P1 -->|Eigenaar van| C2 + + + %% Relatie van Hout Bv zelf + P2 -->|Eigenaar van| C3 + P2 -->|Eigenaar van| C4 + P2 -->|Eigenaar van| C5 + ``` + +
    + +### Consequenties + +**Optie 1 – Ontvangende Partij is eigenaar** + +1. Wanneer een partij mandaat verliest, wordt de contactvoorkeur ongeldig. Omdat de contactvoorkeur eigendom is van de partij die het mandaat verloor, moet die partij zelf de voorkeur aanpassen. Alternatief is dat de profielservice een seintje ontvangt van de mandaatservice (bijv. via een queue). +2. De partij waarmee de dienstverlener contact wil opnemen, kan niet direct inzien via welke kanalen dit gebeurt. Zij hebben partij X mandaat gegeven, maar weten niet hoe partij X benaderd wil worden. _(Ze kunnen wel zichzelf of meerdere partijen als ontvanger opnemen, zodat de dienstverlener naar beide kan sturen.)_ +3. Ondersteunt scenario’s waarin één contactmiddel namens meerdere betreffende partijen wordt gebruikt, zonder dat het automatisch geldt voor alle communicatie. +4. AVG minder privacygevoelig omdat de persoonsgegevens harder gekoppeld zijn aan de persoon van wie deze zijn. +5. Complexere implementatie. + +**Optie 2 – Betreffende Partij is eigenaar** + +1. Persoonsgegevens kunnen opgeslagen zijn onder het ‘eigendom’ van een andere partij. Dit brengt risico’s met zich mee rond verwerking van persoonsgegevens zonder expliciete toestemming. +2. Lastiger om één contactvoorkeur voor meerdere partijen te hergebruiken. +3. Eenvoudigere implementatie. +4. Realistischer in uitwerking qua hoe ondernemers & burgers zouden omgaan met de omgeving. + +### Conclusie + +Wij hebben ervoor gekozen om in deze fase optie 2 te implementeren, omdat wij verwachten dat deze oplossing beter aansluit bij de ondernemers en burgers die van de profielservice gebruik zullen maken. Wel geldt hierbij de kanttekening dat per contactgegeven een taalvoorkeur moet worden vastgelegd, omdat deze kan afwijken van de taalvoorkeur van de partij waaraan het contactgegeven is gekoppeld. diff --git a/structurizr/decisions/0009-nl-design-system-implementeren.md b/structurizr/decisions/0009-nl-design-system-implementeren.md new file mode 100644 index 0000000..2f6fd04 --- /dev/null +++ b/structurizr/decisions/0009-nl-design-system-implementeren.md @@ -0,0 +1,19 @@ +# 9. NL Design System implementeren + +Date: 2025-11-17 + +## Status + +Proposed + +## Context + +The issue motivating this decision, and any context that influences or constrains the decision. + +## Decision + +The change that we're proposing or have agreed to implement. + +## Consequences + +What becomes easier or more difficult to do and any risks introduced by the change that will need to be mitigated. diff --git a/structurizr/decisions/0010-ldv-implementatie.md b/structurizr/decisions/0010-ldv-implementatie.md new file mode 100644 index 0000000..584217c --- /dev/null +++ b/structurizr/decisions/0010-ldv-implementatie.md @@ -0,0 +1,28 @@ +# 10. Logboek dataverwerking implementeren + +Date: 2025-12-01 + +## Status + +Proposed + +## Context + +Het Logboek Dataverwerking (LDV) is een standaard van Logius die gericht is op het vergroten van de controleerbaarheid van de overheid. Dit betekent dat overheidsorganisaties hun handelingen en besluiten altijd moeten kunnen toelichten, aan burgers, bedrijven en andere overheidsinstanties. +Het LDV-standaard helpt hierbij door een uniforme manier te bieden om vast te leggen welke gegevens van burgers en bedrijven worden verwerkt, hoe dit gebeurt en om welke redenen. + +### Fieldlab 2025 Bestaandzekerheid bij levensgebeurtenissen + +Bij dit fieldlab hebben wij nauw samengewerkt met het team van LDV. Hier liepen wij tegen diverse hindernissen aan in het standaard die we samen hebben kunnen oplossen. Uiteindelijk hebben wij hiervoor een open-source java package ontwikkeld waarmee wij, of andere geintereseerde, makkelijk het LDV standaard kunnen implementeren. De java package staat op [Github](https://github.com/MinBZK/moza-logboekdataverwerking) +Ook heeft LDV zelf deze package toegelicht hier: [developer.overheid.nl - jakarta](https://developer.overheid.nl/kennisbank/data/standaarden/logboek-dataverwerkingen/implementaties/jakarta) + +## Decision + +MOZa heeft de beslissing genomen om Logboek dataverwerking te implementeren in de profiel service. +Hiernaast zullen wij ook aan de gebruiker de logging gaan tonen in het MOZa portaal, dit houdt in dat wanneer deze inlogt er een pagina of widget beschikbaar zal zijn waar de geschiedenis van bevragingen te zien is. + +## Consequences + +De consequenties hiervan zijn driedelig. Ten eerste zoals benoemd, hebben wij hiervoor een java package gemaakt en geupload naar de maven repository, enige onderhoud hiervan zal op kort termijn nog nodig zijn. De tweede consequentie is dat wij een Clickhouse database neer hebben moeten zetten in onze omgeving waarnaar deze logging kan worden gestuurd. Hiernaast zullen wij het MOZa portaal moeten gaan aanpassen zodat deze logging kan ophalen en tonen aan ingelogde gebruikers. + +Als laatste zullen wij in de toekomst nog met het team van LDV in overleg om onze logging open te stellen aan de inzichte API, maar die is nog in development. diff --git a/structurizr/decisions/images/BetreffendePartijEigenaar.png b/structurizr/decisions/images/BetreffendePartijEigenaar.png new file mode 100644 index 0000000..4d18199 Binary files /dev/null and b/structurizr/decisions/images/BetreffendePartijEigenaar.png differ diff --git a/structurizr/decisions/images/EventSourceRead.png b/structurizr/decisions/images/EventSourceRead.png new file mode 100644 index 0000000..e538c70 Binary files /dev/null and b/structurizr/decisions/images/EventSourceRead.png differ diff --git a/structurizr/decisions/images/OntvangendePartijEigenaar.png b/structurizr/decisions/images/OntvangendePartijEigenaar.png new file mode 100644 index 0000000..9940c51 Binary files /dev/null and b/structurizr/decisions/images/OntvangendePartijEigenaar.png differ diff --git a/structurizr/decisions/images/ProfielTijdlijn.png b/structurizr/decisions/images/ProfielTijdlijn.png new file mode 100644 index 0000000..aa7a99d Binary files /dev/null and b/structurizr/decisions/images/ProfielTijdlijn.png differ diff --git a/structurizr/decisions/images/ReverseDeltaRead.png b/structurizr/decisions/images/ReverseDeltaRead.png new file mode 100644 index 0000000..5e2aced Binary files /dev/null and b/structurizr/decisions/images/ReverseDeltaRead.png differ diff --git a/structurizr/decisions/images/Scenario2.png b/structurizr/decisions/images/Scenario2.png new file mode 100644 index 0000000..3c58269 Binary files /dev/null and b/structurizr/decisions/images/Scenario2.png differ diff --git a/structurizr/decisions/images/Scenario8.png b/structurizr/decisions/images/Scenario8.png new file mode 100644 index 0000000..a98376e Binary files /dev/null and b/structurizr/decisions/images/Scenario8.png differ diff --git a/structurizr/decisions/images/SimpelAuditCRUD.png b/structurizr/decisions/images/SimpelAuditCRUD.png new file mode 100644 index 0000000..8c4e46a Binary files /dev/null and b/structurizr/decisions/images/SimpelAuditCRUD.png differ diff --git a/structurizr/img/structurizr-banner-dark.png b/structurizr/img/structurizr-banner-dark.png new file mode 100644 index 0000000..822f9ba Binary files /dev/null and b/structurizr/img/structurizr-banner-dark.png differ diff --git a/structurizr/img/structurizr-banner-light.png b/structurizr/img/structurizr-banner-light.png new file mode 100644 index 0000000..a9a0b0a Binary files /dev/null and b/structurizr/img/structurizr-banner-light.png differ diff --git a/structurizr/js/backbone-1.4.1.js b/structurizr/js/backbone-1.4.1.js new file mode 100644 index 0000000..fd64012 --- /dev/null +++ b/structurizr/js/backbone-1.4.1.js @@ -0,0 +1,2106 @@ +// Backbone.js 1.4.1 + +// (c) 2010-2022 Jeremy Ashkenas and DocumentCloud +// Backbone may be freely distributed under the MIT license. +// For all details and documentation: +// http://backbonejs.org + +(function(factory) { + + // Establish the root object, `window` (`self`) in the browser, or `global` on the server. + // We use `self` instead of `window` for `WebWorker` support. + var root = typeof self == 'object' && self.self === self && self || + typeof global == 'object' && global.global === global && global; + + // Set up Backbone appropriately for the environment. Start with AMD. + if (typeof define === 'function' && define.amd) { + define(['underscore', 'jquery', 'exports'], function(_, $, exports) { + // Export global even in AMD case in case this script is loaded with + // others that may still expect a global Backbone. + root.Backbone = factory(root, exports, _, $); + }); + + // Next for Node.js or CommonJS. jQuery may not be needed as a module. + } else if (typeof exports !== 'undefined') { + var _ = require('underscore'), $; + try { $ = require('jquery'); } catch (e) {} + factory(root, exports, _, $); + + // Finally, as a browser global. + } else { + root.Backbone = factory(root, {}, root._, root.jQuery || root.Zepto || root.ender || root.$); + } + +})(function(root, Backbone, _, $) { + + // Initial Setup + // ------------- + + // Save the previous value of the `Backbone` variable, so that it can be + // restored later on, if `noConflict` is used. + var previousBackbone = root.Backbone; + + // Create a local reference to a common array method we'll want to use later. + var slice = Array.prototype.slice; + + // Current version of the library. Keep in sync with `package.json`. + Backbone.VERSION = '1.4.1'; + + // For Backbone's purposes, jQuery, Zepto, Ender, or My Library (kidding) owns + // the `$` variable. + Backbone.$ = $; + + // Runs Backbone.js in *noConflict* mode, returning the `Backbone` variable + // to its previous owner. Returns a reference to this Backbone object. + Backbone.noConflict = function() { + root.Backbone = previousBackbone; + return this; + }; + + // Turn on `emulateHTTP` to support legacy HTTP servers. Setting this option + // will fake `"PATCH"`, `"PUT"` and `"DELETE"` requests via the `_method` parameter and + // set a `X-Http-Method-Override` header. + Backbone.emulateHTTP = false; + + // Turn on `emulateJSON` to support legacy servers that can't deal with direct + // `application/json` requests ... this will encode the body as + // `application/x-www-form-urlencoded` instead and will send the model in a + // form param named `model`. + Backbone.emulateJSON = false; + + // Backbone.Events + // --------------- + + // A module that can be mixed in to *any object* in order to provide it with + // a custom event channel. You may bind a callback to an event with `on` or + // remove with `off`; `trigger`-ing an event fires all callbacks in + // succession. + // + // var object = {}; + // _.extend(object, Backbone.Events); + // object.on('expand', function(){ alert('expanded'); }); + // object.trigger('expand'); + // + var Events = Backbone.Events = {}; + + // Regular expression used to split event strings. + var eventSplitter = /\s+/; + + // A private global variable to share between listeners and listenees. + var _listening; + + // Iterates over the standard `event, callback` (as well as the fancy multiple + // space-separated events `"change blur", callback` and jQuery-style event + // maps `{event: callback}`). + var eventsApi = function(iteratee, events, name, callback, opts) { + var i = 0, names; + if (name && typeof name === 'object') { + // Handle event maps. + if (callback !== void 0 && 'context' in opts && opts.context === void 0) opts.context = callback; + for (names = _.keys(name); i < names.length ; i++) { + events = eventsApi(iteratee, events, names[i], name[names[i]], opts); + } + } else if (name && eventSplitter.test(name)) { + // Handle space-separated event names by delegating them individually. + for (names = name.split(eventSplitter); i < names.length; i++) { + events = iteratee(events, names[i], callback, opts); + } + } else { + // Finally, standard events. + events = iteratee(events, name, callback, opts); + } + return events; + }; + + // Bind an event to a `callback` function. Passing `"all"` will bind + // the callback to all events fired. + Events.on = function(name, callback, context) { + this._events = eventsApi(onApi, this._events || {}, name, callback, { + context: context, + ctx: this, + listening: _listening + }); + + if (_listening) { + var listeners = this._listeners || (this._listeners = {}); + listeners[_listening.id] = _listening; + // Allow the listening to use a counter, instead of tracking + // callbacks for library interop + _listening.interop = false; + } + + return this; + }; + + // Inversion-of-control versions of `on`. Tell *this* object to listen to + // an event in another object... keeping track of what it's listening to + // for easier unbinding later. + Events.listenTo = function(obj, name, callback) { + if (!obj) return this; + var id = obj._listenId || (obj._listenId = _.uniqueId('l')); + var listeningTo = this._listeningTo || (this._listeningTo = {}); + var listening = _listening = listeningTo[id]; + + // This object is not listening to any other events on `obj` yet. + // Setup the necessary references to track the listening callbacks. + if (!listening) { + this._listenId || (this._listenId = _.uniqueId('l')); + listening = _listening = listeningTo[id] = new Listening(this, obj); + } + + // Bind callbacks on obj. + var error = tryCatchOn(obj, name, callback, this); + _listening = void 0; + + if (error) throw error; + // If the target obj is not Backbone.Events, track events manually. + if (listening.interop) listening.on(name, callback); + + return this; + }; + + // The reducing API that adds a callback to the `events` object. + var onApi = function(events, name, callback, options) { + if (callback) { + var handlers = events[name] || (events[name] = []); + var context = options.context, ctx = options.ctx, listening = options.listening; + if (listening) listening.count++; + + handlers.push({callback: callback, context: context, ctx: context || ctx, listening: listening}); + } + return events; + }; + + // An try-catch guarded #on function, to prevent poisoning the global + // `_listening` variable. + var tryCatchOn = function(obj, name, callback, context) { + try { + obj.on(name, callback, context); + } catch (e) { + return e; + } + }; + + // Remove one or many callbacks. If `context` is null, removes all + // callbacks with that function. If `callback` is null, removes all + // callbacks for the event. If `name` is null, removes all bound + // callbacks for all events. + Events.off = function(name, callback, context) { + if (!this._events) return this; + this._events = eventsApi(offApi, this._events, name, callback, { + context: context, + listeners: this._listeners + }); + + return this; + }; + + // Tell this object to stop listening to either specific events ... or + // to every object it's currently listening to. + Events.stopListening = function(obj, name, callback) { + var listeningTo = this._listeningTo; + if (!listeningTo) return this; + + var ids = obj ? [obj._listenId] : _.keys(listeningTo); + for (var i = 0; i < ids.length; i++) { + var listening = listeningTo[ids[i]]; + + // If listening doesn't exist, this object is not currently + // listening to obj. Break out early. + if (!listening) break; + + listening.obj.off(name, callback, this); + if (listening.interop) listening.off(name, callback); + } + if (_.isEmpty(listeningTo)) this._listeningTo = void 0; + + return this; + }; + + // The reducing API that removes a callback from the `events` object. + var offApi = function(events, name, callback, options) { + if (!events) return; + + var context = options.context, listeners = options.listeners; + var i = 0, names; + + // Delete all event listeners and "drop" events. + if (!name && !context && !callback) { + for (names = _.keys(listeners); i < names.length; i++) { + listeners[names[i]].cleanup(); + } + return; + } + + names = name ? [name] : _.keys(events); + for (; i < names.length; i++) { + name = names[i]; + var handlers = events[name]; + + // Bail out if there are no events stored. + if (!handlers) break; + + // Find any remaining events. + var remaining = []; + for (var j = 0; j < handlers.length; j++) { + var handler = handlers[j]; + if ( + callback && callback !== handler.callback && + callback !== handler.callback._callback || + context && context !== handler.context + ) { + remaining.push(handler); + } else { + var listening = handler.listening; + if (listening) listening.off(name, callback); + } + } + + // Replace events if there are any remaining. Otherwise, clean up. + if (remaining.length) { + events[name] = remaining; + } else { + delete events[name]; + } + } + + return events; + }; + + // Bind an event to only be triggered a single time. After the first time + // the callback is invoked, its listener will be removed. If multiple events + // are passed in using the space-separated syntax, the handler will fire + // once for each event, not once for a combination of all events. + Events.once = function(name, callback, context) { + // Map the event into a `{event: once}` object. + var events = eventsApi(onceMap, {}, name, callback, this.off.bind(this)); + if (typeof name === 'string' && context == null) callback = void 0; + return this.on(events, callback, context); + }; + + // Inversion-of-control versions of `once`. + Events.listenToOnce = function(obj, name, callback) { + // Map the event into a `{event: once}` object. + var events = eventsApi(onceMap, {}, name, callback, this.stopListening.bind(this, obj)); + return this.listenTo(obj, events); + }; + + // Reduces the event callbacks into a map of `{event: onceWrapper}`. + // `offer` unbinds the `onceWrapper` after it has been called. + var onceMap = function(map, name, callback, offer) { + if (callback) { + var once = map[name] = _.once(function() { + offer(name, once); + callback.apply(this, arguments); + }); + once._callback = callback; + } + return map; + }; + + // Trigger one or many events, firing all bound callbacks. Callbacks are + // passed the same arguments as `trigger` is, apart from the event name + // (unless you're listening on `"all"`, which will cause your callback to + // receive the true name of the event as the first argument). + Events.trigger = function(name) { + if (!this._events) return this; + + var length = Math.max(0, arguments.length - 1); + var args = Array(length); + for (var i = 0; i < length; i++) args[i] = arguments[i + 1]; + + eventsApi(triggerApi, this._events, name, void 0, args); + return this; + }; + + // Handles triggering the appropriate event callbacks. + var triggerApi = function(objEvents, name, callback, args) { + if (objEvents) { + var events = objEvents[name]; + var allEvents = objEvents.all; + if (events && allEvents) allEvents = allEvents.slice(); + if (events) triggerEvents(events, args); + if (allEvents) triggerEvents(allEvents, [name].concat(args)); + } + return objEvents; + }; + + // A difficult-to-believe, but optimized internal dispatch function for + // triggering events. Tries to keep the usual cases speedy (most internal + // Backbone events have 3 arguments). + var triggerEvents = function(events, args) { + var ev, i = -1, l = events.length, a1 = args[0], a2 = args[1], a3 = args[2]; + switch (args.length) { + case 0: while (++i < l) (ev = events[i]).callback.call(ev.ctx); return; + case 1: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1); return; + case 2: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2); return; + case 3: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2, a3); return; + default: while (++i < l) (ev = events[i]).callback.apply(ev.ctx, args); return; + } + }; + + // A listening class that tracks and cleans up memory bindings + // when all callbacks have been offed. + var Listening = function(listener, obj) { + this.id = listener._listenId; + this.listener = listener; + this.obj = obj; + this.interop = true; + this.count = 0; + this._events = void 0; + }; + + Listening.prototype.on = Events.on; + + // Offs a callback (or several). + // Uses an optimized counter if the listenee uses Backbone.Events. + // Otherwise, falls back to manual tracking to support events + // library interop. + Listening.prototype.off = function(name, callback) { + var cleanup; + if (this.interop) { + this._events = eventsApi(offApi, this._events, name, callback, { + context: void 0, + listeners: void 0 + }); + cleanup = !this._events; + } else { + this.count--; + cleanup = this.count === 0; + } + if (cleanup) this.cleanup(); + }; + + // Cleans up memory bindings between the listener and the listenee. + Listening.prototype.cleanup = function() { + delete this.listener._listeningTo[this.obj._listenId]; + if (!this.interop) delete this.obj._listeners[this.id]; + }; + + // Aliases for backwards compatibility. + Events.bind = Events.on; + Events.unbind = Events.off; + + // Allow the `Backbone` object to serve as a global event bus, for folks who + // want global "pubsub" in a convenient place. + _.extend(Backbone, Events); + + // Backbone.Model + // -------------- + + // Backbone **Models** are the basic data object in the framework -- + // frequently representing a row in a table in a database on your server. + // A discrete chunk of data and a bunch of useful, related methods for + // performing computations and transformations on that data. + + // Create a new model with the specified attributes. A client id (`cid`) + // is automatically generated and assigned for you. + var Model = Backbone.Model = function(attributes, options) { + var attrs = attributes || {}; + options || (options = {}); + this.preinitialize.apply(this, arguments); + this.cid = _.uniqueId(this.cidPrefix); + this.attributes = {}; + if (options.collection) this.collection = options.collection; + if (options.parse) attrs = this.parse(attrs, options) || {}; + var defaults = _.result(this, 'defaults'); + attrs = _.defaults(_.extend({}, defaults, attrs), defaults); + this.set(attrs, options); + this.changed = {}; + this.initialize.apply(this, arguments); + }; + + // Attach all inheritable methods to the Model prototype. + _.extend(Model.prototype, Events, { + + // A hash of attributes whose current and previous value differ. + changed: null, + + // The value returned during the last failed validation. + validationError: null, + + // The default name for the JSON `id` attribute is `"id"`. MongoDB and + // CouchDB users may want to set this to `"_id"`. + idAttribute: 'id', + + // The prefix is used to create the client id which is used to identify models locally. + // You may want to override this if you're experiencing name clashes with model ids. + cidPrefix: 'c', + + // preinitialize is an empty function by default. You can override it with a function + // or object. preinitialize will run before any instantiation logic is run in the Model. + preinitialize: function(){}, + + // Initialize is an empty function by default. Override it with your own + // initialization logic. + initialize: function(){}, + + // Return a copy of the model's `attributes` object. + toJSON: function(options) { + return _.clone(this.attributes); + }, + + // Proxy `Backbone.sync` by default -- but override this if you need + // custom syncing semantics for *this* particular model. + sync: function() { + return Backbone.sync.apply(this, arguments); + }, + + // Get the value of an attribute. + get: function(attr) { + return this.attributes[attr]; + }, + + // Get the HTML-escaped value of an attribute. + escape: function(attr) { + return _.escape(this.get(attr)); + }, + + // Returns `true` if the attribute contains a value that is not null + // or undefined. + has: function(attr) { + return this.get(attr) != null; + }, + + // Special-cased proxy to underscore's `_.matches` method. + matches: function(attrs) { + return !!_.iteratee(attrs, this)(this.attributes); + }, + + // Set a hash of model attributes on the object, firing `"change"`. This is + // the core primitive operation of a model, updating the data and notifying + // anyone who needs to know about the change in state. The heart of the beast. + set: function(key, val, options) { + if (key == null) return this; + + // Handle both `"key", value` and `{key: value}` -style arguments. + var attrs; + if (typeof key === 'object') { + attrs = key; + options = val; + } else { + (attrs = {})[key] = val; + } + + options || (options = {}); + + // Run validation. + if (!this._validate(attrs, options)) return false; + + // Extract attributes and options. + var unset = options.unset; + var silent = options.silent; + var changes = []; + var changing = this._changing; + this._changing = true; + + if (!changing) { + this._previousAttributes = _.clone(this.attributes); + this.changed = {}; + } + + var current = this.attributes; + var changed = this.changed; + var prev = this._previousAttributes; + + // For each `set` attribute, update or delete the current value. + for (var attr in attrs) { + val = attrs[attr]; + if (!_.isEqual(current[attr], val)) changes.push(attr); + if (!_.isEqual(prev[attr], val)) { + changed[attr] = val; + } else { + delete changed[attr]; + } + unset ? delete current[attr] : current[attr] = val; + } + + // Update the `id`. + if (this.idAttribute in attrs) { + var prevId = this.id; + this.id = this.get(this.idAttribute); + this.trigger('changeId', this, prevId, options); + } + + // Trigger all relevant attribute changes. + if (!silent) { + if (changes.length) this._pending = options; + for (var i = 0; i < changes.length; i++) { + this.trigger('change:' + changes[i], this, current[changes[i]], options); + } + } + + // You might be wondering why there's a `while` loop here. Changes can + // be recursively nested within `"change"` events. + if (changing) return this; + if (!silent) { + while (this._pending) { + options = this._pending; + this._pending = false; + this.trigger('change', this, options); + } + } + this._pending = false; + this._changing = false; + return this; + }, + + // Remove an attribute from the model, firing `"change"`. `unset` is a noop + // if the attribute doesn't exist. + unset: function(attr, options) { + return this.set(attr, void 0, _.extend({}, options, {unset: true})); + }, + + // Clear all attributes on the model, firing `"change"`. + clear: function(options) { + var attrs = {}; + for (var key in this.attributes) attrs[key] = void 0; + return this.set(attrs, _.extend({}, options, {unset: true})); + }, + + // Determine if the model has changed since the last `"change"` event. + // If you specify an attribute name, determine if that attribute has changed. + hasChanged: function(attr) { + if (attr == null) return !_.isEmpty(this.changed); + return _.has(this.changed, attr); + }, + + // Return an object containing all the attributes that have changed, or + // false if there are no changed attributes. Useful for determining what + // parts of a view need to be updated and/or what attributes need to be + // persisted to the server. Unset attributes will be set to undefined. + // You can also pass an attributes object to diff against the model, + // determining if there *would be* a change. + changedAttributes: function(diff) { + if (!diff) return this.hasChanged() ? _.clone(this.changed) : false; + var old = this._changing ? this._previousAttributes : this.attributes; + var changed = {}; + var hasChanged; + for (var attr in diff) { + var val = diff[attr]; + if (_.isEqual(old[attr], val)) continue; + changed[attr] = val; + hasChanged = true; + } + return hasChanged ? changed : false; + }, + + // Get the previous value of an attribute, recorded at the time the last + // `"change"` event was fired. + previous: function(attr) { + if (attr == null || !this._previousAttributes) return null; + return this._previousAttributes[attr]; + }, + + // Get all of the attributes of the model at the time of the previous + // `"change"` event. + previousAttributes: function() { + return _.clone(this._previousAttributes); + }, + + // Fetch the model from the server, merging the response with the model's + // local attributes. Any changed attributes will trigger a "change" event. + fetch: function(options) { + options = _.extend({parse: true}, options); + var model = this; + var success = options.success; + options.success = function(resp) { + var serverAttrs = options.parse ? model.parse(resp, options) : resp; + if (!model.set(serverAttrs, options)) return false; + if (success) success.call(options.context, model, resp, options); + model.trigger('sync', model, resp, options); + }; + wrapError(this, options); + return this.sync('read', this, options); + }, + + // Set a hash of model attributes, and sync the model to the server. + // If the server returns an attributes hash that differs, the model's + // state will be `set` again. + save: function(key, val, options) { + // Handle both `"key", value` and `{key: value}` -style arguments. + var attrs; + if (key == null || typeof key === 'object') { + attrs = key; + options = val; + } else { + (attrs = {})[key] = val; + } + + options = _.extend({validate: true, parse: true}, options); + var wait = options.wait; + + // If we're not waiting and attributes exist, save acts as + // `set(attr).save(null, opts)` with validation. Otherwise, check if + // the model will be valid when the attributes, if any, are set. + if (attrs && !wait) { + if (!this.set(attrs, options)) return false; + } else if (!this._validate(attrs, options)) { + return false; + } + + // After a successful server-side save, the client is (optionally) + // updated with the server-side state. + var model = this; + var success = options.success; + var attributes = this.attributes; + options.success = function(resp) { + // Ensure attributes are restored during synchronous saves. + model.attributes = attributes; + var serverAttrs = options.parse ? model.parse(resp, options) : resp; + if (wait) serverAttrs = _.extend({}, attrs, serverAttrs); + if (serverAttrs && !model.set(serverAttrs, options)) return false; + if (success) success.call(options.context, model, resp, options); + model.trigger('sync', model, resp, options); + }; + wrapError(this, options); + + // Set temporary attributes if `{wait: true}` to properly find new ids. + if (attrs && wait) this.attributes = _.extend({}, attributes, attrs); + + var method = this.isNew() ? 'create' : options.patch ? 'patch' : 'update'; + if (method === 'patch' && !options.attrs) options.attrs = attrs; + var xhr = this.sync(method, this, options); + + // Restore attributes. + this.attributes = attributes; + + return xhr; + }, + + // Destroy this model on the server if it was already persisted. + // Optimistically removes the model from its collection, if it has one. + // If `wait: true` is passed, waits for the server to respond before removal. + destroy: function(options) { + options = options ? _.clone(options) : {}; + var model = this; + var success = options.success; + var wait = options.wait; + + var destroy = function() { + model.stopListening(); + model.trigger('destroy', model, model.collection, options); + }; + + options.success = function(resp) { + if (wait) destroy(); + if (success) success.call(options.context, model, resp, options); + if (!model.isNew()) model.trigger('sync', model, resp, options); + }; + + var xhr = false; + if (this.isNew()) { + _.defer(options.success); + } else { + wrapError(this, options); + xhr = this.sync('delete', this, options); + } + if (!wait) destroy(); + return xhr; + }, + + // Default URL for the model's representation on the server -- if you're + // using Backbone's restful methods, override this to change the endpoint + // that will be called. + url: function() { + var base = + _.result(this, 'urlRoot') || + _.result(this.collection, 'url') || + urlError(); + if (this.isNew()) return base; + var id = this.get(this.idAttribute); + return base.replace(/[^\/]$/, '$&/') + encodeURIComponent(id); + }, + + // **parse** converts a response into the hash of attributes to be `set` on + // the model. The default implementation is just to pass the response along. + parse: function(resp, options) { + return resp; + }, + + // Create a new model with identical attributes to this one. + clone: function() { + return new this.constructor(this.attributes); + }, + + // A model is new if it has never been saved to the server, and lacks an id. + isNew: function() { + return !this.has(this.idAttribute); + }, + + // Check if the model is currently in a valid state. + isValid: function(options) { + return this._validate({}, _.extend({}, options, {validate: true})); + }, + + // Run validation against the next complete set of model attributes, + // returning `true` if all is well. Otherwise, fire an `"invalid"` event. + _validate: function(attrs, options) { + if (!options.validate || !this.validate) return true; + attrs = _.extend({}, this.attributes, attrs); + var error = this.validationError = this.validate(attrs, options) || null; + if (!error) return true; + this.trigger('invalid', this, error, _.extend(options, {validationError: error})); + return false; + } + + }); + + // Backbone.Collection + // ------------------- + + // If models tend to represent a single row of data, a Backbone Collection is + // more analogous to a table full of data ... or a small slice or page of that + // table, or a collection of rows that belong together for a particular reason + // -- all of the messages in this particular folder, all of the documents + // belonging to this particular author, and so on. Collections maintain + // indexes of their models, both in order, and for lookup by `id`. + + // Create a new **Collection**, perhaps to contain a specific type of `model`. + // If a `comparator` is specified, the Collection will maintain + // its models in sort order, as they're added and removed. + var Collection = Backbone.Collection = function(models, options) { + options || (options = {}); + this.preinitialize.apply(this, arguments); + if (options.model) this.model = options.model; + if (options.comparator !== void 0) this.comparator = options.comparator; + this._reset(); + this.initialize.apply(this, arguments); + if (models) this.reset(models, _.extend({silent: true}, options)); + }; + + // Default options for `Collection#set`. + var setOptions = {add: true, remove: true, merge: true}; + var addOptions = {add: true, remove: false}; + + // Splices `insert` into `array` at index `at`. + var splice = function(array, insert, at) { + at = Math.min(Math.max(at, 0), array.length); + var tail = Array(array.length - at); + var length = insert.length; + var i; + for (i = 0; i < tail.length; i++) tail[i] = array[i + at]; + for (i = 0; i < length; i++) array[i + at] = insert[i]; + for (i = 0; i < tail.length; i++) array[i + length + at] = tail[i]; + }; + + // Define the Collection's inheritable methods. + _.extend(Collection.prototype, Events, { + + // The default model for a collection is just a **Backbone.Model**. + // This should be overridden in most cases. + model: Model, + + + // preinitialize is an empty function by default. You can override it with a function + // or object. preinitialize will run before any instantiation logic is run in the Collection. + preinitialize: function(){}, + + // Initialize is an empty function by default. Override it with your own + // initialization logic. + initialize: function(){}, + + // The JSON representation of a Collection is an array of the + // models' attributes. + toJSON: function(options) { + return this.map(function(model) { return model.toJSON(options); }); + }, + + // Proxy `Backbone.sync` by default. + sync: function() { + return Backbone.sync.apply(this, arguments); + }, + + // Add a model, or list of models to the set. `models` may be Backbone + // Models or raw JavaScript objects to be converted to Models, or any + // combination of the two. + add: function(models, options) { + return this.set(models, _.extend({merge: false}, options, addOptions)); + }, + + // Remove a model, or a list of models from the set. + remove: function(models, options) { + options = _.extend({}, options); + var singular = !_.isArray(models); + models = singular ? [models] : models.slice(); + var removed = this._removeModels(models, options); + if (!options.silent && removed.length) { + options.changes = {added: [], merged: [], removed: removed}; + this.trigger('update', this, options); + } + return singular ? removed[0] : removed; + }, + + // Update a collection by `set`-ing a new list of models, adding new ones, + // removing models that are no longer present, and merging models that + // already exist in the collection, as necessary. Similar to **Model#set**, + // the core operation for updating the data contained by the collection. + set: function(models, options) { + if (models == null) return; + + options = _.extend({}, setOptions, options); + if (options.parse && !this._isModel(models)) { + models = this.parse(models, options) || []; + } + + var singular = !_.isArray(models); + models = singular ? [models] : models.slice(); + + var at = options.at; + if (at != null) at = +at; + if (at > this.length) at = this.length; + if (at < 0) at += this.length + 1; + + var set = []; + var toAdd = []; + var toMerge = []; + var toRemove = []; + var modelMap = {}; + + var add = options.add; + var merge = options.merge; + var remove = options.remove; + + var sort = false; + var sortable = this.comparator && at == null && options.sort !== false; + var sortAttr = _.isString(this.comparator) ? this.comparator : null; + + // Turn bare objects into model references, and prevent invalid models + // from being added. + var model, i; + for (i = 0; i < models.length; i++) { + model = models[i]; + + // If a duplicate is found, prevent it from being added and + // optionally merge it into the existing model. + var existing = this.get(model); + if (existing) { + if (merge && model !== existing) { + var attrs = this._isModel(model) ? model.attributes : model; + if (options.parse) attrs = existing.parse(attrs, options); + existing.set(attrs, options); + toMerge.push(existing); + if (sortable && !sort) sort = existing.hasChanged(sortAttr); + } + if (!modelMap[existing.cid]) { + modelMap[existing.cid] = true; + set.push(existing); + } + models[i] = existing; + + // If this is a new, valid model, push it to the `toAdd` list. + } else if (add) { + model = models[i] = this._prepareModel(model, options); + if (model) { + toAdd.push(model); + this._addReference(model, options); + modelMap[model.cid] = true; + set.push(model); + } + } + } + + // Remove stale models. + if (remove) { + for (i = 0; i < this.length; i++) { + model = this.models[i]; + if (!modelMap[model.cid]) toRemove.push(model); + } + if (toRemove.length) this._removeModels(toRemove, options); + } + + // See if sorting is needed, update `length` and splice in new models. + var orderChanged = false; + var replace = !sortable && add && remove; + if (set.length && replace) { + orderChanged = this.length !== set.length || _.some(this.models, function(m, index) { + return m !== set[index]; + }); + this.models.length = 0; + splice(this.models, set, 0); + this.length = this.models.length; + } else if (toAdd.length) { + if (sortable) sort = true; + splice(this.models, toAdd, at == null ? this.length : at); + this.length = this.models.length; + } + + // Silently sort the collection if appropriate. + if (sort) this.sort({silent: true}); + + // Unless silenced, it's time to fire all appropriate add/sort/update events. + if (!options.silent) { + for (i = 0; i < toAdd.length; i++) { + if (at != null) options.index = at + i; + model = toAdd[i]; + model.trigger('add', model, this, options); + } + if (sort || orderChanged) this.trigger('sort', this, options); + if (toAdd.length || toRemove.length || toMerge.length) { + options.changes = { + added: toAdd, + removed: toRemove, + merged: toMerge + }; + this.trigger('update', this, options); + } + } + + // Return the added (or merged) model (or models). + return singular ? models[0] : models; + }, + + // When you have more items than you want to add or remove individually, + // you can reset the entire set with a new list of models, without firing + // any granular `add` or `remove` events. Fires `reset` when finished. + // Useful for bulk operations and optimizations. + reset: function(models, options) { + options = options ? _.clone(options) : {}; + for (var i = 0; i < this.models.length; i++) { + this._removeReference(this.models[i], options); + } + options.previousModels = this.models; + this._reset(); + models = this.add(models, _.extend({silent: true}, options)); + if (!options.silent) this.trigger('reset', this, options); + return models; + }, + + // Add a model to the end of the collection. + push: function(model, options) { + return this.add(model, _.extend({at: this.length}, options)); + }, + + // Remove a model from the end of the collection. + pop: function(options) { + var model = this.at(this.length - 1); + return this.remove(model, options); + }, + + // Add a model to the beginning of the collection. + unshift: function(model, options) { + return this.add(model, _.extend({at: 0}, options)); + }, + + // Remove a model from the beginning of the collection. + shift: function(options) { + var model = this.at(0); + return this.remove(model, options); + }, + + // Slice out a sub-array of models from the collection. + slice: function() { + return slice.apply(this.models, arguments); + }, + + // Get a model from the set by id, cid, model object with id or cid + // properties, or an attributes object that is transformed through modelId. + get: function(obj) { + if (obj == null) return void 0; + return this._byId[obj] || + this._byId[this.modelId(this._isModel(obj) ? obj.attributes : obj, obj.idAttribute)] || + obj.cid && this._byId[obj.cid]; + }, + + // Returns `true` if the model is in the collection. + has: function(obj) { + return this.get(obj) != null; + }, + + // Get the model at the given index. + at: function(index) { + if (index < 0) index += this.length; + return this.models[index]; + }, + + // Return models with matching attributes. Useful for simple cases of + // `filter`. + where: function(attrs, first) { + return this[first ? 'find' : 'filter'](attrs); + }, + + // Return the first model with matching attributes. Useful for simple cases + // of `find`. + findWhere: function(attrs) { + return this.where(attrs, true); + }, + + // Force the collection to re-sort itself. You don't need to call this under + // normal circumstances, as the set will maintain sort order as each item + // is added. + sort: function(options) { + var comparator = this.comparator; + if (!comparator) throw new Error('Cannot sort a set without a comparator'); + options || (options = {}); + + var length = comparator.length; + if (_.isFunction(comparator)) comparator = comparator.bind(this); + + // Run sort based on type of `comparator`. + if (length === 1 || _.isString(comparator)) { + this.models = this.sortBy(comparator); + } else { + this.models.sort(comparator); + } + if (!options.silent) this.trigger('sort', this, options); + return this; + }, + + // Pluck an attribute from each model in the collection. + pluck: function(attr) { + return this.map(attr + ''); + }, + + // Fetch the default set of models for this collection, resetting the + // collection when they arrive. If `reset: true` is passed, the response + // data will be passed through the `reset` method instead of `set`. + fetch: function(options) { + options = _.extend({parse: true}, options); + var success = options.success; + var collection = this; + options.success = function(resp) { + var method = options.reset ? 'reset' : 'set'; + collection[method](resp, options); + if (success) success.call(options.context, collection, resp, options); + collection.trigger('sync', collection, resp, options); + }; + wrapError(this, options); + return this.sync('read', this, options); + }, + + // Create a new instance of a model in this collection. Add the model to the + // collection immediately, unless `wait: true` is passed, in which case we + // wait for the server to agree. + create: function(model, options) { + options = options ? _.clone(options) : {}; + var wait = options.wait; + model = this._prepareModel(model, options); + if (!model) return false; + if (!wait) this.add(model, options); + var collection = this; + var success = options.success; + options.success = function(m, resp, callbackOpts) { + if (wait) collection.add(m, callbackOpts); + if (success) success.call(callbackOpts.context, m, resp, callbackOpts); + }; + model.save(null, options); + return model; + }, + + // **parse** converts a response into a list of models to be added to the + // collection. The default implementation is just to pass it through. + parse: function(resp, options) { + return resp; + }, + + // Create a new collection with an identical list of models as this one. + clone: function() { + return new this.constructor(this.models, { + model: this.model, + comparator: this.comparator + }); + }, + + // Define how to uniquely identify models in the collection. + modelId: function(attrs, idAttribute) { + return attrs[idAttribute || this.model.prototype.idAttribute || 'id']; + }, + + // Get an iterator of all models in this collection. + values: function() { + return new CollectionIterator(this, ITERATOR_VALUES); + }, + + // Get an iterator of all model IDs in this collection. + keys: function() { + return new CollectionIterator(this, ITERATOR_KEYS); + }, + + // Get an iterator of all [ID, model] tuples in this collection. + entries: function() { + return new CollectionIterator(this, ITERATOR_KEYSVALUES); + }, + + // Private method to reset all internal state. Called when the collection + // is first initialized or reset. + _reset: function() { + this.length = 0; + this.models = []; + this._byId = {}; + }, + + // Prepare a hash of attributes (or other model) to be added to this + // collection. + _prepareModel: function(attrs, options) { + if (this._isModel(attrs)) { + if (!attrs.collection) attrs.collection = this; + return attrs; + } + options = options ? _.clone(options) : {}; + options.collection = this; + + var model; + if (this.model.prototype) { + model = new this.model(attrs, options); + } else { + // ES class methods didn't have prototype + model = this.model(attrs, options); + } + + if (!model.validationError) return model; + this.trigger('invalid', this, model.validationError, options); + return false; + }, + + // Internal method called by both remove and set. + _removeModels: function(models, options) { + var removed = []; + for (var i = 0; i < models.length; i++) { + var model = this.get(models[i]); + if (!model) continue; + + var index = this.indexOf(model); + this.models.splice(index, 1); + this.length--; + + // Remove references before triggering 'remove' event to prevent an + // infinite loop. #3693 + delete this._byId[model.cid]; + var id = this.modelId(model.attributes, model.idAttribute); + if (id != null) delete this._byId[id]; + + if (!options.silent) { + options.index = index; + model.trigger('remove', model, this, options); + } + + removed.push(model); + this._removeReference(model, options); + } + return removed; + }, + + // Method for checking whether an object should be considered a model for + // the purposes of adding to the collection. + _isModel: function(model) { + return model instanceof Model; + }, + + // Internal method to create a model's ties to a collection. + _addReference: function(model, options) { + this._byId[model.cid] = model; + var id = this.modelId(model.attributes, model.idAttribute); + if (id != null) this._byId[id] = model; + model.on('all', this._onModelEvent, this); + }, + + // Internal method to sever a model's ties to a collection. + _removeReference: function(model, options) { + delete this._byId[model.cid]; + var id = this.modelId(model.attributes, model.idAttribute); + if (id != null) delete this._byId[id]; + if (this === model.collection) delete model.collection; + model.off('all', this._onModelEvent, this); + }, + + // Internal method called every time a model in the set fires an event. + // Sets need to update their indexes when models change ids. All other + // events simply proxy through. "add" and "remove" events that originate + // in other collections are ignored. + _onModelEvent: function(event, model, collection, options) { + if (model) { + if ((event === 'add' || event === 'remove') && collection !== this) return; + if (event === 'destroy') this.remove(model, options); + if (event === 'changeId') { + var prevId = this.modelId(model.previousAttributes(), model.idAttribute); + var id = this.modelId(model.attributes, model.idAttribute); + if (prevId != null) delete this._byId[prevId]; + if (id != null) this._byId[id] = model; + } + } + this.trigger.apply(this, arguments); + } + + }); + + // Defining an @@iterator method implements JavaScript's Iterable protocol. + // In modern ES2015 browsers, this value is found at Symbol.iterator. + /* global Symbol */ + var $$iterator = typeof Symbol === 'function' && Symbol.iterator; + if ($$iterator) { + Collection.prototype[$$iterator] = Collection.prototype.values; + } + + // CollectionIterator + // ------------------ + + // A CollectionIterator implements JavaScript's Iterator protocol, allowing the + // use of `for of` loops in modern browsers and interoperation between + // Backbone.Collection and other JavaScript functions and third-party libraries + // which can operate on Iterables. + var CollectionIterator = function(collection, kind) { + this._collection = collection; + this._kind = kind; + this._index = 0; + }; + + // This "enum" defines the three possible kinds of values which can be emitted + // by a CollectionIterator that correspond to the values(), keys() and entries() + // methods on Collection, respectively. + var ITERATOR_VALUES = 1; + var ITERATOR_KEYS = 2; + var ITERATOR_KEYSVALUES = 3; + + // All Iterators should themselves be Iterable. + if ($$iterator) { + CollectionIterator.prototype[$$iterator] = function() { + return this; + }; + } + + CollectionIterator.prototype.next = function() { + if (this._collection) { + + // Only continue iterating if the iterated collection is long enough. + if (this._index < this._collection.length) { + var model = this._collection.at(this._index); + this._index++; + + // Construct a value depending on what kind of values should be iterated. + var value; + if (this._kind === ITERATOR_VALUES) { + value = model; + } else { + var id = this._collection.modelId(model.attributes, model.idAttribute); + if (this._kind === ITERATOR_KEYS) { + value = id; + } else { // ITERATOR_KEYSVALUES + value = [id, model]; + } + } + return {value: value, done: false}; + } + + // Once exhausted, remove the reference to the collection so future + // calls to the next method always return done. + this._collection = void 0; + } + + return {value: void 0, done: true}; + }; + + // Backbone.View + // ------------- + + // Backbone Views are almost more convention than they are actual code. A View + // is simply a JavaScript object that represents a logical chunk of UI in the + // DOM. This might be a single item, an entire list, a sidebar or panel, or + // even the surrounding frame which wraps your whole app. Defining a chunk of + // UI as a **View** allows you to define your DOM events declaratively, without + // having to worry about render order ... and makes it easy for the view to + // react to specific changes in the state of your models. + + // Creating a Backbone.View creates its initial element outside of the DOM, + // if an existing element is not provided... + var View = Backbone.View = function(options) { + this.cid = _.uniqueId('view'); + this.preinitialize.apply(this, arguments); + _.extend(this, _.pick(options, viewOptions)); + this._ensureElement(); + this.initialize.apply(this, arguments); + }; + + // Cached regex to split keys for `delegate`. + var delegateEventSplitter = /^(\S+)\s*(.*)$/; + + // List of view options to be set as properties. + var viewOptions = ['model', 'collection', 'el', 'id', 'attributes', 'className', 'tagName', 'events']; + + // Set up all inheritable **Backbone.View** properties and methods. + _.extend(View.prototype, Events, { + + // The default `tagName` of a View's element is `"div"`. + tagName: 'div', + + // jQuery delegate for element lookup, scoped to DOM elements within the + // current view. This should be preferred to global lookups where possible. + $: function(selector) { + return this.$el.find(selector); + }, + + // preinitialize is an empty function by default. You can override it with a function + // or object. preinitialize will run before any instantiation logic is run in the View + preinitialize: function(){}, + + // Initialize is an empty function by default. Override it with your own + // initialization logic. + initialize: function(){}, + + // **render** is the core function that your view should override, in order + // to populate its element (`this.el`), with the appropriate HTML. The + // convention is for **render** to always return `this`. + render: function() { + return this; + }, + + // Remove this view by taking the element out of the DOM, and removing any + // applicable Backbone.Events listeners. + remove: function() { + this._removeElement(); + this.stopListening(); + return this; + }, + + // Remove this view's element from the document and all event listeners + // attached to it. Exposed for subclasses using an alternative DOM + // manipulation API. + _removeElement: function() { + this.$el.remove(); + }, + + // Change the view's element (`this.el` property) and re-delegate the + // view's events on the new element. + setElement: function(element) { + this.undelegateEvents(); + this._setElement(element); + this.delegateEvents(); + return this; + }, + + // Creates the `this.el` and `this.$el` references for this view using the + // given `el`. `el` can be a CSS selector or an HTML string, a jQuery + // context or an element. Subclasses can override this to utilize an + // alternative DOM manipulation API and are only required to set the + // `this.el` property. + _setElement: function(el) { + this.$el = el instanceof Backbone.$ ? el : Backbone.$(el); + this.el = this.$el[0]; + }, + + // Set callbacks, where `this.events` is a hash of + // + // *{"event selector": "callback"}* + // + // { + // 'mousedown .title': 'edit', + // 'click .button': 'save', + // 'click .open': function(e) { ... } + // } + // + // pairs. Callbacks will be bound to the view, with `this` set properly. + // Uses event delegation for efficiency. + // Omitting the selector binds the event to `this.el`. + delegateEvents: function(events) { + events || (events = _.result(this, 'events')); + if (!events) return this; + this.undelegateEvents(); + for (var key in events) { + var method = events[key]; + if (!_.isFunction(method)) method = this[method]; + if (!method) continue; + var match = key.match(delegateEventSplitter); + this.delegate(match[1], match[2], method.bind(this)); + } + return this; + }, + + // Add a single event listener to the view's element (or a child element + // using `selector`). This only works for delegate-able events: not `focus`, + // `blur`, and not `change`, `submit`, and `reset` in Internet Explorer. + delegate: function(eventName, selector, listener) { + this.$el.on(eventName + '.delegateEvents' + this.cid, selector, listener); + return this; + }, + + // Clears all callbacks previously bound to the view by `delegateEvents`. + // You usually don't need to use this, but may wish to if you have multiple + // Backbone views attached to the same DOM element. + undelegateEvents: function() { + if (this.$el) this.$el.off('.delegateEvents' + this.cid); + return this; + }, + + // A finer-grained `undelegateEvents` for removing a single delegated event. + // `selector` and `listener` are both optional. + undelegate: function(eventName, selector, listener) { + this.$el.off(eventName + '.delegateEvents' + this.cid, selector, listener); + return this; + }, + + // Produces a DOM element to be assigned to your view. Exposed for + // subclasses using an alternative DOM manipulation API. + _createElement: function(tagName) { + return document.createElement(tagName); + }, + + // Ensure that the View has a DOM element to render into. + // If `this.el` is a string, pass it through `$()`, take the first + // matching element, and re-assign it to `el`. Otherwise, create + // an element from the `id`, `className` and `tagName` properties. + _ensureElement: function() { + if (!this.el) { + var attrs = _.extend({}, _.result(this, 'attributes')); + if (this.id) attrs.id = _.result(this, 'id'); + if (this.className) attrs['class'] = _.result(this, 'className'); + this.setElement(this._createElement(_.result(this, 'tagName'))); + this._setAttributes(attrs); + } else { + this.setElement(_.result(this, 'el')); + } + }, + + // Set attributes from a hash on this view's element. Exposed for + // subclasses using an alternative DOM manipulation API. + _setAttributes: function(attributes) { + this.$el.attr(attributes); + } + + }); + + // Proxy Backbone class methods to Underscore functions, wrapping the model's + // `attributes` object or collection's `models` array behind the scenes. + // + // collection.filter(function(model) { return model.get('age') > 10 }); + // collection.each(this.addView); + // + // `Function#apply` can be slow so we use the method's arg count, if we know it. + var addMethod = function(base, length, method, attribute) { + switch (length) { + case 1: return function() { + return base[method](this[attribute]); + }; + case 2: return function(value) { + return base[method](this[attribute], value); + }; + case 3: return function(iteratee, context) { + return base[method](this[attribute], cb(iteratee, this), context); + }; + case 4: return function(iteratee, defaultVal, context) { + return base[method](this[attribute], cb(iteratee, this), defaultVal, context); + }; + default: return function() { + var args = slice.call(arguments); + args.unshift(this[attribute]); + return base[method].apply(base, args); + }; + } + }; + + var addUnderscoreMethods = function(Class, base, methods, attribute) { + _.each(methods, function(length, method) { + if (base[method]) Class.prototype[method] = addMethod(base, length, method, attribute); + }); + }; + + // Support `collection.sortBy('attr')` and `collection.findWhere({id: 1})`. + var cb = function(iteratee, instance) { + if (_.isFunction(iteratee)) return iteratee; + if (_.isObject(iteratee) && !instance._isModel(iteratee)) return modelMatcher(iteratee); + if (_.isString(iteratee)) return function(model) { return model.get(iteratee); }; + return iteratee; + }; + var modelMatcher = function(attrs) { + var matcher = _.matches(attrs); + return function(model) { + return matcher(model.attributes); + }; + }; + + // Underscore methods that we want to implement on the Collection. + // 90% of the core usefulness of Backbone Collections is actually implemented + // right here: + var collectionMethods = {forEach: 3, each: 3, map: 3, collect: 3, reduce: 0, + foldl: 0, inject: 0, reduceRight: 0, foldr: 0, find: 3, detect: 3, filter: 3, + select: 3, reject: 3, every: 3, all: 3, some: 3, any: 3, include: 3, includes: 3, + contains: 3, invoke: 0, max: 3, min: 3, toArray: 1, size: 1, first: 3, + head: 3, take: 3, initial: 3, rest: 3, tail: 3, drop: 3, last: 3, + without: 0, difference: 0, indexOf: 3, shuffle: 1, lastIndexOf: 3, + isEmpty: 1, chain: 1, sample: 3, partition: 3, groupBy: 3, countBy: 3, + sortBy: 3, indexBy: 3, findIndex: 3, findLastIndex: 3}; + + + // Underscore methods that we want to implement on the Model, mapped to the + // number of arguments they take. + var modelMethods = {keys: 1, values: 1, pairs: 1, invert: 1, pick: 0, + omit: 0, chain: 1, isEmpty: 1}; + + // Mix in each Underscore method as a proxy to `Collection#models`. + + _.each([ + [Collection, collectionMethods, 'models'], + [Model, modelMethods, 'attributes'] + ], function(config) { + var Base = config[0], + methods = config[1], + attribute = config[2]; + + Base.mixin = function(obj) { + var mappings = _.reduce(_.functions(obj), function(memo, name) { + memo[name] = 0; + return memo; + }, {}); + addUnderscoreMethods(Base, obj, mappings, attribute); + }; + + addUnderscoreMethods(Base, _, methods, attribute); + }); + + // Backbone.sync + // ------------- + + // Override this function to change the manner in which Backbone persists + // models to the server. You will be passed the type of request, and the + // model in question. By default, makes a RESTful Ajax request + // to the model's `url()`. Some possible customizations could be: + // + // * Use `setTimeout` to batch rapid-fire updates into a single request. + // * Send up the models as XML instead of JSON. + // * Persist models via WebSockets instead of Ajax. + // + // Turn on `Backbone.emulateHTTP` in order to send `PUT` and `DELETE` requests + // as `POST`, with a `_method` parameter containing the true HTTP method, + // as well as all requests with the body as `application/x-www-form-urlencoded` + // instead of `application/json` with the model in a param named `model`. + // Useful when interfacing with server-side languages like **PHP** that make + // it difficult to read the body of `PUT` requests. + Backbone.sync = function(method, model, options) { + var type = methodMap[method]; + + // Default options, unless specified. + _.defaults(options || (options = {}), { + emulateHTTP: Backbone.emulateHTTP, + emulateJSON: Backbone.emulateJSON + }); + + // Default JSON-request options. + var params = {type: type, dataType: 'json'}; + + // Ensure that we have a URL. + if (!options.url) { + params.url = _.result(model, 'url') || urlError(); + } + + // Ensure that we have the appropriate request data. + if (options.data == null && model && (method === 'create' || method === 'update' || method === 'patch')) { + params.contentType = 'application/json'; + params.data = JSON.stringify(options.attrs || model.toJSON(options)); + } + + // For older servers, emulate JSON by encoding the request into an HTML-form. + if (options.emulateJSON) { + params.contentType = 'application/x-www-form-urlencoded'; + params.data = params.data ? {model: params.data} : {}; + } + + // For older servers, emulate HTTP by mimicking the HTTP method with `_method` + // And an `X-HTTP-Method-Override` header. + if (options.emulateHTTP && (type === 'PUT' || type === 'DELETE' || type === 'PATCH')) { + params.type = 'POST'; + if (options.emulateJSON) params.data._method = type; + var beforeSend = options.beforeSend; + options.beforeSend = function(xhr) { + xhr.setRequestHeader('X-HTTP-Method-Override', type); + if (beforeSend) return beforeSend.apply(this, arguments); + }; + } + + // Don't process data on a non-GET request. + if (params.type !== 'GET' && !options.emulateJSON) { + params.processData = false; + } + + // Pass along `textStatus` and `errorThrown` from jQuery. + var error = options.error; + options.error = function(xhr, textStatus, errorThrown) { + options.textStatus = textStatus; + options.errorThrown = errorThrown; + if (error) error.call(options.context, xhr, textStatus, errorThrown); + }; + + // Make the request, allowing the user to override any Ajax options. + var xhr = options.xhr = Backbone.ajax(_.extend(params, options)); + model.trigger('request', model, xhr, options); + return xhr; + }; + + // Map from CRUD to HTTP for our default `Backbone.sync` implementation. + var methodMap = { + 'create': 'POST', + 'update': 'PUT', + 'patch': 'PATCH', + 'delete': 'DELETE', + 'read': 'GET' + }; + + // Set the default implementation of `Backbone.ajax` to proxy through to `$`. + // Override this if you'd like to use a different library. + Backbone.ajax = function() { + return Backbone.$.ajax.apply(Backbone.$, arguments); + }; + + // Backbone.Router + // --------------- + + // Routers map faux-URLs to actions, and fire events when routes are + // matched. Creating a new one sets its `routes` hash, if not set statically. + var Router = Backbone.Router = function(options) { + options || (options = {}); + this.preinitialize.apply(this, arguments); + if (options.routes) this.routes = options.routes; + this._bindRoutes(); + this.initialize.apply(this, arguments); + }; + + // Cached regular expressions for matching named param parts and splatted + // parts of route strings. + var optionalParam = /\((.*?)\)/g; + var namedParam = /(\(\?)?:\w+/g; + var splatParam = /\*\w+/g; + var escapeRegExp = /[\-{}\[\]+?.,\\\^$|#\s]/g; + + // Set up all inheritable **Backbone.Router** properties and methods. + _.extend(Router.prototype, Events, { + + // preinitialize is an empty function by default. You can override it with a function + // or object. preinitialize will run before any instantiation logic is run in the Router. + preinitialize: function(){}, + + // Initialize is an empty function by default. Override it with your own + // initialization logic. + initialize: function(){}, + + // Manually bind a single named route to a callback. For example: + // + // this.route('search/:query/p:num', 'search', function(query, num) { + // ... + // }); + // + route: function(route, name, callback) { + if (!_.isRegExp(route)) route = this._routeToRegExp(route); + if (_.isFunction(name)) { + callback = name; + name = ''; + } + if (!callback) callback = this[name]; + var router = this; + Backbone.history.route(route, function(fragment) { + var args = router._extractParameters(route, fragment); + if (router.execute(callback, args, name) !== false) { + router.trigger.apply(router, ['route:' + name].concat(args)); + router.trigger('route', name, args); + Backbone.history.trigger('route', router, name, args); + } + }); + return this; + }, + + // Execute a route handler with the provided parameters. This is an + // excellent place to do pre-route setup or post-route cleanup. + execute: function(callback, args, name) { + if (callback) callback.apply(this, args); + }, + + // Simple proxy to `Backbone.history` to save a fragment into the history. + navigate: function(fragment, options) { + Backbone.history.navigate(fragment, options); + return this; + }, + + // Bind all defined routes to `Backbone.history`. We have to reverse the + // order of the routes here to support behavior where the most general + // routes can be defined at the bottom of the route map. + _bindRoutes: function() { + if (!this.routes) return; + this.routes = _.result(this, 'routes'); + var route, routes = _.keys(this.routes); + while ((route = routes.pop()) != null) { + this.route(route, this.routes[route]); + } + }, + + // Convert a route string into a regular expression, suitable for matching + // against the current location hash. + _routeToRegExp: function(route) { + route = route.replace(escapeRegExp, '\\$&') + .replace(optionalParam, '(?:$1)?') + .replace(namedParam, function(match, optional) { + return optional ? match : '([^/?]+)'; + }) + .replace(splatParam, '([^?]*?)'); + return new RegExp('^' + route + '(?:\\?([\\s\\S]*))?$'); + }, + + // Given a route, and a URL fragment that it matches, return the array of + // extracted decoded parameters. Empty or unmatched parameters will be + // treated as `null` to normalize cross-browser behavior. + _extractParameters: function(route, fragment) { + var params = route.exec(fragment).slice(1); + return _.map(params, function(param, i) { + // Don't decode the search params. + if (i === params.length - 1) return param || null; + return param ? decodeURIComponent(param) : null; + }); + } + + }); + + // Backbone.History + // ---------------- + + // Handles cross-browser history management, based on either + // [pushState](http://diveintohtml5.info/history.html) and real URLs, or + // [onhashchange](https://developer.mozilla.org/en-US/docs/DOM/window.onhashchange) + // and URL fragments. If the browser supports neither (old IE, natch), + // falls back to polling. + var History = Backbone.History = function() { + this.handlers = []; + this.checkUrl = this.checkUrl.bind(this); + + // Ensure that `History` can be used outside of the browser. + if (typeof window !== 'undefined') { + this.location = window.location; + this.history = window.history; + } + }; + + // Cached regex for stripping a leading hash/slash and trailing space. + var routeStripper = /^[#\/]|\s+$/g; + + // Cached regex for stripping leading and trailing slashes. + var rootStripper = /^\/+|\/+$/g; + + // Cached regex for stripping urls of hash. + var pathStripper = /#.*$/; + + // Has the history handling already been started? + History.started = false; + + // Set up all inheritable **Backbone.History** properties and methods. + _.extend(History.prototype, Events, { + + // The default interval to poll for hash changes, if necessary, is + // twenty times a second. + interval: 50, + + // Are we at the app root? + atRoot: function() { + var path = this.location.pathname.replace(/[^\/]$/, '$&/'); + return path === this.root && !this.getSearch(); + }, + + // Does the pathname match the root? + matchRoot: function() { + var path = this.decodeFragment(this.location.pathname); + var rootPath = path.slice(0, this.root.length - 1) + '/'; + return rootPath === this.root; + }, + + // Unicode characters in `location.pathname` are percent encoded so they're + // decoded for comparison. `%25` should not be decoded since it may be part + // of an encoded parameter. + decodeFragment: function(fragment) { + return decodeURI(fragment.replace(/%25/g, '%2525')); + }, + + // In IE6, the hash fragment and search params are incorrect if the + // fragment contains `?`. + getSearch: function() { + var match = this.location.href.replace(/#.*/, '').match(/\?.+/); + return match ? match[0] : ''; + }, + + // Gets the true hash value. Cannot use location.hash directly due to bug + // in Firefox where location.hash will always be decoded. + getHash: function(window) { + var match = (window || this).location.href.match(/#(.*)$/); + return match ? match[1] : ''; + }, + + // Get the pathname and search params, without the root. + getPath: function() { + var path = this.decodeFragment( + this.location.pathname + this.getSearch() + ).slice(this.root.length - 1); + return path.charAt(0) === '/' ? path.slice(1) : path; + }, + + // Get the cross-browser normalized URL fragment from the path or hash. + getFragment: function(fragment) { + if (fragment == null) { + if (this._usePushState || !this._wantsHashChange) { + fragment = this.getPath(); + } else { + fragment = this.getHash(); + } + } + return fragment.replace(routeStripper, ''); + }, + + // Start the hash change handling, returning `true` if the current URL matches + // an existing route, and `false` otherwise. + start: function(options) { + if (History.started) throw new Error('Backbone.history has already been started'); + History.started = true; + + // Figure out the initial configuration. Do we need an iframe? + // Is pushState desired ... is it available? + this.options = _.extend({root: '/'}, this.options, options); + this.root = this.options.root; + this._wantsHashChange = this.options.hashChange !== false; + this._hasHashChange = 'onhashchange' in window && (document.documentMode === void 0 || document.documentMode > 7); + this._useHashChange = this._wantsHashChange && this._hasHashChange; + this._wantsPushState = !!this.options.pushState; + this._hasPushState = !!(this.history && this.history.pushState); + this._usePushState = this._wantsPushState && this._hasPushState; + this.fragment = this.getFragment(); + + // Normalize root to always include a leading and trailing slash. + this.root = ('/' + this.root + '/').replace(rootStripper, '/'); + + // Transition from hashChange to pushState or vice versa if both are + // requested. + if (this._wantsHashChange && this._wantsPushState) { + + // If we've started off with a route from a `pushState`-enabled + // browser, but we're currently in a browser that doesn't support it... + if (!this._hasPushState && !this.atRoot()) { + var rootPath = this.root.slice(0, -1) || '/'; + this.location.replace(rootPath + '#' + this.getPath()); + // Return immediately as browser will do redirect to new url + return true; + + // Or if we've started out with a hash-based route, but we're currently + // in a browser where it could be `pushState`-based instead... + } else if (this._hasPushState && this.atRoot()) { + this.navigate(this.getHash(), {replace: true}); + } + + } + + // Proxy an iframe to handle location events if the browser doesn't + // support the `hashchange` event, HTML5 history, or the user wants + // `hashChange` but not `pushState`. + if (!this._hasHashChange && this._wantsHashChange && !this._usePushState) { + this.iframe = document.createElement('iframe'); + this.iframe.src = 'javascript:0'; + this.iframe.style.display = 'none'; + this.iframe.tabIndex = -1; + var body = document.body; + // Using `appendChild` will throw on IE < 9 if the document is not ready. + var iWindow = body.insertBefore(this.iframe, body.firstChild).contentWindow; + iWindow.document.open(); + iWindow.document.close(); + iWindow.location.hash = '#' + this.fragment; + } + + // Add a cross-platform `addEventListener` shim for older browsers. + var addEventListener = window.addEventListener || function(eventName, listener) { + return attachEvent('on' + eventName, listener); + }; + + // Depending on whether we're using pushState or hashes, and whether + // 'onhashchange' is supported, determine how we check the URL state. + if (this._usePushState) { + addEventListener('popstate', this.checkUrl, false); + } else if (this._useHashChange && !this.iframe) { + addEventListener('hashchange', this.checkUrl, false); + } else if (this._wantsHashChange) { + this._checkUrlInterval = setInterval(this.checkUrl, this.interval); + } + + if (!this.options.silent) return this.loadUrl(); + }, + + // Disable Backbone.history, perhaps temporarily. Not useful in a real app, + // but possibly useful for unit testing Routers. + stop: function() { + // Add a cross-platform `removeEventListener` shim for older browsers. + var removeEventListener = window.removeEventListener || function(eventName, listener) { + return detachEvent('on' + eventName, listener); + }; + + // Remove window listeners. + if (this._usePushState) { + removeEventListener('popstate', this.checkUrl, false); + } else if (this._useHashChange && !this.iframe) { + removeEventListener('hashchange', this.checkUrl, false); + } + + // Clean up the iframe if necessary. + if (this.iframe) { + document.body.removeChild(this.iframe); + this.iframe = null; + } + + // Some environments will throw when clearing an undefined interval. + if (this._checkUrlInterval) clearInterval(this._checkUrlInterval); + History.started = false; + }, + + // Add a route to be tested when the fragment changes. Routes added later + // may override previous routes. + route: function(route, callback) { + this.handlers.unshift({route: route, callback: callback}); + }, + + // Checks the current URL to see if it has changed, and if it has, + // calls `loadUrl`, normalizing across the hidden iframe. + checkUrl: function(e) { + var current = this.getFragment(); + + // If the user pressed the back button, the iframe's hash will have + // changed and we should use that for comparison. + if (current === this.fragment && this.iframe) { + current = this.getHash(this.iframe.contentWindow); + } + + if (current === this.fragment) return false; + if (this.iframe) this.navigate(current); + this.loadUrl(); + }, + + // Attempt to load the current URL fragment. If a route succeeds with a + // match, returns `true`. If no defined routes matches the fragment, + // returns `false`. + loadUrl: function(fragment) { + // If the root doesn't match, no routes can match either. + if (!this.matchRoot()) return false; + fragment = this.fragment = this.getFragment(fragment); + return _.some(this.handlers, function(handler) { + if (handler.route.test(fragment)) { + handler.callback(fragment); + return true; + } + }); + }, + + // Save a fragment into the hash history, or replace the URL state if the + // 'replace' option is passed. You are responsible for properly URL-encoding + // the fragment in advance. + // + // The options object can contain `trigger: true` if you wish to have the + // route callback be fired (not usually desirable), or `replace: true`, if + // you wish to modify the current URL without adding an entry to the history. + navigate: function(fragment, options) { + if (!History.started) return false; + if (!options || options === true) options = {trigger: !!options}; + + // Normalize the fragment. + fragment = this.getFragment(fragment || ''); + + // Don't include a trailing slash on the root. + var rootPath = this.root; + if (fragment === '' || fragment.charAt(0) === '?') { + rootPath = rootPath.slice(0, -1) || '/'; + } + var url = rootPath + fragment; + + // Strip the fragment of the query and hash for matching. + fragment = fragment.replace(pathStripper, ''); + + // Decode for matching. + var decodedFragment = this.decodeFragment(fragment); + + if (this.fragment === decodedFragment) return; + this.fragment = decodedFragment; + + // If pushState is available, we use it to set the fragment as a real URL. + if (this._usePushState) { + this.history[options.replace ? 'replaceState' : 'pushState']({}, document.title, url); + + // If hash changes haven't been explicitly disabled, update the hash + // fragment to store history. + } else if (this._wantsHashChange) { + this._updateHash(this.location, fragment, options.replace); + if (this.iframe && fragment !== this.getHash(this.iframe.contentWindow)) { + var iWindow = this.iframe.contentWindow; + + // Opening and closing the iframe tricks IE7 and earlier to push a + // history entry on hash-tag change. When replace is true, we don't + // want this. + if (!options.replace) { + iWindow.document.open(); + iWindow.document.close(); + } + + this._updateHash(iWindow.location, fragment, options.replace); + } + + // If you've told us that you explicitly don't want fallback hashchange- + // based history, then `navigate` becomes a page refresh. + } else { + return this.location.assign(url); + } + if (options.trigger) return this.loadUrl(fragment); + }, + + // Update the hash location, either replacing the current entry, or adding + // a new one to the browser history. + _updateHash: function(location, fragment, replace) { + if (replace) { + var href = location.href.replace(/(javascript:|#).*$/, ''); + location.replace(href + '#' + fragment); + } else { + // Some browsers require that `hash` contains a leading #. + location.hash = '#' + fragment; + } + } + + }); + + // Create the default Backbone.history. + Backbone.history = new History; + + // Helpers + // ------- + + // Helper function to correctly set up the prototype chain for subclasses. + // Similar to `goog.inherits`, but uses a hash of prototype properties and + // class properties to be extended. + var extend = function(protoProps, staticProps) { + var parent = this; + var child; + + // The constructor function for the new subclass is either defined by you + // (the "constructor" property in your `extend` definition), or defaulted + // by us to simply call the parent constructor. + if (protoProps && _.has(protoProps, 'constructor')) { + child = protoProps.constructor; + } else { + child = function(){ return parent.apply(this, arguments); }; + } + + // Add static properties to the constructor function, if supplied. + _.extend(child, parent, staticProps); + + // Set the prototype chain to inherit from `parent`, without calling + // `parent`'s constructor function and add the prototype properties. + child.prototype = _.create(parent.prototype, protoProps); + child.prototype.constructor = child; + + // Set a convenience property in case the parent's prototype is needed + // later. + child.__super__ = parent.prototype; + + return child; + }; + + // Set up inheritance for the model, collection, router, view and history. + Model.extend = Collection.extend = Router.extend = View.extend = History.extend = extend; + + // Throw an error when a URL is needed, and none is supplied. + var urlError = function() { + throw new Error('A "url" property or function must be specified'); + }; + + // Wrap an optional error callback with a fallback error event. + var wrapError = function(model, options) { + var error = options.error; + options.error = function(resp) { + if (error) error.call(options.context, model, resp, options); + model.trigger('error', model, resp, options); + }; + }; + + return Backbone; +}); diff --git a/structurizr/js/bootstrap-5.3.7.min.js b/structurizr/js/bootstrap-5.3.7.min.js new file mode 100644 index 0000000..3d91751 --- /dev/null +++ b/structurizr/js/bootstrap-5.3.7.min.js @@ -0,0 +1,7 @@ +/*! + * Bootstrap v5.3.7 (https://getbootstrap.com/) + * Copyright 2011-2025 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors) + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) + */ +!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t="undefined"!=typeof globalThis?globalThis:t||self).bootstrap=e()}(this,(function(){"use strict";const t=new Map,e={set(e,i,n){t.has(e)||t.set(e,new Map);const s=t.get(e);s.has(i)||0===s.size?s.set(i,n):console.error(`Bootstrap doesn't allow more than one instance per element. Bound instance: ${Array.from(s.keys())[0]}.`)},get:(e,i)=>t.has(e)&&t.get(e).get(i)||null,remove(e,i){if(!t.has(e))return;const n=t.get(e);n.delete(i),0===n.size&&t.delete(e)}},i="transitionend",n=t=>(t&&window.CSS&&window.CSS.escape&&(t=t.replace(/#([^\s"#']+)/g,((t,e)=>`#${CSS.escape(e)}`))),t),s=t=>{t.dispatchEvent(new Event(i))},o=t=>!(!t||"object"!=typeof t)&&(void 0!==t.jquery&&(t=t[0]),void 0!==t.nodeType),r=t=>o(t)?t.jquery?t[0]:t:"string"==typeof t&&t.length>0?document.querySelector(n(t)):null,a=t=>{if(!o(t)||0===t.getClientRects().length)return!1;const e="visible"===getComputedStyle(t).getPropertyValue("visibility"),i=t.closest("details:not([open])");if(!i)return e;if(i!==t){const e=t.closest("summary");if(e&&e.parentNode!==i)return!1;if(null===e)return!1}return e},l=t=>!t||t.nodeType!==Node.ELEMENT_NODE||!!t.classList.contains("disabled")||(void 0!==t.disabled?t.disabled:t.hasAttribute("disabled")&&"false"!==t.getAttribute("disabled")),c=t=>{if(!document.documentElement.attachShadow)return null;if("function"==typeof t.getRootNode){const e=t.getRootNode();return e instanceof ShadowRoot?e:null}return t instanceof ShadowRoot?t:t.parentNode?c(t.parentNode):null},h=()=>{},d=t=>{t.offsetHeight},u=()=>window.jQuery&&!document.body.hasAttribute("data-bs-no-jquery")?window.jQuery:null,f=[],p=()=>"rtl"===document.documentElement.dir,m=t=>{var e;e=()=>{const e=u();if(e){const i=t.NAME,n=e.fn[i];e.fn[i]=t.jQueryInterface,e.fn[i].Constructor=t,e.fn[i].noConflict=()=>(e.fn[i]=n,t.jQueryInterface)}},"loading"===document.readyState?(f.length||document.addEventListener("DOMContentLoaded",(()=>{for(const t of f)t()})),f.push(e)):e()},g=(t,e=[],i=t)=>"function"==typeof t?t.call(...e):i,_=(t,e,n=!0)=>{if(!n)return void g(t);const o=(t=>{if(!t)return 0;let{transitionDuration:e,transitionDelay:i}=window.getComputedStyle(t);const n=Number.parseFloat(e),s=Number.parseFloat(i);return n||s?(e=e.split(",")[0],i=i.split(",")[0],1e3*(Number.parseFloat(e)+Number.parseFloat(i))):0})(e)+5;let r=!1;const a=({target:n})=>{n===e&&(r=!0,e.removeEventListener(i,a),g(t))};e.addEventListener(i,a),setTimeout((()=>{r||s(e)}),o)},b=(t,e,i,n)=>{const s=t.length;let o=t.indexOf(e);return-1===o?!i&&n?t[s-1]:t[0]:(o+=i?1:-1,n&&(o=(o+s)%s),t[Math.max(0,Math.min(o,s-1))])},v=/[^.]*(?=\..*)\.|.*/,y=/\..*/,w=/::\d+$/,A={};let E=1;const T={mouseenter:"mouseover",mouseleave:"mouseout"},C=new Set(["click","dblclick","mouseup","mousedown","contextmenu","mousewheel","DOMMouseScroll","mouseover","mouseout","mousemove","selectstart","selectend","keydown","keypress","keyup","orientationchange","touchstart","touchmove","touchend","touchcancel","pointerdown","pointermove","pointerup","pointerleave","pointercancel","gesturestart","gesturechange","gestureend","focus","blur","change","reset","select","submit","focusin","focusout","load","unload","beforeunload","resize","move","DOMContentLoaded","readystatechange","error","abort","scroll"]);function O(t,e){return e&&`${e}::${E++}`||t.uidEvent||E++}function x(t){const e=O(t);return t.uidEvent=e,A[e]=A[e]||{},A[e]}function k(t,e,i=null){return Object.values(t).find((t=>t.callable===e&&t.delegationSelector===i))}function L(t,e,i){const n="string"==typeof e,s=n?i:e||i;let o=I(t);return C.has(o)||(o=t),[n,s,o]}function S(t,e,i,n,s){if("string"!=typeof e||!t)return;let[o,r,a]=L(e,i,n);if(e in T){const t=t=>function(e){if(!e.relatedTarget||e.relatedTarget!==e.delegateTarget&&!e.delegateTarget.contains(e.relatedTarget))return t.call(this,e)};r=t(r)}const l=x(t),c=l[a]||(l[a]={}),h=k(c,r,o?i:null);if(h)return void(h.oneOff=h.oneOff&&s);const d=O(r,e.replace(v,"")),u=o?function(t,e,i){return function n(s){const o=t.querySelectorAll(e);for(let{target:r}=s;r&&r!==this;r=r.parentNode)for(const a of o)if(a===r)return P(s,{delegateTarget:r}),n.oneOff&&N.off(t,s.type,e,i),i.apply(r,[s])}}(t,i,r):function(t,e){return function i(n){return P(n,{delegateTarget:t}),i.oneOff&&N.off(t,n.type,e),e.apply(t,[n])}}(t,r);u.delegationSelector=o?i:null,u.callable=r,u.oneOff=s,u.uidEvent=d,c[d]=u,t.addEventListener(a,u,o)}function D(t,e,i,n,s){const o=k(e[i],n,s);o&&(t.removeEventListener(i,o,Boolean(s)),delete e[i][o.uidEvent])}function $(t,e,i,n){const s=e[i]||{};for(const[o,r]of Object.entries(s))o.includes(n)&&D(t,e,i,r.callable,r.delegationSelector)}function I(t){return t=t.replace(y,""),T[t]||t}const N={on(t,e,i,n){S(t,e,i,n,!1)},one(t,e,i,n){S(t,e,i,n,!0)},off(t,e,i,n){if("string"!=typeof e||!t)return;const[s,o,r]=L(e,i,n),a=r!==e,l=x(t),c=l[r]||{},h=e.startsWith(".");if(void 0===o){if(h)for(const i of Object.keys(l))$(t,l,i,e.slice(1));for(const[i,n]of Object.entries(c)){const s=i.replace(w,"");a&&!e.includes(s)||D(t,l,r,n.callable,n.delegationSelector)}}else{if(!Object.keys(c).length)return;D(t,l,r,o,s?i:null)}},trigger(t,e,i){if("string"!=typeof e||!t)return null;const n=u();let s=null,o=!0,r=!0,a=!1;e!==I(e)&&n&&(s=n.Event(e,i),n(t).trigger(s),o=!s.isPropagationStopped(),r=!s.isImmediatePropagationStopped(),a=s.isDefaultPrevented());const l=P(new Event(e,{bubbles:o,cancelable:!0}),i);return a&&l.preventDefault(),r&&t.dispatchEvent(l),l.defaultPrevented&&s&&s.preventDefault(),l}};function P(t,e={}){for(const[i,n]of Object.entries(e))try{t[i]=n}catch(e){Object.defineProperty(t,i,{configurable:!0,get:()=>n})}return t}function j(t){if("true"===t)return!0;if("false"===t)return!1;if(t===Number(t).toString())return Number(t);if(""===t||"null"===t)return null;if("string"!=typeof t)return t;try{return JSON.parse(decodeURIComponent(t))}catch(e){return t}}function M(t){return t.replace(/[A-Z]/g,(t=>`-${t.toLowerCase()}`))}const F={setDataAttribute(t,e,i){t.setAttribute(`data-bs-${M(e)}`,i)},removeDataAttribute(t,e){t.removeAttribute(`data-bs-${M(e)}`)},getDataAttributes(t){if(!t)return{};const e={},i=Object.keys(t.dataset).filter((t=>t.startsWith("bs")&&!t.startsWith("bsConfig")));for(const n of i){let i=n.replace(/^bs/,"");i=i.charAt(0).toLowerCase()+i.slice(1),e[i]=j(t.dataset[n])}return e},getDataAttribute:(t,e)=>j(t.getAttribute(`data-bs-${M(e)}`))};class H{static get Default(){return{}}static get DefaultType(){return{}}static get NAME(){throw new Error('You have to implement the static method "NAME", for each component!')}_getConfig(t){return t=this._mergeConfigObj(t),t=this._configAfterMerge(t),this._typeCheckConfig(t),t}_configAfterMerge(t){return t}_mergeConfigObj(t,e){const i=o(e)?F.getDataAttribute(e,"config"):{};return{...this.constructor.Default,..."object"==typeof i?i:{},...o(e)?F.getDataAttributes(e):{},..."object"==typeof t?t:{}}}_typeCheckConfig(t,e=this.constructor.DefaultType){for(const[n,s]of Object.entries(e)){const e=t[n],r=o(e)?"element":null==(i=e)?`${i}`:Object.prototype.toString.call(i).match(/\s([a-z]+)/i)[1].toLowerCase();if(!new RegExp(s).test(r))throw new TypeError(`${this.constructor.NAME.toUpperCase()}: Option "${n}" provided type "${r}" but expected type "${s}".`)}var i}}class W extends H{constructor(t,i){super(),(t=r(t))&&(this._element=t,this._config=this._getConfig(i),e.set(this._element,this.constructor.DATA_KEY,this))}dispose(){e.remove(this._element,this.constructor.DATA_KEY),N.off(this._element,this.constructor.EVENT_KEY);for(const t of Object.getOwnPropertyNames(this))this[t]=null}_queueCallback(t,e,i=!0){_(t,e,i)}_getConfig(t){return t=this._mergeConfigObj(t,this._element),t=this._configAfterMerge(t),this._typeCheckConfig(t),t}static getInstance(t){return e.get(r(t),this.DATA_KEY)}static getOrCreateInstance(t,e={}){return this.getInstance(t)||new this(t,"object"==typeof e?e:null)}static get VERSION(){return"5.3.7"}static get DATA_KEY(){return`bs.${this.NAME}`}static get EVENT_KEY(){return`.${this.DATA_KEY}`}static eventName(t){return`${t}${this.EVENT_KEY}`}}const B=t=>{let e=t.getAttribute("data-bs-target");if(!e||"#"===e){let i=t.getAttribute("href");if(!i||!i.includes("#")&&!i.startsWith("."))return null;i.includes("#")&&!i.startsWith("#")&&(i=`#${i.split("#")[1]}`),e=i&&"#"!==i?i.trim():null}return e?e.split(",").map((t=>n(t))).join(","):null},z={find:(t,e=document.documentElement)=>[].concat(...Element.prototype.querySelectorAll.call(e,t)),findOne:(t,e=document.documentElement)=>Element.prototype.querySelector.call(e,t),children:(t,e)=>[].concat(...t.children).filter((t=>t.matches(e))),parents(t,e){const i=[];let n=t.parentNode.closest(e);for(;n;)i.push(n),n=n.parentNode.closest(e);return i},prev(t,e){let i=t.previousElementSibling;for(;i;){if(i.matches(e))return[i];i=i.previousElementSibling}return[]},next(t,e){let i=t.nextElementSibling;for(;i;){if(i.matches(e))return[i];i=i.nextElementSibling}return[]},focusableChildren(t){const e=["a","button","input","textarea","select","details","[tabindex]",'[contenteditable="true"]'].map((t=>`${t}:not([tabindex^="-"])`)).join(",");return this.find(e,t).filter((t=>!l(t)&&a(t)))},getSelectorFromElement(t){const e=B(t);return e&&z.findOne(e)?e:null},getElementFromSelector(t){const e=B(t);return e?z.findOne(e):null},getMultipleElementsFromSelector(t){const e=B(t);return e?z.find(e):[]}},R=(t,e="hide")=>{const i=`click.dismiss${t.EVENT_KEY}`,n=t.NAME;N.on(document,i,`[data-bs-dismiss="${n}"]`,(function(i){if(["A","AREA"].includes(this.tagName)&&i.preventDefault(),l(this))return;const s=z.getElementFromSelector(this)||this.closest(`.${n}`);t.getOrCreateInstance(s)[e]()}))},q=".bs.alert",V=`close${q}`,K=`closed${q}`;class Q extends W{static get NAME(){return"alert"}close(){if(N.trigger(this._element,V).defaultPrevented)return;this._element.classList.remove("show");const t=this._element.classList.contains("fade");this._queueCallback((()=>this._destroyElement()),this._element,t)}_destroyElement(){this._element.remove(),N.trigger(this._element,K),this.dispose()}static jQueryInterface(t){return this.each((function(){const e=Q.getOrCreateInstance(this);if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t](this)}}))}}R(Q,"close"),m(Q);const X='[data-bs-toggle="button"]';class Y extends W{static get NAME(){return"button"}toggle(){this._element.setAttribute("aria-pressed",this._element.classList.toggle("active"))}static jQueryInterface(t){return this.each((function(){const e=Y.getOrCreateInstance(this);"toggle"===t&&e[t]()}))}}N.on(document,"click.bs.button.data-api",X,(t=>{t.preventDefault();const e=t.target.closest(X);Y.getOrCreateInstance(e).toggle()})),m(Y);const U=".bs.swipe",G=`touchstart${U}`,J=`touchmove${U}`,Z=`touchend${U}`,tt=`pointerdown${U}`,et=`pointerup${U}`,it={endCallback:null,leftCallback:null,rightCallback:null},nt={endCallback:"(function|null)",leftCallback:"(function|null)",rightCallback:"(function|null)"};class st extends H{constructor(t,e){super(),this._element=t,t&&st.isSupported()&&(this._config=this._getConfig(e),this._deltaX=0,this._supportPointerEvents=Boolean(window.PointerEvent),this._initEvents())}static get Default(){return it}static get DefaultType(){return nt}static get NAME(){return"swipe"}dispose(){N.off(this._element,U)}_start(t){this._supportPointerEvents?this._eventIsPointerPenTouch(t)&&(this._deltaX=t.clientX):this._deltaX=t.touches[0].clientX}_end(t){this._eventIsPointerPenTouch(t)&&(this._deltaX=t.clientX-this._deltaX),this._handleSwipe(),g(this._config.endCallback)}_move(t){this._deltaX=t.touches&&t.touches.length>1?0:t.touches[0].clientX-this._deltaX}_handleSwipe(){const t=Math.abs(this._deltaX);if(t<=40)return;const e=t/this._deltaX;this._deltaX=0,e&&g(e>0?this._config.rightCallback:this._config.leftCallback)}_initEvents(){this._supportPointerEvents?(N.on(this._element,tt,(t=>this._start(t))),N.on(this._element,et,(t=>this._end(t))),this._element.classList.add("pointer-event")):(N.on(this._element,G,(t=>this._start(t))),N.on(this._element,J,(t=>this._move(t))),N.on(this._element,Z,(t=>this._end(t))))}_eventIsPointerPenTouch(t){return this._supportPointerEvents&&("pen"===t.pointerType||"touch"===t.pointerType)}static isSupported(){return"ontouchstart"in document.documentElement||navigator.maxTouchPoints>0}}const ot=".bs.carousel",rt=".data-api",at="ArrowLeft",lt="ArrowRight",ct="next",ht="prev",dt="left",ut="right",ft=`slide${ot}`,pt=`slid${ot}`,mt=`keydown${ot}`,gt=`mouseenter${ot}`,_t=`mouseleave${ot}`,bt=`dragstart${ot}`,vt=`load${ot}${rt}`,yt=`click${ot}${rt}`,wt="carousel",At="active",Et=".active",Tt=".carousel-item",Ct=Et+Tt,Ot={[at]:ut,[lt]:dt},xt={interval:5e3,keyboard:!0,pause:"hover",ride:!1,touch:!0,wrap:!0},kt={interval:"(number|boolean)",keyboard:"boolean",pause:"(string|boolean)",ride:"(boolean|string)",touch:"boolean",wrap:"boolean"};class Lt extends W{constructor(t,e){super(t,e),this._interval=null,this._activeElement=null,this._isSliding=!1,this.touchTimeout=null,this._swipeHelper=null,this._indicatorsElement=z.findOne(".carousel-indicators",this._element),this._addEventListeners(),this._config.ride===wt&&this.cycle()}static get Default(){return xt}static get DefaultType(){return kt}static get NAME(){return"carousel"}next(){this._slide(ct)}nextWhenVisible(){!document.hidden&&a(this._element)&&this.next()}prev(){this._slide(ht)}pause(){this._isSliding&&s(this._element),this._clearInterval()}cycle(){this._clearInterval(),this._updateInterval(),this._interval=setInterval((()=>this.nextWhenVisible()),this._config.interval)}_maybeEnableCycle(){this._config.ride&&(this._isSliding?N.one(this._element,pt,(()=>this.cycle())):this.cycle())}to(t){const e=this._getItems();if(t>e.length-1||t<0)return;if(this._isSliding)return void N.one(this._element,pt,(()=>this.to(t)));const i=this._getItemIndex(this._getActive());if(i===t)return;const n=t>i?ct:ht;this._slide(n,e[t])}dispose(){this._swipeHelper&&this._swipeHelper.dispose(),super.dispose()}_configAfterMerge(t){return t.defaultInterval=t.interval,t}_addEventListeners(){this._config.keyboard&&N.on(this._element,mt,(t=>this._keydown(t))),"hover"===this._config.pause&&(N.on(this._element,gt,(()=>this.pause())),N.on(this._element,_t,(()=>this._maybeEnableCycle()))),this._config.touch&&st.isSupported()&&this._addTouchEventListeners()}_addTouchEventListeners(){for(const t of z.find(".carousel-item img",this._element))N.on(t,bt,(t=>t.preventDefault()));const t={leftCallback:()=>this._slide(this._directionToOrder(dt)),rightCallback:()=>this._slide(this._directionToOrder(ut)),endCallback:()=>{"hover"===this._config.pause&&(this.pause(),this.touchTimeout&&clearTimeout(this.touchTimeout),this.touchTimeout=setTimeout((()=>this._maybeEnableCycle()),500+this._config.interval))}};this._swipeHelper=new st(this._element,t)}_keydown(t){if(/input|textarea/i.test(t.target.tagName))return;const e=Ot[t.key];e&&(t.preventDefault(),this._slide(this._directionToOrder(e)))}_getItemIndex(t){return this._getItems().indexOf(t)}_setActiveIndicatorElement(t){if(!this._indicatorsElement)return;const e=z.findOne(Et,this._indicatorsElement);e.classList.remove(At),e.removeAttribute("aria-current");const i=z.findOne(`[data-bs-slide-to="${t}"]`,this._indicatorsElement);i&&(i.classList.add(At),i.setAttribute("aria-current","true"))}_updateInterval(){const t=this._activeElement||this._getActive();if(!t)return;const e=Number.parseInt(t.getAttribute("data-bs-interval"),10);this._config.interval=e||this._config.defaultInterval}_slide(t,e=null){if(this._isSliding)return;const i=this._getActive(),n=t===ct,s=e||b(this._getItems(),i,n,this._config.wrap);if(s===i)return;const o=this._getItemIndex(s),r=e=>N.trigger(this._element,e,{relatedTarget:s,direction:this._orderToDirection(t),from:this._getItemIndex(i),to:o});if(r(ft).defaultPrevented)return;if(!i||!s)return;const a=Boolean(this._interval);this.pause(),this._isSliding=!0,this._setActiveIndicatorElement(o),this._activeElement=s;const l=n?"carousel-item-start":"carousel-item-end",c=n?"carousel-item-next":"carousel-item-prev";s.classList.add(c),d(s),i.classList.add(l),s.classList.add(l),this._queueCallback((()=>{s.classList.remove(l,c),s.classList.add(At),i.classList.remove(At,c,l),this._isSliding=!1,r(pt)}),i,this._isAnimated()),a&&this.cycle()}_isAnimated(){return this._element.classList.contains("slide")}_getActive(){return z.findOne(Ct,this._element)}_getItems(){return z.find(Tt,this._element)}_clearInterval(){this._interval&&(clearInterval(this._interval),this._interval=null)}_directionToOrder(t){return p()?t===dt?ht:ct:t===dt?ct:ht}_orderToDirection(t){return p()?t===ht?dt:ut:t===ht?ut:dt}static jQueryInterface(t){return this.each((function(){const e=Lt.getOrCreateInstance(this,t);if("number"!=typeof t){if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t]()}}else e.to(t)}))}}N.on(document,yt,"[data-bs-slide], [data-bs-slide-to]",(function(t){const e=z.getElementFromSelector(this);if(!e||!e.classList.contains(wt))return;t.preventDefault();const i=Lt.getOrCreateInstance(e),n=this.getAttribute("data-bs-slide-to");return n?(i.to(n),void i._maybeEnableCycle()):"next"===F.getDataAttribute(this,"slide")?(i.next(),void i._maybeEnableCycle()):(i.prev(),void i._maybeEnableCycle())})),N.on(window,vt,(()=>{const t=z.find('[data-bs-ride="carousel"]');for(const e of t)Lt.getOrCreateInstance(e)})),m(Lt);const St=".bs.collapse",Dt=`show${St}`,$t=`shown${St}`,It=`hide${St}`,Nt=`hidden${St}`,Pt=`click${St}.data-api`,jt="show",Mt="collapse",Ft="collapsing",Ht=`:scope .${Mt} .${Mt}`,Wt='[data-bs-toggle="collapse"]',Bt={parent:null,toggle:!0},zt={parent:"(null|element)",toggle:"boolean"};class Rt extends W{constructor(t,e){super(t,e),this._isTransitioning=!1,this._triggerArray=[];const i=z.find(Wt);for(const t of i){const e=z.getSelectorFromElement(t),i=z.find(e).filter((t=>t===this._element));null!==e&&i.length&&this._triggerArray.push(t)}this._initializeChildren(),this._config.parent||this._addAriaAndCollapsedClass(this._triggerArray,this._isShown()),this._config.toggle&&this.toggle()}static get Default(){return Bt}static get DefaultType(){return zt}static get NAME(){return"collapse"}toggle(){this._isShown()?this.hide():this.show()}show(){if(this._isTransitioning||this._isShown())return;let t=[];if(this._config.parent&&(t=this._getFirstLevelChildren(".collapse.show, .collapse.collapsing").filter((t=>t!==this._element)).map((t=>Rt.getOrCreateInstance(t,{toggle:!1})))),t.length&&t[0]._isTransitioning)return;if(N.trigger(this._element,Dt).defaultPrevented)return;for(const e of t)e.hide();const e=this._getDimension();this._element.classList.remove(Mt),this._element.classList.add(Ft),this._element.style[e]=0,this._addAriaAndCollapsedClass(this._triggerArray,!0),this._isTransitioning=!0;const i=`scroll${e[0].toUpperCase()+e.slice(1)}`;this._queueCallback((()=>{this._isTransitioning=!1,this._element.classList.remove(Ft),this._element.classList.add(Mt,jt),this._element.style[e]="",N.trigger(this._element,$t)}),this._element,!0),this._element.style[e]=`${this._element[i]}px`}hide(){if(this._isTransitioning||!this._isShown())return;if(N.trigger(this._element,It).defaultPrevented)return;const t=this._getDimension();this._element.style[t]=`${this._element.getBoundingClientRect()[t]}px`,d(this._element),this._element.classList.add(Ft),this._element.classList.remove(Mt,jt);for(const t of this._triggerArray){const e=z.getElementFromSelector(t);e&&!this._isShown(e)&&this._addAriaAndCollapsedClass([t],!1)}this._isTransitioning=!0,this._element.style[t]="",this._queueCallback((()=>{this._isTransitioning=!1,this._element.classList.remove(Ft),this._element.classList.add(Mt),N.trigger(this._element,Nt)}),this._element,!0)}_isShown(t=this._element){return t.classList.contains(jt)}_configAfterMerge(t){return t.toggle=Boolean(t.toggle),t.parent=r(t.parent),t}_getDimension(){return this._element.classList.contains("collapse-horizontal")?"width":"height"}_initializeChildren(){if(!this._config.parent)return;const t=this._getFirstLevelChildren(Wt);for(const e of t){const t=z.getElementFromSelector(e);t&&this._addAriaAndCollapsedClass([e],this._isShown(t))}}_getFirstLevelChildren(t){const e=z.find(Ht,this._config.parent);return z.find(t,this._config.parent).filter((t=>!e.includes(t)))}_addAriaAndCollapsedClass(t,e){if(t.length)for(const i of t)i.classList.toggle("collapsed",!e),i.setAttribute("aria-expanded",e)}static jQueryInterface(t){const e={};return"string"==typeof t&&/show|hide/.test(t)&&(e.toggle=!1),this.each((function(){const i=Rt.getOrCreateInstance(this,e);if("string"==typeof t){if(void 0===i[t])throw new TypeError(`No method named "${t}"`);i[t]()}}))}}N.on(document,Pt,Wt,(function(t){("A"===t.target.tagName||t.delegateTarget&&"A"===t.delegateTarget.tagName)&&t.preventDefault();for(const t of z.getMultipleElementsFromSelector(this))Rt.getOrCreateInstance(t,{toggle:!1}).toggle()})),m(Rt);var qt="top",Vt="bottom",Kt="right",Qt="left",Xt="auto",Yt=[qt,Vt,Kt,Qt],Ut="start",Gt="end",Jt="clippingParents",Zt="viewport",te="popper",ee="reference",ie=Yt.reduce((function(t,e){return t.concat([e+"-"+Ut,e+"-"+Gt])}),[]),ne=[].concat(Yt,[Xt]).reduce((function(t,e){return t.concat([e,e+"-"+Ut,e+"-"+Gt])}),[]),se="beforeRead",oe="read",re="afterRead",ae="beforeMain",le="main",ce="afterMain",he="beforeWrite",de="write",ue="afterWrite",fe=[se,oe,re,ae,le,ce,he,de,ue];function pe(t){return t?(t.nodeName||"").toLowerCase():null}function me(t){if(null==t)return window;if("[object Window]"!==t.toString()){var e=t.ownerDocument;return e&&e.defaultView||window}return t}function ge(t){return t instanceof me(t).Element||t instanceof Element}function _e(t){return t instanceof me(t).HTMLElement||t instanceof HTMLElement}function be(t){return"undefined"!=typeof ShadowRoot&&(t instanceof me(t).ShadowRoot||t instanceof ShadowRoot)}const ve={name:"applyStyles",enabled:!0,phase:"write",fn:function(t){var e=t.state;Object.keys(e.elements).forEach((function(t){var i=e.styles[t]||{},n=e.attributes[t]||{},s=e.elements[t];_e(s)&&pe(s)&&(Object.assign(s.style,i),Object.keys(n).forEach((function(t){var e=n[t];!1===e?s.removeAttribute(t):s.setAttribute(t,!0===e?"":e)})))}))},effect:function(t){var e=t.state,i={popper:{position:e.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(e.elements.popper.style,i.popper),e.styles=i,e.elements.arrow&&Object.assign(e.elements.arrow.style,i.arrow),function(){Object.keys(e.elements).forEach((function(t){var n=e.elements[t],s=e.attributes[t]||{},o=Object.keys(e.styles.hasOwnProperty(t)?e.styles[t]:i[t]).reduce((function(t,e){return t[e]="",t}),{});_e(n)&&pe(n)&&(Object.assign(n.style,o),Object.keys(s).forEach((function(t){n.removeAttribute(t)})))}))}},requires:["computeStyles"]};function ye(t){return t.split("-")[0]}var we=Math.max,Ae=Math.min,Ee=Math.round;function Te(){var t=navigator.userAgentData;return null!=t&&t.brands&&Array.isArray(t.brands)?t.brands.map((function(t){return t.brand+"/"+t.version})).join(" "):navigator.userAgent}function Ce(){return!/^((?!chrome|android).)*safari/i.test(Te())}function Oe(t,e,i){void 0===e&&(e=!1),void 0===i&&(i=!1);var n=t.getBoundingClientRect(),s=1,o=1;e&&_e(t)&&(s=t.offsetWidth>0&&Ee(n.width)/t.offsetWidth||1,o=t.offsetHeight>0&&Ee(n.height)/t.offsetHeight||1);var r=(ge(t)?me(t):window).visualViewport,a=!Ce()&&i,l=(n.left+(a&&r?r.offsetLeft:0))/s,c=(n.top+(a&&r?r.offsetTop:0))/o,h=n.width/s,d=n.height/o;return{width:h,height:d,top:c,right:l+h,bottom:c+d,left:l,x:l,y:c}}function xe(t){var e=Oe(t),i=t.offsetWidth,n=t.offsetHeight;return Math.abs(e.width-i)<=1&&(i=e.width),Math.abs(e.height-n)<=1&&(n=e.height),{x:t.offsetLeft,y:t.offsetTop,width:i,height:n}}function ke(t,e){var i=e.getRootNode&&e.getRootNode();if(t.contains(e))return!0;if(i&&be(i)){var n=e;do{if(n&&t.isSameNode(n))return!0;n=n.parentNode||n.host}while(n)}return!1}function Le(t){return me(t).getComputedStyle(t)}function Se(t){return["table","td","th"].indexOf(pe(t))>=0}function De(t){return((ge(t)?t.ownerDocument:t.document)||window.document).documentElement}function $e(t){return"html"===pe(t)?t:t.assignedSlot||t.parentNode||(be(t)?t.host:null)||De(t)}function Ie(t){return _e(t)&&"fixed"!==Le(t).position?t.offsetParent:null}function Ne(t){for(var e=me(t),i=Ie(t);i&&Se(i)&&"static"===Le(i).position;)i=Ie(i);return i&&("html"===pe(i)||"body"===pe(i)&&"static"===Le(i).position)?e:i||function(t){var e=/firefox/i.test(Te());if(/Trident/i.test(Te())&&_e(t)&&"fixed"===Le(t).position)return null;var i=$e(t);for(be(i)&&(i=i.host);_e(i)&&["html","body"].indexOf(pe(i))<0;){var n=Le(i);if("none"!==n.transform||"none"!==n.perspective||"paint"===n.contain||-1!==["transform","perspective"].indexOf(n.willChange)||e&&"filter"===n.willChange||e&&n.filter&&"none"!==n.filter)return i;i=i.parentNode}return null}(t)||e}function Pe(t){return["top","bottom"].indexOf(t)>=0?"x":"y"}function je(t,e,i){return we(t,Ae(e,i))}function Me(t){return Object.assign({},{top:0,right:0,bottom:0,left:0},t)}function Fe(t,e){return e.reduce((function(e,i){return e[i]=t,e}),{})}const He={name:"arrow",enabled:!0,phase:"main",fn:function(t){var e,i=t.state,n=t.name,s=t.options,o=i.elements.arrow,r=i.modifiersData.popperOffsets,a=ye(i.placement),l=Pe(a),c=[Qt,Kt].indexOf(a)>=0?"height":"width";if(o&&r){var h=function(t,e){return Me("number"!=typeof(t="function"==typeof t?t(Object.assign({},e.rects,{placement:e.placement})):t)?t:Fe(t,Yt))}(s.padding,i),d=xe(o),u="y"===l?qt:Qt,f="y"===l?Vt:Kt,p=i.rects.reference[c]+i.rects.reference[l]-r[l]-i.rects.popper[c],m=r[l]-i.rects.reference[l],g=Ne(o),_=g?"y"===l?g.clientHeight||0:g.clientWidth||0:0,b=p/2-m/2,v=h[u],y=_-d[c]-h[f],w=_/2-d[c]/2+b,A=je(v,w,y),E=l;i.modifiersData[n]=((e={})[E]=A,e.centerOffset=A-w,e)}},effect:function(t){var e=t.state,i=t.options.element,n=void 0===i?"[data-popper-arrow]":i;null!=n&&("string"!=typeof n||(n=e.elements.popper.querySelector(n)))&&ke(e.elements.popper,n)&&(e.elements.arrow=n)},requires:["popperOffsets"],requiresIfExists:["preventOverflow"]};function We(t){return t.split("-")[1]}var Be={top:"auto",right:"auto",bottom:"auto",left:"auto"};function ze(t){var e,i=t.popper,n=t.popperRect,s=t.placement,o=t.variation,r=t.offsets,a=t.position,l=t.gpuAcceleration,c=t.adaptive,h=t.roundOffsets,d=t.isFixed,u=r.x,f=void 0===u?0:u,p=r.y,m=void 0===p?0:p,g="function"==typeof h?h({x:f,y:m}):{x:f,y:m};f=g.x,m=g.y;var _=r.hasOwnProperty("x"),b=r.hasOwnProperty("y"),v=Qt,y=qt,w=window;if(c){var A=Ne(i),E="clientHeight",T="clientWidth";A===me(i)&&"static"!==Le(A=De(i)).position&&"absolute"===a&&(E="scrollHeight",T="scrollWidth"),(s===qt||(s===Qt||s===Kt)&&o===Gt)&&(y=Vt,m-=(d&&A===w&&w.visualViewport?w.visualViewport.height:A[E])-n.height,m*=l?1:-1),s!==Qt&&(s!==qt&&s!==Vt||o!==Gt)||(v=Kt,f-=(d&&A===w&&w.visualViewport?w.visualViewport.width:A[T])-n.width,f*=l?1:-1)}var C,O=Object.assign({position:a},c&&Be),x=!0===h?function(t,e){var i=t.x,n=t.y,s=e.devicePixelRatio||1;return{x:Ee(i*s)/s||0,y:Ee(n*s)/s||0}}({x:f,y:m},me(i)):{x:f,y:m};return f=x.x,m=x.y,l?Object.assign({},O,((C={})[y]=b?"0":"",C[v]=_?"0":"",C.transform=(w.devicePixelRatio||1)<=1?"translate("+f+"px, "+m+"px)":"translate3d("+f+"px, "+m+"px, 0)",C)):Object.assign({},O,((e={})[y]=b?m+"px":"",e[v]=_?f+"px":"",e.transform="",e))}const Re={name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:function(t){var e=t.state,i=t.options,n=i.gpuAcceleration,s=void 0===n||n,o=i.adaptive,r=void 0===o||o,a=i.roundOffsets,l=void 0===a||a,c={placement:ye(e.placement),variation:We(e.placement),popper:e.elements.popper,popperRect:e.rects.popper,gpuAcceleration:s,isFixed:"fixed"===e.options.strategy};null!=e.modifiersData.popperOffsets&&(e.styles.popper=Object.assign({},e.styles.popper,ze(Object.assign({},c,{offsets:e.modifiersData.popperOffsets,position:e.options.strategy,adaptive:r,roundOffsets:l})))),null!=e.modifiersData.arrow&&(e.styles.arrow=Object.assign({},e.styles.arrow,ze(Object.assign({},c,{offsets:e.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:l})))),e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-placement":e.placement})},data:{}};var qe={passive:!0};const Ve={name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:function(t){var e=t.state,i=t.instance,n=t.options,s=n.scroll,o=void 0===s||s,r=n.resize,a=void 0===r||r,l=me(e.elements.popper),c=[].concat(e.scrollParents.reference,e.scrollParents.popper);return o&&c.forEach((function(t){t.addEventListener("scroll",i.update,qe)})),a&&l.addEventListener("resize",i.update,qe),function(){o&&c.forEach((function(t){t.removeEventListener("scroll",i.update,qe)})),a&&l.removeEventListener("resize",i.update,qe)}},data:{}};var Ke={left:"right",right:"left",bottom:"top",top:"bottom"};function Qe(t){return t.replace(/left|right|bottom|top/g,(function(t){return Ke[t]}))}var Xe={start:"end",end:"start"};function Ye(t){return t.replace(/start|end/g,(function(t){return Xe[t]}))}function Ue(t){var e=me(t);return{scrollLeft:e.pageXOffset,scrollTop:e.pageYOffset}}function Ge(t){return Oe(De(t)).left+Ue(t).scrollLeft}function Je(t){var e=Le(t),i=e.overflow,n=e.overflowX,s=e.overflowY;return/auto|scroll|overlay|hidden/.test(i+s+n)}function Ze(t){return["html","body","#document"].indexOf(pe(t))>=0?t.ownerDocument.body:_e(t)&&Je(t)?t:Ze($e(t))}function ti(t,e){var i;void 0===e&&(e=[]);var n=Ze(t),s=n===(null==(i=t.ownerDocument)?void 0:i.body),o=me(n),r=s?[o].concat(o.visualViewport||[],Je(n)?n:[]):n,a=e.concat(r);return s?a:a.concat(ti($e(r)))}function ei(t){return Object.assign({},t,{left:t.x,top:t.y,right:t.x+t.width,bottom:t.y+t.height})}function ii(t,e,i){return e===Zt?ei(function(t,e){var i=me(t),n=De(t),s=i.visualViewport,o=n.clientWidth,r=n.clientHeight,a=0,l=0;if(s){o=s.width,r=s.height;var c=Ce();(c||!c&&"fixed"===e)&&(a=s.offsetLeft,l=s.offsetTop)}return{width:o,height:r,x:a+Ge(t),y:l}}(t,i)):ge(e)?function(t,e){var i=Oe(t,!1,"fixed"===e);return i.top=i.top+t.clientTop,i.left=i.left+t.clientLeft,i.bottom=i.top+t.clientHeight,i.right=i.left+t.clientWidth,i.width=t.clientWidth,i.height=t.clientHeight,i.x=i.left,i.y=i.top,i}(e,i):ei(function(t){var e,i=De(t),n=Ue(t),s=null==(e=t.ownerDocument)?void 0:e.body,o=we(i.scrollWidth,i.clientWidth,s?s.scrollWidth:0,s?s.clientWidth:0),r=we(i.scrollHeight,i.clientHeight,s?s.scrollHeight:0,s?s.clientHeight:0),a=-n.scrollLeft+Ge(t),l=-n.scrollTop;return"rtl"===Le(s||i).direction&&(a+=we(i.clientWidth,s?s.clientWidth:0)-o),{width:o,height:r,x:a,y:l}}(De(t)))}function ni(t){var e,i=t.reference,n=t.element,s=t.placement,o=s?ye(s):null,r=s?We(s):null,a=i.x+i.width/2-n.width/2,l=i.y+i.height/2-n.height/2;switch(o){case qt:e={x:a,y:i.y-n.height};break;case Vt:e={x:a,y:i.y+i.height};break;case Kt:e={x:i.x+i.width,y:l};break;case Qt:e={x:i.x-n.width,y:l};break;default:e={x:i.x,y:i.y}}var c=o?Pe(o):null;if(null!=c){var h="y"===c?"height":"width";switch(r){case Ut:e[c]=e[c]-(i[h]/2-n[h]/2);break;case Gt:e[c]=e[c]+(i[h]/2-n[h]/2)}}return e}function si(t,e){void 0===e&&(e={});var i=e,n=i.placement,s=void 0===n?t.placement:n,o=i.strategy,r=void 0===o?t.strategy:o,a=i.boundary,l=void 0===a?Jt:a,c=i.rootBoundary,h=void 0===c?Zt:c,d=i.elementContext,u=void 0===d?te:d,f=i.altBoundary,p=void 0!==f&&f,m=i.padding,g=void 0===m?0:m,_=Me("number"!=typeof g?g:Fe(g,Yt)),b=u===te?ee:te,v=t.rects.popper,y=t.elements[p?b:u],w=function(t,e,i,n){var s="clippingParents"===e?function(t){var e=ti($e(t)),i=["absolute","fixed"].indexOf(Le(t).position)>=0&&_e(t)?Ne(t):t;return ge(i)?e.filter((function(t){return ge(t)&&ke(t,i)&&"body"!==pe(t)})):[]}(t):[].concat(e),o=[].concat(s,[i]),r=o[0],a=o.reduce((function(e,i){var s=ii(t,i,n);return e.top=we(s.top,e.top),e.right=Ae(s.right,e.right),e.bottom=Ae(s.bottom,e.bottom),e.left=we(s.left,e.left),e}),ii(t,r,n));return a.width=a.right-a.left,a.height=a.bottom-a.top,a.x=a.left,a.y=a.top,a}(ge(y)?y:y.contextElement||De(t.elements.popper),l,h,r),A=Oe(t.elements.reference),E=ni({reference:A,element:v,placement:s}),T=ei(Object.assign({},v,E)),C=u===te?T:A,O={top:w.top-C.top+_.top,bottom:C.bottom-w.bottom+_.bottom,left:w.left-C.left+_.left,right:C.right-w.right+_.right},x=t.modifiersData.offset;if(u===te&&x){var k=x[s];Object.keys(O).forEach((function(t){var e=[Kt,Vt].indexOf(t)>=0?1:-1,i=[qt,Vt].indexOf(t)>=0?"y":"x";O[t]+=k[i]*e}))}return O}function oi(t,e){void 0===e&&(e={});var i=e,n=i.placement,s=i.boundary,o=i.rootBoundary,r=i.padding,a=i.flipVariations,l=i.allowedAutoPlacements,c=void 0===l?ne:l,h=We(n),d=h?a?ie:ie.filter((function(t){return We(t)===h})):Yt,u=d.filter((function(t){return c.indexOf(t)>=0}));0===u.length&&(u=d);var f=u.reduce((function(e,i){return e[i]=si(t,{placement:i,boundary:s,rootBoundary:o,padding:r})[ye(i)],e}),{});return Object.keys(f).sort((function(t,e){return f[t]-f[e]}))}const ri={name:"flip",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,n=t.name;if(!e.modifiersData[n]._skip){for(var s=i.mainAxis,o=void 0===s||s,r=i.altAxis,a=void 0===r||r,l=i.fallbackPlacements,c=i.padding,h=i.boundary,d=i.rootBoundary,u=i.altBoundary,f=i.flipVariations,p=void 0===f||f,m=i.allowedAutoPlacements,g=e.options.placement,_=ye(g),b=l||(_!==g&&p?function(t){if(ye(t)===Xt)return[];var e=Qe(t);return[Ye(t),e,Ye(e)]}(g):[Qe(g)]),v=[g].concat(b).reduce((function(t,i){return t.concat(ye(i)===Xt?oi(e,{placement:i,boundary:h,rootBoundary:d,padding:c,flipVariations:p,allowedAutoPlacements:m}):i)}),[]),y=e.rects.reference,w=e.rects.popper,A=new Map,E=!0,T=v[0],C=0;C=0,S=L?"width":"height",D=si(e,{placement:O,boundary:h,rootBoundary:d,altBoundary:u,padding:c}),$=L?k?Kt:Qt:k?Vt:qt;y[S]>w[S]&&($=Qe($));var I=Qe($),N=[];if(o&&N.push(D[x]<=0),a&&N.push(D[$]<=0,D[I]<=0),N.every((function(t){return t}))){T=O,E=!1;break}A.set(O,N)}if(E)for(var P=function(t){var e=v.find((function(e){var i=A.get(e);if(i)return i.slice(0,t).every((function(t){return t}))}));if(e)return T=e,"break"},j=p?3:1;j>0&&"break"!==P(j);j--);e.placement!==T&&(e.modifiersData[n]._skip=!0,e.placement=T,e.reset=!0)}},requiresIfExists:["offset"],data:{_skip:!1}};function ai(t,e,i){return void 0===i&&(i={x:0,y:0}),{top:t.top-e.height-i.y,right:t.right-e.width+i.x,bottom:t.bottom-e.height+i.y,left:t.left-e.width-i.x}}function li(t){return[qt,Kt,Vt,Qt].some((function(e){return t[e]>=0}))}const ci={name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:function(t){var e=t.state,i=t.name,n=e.rects.reference,s=e.rects.popper,o=e.modifiersData.preventOverflow,r=si(e,{elementContext:"reference"}),a=si(e,{altBoundary:!0}),l=ai(r,n),c=ai(a,s,o),h=li(l),d=li(c);e.modifiersData[i]={referenceClippingOffsets:l,popperEscapeOffsets:c,isReferenceHidden:h,hasPopperEscaped:d},e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-reference-hidden":h,"data-popper-escaped":d})}},hi={name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:function(t){var e=t.state,i=t.options,n=t.name,s=i.offset,o=void 0===s?[0,0]:s,r=ne.reduce((function(t,i){return t[i]=function(t,e,i){var n=ye(t),s=[Qt,qt].indexOf(n)>=0?-1:1,o="function"==typeof i?i(Object.assign({},e,{placement:t})):i,r=o[0],a=o[1];return r=r||0,a=(a||0)*s,[Qt,Kt].indexOf(n)>=0?{x:a,y:r}:{x:r,y:a}}(i,e.rects,o),t}),{}),a=r[e.placement],l=a.x,c=a.y;null!=e.modifiersData.popperOffsets&&(e.modifiersData.popperOffsets.x+=l,e.modifiersData.popperOffsets.y+=c),e.modifiersData[n]=r}},di={name:"popperOffsets",enabled:!0,phase:"read",fn:function(t){var e=t.state,i=t.name;e.modifiersData[i]=ni({reference:e.rects.reference,element:e.rects.popper,placement:e.placement})},data:{}},ui={name:"preventOverflow",enabled:!0,phase:"main",fn:function(t){var e=t.state,i=t.options,n=t.name,s=i.mainAxis,o=void 0===s||s,r=i.altAxis,a=void 0!==r&&r,l=i.boundary,c=i.rootBoundary,h=i.altBoundary,d=i.padding,u=i.tether,f=void 0===u||u,p=i.tetherOffset,m=void 0===p?0:p,g=si(e,{boundary:l,rootBoundary:c,padding:d,altBoundary:h}),_=ye(e.placement),b=We(e.placement),v=!b,y=Pe(_),w="x"===y?"y":"x",A=e.modifiersData.popperOffsets,E=e.rects.reference,T=e.rects.popper,C="function"==typeof m?m(Object.assign({},e.rects,{placement:e.placement})):m,O="number"==typeof C?{mainAxis:C,altAxis:C}:Object.assign({mainAxis:0,altAxis:0},C),x=e.modifiersData.offset?e.modifiersData.offset[e.placement]:null,k={x:0,y:0};if(A){if(o){var L,S="y"===y?qt:Qt,D="y"===y?Vt:Kt,$="y"===y?"height":"width",I=A[y],N=I+g[S],P=I-g[D],j=f?-T[$]/2:0,M=b===Ut?E[$]:T[$],F=b===Ut?-T[$]:-E[$],H=e.elements.arrow,W=f&&H?xe(H):{width:0,height:0},B=e.modifiersData["arrow#persistent"]?e.modifiersData["arrow#persistent"].padding:{top:0,right:0,bottom:0,left:0},z=B[S],R=B[D],q=je(0,E[$],W[$]),V=v?E[$]/2-j-q-z-O.mainAxis:M-q-z-O.mainAxis,K=v?-E[$]/2+j+q+R+O.mainAxis:F+q+R+O.mainAxis,Q=e.elements.arrow&&Ne(e.elements.arrow),X=Q?"y"===y?Q.clientTop||0:Q.clientLeft||0:0,Y=null!=(L=null==x?void 0:x[y])?L:0,U=I+K-Y,G=je(f?Ae(N,I+V-Y-X):N,I,f?we(P,U):P);A[y]=G,k[y]=G-I}if(a){var J,Z="x"===y?qt:Qt,tt="x"===y?Vt:Kt,et=A[w],it="y"===w?"height":"width",nt=et+g[Z],st=et-g[tt],ot=-1!==[qt,Qt].indexOf(_),rt=null!=(J=null==x?void 0:x[w])?J:0,at=ot?nt:et-E[it]-T[it]-rt+O.altAxis,lt=ot?et+E[it]+T[it]-rt-O.altAxis:st,ct=f&&ot?function(t,e,i){var n=je(t,e,i);return n>i?i:n}(at,et,lt):je(f?at:nt,et,f?lt:st);A[w]=ct,k[w]=ct-et}e.modifiersData[n]=k}},requiresIfExists:["offset"]};function fi(t,e,i){void 0===i&&(i=!1);var n,s,o=_e(e),r=_e(e)&&function(t){var e=t.getBoundingClientRect(),i=Ee(e.width)/t.offsetWidth||1,n=Ee(e.height)/t.offsetHeight||1;return 1!==i||1!==n}(e),a=De(e),l=Oe(t,r,i),c={scrollLeft:0,scrollTop:0},h={x:0,y:0};return(o||!o&&!i)&&(("body"!==pe(e)||Je(a))&&(c=(n=e)!==me(n)&&_e(n)?{scrollLeft:(s=n).scrollLeft,scrollTop:s.scrollTop}:Ue(n)),_e(e)?((h=Oe(e,!0)).x+=e.clientLeft,h.y+=e.clientTop):a&&(h.x=Ge(a))),{x:l.left+c.scrollLeft-h.x,y:l.top+c.scrollTop-h.y,width:l.width,height:l.height}}function pi(t){var e=new Map,i=new Set,n=[];function s(t){i.add(t.name),[].concat(t.requires||[],t.requiresIfExists||[]).forEach((function(t){if(!i.has(t)){var n=e.get(t);n&&s(n)}})),n.push(t)}return t.forEach((function(t){e.set(t.name,t)})),t.forEach((function(t){i.has(t.name)||s(t)})),n}var mi={placement:"bottom",modifiers:[],strategy:"absolute"};function gi(){for(var t=arguments.length,e=new Array(t),i=0;iNumber.parseInt(t,10))):"function"==typeof t?e=>t(e,this._element):t}_getPopperConfig(){const t={placement:this._getPlacement(),modifiers:[{name:"preventOverflow",options:{boundary:this._config.boundary}},{name:"offset",options:{offset:this._getOffset()}}]};return(this._inNavbar||"static"===this._config.display)&&(F.setDataAttribute(this._menu,"popper","static"),t.modifiers=[{name:"applyStyles",enabled:!1}]),{...t,...g(this._config.popperConfig,[void 0,t])}}_selectMenuItem({key:t,target:e}){const i=z.find(".dropdown-menu .dropdown-item:not(.disabled):not(:disabled)",this._menu).filter((t=>a(t)));i.length&&b(i,e,t===Oi,!i.includes(e)).focus()}static jQueryInterface(t){return this.each((function(){const e=Ki.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}static clearMenus(t){if(2===t.button||"keyup"===t.type&&"Tab"!==t.key)return;const e=z.find(ji);for(const i of e){const e=Ki.getInstance(i);if(!e||!1===e._config.autoClose)continue;const n=t.composedPath(),s=n.includes(e._menu);if(n.includes(e._element)||"inside"===e._config.autoClose&&!s||"outside"===e._config.autoClose&&s)continue;if(e._menu.contains(t.target)&&("keyup"===t.type&&"Tab"===t.key||/input|select|option|textarea|form/i.test(t.target.tagName)))continue;const o={relatedTarget:e._element};"click"===t.type&&(o.clickEvent=t),e._completeHide(o)}}static dataApiKeydownHandler(t){const e=/input|textarea/i.test(t.target.tagName),i="Escape"===t.key,n=[Ci,Oi].includes(t.key);if(!n&&!i)return;if(e&&!i)return;t.preventDefault();const s=this.matches(Pi)?this:z.prev(this,Pi)[0]||z.next(this,Pi)[0]||z.findOne(Pi,t.delegateTarget.parentNode),o=Ki.getOrCreateInstance(s);if(n)return t.stopPropagation(),o.show(),void o._selectMenuItem(t);o._isShown()&&(t.stopPropagation(),o.hide(),s.focus())}}N.on(document,$i,Pi,Ki.dataApiKeydownHandler),N.on(document,$i,Mi,Ki.dataApiKeydownHandler),N.on(document,Di,Ki.clearMenus),N.on(document,Ii,Ki.clearMenus),N.on(document,Di,Pi,(function(t){t.preventDefault(),Ki.getOrCreateInstance(this).toggle()})),m(Ki);const Qi="backdrop",Xi="show",Yi=`mousedown.bs.${Qi}`,Ui={className:"modal-backdrop",clickCallback:null,isAnimated:!1,isVisible:!0,rootElement:"body"},Gi={className:"string",clickCallback:"(function|null)",isAnimated:"boolean",isVisible:"boolean",rootElement:"(element|string)"};class Ji extends H{constructor(t){super(),this._config=this._getConfig(t),this._isAppended=!1,this._element=null}static get Default(){return Ui}static get DefaultType(){return Gi}static get NAME(){return Qi}show(t){if(!this._config.isVisible)return void g(t);this._append();const e=this._getElement();this._config.isAnimated&&d(e),e.classList.add(Xi),this._emulateAnimation((()=>{g(t)}))}hide(t){this._config.isVisible?(this._getElement().classList.remove(Xi),this._emulateAnimation((()=>{this.dispose(),g(t)}))):g(t)}dispose(){this._isAppended&&(N.off(this._element,Yi),this._element.remove(),this._isAppended=!1)}_getElement(){if(!this._element){const t=document.createElement("div");t.className=this._config.className,this._config.isAnimated&&t.classList.add("fade"),this._element=t}return this._element}_configAfterMerge(t){return t.rootElement=r(t.rootElement),t}_append(){if(this._isAppended)return;const t=this._getElement();this._config.rootElement.append(t),N.on(t,Yi,(()=>{g(this._config.clickCallback)})),this._isAppended=!0}_emulateAnimation(t){_(t,this._getElement(),this._config.isAnimated)}}const Zi=".bs.focustrap",tn=`focusin${Zi}`,en=`keydown.tab${Zi}`,nn="backward",sn={autofocus:!0,trapElement:null},on={autofocus:"boolean",trapElement:"element"};class rn extends H{constructor(t){super(),this._config=this._getConfig(t),this._isActive=!1,this._lastTabNavDirection=null}static get Default(){return sn}static get DefaultType(){return on}static get NAME(){return"focustrap"}activate(){this._isActive||(this._config.autofocus&&this._config.trapElement.focus(),N.off(document,Zi),N.on(document,tn,(t=>this._handleFocusin(t))),N.on(document,en,(t=>this._handleKeydown(t))),this._isActive=!0)}deactivate(){this._isActive&&(this._isActive=!1,N.off(document,Zi))}_handleFocusin(t){const{trapElement:e}=this._config;if(t.target===document||t.target===e||e.contains(t.target))return;const i=z.focusableChildren(e);0===i.length?e.focus():this._lastTabNavDirection===nn?i[i.length-1].focus():i[0].focus()}_handleKeydown(t){"Tab"===t.key&&(this._lastTabNavDirection=t.shiftKey?nn:"forward")}}const an=".fixed-top, .fixed-bottom, .is-fixed, .sticky-top",ln=".sticky-top",cn="padding-right",hn="margin-right";class dn{constructor(){this._element=document.body}getWidth(){const t=document.documentElement.clientWidth;return Math.abs(window.innerWidth-t)}hide(){const t=this.getWidth();this._disableOverFlow(),this._setElementAttributes(this._element,cn,(e=>e+t)),this._setElementAttributes(an,cn,(e=>e+t)),this._setElementAttributes(ln,hn,(e=>e-t))}reset(){this._resetElementAttributes(this._element,"overflow"),this._resetElementAttributes(this._element,cn),this._resetElementAttributes(an,cn),this._resetElementAttributes(ln,hn)}isOverflowing(){return this.getWidth()>0}_disableOverFlow(){this._saveInitialAttribute(this._element,"overflow"),this._element.style.overflow="hidden"}_setElementAttributes(t,e,i){const n=this.getWidth();this._applyManipulationCallback(t,(t=>{if(t!==this._element&&window.innerWidth>t.clientWidth+n)return;this._saveInitialAttribute(t,e);const s=window.getComputedStyle(t).getPropertyValue(e);t.style.setProperty(e,`${i(Number.parseFloat(s))}px`)}))}_saveInitialAttribute(t,e){const i=t.style.getPropertyValue(e);i&&F.setDataAttribute(t,e,i)}_resetElementAttributes(t,e){this._applyManipulationCallback(t,(t=>{const i=F.getDataAttribute(t,e);null!==i?(F.removeDataAttribute(t,e),t.style.setProperty(e,i)):t.style.removeProperty(e)}))}_applyManipulationCallback(t,e){if(o(t))e(t);else for(const i of z.find(t,this._element))e(i)}}const un=".bs.modal",fn=`hide${un}`,pn=`hidePrevented${un}`,mn=`hidden${un}`,gn=`show${un}`,_n=`shown${un}`,bn=`resize${un}`,vn=`click.dismiss${un}`,yn=`mousedown.dismiss${un}`,wn=`keydown.dismiss${un}`,An=`click${un}.data-api`,En="modal-open",Tn="show",Cn="modal-static",On={backdrop:!0,focus:!0,keyboard:!0},xn={backdrop:"(boolean|string)",focus:"boolean",keyboard:"boolean"};class kn extends W{constructor(t,e){super(t,e),this._dialog=z.findOne(".modal-dialog",this._element),this._backdrop=this._initializeBackDrop(),this._focustrap=this._initializeFocusTrap(),this._isShown=!1,this._isTransitioning=!1,this._scrollBar=new dn,this._addEventListeners()}static get Default(){return On}static get DefaultType(){return xn}static get NAME(){return"modal"}toggle(t){return this._isShown?this.hide():this.show(t)}show(t){this._isShown||this._isTransitioning||N.trigger(this._element,gn,{relatedTarget:t}).defaultPrevented||(this._isShown=!0,this._isTransitioning=!0,this._scrollBar.hide(),document.body.classList.add(En),this._adjustDialog(),this._backdrop.show((()=>this._showElement(t))))}hide(){this._isShown&&!this._isTransitioning&&(N.trigger(this._element,fn).defaultPrevented||(this._isShown=!1,this._isTransitioning=!0,this._focustrap.deactivate(),this._element.classList.remove(Tn),this._queueCallback((()=>this._hideModal()),this._element,this._isAnimated())))}dispose(){N.off(window,un),N.off(this._dialog,un),this._backdrop.dispose(),this._focustrap.deactivate(),super.dispose()}handleUpdate(){this._adjustDialog()}_initializeBackDrop(){return new Ji({isVisible:Boolean(this._config.backdrop),isAnimated:this._isAnimated()})}_initializeFocusTrap(){return new rn({trapElement:this._element})}_showElement(t){document.body.contains(this._element)||document.body.append(this._element),this._element.style.display="block",this._element.removeAttribute("aria-hidden"),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.scrollTop=0;const e=z.findOne(".modal-body",this._dialog);e&&(e.scrollTop=0),d(this._element),this._element.classList.add(Tn),this._queueCallback((()=>{this._config.focus&&this._focustrap.activate(),this._isTransitioning=!1,N.trigger(this._element,_n,{relatedTarget:t})}),this._dialog,this._isAnimated())}_addEventListeners(){N.on(this._element,wn,(t=>{"Escape"===t.key&&(this._config.keyboard?this.hide():this._triggerBackdropTransition())})),N.on(window,bn,(()=>{this._isShown&&!this._isTransitioning&&this._adjustDialog()})),N.on(this._element,yn,(t=>{N.one(this._element,vn,(e=>{this._element===t.target&&this._element===e.target&&("static"!==this._config.backdrop?this._config.backdrop&&this.hide():this._triggerBackdropTransition())}))}))}_hideModal(){this._element.style.display="none",this._element.setAttribute("aria-hidden",!0),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._isTransitioning=!1,this._backdrop.hide((()=>{document.body.classList.remove(En),this._resetAdjustments(),this._scrollBar.reset(),N.trigger(this._element,mn)}))}_isAnimated(){return this._element.classList.contains("fade")}_triggerBackdropTransition(){if(N.trigger(this._element,pn).defaultPrevented)return;const t=this._element.scrollHeight>document.documentElement.clientHeight,e=this._element.style.overflowY;"hidden"===e||this._element.classList.contains(Cn)||(t||(this._element.style.overflowY="hidden"),this._element.classList.add(Cn),this._queueCallback((()=>{this._element.classList.remove(Cn),this._queueCallback((()=>{this._element.style.overflowY=e}),this._dialog)}),this._dialog),this._element.focus())}_adjustDialog(){const t=this._element.scrollHeight>document.documentElement.clientHeight,e=this._scrollBar.getWidth(),i=e>0;if(i&&!t){const t=p()?"paddingLeft":"paddingRight";this._element.style[t]=`${e}px`}if(!i&&t){const t=p()?"paddingRight":"paddingLeft";this._element.style[t]=`${e}px`}}_resetAdjustments(){this._element.style.paddingLeft="",this._element.style.paddingRight=""}static jQueryInterface(t,e){return this.each((function(){const i=kn.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===i[t])throw new TypeError(`No method named "${t}"`);i[t](e)}}))}}N.on(document,An,'[data-bs-toggle="modal"]',(function(t){const e=z.getElementFromSelector(this);["A","AREA"].includes(this.tagName)&&t.preventDefault(),N.one(e,gn,(t=>{t.defaultPrevented||N.one(e,mn,(()=>{a(this)&&this.focus()}))}));const i=z.findOne(".modal.show");i&&kn.getInstance(i).hide(),kn.getOrCreateInstance(e).toggle(this)})),R(kn),m(kn);const Ln=".bs.offcanvas",Sn=".data-api",Dn=`load${Ln}${Sn}`,$n="show",In="showing",Nn="hiding",Pn=".offcanvas.show",jn=`show${Ln}`,Mn=`shown${Ln}`,Fn=`hide${Ln}`,Hn=`hidePrevented${Ln}`,Wn=`hidden${Ln}`,Bn=`resize${Ln}`,zn=`click${Ln}${Sn}`,Rn=`keydown.dismiss${Ln}`,qn={backdrop:!0,keyboard:!0,scroll:!1},Vn={backdrop:"(boolean|string)",keyboard:"boolean",scroll:"boolean"};class Kn extends W{constructor(t,e){super(t,e),this._isShown=!1,this._backdrop=this._initializeBackDrop(),this._focustrap=this._initializeFocusTrap(),this._addEventListeners()}static get Default(){return qn}static get DefaultType(){return Vn}static get NAME(){return"offcanvas"}toggle(t){return this._isShown?this.hide():this.show(t)}show(t){this._isShown||N.trigger(this._element,jn,{relatedTarget:t}).defaultPrevented||(this._isShown=!0,this._backdrop.show(),this._config.scroll||(new dn).hide(),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.classList.add(In),this._queueCallback((()=>{this._config.scroll&&!this._config.backdrop||this._focustrap.activate(),this._element.classList.add($n),this._element.classList.remove(In),N.trigger(this._element,Mn,{relatedTarget:t})}),this._element,!0))}hide(){this._isShown&&(N.trigger(this._element,Fn).defaultPrevented||(this._focustrap.deactivate(),this._element.blur(),this._isShown=!1,this._element.classList.add(Nn),this._backdrop.hide(),this._queueCallback((()=>{this._element.classList.remove($n,Nn),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._config.scroll||(new dn).reset(),N.trigger(this._element,Wn)}),this._element,!0)))}dispose(){this._backdrop.dispose(),this._focustrap.deactivate(),super.dispose()}_initializeBackDrop(){const t=Boolean(this._config.backdrop);return new Ji({className:"offcanvas-backdrop",isVisible:t,isAnimated:!0,rootElement:this._element.parentNode,clickCallback:t?()=>{"static"!==this._config.backdrop?this.hide():N.trigger(this._element,Hn)}:null})}_initializeFocusTrap(){return new rn({trapElement:this._element})}_addEventListeners(){N.on(this._element,Rn,(t=>{"Escape"===t.key&&(this._config.keyboard?this.hide():N.trigger(this._element,Hn))}))}static jQueryInterface(t){return this.each((function(){const e=Kn.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t](this)}}))}}N.on(document,zn,'[data-bs-toggle="offcanvas"]',(function(t){const e=z.getElementFromSelector(this);if(["A","AREA"].includes(this.tagName)&&t.preventDefault(),l(this))return;N.one(e,Wn,(()=>{a(this)&&this.focus()}));const i=z.findOne(Pn);i&&i!==e&&Kn.getInstance(i).hide(),Kn.getOrCreateInstance(e).toggle(this)})),N.on(window,Dn,(()=>{for(const t of z.find(Pn))Kn.getOrCreateInstance(t).show()})),N.on(window,Bn,(()=>{for(const t of z.find("[aria-modal][class*=show][class*=offcanvas-]"))"fixed"!==getComputedStyle(t).position&&Kn.getOrCreateInstance(t).hide()})),R(Kn),m(Kn);const Qn={"*":["class","dir","id","lang","role",/^aria-[\w-]*$/i],a:["target","href","title","rel"],area:[],b:[],br:[],col:[],code:[],dd:[],div:[],dl:[],dt:[],em:[],hr:[],h1:[],h2:[],h3:[],h4:[],h5:[],h6:[],i:[],img:["src","srcset","alt","title","width","height"],li:[],ol:[],p:[],pre:[],s:[],small:[],span:[],sub:[],sup:[],strong:[],u:[],ul:[]},Xn=new Set(["background","cite","href","itemtype","longdesc","poster","src","xlink:href"]),Yn=/^(?!javascript:)(?:[a-z0-9+.-]+:|[^&:/?#]*(?:[/?#]|$))/i,Un=(t,e)=>{const i=t.nodeName.toLowerCase();return e.includes(i)?!Xn.has(i)||Boolean(Yn.test(t.nodeValue)):e.filter((t=>t instanceof RegExp)).some((t=>t.test(i)))},Gn={allowList:Qn,content:{},extraClass:"",html:!1,sanitize:!0,sanitizeFn:null,template:"
    "},Jn={allowList:"object",content:"object",extraClass:"(string|function)",html:"boolean",sanitize:"boolean",sanitizeFn:"(null|function)",template:"string"},Zn={entry:"(string|element|function|null)",selector:"(string|element)"};class ts extends H{constructor(t){super(),this._config=this._getConfig(t)}static get Default(){return Gn}static get DefaultType(){return Jn}static get NAME(){return"TemplateFactory"}getContent(){return Object.values(this._config.content).map((t=>this._resolvePossibleFunction(t))).filter(Boolean)}hasContent(){return this.getContent().length>0}changeContent(t){return this._checkContent(t),this._config.content={...this._config.content,...t},this}toHtml(){const t=document.createElement("div");t.innerHTML=this._maybeSanitize(this._config.template);for(const[e,i]of Object.entries(this._config.content))this._setContent(t,i,e);const e=t.children[0],i=this._resolvePossibleFunction(this._config.extraClass);return i&&e.classList.add(...i.split(" ")),e}_typeCheckConfig(t){super._typeCheckConfig(t),this._checkContent(t.content)}_checkContent(t){for(const[e,i]of Object.entries(t))super._typeCheckConfig({selector:e,entry:i},Zn)}_setContent(t,e,i){const n=z.findOne(i,t);n&&((e=this._resolvePossibleFunction(e))?o(e)?this._putElementInTemplate(r(e),n):this._config.html?n.innerHTML=this._maybeSanitize(e):n.textContent=e:n.remove())}_maybeSanitize(t){return this._config.sanitize?function(t,e,i){if(!t.length)return t;if(i&&"function"==typeof i)return i(t);const n=(new window.DOMParser).parseFromString(t,"text/html"),s=[].concat(...n.body.querySelectorAll("*"));for(const t of s){const i=t.nodeName.toLowerCase();if(!Object.keys(e).includes(i)){t.remove();continue}const n=[].concat(...t.attributes),s=[].concat(e["*"]||[],e[i]||[]);for(const e of n)Un(e,s)||t.removeAttribute(e.nodeName)}return n.body.innerHTML}(t,this._config.allowList,this._config.sanitizeFn):t}_resolvePossibleFunction(t){return g(t,[void 0,this])}_putElementInTemplate(t,e){if(this._config.html)return e.innerHTML="",void e.append(t);e.textContent=t.textContent}}const es=new Set(["sanitize","allowList","sanitizeFn"]),is="fade",ns="show",ss=".tooltip-inner",os=".modal",rs="hide.bs.modal",as="hover",ls="focus",cs="click",hs={AUTO:"auto",TOP:"top",RIGHT:p()?"left":"right",BOTTOM:"bottom",LEFT:p()?"right":"left"},ds={allowList:Qn,animation:!0,boundary:"clippingParents",container:!1,customClass:"",delay:0,fallbackPlacements:["top","right","bottom","left"],html:!1,offset:[0,6],placement:"top",popperConfig:null,sanitize:!0,sanitizeFn:null,selector:!1,template:'',title:"",trigger:"hover focus"},us={allowList:"object",animation:"boolean",boundary:"(string|element)",container:"(string|element|boolean)",customClass:"(string|function)",delay:"(number|object)",fallbackPlacements:"array",html:"boolean",offset:"(array|string|function)",placement:"(string|function)",popperConfig:"(null|object|function)",sanitize:"boolean",sanitizeFn:"(null|function)",selector:"(string|boolean)",template:"string",title:"(string|element|function)",trigger:"string"};class fs extends W{constructor(t,e){if(void 0===wi)throw new TypeError("Bootstrap's tooltips require Popper (https://popper.js.org/docs/v2/)");super(t,e),this._isEnabled=!0,this._timeout=0,this._isHovered=null,this._activeTrigger={},this._popper=null,this._templateFactory=null,this._newContent=null,this.tip=null,this._setListeners(),this._config.selector||this._fixTitle()}static get Default(){return ds}static get DefaultType(){return us}static get NAME(){return"tooltip"}enable(){this._isEnabled=!0}disable(){this._isEnabled=!1}toggleEnabled(){this._isEnabled=!this._isEnabled}toggle(){this._isEnabled&&(this._isShown()?this._leave():this._enter())}dispose(){clearTimeout(this._timeout),N.off(this._element.closest(os),rs,this._hideModalHandler),this._element.getAttribute("data-bs-original-title")&&this._element.setAttribute("title",this._element.getAttribute("data-bs-original-title")),this._disposePopper(),super.dispose()}show(){if("none"===this._element.style.display)throw new Error("Please use show on visible elements");if(!this._isWithContent()||!this._isEnabled)return;const t=N.trigger(this._element,this.constructor.eventName("show")),e=(c(this._element)||this._element.ownerDocument.documentElement).contains(this._element);if(t.defaultPrevented||!e)return;this._disposePopper();const i=this._getTipElement();this._element.setAttribute("aria-describedby",i.getAttribute("id"));const{container:n}=this._config;if(this._element.ownerDocument.documentElement.contains(this.tip)||(n.append(i),N.trigger(this._element,this.constructor.eventName("inserted"))),this._popper=this._createPopper(i),i.classList.add(ns),"ontouchstart"in document.documentElement)for(const t of[].concat(...document.body.children))N.on(t,"mouseover",h);this._queueCallback((()=>{N.trigger(this._element,this.constructor.eventName("shown")),!1===this._isHovered&&this._leave(),this._isHovered=!1}),this.tip,this._isAnimated())}hide(){if(this._isShown()&&!N.trigger(this._element,this.constructor.eventName("hide")).defaultPrevented){if(this._getTipElement().classList.remove(ns),"ontouchstart"in document.documentElement)for(const t of[].concat(...document.body.children))N.off(t,"mouseover",h);this._activeTrigger[cs]=!1,this._activeTrigger[ls]=!1,this._activeTrigger[as]=!1,this._isHovered=null,this._queueCallback((()=>{this._isWithActiveTrigger()||(this._isHovered||this._disposePopper(),this._element.removeAttribute("aria-describedby"),N.trigger(this._element,this.constructor.eventName("hidden")))}),this.tip,this._isAnimated())}}update(){this._popper&&this._popper.update()}_isWithContent(){return Boolean(this._getTitle())}_getTipElement(){return this.tip||(this.tip=this._createTipElement(this._newContent||this._getContentForTemplate())),this.tip}_createTipElement(t){const e=this._getTemplateFactory(t).toHtml();if(!e)return null;e.classList.remove(is,ns),e.classList.add(`bs-${this.constructor.NAME}-auto`);const i=(t=>{do{t+=Math.floor(1e6*Math.random())}while(document.getElementById(t));return t})(this.constructor.NAME).toString();return e.setAttribute("id",i),this._isAnimated()&&e.classList.add(is),e}setContent(t){this._newContent=t,this._isShown()&&(this._disposePopper(),this.show())}_getTemplateFactory(t){return this._templateFactory?this._templateFactory.changeContent(t):this._templateFactory=new ts({...this._config,content:t,extraClass:this._resolvePossibleFunction(this._config.customClass)}),this._templateFactory}_getContentForTemplate(){return{[ss]:this._getTitle()}}_getTitle(){return this._resolvePossibleFunction(this._config.title)||this._element.getAttribute("data-bs-original-title")}_initializeOnDelegatedTarget(t){return this.constructor.getOrCreateInstance(t.delegateTarget,this._getDelegateConfig())}_isAnimated(){return this._config.animation||this.tip&&this.tip.classList.contains(is)}_isShown(){return this.tip&&this.tip.classList.contains(ns)}_createPopper(t){const e=g(this._config.placement,[this,t,this._element]),i=hs[e.toUpperCase()];return yi(this._element,t,this._getPopperConfig(i))}_getOffset(){const{offset:t}=this._config;return"string"==typeof t?t.split(",").map((t=>Number.parseInt(t,10))):"function"==typeof t?e=>t(e,this._element):t}_resolvePossibleFunction(t){return g(t,[this._element,this._element])}_getPopperConfig(t){const e={placement:t,modifiers:[{name:"flip",options:{fallbackPlacements:this._config.fallbackPlacements}},{name:"offset",options:{offset:this._getOffset()}},{name:"preventOverflow",options:{boundary:this._config.boundary}},{name:"arrow",options:{element:`.${this.constructor.NAME}-arrow`}},{name:"preSetPlacement",enabled:!0,phase:"beforeMain",fn:t=>{this._getTipElement().setAttribute("data-popper-placement",t.state.placement)}}]};return{...e,...g(this._config.popperConfig,[void 0,e])}}_setListeners(){const t=this._config.trigger.split(" ");for(const e of t)if("click"===e)N.on(this._element,this.constructor.eventName("click"),this._config.selector,(t=>{const e=this._initializeOnDelegatedTarget(t);e._activeTrigger[cs]=!(e._isShown()&&e._activeTrigger[cs]),e.toggle()}));else if("manual"!==e){const t=e===as?this.constructor.eventName("mouseenter"):this.constructor.eventName("focusin"),i=e===as?this.constructor.eventName("mouseleave"):this.constructor.eventName("focusout");N.on(this._element,t,this._config.selector,(t=>{const e=this._initializeOnDelegatedTarget(t);e._activeTrigger["focusin"===t.type?ls:as]=!0,e._enter()})),N.on(this._element,i,this._config.selector,(t=>{const e=this._initializeOnDelegatedTarget(t);e._activeTrigger["focusout"===t.type?ls:as]=e._element.contains(t.relatedTarget),e._leave()}))}this._hideModalHandler=()=>{this._element&&this.hide()},N.on(this._element.closest(os),rs,this._hideModalHandler)}_fixTitle(){const t=this._element.getAttribute("title");t&&(this._element.getAttribute("aria-label")||this._element.textContent.trim()||this._element.setAttribute("aria-label",t),this._element.setAttribute("data-bs-original-title",t),this._element.removeAttribute("title"))}_enter(){this._isShown()||this._isHovered?this._isHovered=!0:(this._isHovered=!0,this._setTimeout((()=>{this._isHovered&&this.show()}),this._config.delay.show))}_leave(){this._isWithActiveTrigger()||(this._isHovered=!1,this._setTimeout((()=>{this._isHovered||this.hide()}),this._config.delay.hide))}_setTimeout(t,e){clearTimeout(this._timeout),this._timeout=setTimeout(t,e)}_isWithActiveTrigger(){return Object.values(this._activeTrigger).includes(!0)}_getConfig(t){const e=F.getDataAttributes(this._element);for(const t of Object.keys(e))es.has(t)&&delete e[t];return t={...e,..."object"==typeof t&&t?t:{}},t=this._mergeConfigObj(t),t=this._configAfterMerge(t),this._typeCheckConfig(t),t}_configAfterMerge(t){return t.container=!1===t.container?document.body:r(t.container),"number"==typeof t.delay&&(t.delay={show:t.delay,hide:t.delay}),"number"==typeof t.title&&(t.title=t.title.toString()),"number"==typeof t.content&&(t.content=t.content.toString()),t}_getDelegateConfig(){const t={};for(const[e,i]of Object.entries(this._config))this.constructor.Default[e]!==i&&(t[e]=i);return t.selector=!1,t.trigger="manual",t}_disposePopper(){this._popper&&(this._popper.destroy(),this._popper=null),this.tip&&(this.tip.remove(),this.tip=null)}static jQueryInterface(t){return this.each((function(){const e=fs.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}}m(fs);const ps=".popover-header",ms=".popover-body",gs={...fs.Default,content:"",offset:[0,8],placement:"right",template:'',trigger:"click"},_s={...fs.DefaultType,content:"(null|string|element|function)"};class bs extends fs{static get Default(){return gs}static get DefaultType(){return _s}static get NAME(){return"popover"}_isWithContent(){return this._getTitle()||this._getContent()}_getContentForTemplate(){return{[ps]:this._getTitle(),[ms]:this._getContent()}}_getContent(){return this._resolvePossibleFunction(this._config.content)}static jQueryInterface(t){return this.each((function(){const e=bs.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t]()}}))}}m(bs);const vs=".bs.scrollspy",ys=`activate${vs}`,ws=`click${vs}`,As=`load${vs}.data-api`,Es="active",Ts="[href]",Cs=".nav-link",Os=`${Cs}, .nav-item > ${Cs}, .list-group-item`,xs={offset:null,rootMargin:"0px 0px -25%",smoothScroll:!1,target:null,threshold:[.1,.5,1]},ks={offset:"(number|null)",rootMargin:"string",smoothScroll:"boolean",target:"element",threshold:"array"};class Ls extends W{constructor(t,e){super(t,e),this._targetLinks=new Map,this._observableSections=new Map,this._rootElement="visible"===getComputedStyle(this._element).overflowY?null:this._element,this._activeTarget=null,this._observer=null,this._previousScrollData={visibleEntryTop:0,parentScrollTop:0},this.refresh()}static get Default(){return xs}static get DefaultType(){return ks}static get NAME(){return"scrollspy"}refresh(){this._initializeTargetsAndObservables(),this._maybeEnableSmoothScroll(),this._observer?this._observer.disconnect():this._observer=this._getNewObserver();for(const t of this._observableSections.values())this._observer.observe(t)}dispose(){this._observer.disconnect(),super.dispose()}_configAfterMerge(t){return t.target=r(t.target)||document.body,t.rootMargin=t.offset?`${t.offset}px 0px -30%`:t.rootMargin,"string"==typeof t.threshold&&(t.threshold=t.threshold.split(",").map((t=>Number.parseFloat(t)))),t}_maybeEnableSmoothScroll(){this._config.smoothScroll&&(N.off(this._config.target,ws),N.on(this._config.target,ws,Ts,(t=>{const e=this._observableSections.get(t.target.hash);if(e){t.preventDefault();const i=this._rootElement||window,n=e.offsetTop-this._element.offsetTop;if(i.scrollTo)return void i.scrollTo({top:n,behavior:"smooth"});i.scrollTop=n}})))}_getNewObserver(){const t={root:this._rootElement,threshold:this._config.threshold,rootMargin:this._config.rootMargin};return new IntersectionObserver((t=>this._observerCallback(t)),t)}_observerCallback(t){const e=t=>this._targetLinks.get(`#${t.target.id}`),i=t=>{this._previousScrollData.visibleEntryTop=t.target.offsetTop,this._process(e(t))},n=(this._rootElement||document.documentElement).scrollTop,s=n>=this._previousScrollData.parentScrollTop;this._previousScrollData.parentScrollTop=n;for(const o of t){if(!o.isIntersecting){this._activeTarget=null,this._clearActiveClass(e(o));continue}const t=o.target.offsetTop>=this._previousScrollData.visibleEntryTop;if(s&&t){if(i(o),!n)return}else s||t||i(o)}}_initializeTargetsAndObservables(){this._targetLinks=new Map,this._observableSections=new Map;const t=z.find(Ts,this._config.target);for(const e of t){if(!e.hash||l(e))continue;const t=z.findOne(decodeURI(e.hash),this._element);a(t)&&(this._targetLinks.set(decodeURI(e.hash),e),this._observableSections.set(e.hash,t))}}_process(t){this._activeTarget!==t&&(this._clearActiveClass(this._config.target),this._activeTarget=t,t.classList.add(Es),this._activateParents(t),N.trigger(this._element,ys,{relatedTarget:t}))}_activateParents(t){if(t.classList.contains("dropdown-item"))z.findOne(".dropdown-toggle",t.closest(".dropdown")).classList.add(Es);else for(const e of z.parents(t,".nav, .list-group"))for(const t of z.prev(e,Os))t.classList.add(Es)}_clearActiveClass(t){t.classList.remove(Es);const e=z.find(`${Ts}.${Es}`,t);for(const t of e)t.classList.remove(Es)}static jQueryInterface(t){return this.each((function(){const e=Ls.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t]()}}))}}N.on(window,As,(()=>{for(const t of z.find('[data-bs-spy="scroll"]'))Ls.getOrCreateInstance(t)})),m(Ls);const Ss=".bs.tab",Ds=`hide${Ss}`,$s=`hidden${Ss}`,Is=`show${Ss}`,Ns=`shown${Ss}`,Ps=`click${Ss}`,js=`keydown${Ss}`,Ms=`load${Ss}`,Fs="ArrowLeft",Hs="ArrowRight",Ws="ArrowUp",Bs="ArrowDown",zs="Home",Rs="End",qs="active",Vs="fade",Ks="show",Qs=".dropdown-toggle",Xs=`:not(${Qs})`,Ys='[data-bs-toggle="tab"], [data-bs-toggle="pill"], [data-bs-toggle="list"]',Us=`.nav-link${Xs}, .list-group-item${Xs}, [role="tab"]${Xs}, ${Ys}`,Gs=`.${qs}[data-bs-toggle="tab"], .${qs}[data-bs-toggle="pill"], .${qs}[data-bs-toggle="list"]`;class Js extends W{constructor(t){super(t),this._parent=this._element.closest('.list-group, .nav, [role="tablist"]'),this._parent&&(this._setInitialAttributes(this._parent,this._getChildren()),N.on(this._element,js,(t=>this._keydown(t))))}static get NAME(){return"tab"}show(){const t=this._element;if(this._elemIsActive(t))return;const e=this._getActiveElem(),i=e?N.trigger(e,Ds,{relatedTarget:t}):null;N.trigger(t,Is,{relatedTarget:e}).defaultPrevented||i&&i.defaultPrevented||(this._deactivate(e,t),this._activate(t,e))}_activate(t,e){t&&(t.classList.add(qs),this._activate(z.getElementFromSelector(t)),this._queueCallback((()=>{"tab"===t.getAttribute("role")?(t.removeAttribute("tabindex"),t.setAttribute("aria-selected",!0),this._toggleDropDown(t,!0),N.trigger(t,Ns,{relatedTarget:e})):t.classList.add(Ks)}),t,t.classList.contains(Vs)))}_deactivate(t,e){t&&(t.classList.remove(qs),t.blur(),this._deactivate(z.getElementFromSelector(t)),this._queueCallback((()=>{"tab"===t.getAttribute("role")?(t.setAttribute("aria-selected",!1),t.setAttribute("tabindex","-1"),this._toggleDropDown(t,!1),N.trigger(t,$s,{relatedTarget:e})):t.classList.remove(Ks)}),t,t.classList.contains(Vs)))}_keydown(t){if(![Fs,Hs,Ws,Bs,zs,Rs].includes(t.key))return;t.stopPropagation(),t.preventDefault();const e=this._getChildren().filter((t=>!l(t)));let i;if([zs,Rs].includes(t.key))i=e[t.key===zs?0:e.length-1];else{const n=[Hs,Bs].includes(t.key);i=b(e,t.target,n,!0)}i&&(i.focus({preventScroll:!0}),Js.getOrCreateInstance(i).show())}_getChildren(){return z.find(Us,this._parent)}_getActiveElem(){return this._getChildren().find((t=>this._elemIsActive(t)))||null}_setInitialAttributes(t,e){this._setAttributeIfNotExists(t,"role","tablist");for(const t of e)this._setInitialAttributesOnChild(t)}_setInitialAttributesOnChild(t){t=this._getInnerElement(t);const e=this._elemIsActive(t),i=this._getOuterElement(t);t.setAttribute("aria-selected",e),i!==t&&this._setAttributeIfNotExists(i,"role","presentation"),e||t.setAttribute("tabindex","-1"),this._setAttributeIfNotExists(t,"role","tab"),this._setInitialAttributesOnTargetPanel(t)}_setInitialAttributesOnTargetPanel(t){const e=z.getElementFromSelector(t);e&&(this._setAttributeIfNotExists(e,"role","tabpanel"),t.id&&this._setAttributeIfNotExists(e,"aria-labelledby",`${t.id}`))}_toggleDropDown(t,e){const i=this._getOuterElement(t);if(!i.classList.contains("dropdown"))return;const n=(t,n)=>{const s=z.findOne(t,i);s&&s.classList.toggle(n,e)};n(Qs,qs),n(".dropdown-menu",Ks),i.setAttribute("aria-expanded",e)}_setAttributeIfNotExists(t,e,i){t.hasAttribute(e)||t.setAttribute(e,i)}_elemIsActive(t){return t.classList.contains(qs)}_getInnerElement(t){return t.matches(Us)?t:z.findOne(Us,t)}_getOuterElement(t){return t.closest(".nav-item, .list-group-item")||t}static jQueryInterface(t){return this.each((function(){const e=Js.getOrCreateInstance(this);if("string"==typeof t){if(void 0===e[t]||t.startsWith("_")||"constructor"===t)throw new TypeError(`No method named "${t}"`);e[t]()}}))}}N.on(document,Ps,Ys,(function(t){["A","AREA"].includes(this.tagName)&&t.preventDefault(),l(this)||Js.getOrCreateInstance(this).show()})),N.on(window,Ms,(()=>{for(const t of z.find(Gs))Js.getOrCreateInstance(t)})),m(Js);const Zs=".bs.toast",to=`mouseover${Zs}`,eo=`mouseout${Zs}`,io=`focusin${Zs}`,no=`focusout${Zs}`,so=`hide${Zs}`,oo=`hidden${Zs}`,ro=`show${Zs}`,ao=`shown${Zs}`,lo="hide",co="show",ho="showing",uo={animation:"boolean",autohide:"boolean",delay:"number"},fo={animation:!0,autohide:!0,delay:5e3};class po extends W{constructor(t,e){super(t,e),this._timeout=null,this._hasMouseInteraction=!1,this._hasKeyboardInteraction=!1,this._setListeners()}static get Default(){return fo}static get DefaultType(){return uo}static get NAME(){return"toast"}show(){N.trigger(this._element,ro).defaultPrevented||(this._clearTimeout(),this._config.animation&&this._element.classList.add("fade"),this._element.classList.remove(lo),d(this._element),this._element.classList.add(co,ho),this._queueCallback((()=>{this._element.classList.remove(ho),N.trigger(this._element,ao),this._maybeScheduleHide()}),this._element,this._config.animation))}hide(){this.isShown()&&(N.trigger(this._element,so).defaultPrevented||(this._element.classList.add(ho),this._queueCallback((()=>{this._element.classList.add(lo),this._element.classList.remove(ho,co),N.trigger(this._element,oo)}),this._element,this._config.animation)))}dispose(){this._clearTimeout(),this.isShown()&&this._element.classList.remove(co),super.dispose()}isShown(){return this._element.classList.contains(co)}_maybeScheduleHide(){this._config.autohide&&(this._hasMouseInteraction||this._hasKeyboardInteraction||(this._timeout=setTimeout((()=>{this.hide()}),this._config.delay)))}_onInteraction(t,e){switch(t.type){case"mouseover":case"mouseout":this._hasMouseInteraction=e;break;case"focusin":case"focusout":this._hasKeyboardInteraction=e}if(e)return void this._clearTimeout();const i=t.relatedTarget;this._element===i||this._element.contains(i)||this._maybeScheduleHide()}_setListeners(){N.on(this._element,to,(t=>this._onInteraction(t,!0))),N.on(this._element,eo,(t=>this._onInteraction(t,!1))),N.on(this._element,io,(t=>this._onInteraction(t,!0))),N.on(this._element,no,(t=>this._onInteraction(t,!1)))}_clearTimeout(){clearTimeout(this._timeout),this._timeout=null}static jQueryInterface(t){return this.each((function(){const e=po.getOrCreateInstance(this,t);if("string"==typeof t){if(void 0===e[t])throw new TypeError(`No method named "${t}"`);e[t](this)}}))}}return R(po),m(po),{Alert:Q,Button:Y,Carousel:Lt,Collapse:Rt,Dropdown:Ki,Modal:kn,Offcanvas:Kn,Popover:bs,ScrollSpy:Ls,Tab:Js,Toast:po,Tooltip:fs}})); +//# sourceMappingURL=bootstrap.bundle.min.js.map \ No newline at end of file diff --git a/structurizr/js/joint-3.6.5.js b/structurizr/js/joint-3.6.5.js new file mode 100644 index 0000000..4cb3b0b --- /dev/null +++ b/structurizr/js/joint-3.6.5.js @@ -0,0 +1,34467 @@ +/*! JointJS v3.6.5 (2022-12-15) - JavaScript diagramming library + + +This Source Code Form is subject to the terms of the Mozilla Public +License, v. 2.0. If a copy of the MPL was not distributed with this +file, You can obtain one at http://mozilla.org/MPL/2.0/. +*/ +(function (global, factory) { + typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('backbone'), require('lodash'), require('jquery')) : + typeof define === 'function' && define.amd ? define(['exports', 'backbone', 'lodash', 'jquery'], factory) : + (global = global || self, factory(global.joint = {}, global.Backbone, global._, global.$)); +}(this, function (exports, Backbone, _, $) { 'use strict'; + + Backbone = Backbone && Backbone.hasOwnProperty('default') ? Backbone['default'] : Backbone; + _ = _ && _.hasOwnProperty('default') ? _['default'] : _; + $ = $ && $.hasOwnProperty('default') ? $['default'] : $; + + var commonjsGlobal = typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {}; + + function commonjsRequire () { + throw new Error('Dynamic requires are not currently supported by rollup-plugin-commonjs'); + } + + function unwrapExports (x) { + return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x.default : x; + } + + function createCommonjsModule(fn, module) { + return module = { exports: {} }, fn(module, module.exports), module.exports; + } + + function getCjsExportFromNamespace (n) { + return n && n.default || n; + } + + var check = function (it) { + return it && it.Math == Math && it; + }; + + // https://github.com/zloirock/core-js/issues/86#issuecomment-115759028 + var global_1 = + // eslint-disable-next-line no-undef + check(typeof globalThis == 'object' && globalThis) || + check(typeof window == 'object' && window) || + check(typeof self == 'object' && self) || + check(typeof commonjsGlobal == 'object' && commonjsGlobal) || + // eslint-disable-next-line no-new-func + (function () { return this; })() || Function('return this')(); + + var fails = function (exec) { + try { + return !!exec(); + } catch (error) { + return true; + } + }; + + // Detect IE8's incomplete defineProperty implementation + var descriptors = !fails(function () { + return Object.defineProperty({}, 1, { get: function () { return 7; } })[1] != 7; + }); + + 'use strict'; + var nativePropertyIsEnumerable = {}.propertyIsEnumerable; + var getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor; + + // Nashorn ~ JDK8 bug + var NASHORN_BUG = getOwnPropertyDescriptor && !nativePropertyIsEnumerable.call({ 1: 2 }, 1); + + // `Object.prototype.propertyIsEnumerable` method implementation + // https://tc39.es/ecma262/#sec-object.prototype.propertyisenumerable + var f = NASHORN_BUG ? function propertyIsEnumerable(V) { + var descriptor = getOwnPropertyDescriptor(this, V); + return !!descriptor && descriptor.enumerable; + } : nativePropertyIsEnumerable; + + var objectPropertyIsEnumerable = { + f: f + }; + + var createPropertyDescriptor = function (bitmap, value) { + return { + enumerable: !(bitmap & 1), + configurable: !(bitmap & 2), + writable: !(bitmap & 4), + value: value + }; + }; + + var toString = {}.toString; + + var classofRaw = function (it) { + return toString.call(it).slice(8, -1); + }; + + var split = ''.split; + + // fallback for non-array-like ES3 and non-enumerable old V8 strings + var indexedObject = fails(function () { + // throws an error in rhino, see https://github.com/mozilla/rhino/issues/346 + // eslint-disable-next-line no-prototype-builtins + return !Object('z').propertyIsEnumerable(0); + }) ? function (it) { + return classofRaw(it) == 'String' ? split.call(it, '') : Object(it); + } : Object; + + // `RequireObjectCoercible` abstract operation + // https://tc39.es/ecma262/#sec-requireobjectcoercible + var requireObjectCoercible = function (it) { + if (it == undefined) { throw TypeError("Can't call method on " + it); } + return it; + }; + + // toObject with fallback for non-array-like ES3 strings + + + + var toIndexedObject = function (it) { + return indexedObject(requireObjectCoercible(it)); + }; + + var isObject = function (it) { + return typeof it === 'object' ? it !== null : typeof it === 'function'; + }; + + // `ToPrimitive` abstract operation + // https://tc39.es/ecma262/#sec-toprimitive + // instead of the ES6 spec version, we didn't implement @@toPrimitive case + // and the second argument - flag - preferred type is a string + var toPrimitive = function (input, PREFERRED_STRING) { + if (!isObject(input)) { return input; } + var fn, val; + if (PREFERRED_STRING && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) { return val; } + if (typeof (fn = input.valueOf) == 'function' && !isObject(val = fn.call(input))) { return val; } + if (!PREFERRED_STRING && typeof (fn = input.toString) == 'function' && !isObject(val = fn.call(input))) { return val; } + throw TypeError("Can't convert object to primitive value"); + }; + + var hasOwnProperty = {}.hasOwnProperty; + + var has = function (it, key) { + return hasOwnProperty.call(it, key); + }; + + var document$1 = global_1.document; + // typeof document.createElement is 'object' in old IE + var EXISTS = isObject(document$1) && isObject(document$1.createElement); + + var documentCreateElement = function (it) { + return EXISTS ? document$1.createElement(it) : {}; + }; + + // Thank's IE8 for his funny defineProperty + var ie8DomDefine = !descriptors && !fails(function () { + return Object.defineProperty(documentCreateElement('div'), 'a', { + get: function () { return 7; } + }).a != 7; + }); + + var nativeGetOwnPropertyDescriptor = Object.getOwnPropertyDescriptor; + + // `Object.getOwnPropertyDescriptor` method + // https://tc39.es/ecma262/#sec-object.getownpropertydescriptor + var f$1 = descriptors ? nativeGetOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) { + O = toIndexedObject(O); + P = toPrimitive(P, true); + if (ie8DomDefine) { try { + return nativeGetOwnPropertyDescriptor(O, P); + } catch (error) { /* empty */ } } + if (has(O, P)) { return createPropertyDescriptor(!objectPropertyIsEnumerable.f.call(O, P), O[P]); } + }; + + var objectGetOwnPropertyDescriptor = { + f: f$1 + }; + + var anObject = function (it) { + if (!isObject(it)) { + throw TypeError(String(it) + ' is not an object'); + } return it; + }; + + var nativeDefineProperty = Object.defineProperty; + + // `Object.defineProperty` method + // https://tc39.es/ecma262/#sec-object.defineproperty + var f$2 = descriptors ? nativeDefineProperty : function defineProperty(O, P, Attributes) { + anObject(O); + P = toPrimitive(P, true); + anObject(Attributes); + if (ie8DomDefine) { try { + return nativeDefineProperty(O, P, Attributes); + } catch (error) { /* empty */ } } + if ('get' in Attributes || 'set' in Attributes) { throw TypeError('Accessors not supported'); } + if ('value' in Attributes) { O[P] = Attributes.value; } + return O; + }; + + var objectDefineProperty = { + f: f$2 + }; + + var createNonEnumerableProperty = descriptors ? function (object, key, value) { + return objectDefineProperty.f(object, key, createPropertyDescriptor(1, value)); + } : function (object, key, value) { + object[key] = value; + return object; + }; + + var setGlobal = function (key, value) { + try { + createNonEnumerableProperty(global_1, key, value); + } catch (error) { + global_1[key] = value; + } return value; + }; + + var SHARED = '__core-js_shared__'; + var store = global_1[SHARED] || setGlobal(SHARED, {}); + + var sharedStore = store; + + var functionToString = Function.toString; + + // this helper broken in `3.4.1-3.4.4`, so we can't use `shared` helper + if (typeof sharedStore.inspectSource != 'function') { + sharedStore.inspectSource = function (it) { + return functionToString.call(it); + }; + } + + var inspectSource = sharedStore.inspectSource; + + var WeakMap = global_1.WeakMap; + + var nativeWeakMap = typeof WeakMap === 'function' && /native code/.test(inspectSource(WeakMap)); + + var isPure = false; + + var shared = createCommonjsModule(function (module) { + (module.exports = function (key, value) { + return sharedStore[key] || (sharedStore[key] = value !== undefined ? value : {}); + })('versions', []).push({ + version: '3.8.3', + mode: isPure ? 'pure' : 'global', + copyright: '© 2021 Denis Pushkarev (zloirock.ru)' + }); + }); + + var id = 0; + var postfix = Math.random(); + + var uid = function (key) { + return 'Symbol(' + String(key === undefined ? '' : key) + ')_' + (++id + postfix).toString(36); + }; + + var keys = shared('keys'); + + var sharedKey = function (key) { + return keys[key] || (keys[key] = uid(key)); + }; + + var hiddenKeys = {}; + + var WeakMap$1 = global_1.WeakMap; + var set, get, has$1; + + var enforce = function (it) { + return has$1(it) ? get(it) : set(it, {}); + }; + + var getterFor = function (TYPE) { + return function (it) { + var state; + if (!isObject(it) || (state = get(it)).type !== TYPE) { + throw TypeError('Incompatible receiver, ' + TYPE + ' required'); + } return state; + }; + }; + + if (nativeWeakMap) { + var store$1 = sharedStore.state || (sharedStore.state = new WeakMap$1()); + var wmget = store$1.get; + var wmhas = store$1.has; + var wmset = store$1.set; + set = function (it, metadata) { + metadata.facade = it; + wmset.call(store$1, it, metadata); + return metadata; + }; + get = function (it) { + return wmget.call(store$1, it) || {}; + }; + has$1 = function (it) { + return wmhas.call(store$1, it); + }; + } else { + var STATE = sharedKey('state'); + hiddenKeys[STATE] = true; + set = function (it, metadata) { + metadata.facade = it; + createNonEnumerableProperty(it, STATE, metadata); + return metadata; + }; + get = function (it) { + return has(it, STATE) ? it[STATE] : {}; + }; + has$1 = function (it) { + return has(it, STATE); + }; + } + + var internalState = { + set: set, + get: get, + has: has$1, + enforce: enforce, + getterFor: getterFor + }; + var internalState_1 = internalState.set; + var internalState_2 = internalState.get; + var internalState_3 = internalState.has; + var internalState_4 = internalState.enforce; + var internalState_5 = internalState.getterFor; + + var redefine = createCommonjsModule(function (module) { + var getInternalState = internalState.get; + var enforceInternalState = internalState.enforce; + var TEMPLATE = String(String).split('String'); + + (module.exports = function (O, key, value, options) { + var unsafe = options ? !!options.unsafe : false; + var simple = options ? !!options.enumerable : false; + var noTargetGet = options ? !!options.noTargetGet : false; + var state; + if (typeof value == 'function') { + if (typeof key == 'string' && !has(value, 'name')) { + createNonEnumerableProperty(value, 'name', key); + } + state = enforceInternalState(value); + if (!state.source) { + state.source = TEMPLATE.join(typeof key == 'string' ? key : ''); + } + } + if (O === global_1) { + if (simple) { O[key] = value; } + else { setGlobal(key, value); } + return; + } else if (!unsafe) { + delete O[key]; + } else if (!noTargetGet && O[key]) { + simple = true; + } + if (simple) { O[key] = value; } + else { createNonEnumerableProperty(O, key, value); } + // add fake Function#toString for correct work wrapped methods / constructors with methods like LoDash isNative + })(Function.prototype, 'toString', function toString() { + return typeof this == 'function' && getInternalState(this).source || inspectSource(this); + }); + }); + + var path = global_1; + + var aFunction = function (variable) { + return typeof variable == 'function' ? variable : undefined; + }; + + var getBuiltIn = function (namespace, method) { + return arguments.length < 2 ? aFunction(path[namespace]) || aFunction(global_1[namespace]) + : path[namespace] && path[namespace][method] || global_1[namespace] && global_1[namespace][method]; + }; + + var ceil = Math.ceil; + var floor = Math.floor; + + // `ToInteger` abstract operation + // https://tc39.es/ecma262/#sec-tointeger + var toInteger = function (argument) { + return isNaN(argument = +argument) ? 0 : (argument > 0 ? floor : ceil)(argument); + }; + + var min = Math.min; + + // `ToLength` abstract operation + // https://tc39.es/ecma262/#sec-tolength + var toLength = function (argument) { + return argument > 0 ? min(toInteger(argument), 0x1FFFFFFFFFFFFF) : 0; // 2 ** 53 - 1 == 9007199254740991 + }; + + var max = Math.max; + var min$1 = Math.min; + + // Helper for a popular repeating case of the spec: + // Let integer be ? ToInteger(index). + // If integer < 0, let result be max((length + integer), 0); else let result be min(integer, length). + var toAbsoluteIndex = function (index, length) { + var integer = toInteger(index); + return integer < 0 ? max(integer + length, 0) : min$1(integer, length); + }; + + // `Array.prototype.{ indexOf, includes }` methods implementation + var createMethod = function (IS_INCLUDES) { + return function ($this, el, fromIndex) { + var O = toIndexedObject($this); + var length = toLength(O.length); + var index = toAbsoluteIndex(fromIndex, length); + var value; + // Array#includes uses SameValueZero equality algorithm + // eslint-disable-next-line no-self-compare + if (IS_INCLUDES && el != el) { while (length > index) { + value = O[index++]; + // eslint-disable-next-line no-self-compare + if (value != value) { return true; } + // Array#indexOf ignores holes, Array#includes - not + } } else { for (;length > index; index++) { + if ((IS_INCLUDES || index in O) && O[index] === el) { return IS_INCLUDES || index || 0; } + } } return !IS_INCLUDES && -1; + }; + }; + + var arrayIncludes = { + // `Array.prototype.includes` method + // https://tc39.es/ecma262/#sec-array.prototype.includes + includes: createMethod(true), + // `Array.prototype.indexOf` method + // https://tc39.es/ecma262/#sec-array.prototype.indexof + indexOf: createMethod(false) + }; + var arrayIncludes_1 = arrayIncludes.includes; + var arrayIncludes_2 = arrayIncludes.indexOf; + + var indexOf = arrayIncludes.indexOf; + + + var objectKeysInternal = function (object, names) { + var O = toIndexedObject(object); + var i = 0; + var result = []; + var key; + for (key in O) { !has(hiddenKeys, key) && has(O, key) && result.push(key); } + // Don't enum bug & hidden keys + while (names.length > i) { if (has(O, key = names[i++])) { + ~indexOf(result, key) || result.push(key); + } } + return result; + }; + + // IE8- don't enum bug keys + var enumBugKeys = [ + 'constructor', + 'hasOwnProperty', + 'isPrototypeOf', + 'propertyIsEnumerable', + 'toLocaleString', + 'toString', + 'valueOf' + ]; + + var hiddenKeys$1 = enumBugKeys.concat('length', 'prototype'); + + // `Object.getOwnPropertyNames` method + // https://tc39.es/ecma262/#sec-object.getownpropertynames + var f$3 = Object.getOwnPropertyNames || function getOwnPropertyNames(O) { + return objectKeysInternal(O, hiddenKeys$1); + }; + + var objectGetOwnPropertyNames = { + f: f$3 + }; + + var f$4 = Object.getOwnPropertySymbols; + + var objectGetOwnPropertySymbols = { + f: f$4 + }; + + // all object keys, includes non-enumerable and symbols + var ownKeys = getBuiltIn('Reflect', 'ownKeys') || function ownKeys(it) { + var keys = objectGetOwnPropertyNames.f(anObject(it)); + var getOwnPropertySymbols = objectGetOwnPropertySymbols.f; + return getOwnPropertySymbols ? keys.concat(getOwnPropertySymbols(it)) : keys; + }; + + var copyConstructorProperties = function (target, source) { + var keys = ownKeys(source); + var defineProperty = objectDefineProperty.f; + var getOwnPropertyDescriptor = objectGetOwnPropertyDescriptor.f; + for (var i = 0; i < keys.length; i++) { + var key = keys[i]; + if (!has(target, key)) { defineProperty(target, key, getOwnPropertyDescriptor(source, key)); } + } + }; + + var replacement = /#|\.prototype\./; + + var isForced = function (feature, detection) { + var value = data[normalize(feature)]; + return value == POLYFILL ? true + : value == NATIVE ? false + : typeof detection == 'function' ? fails(detection) + : !!detection; + }; + + var normalize = isForced.normalize = function (string) { + return String(string).replace(replacement, '.').toLowerCase(); + }; + + var data = isForced.data = {}; + var NATIVE = isForced.NATIVE = 'N'; + var POLYFILL = isForced.POLYFILL = 'P'; + + var isForced_1 = isForced; + + var getOwnPropertyDescriptor$1 = objectGetOwnPropertyDescriptor.f; + + + + + + + /* + options.target - name of the target object + options.global - target is the global object + options.stat - export as static methods of target + options.proto - export as prototype methods of target + options.real - real prototype method for the `pure` version + options.forced - export even if the native feature is available + options.bind - bind methods to the target, required for the `pure` version + options.wrap - wrap constructors to preventing global pollution, required for the `pure` version + options.unsafe - use the simple assignment of property instead of delete + defineProperty + options.sham - add a flag to not completely full polyfills + options.enumerable - export as enumerable property + options.noTargetGet - prevent calling a getter on target + */ + var _export = function (options, source) { + var TARGET = options.target; + var GLOBAL = options.global; + var STATIC = options.stat; + var FORCED, target, key, targetProperty, sourceProperty, descriptor; + if (GLOBAL) { + target = global_1; + } else if (STATIC) { + target = global_1[TARGET] || setGlobal(TARGET, {}); + } else { + target = (global_1[TARGET] || {}).prototype; + } + if (target) { for (key in source) { + sourceProperty = source[key]; + if (options.noTargetGet) { + descriptor = getOwnPropertyDescriptor$1(target, key); + targetProperty = descriptor && descriptor.value; + } else { targetProperty = target[key]; } + FORCED = isForced_1(GLOBAL ? key : TARGET + (STATIC ? '.' : '#') + key, options.forced); + // contained in target + if (!FORCED && targetProperty !== undefined) { + if (typeof sourceProperty === typeof targetProperty) { continue; } + copyConstructorProperties(sourceProperty, targetProperty); + } + // add a flag to not completely full polyfills + if (options.sham || (targetProperty && targetProperty.sham)) { + createNonEnumerableProperty(sourceProperty, 'sham', true); + } + // extend global + redefine(target, key, sourceProperty, options); + } } + }; + + var nativeSymbol = !!Object.getOwnPropertySymbols && !fails(function () { + // Chrome 38 Symbol has incorrect toString conversion + // eslint-disable-next-line no-undef + return !String(Symbol()); + }); + + var useSymbolAsUid = nativeSymbol + // eslint-disable-next-line no-undef + && !Symbol.sham + // eslint-disable-next-line no-undef + && typeof Symbol.iterator == 'symbol'; + + var WellKnownSymbolsStore = shared('wks'); + var Symbol$1 = global_1.Symbol; + var createWellKnownSymbol = useSymbolAsUid ? Symbol$1 : Symbol$1 && Symbol$1.withoutSetter || uid; + + var wellKnownSymbol = function (name) { + if (!has(WellKnownSymbolsStore, name)) { + if (nativeSymbol && has(Symbol$1, name)) { WellKnownSymbolsStore[name] = Symbol$1[name]; } + else { WellKnownSymbolsStore[name] = createWellKnownSymbol('Symbol.' + name); } + } return WellKnownSymbolsStore[name]; + }; + + // `Object.keys` method + // https://tc39.es/ecma262/#sec-object.keys + var objectKeys = Object.keys || function keys(O) { + return objectKeysInternal(O, enumBugKeys); + }; + + // `Object.defineProperties` method + // https://tc39.es/ecma262/#sec-object.defineproperties + var objectDefineProperties = descriptors ? Object.defineProperties : function defineProperties(O, Properties) { + anObject(O); + var keys = objectKeys(Properties); + var length = keys.length; + var index = 0; + var key; + while (length > index) { objectDefineProperty.f(O, key = keys[index++], Properties[key]); } + return O; + }; + + var html = getBuiltIn('document', 'documentElement'); + + var GT = '>'; + var LT = '<'; + var PROTOTYPE = 'prototype'; + var SCRIPT = 'script'; + var IE_PROTO = sharedKey('IE_PROTO'); + + var EmptyConstructor = function () { /* empty */ }; + + var scriptTag = function (content) { + return LT + SCRIPT + GT + content + LT + '/' + SCRIPT + GT; + }; + + // Create object with fake `null` prototype: use ActiveX Object with cleared prototype + var NullProtoObjectViaActiveX = function (activeXDocument) { + activeXDocument.write(scriptTag('')); + activeXDocument.close(); + var temp = activeXDocument.parentWindow.Object; + activeXDocument = null; // avoid memory leak + return temp; + }; + + // Create object with fake `null` prototype: use iframe Object with cleared prototype + var NullProtoObjectViaIFrame = function () { + // Thrash, waste and sodomy: IE GC bug + var iframe = documentCreateElement('iframe'); + var JS = 'java' + SCRIPT + ':'; + var iframeDocument; + iframe.style.display = 'none'; + html.appendChild(iframe); + // https://github.com/zloirock/core-js/issues/475 + iframe.src = String(JS); + iframeDocument = iframe.contentWindow.document; + iframeDocument.open(); + iframeDocument.write(scriptTag('document.F=Object')); + iframeDocument.close(); + return iframeDocument.F; + }; + + // Check for document.domain and active x support + // No need to use active x approach when document.domain is not set + // see https://github.com/es-shims/es5-shim/issues/150 + // variation of https://github.com/kitcambridge/es5-shim/commit/4f738ac066346 + // avoid IE GC bug + var activeXDocument; + var NullProtoObject = function () { + try { + /* global ActiveXObject */ + activeXDocument = document.domain && new ActiveXObject('htmlfile'); + } catch (error) { /* ignore */ } + NullProtoObject = activeXDocument ? NullProtoObjectViaActiveX(activeXDocument) : NullProtoObjectViaIFrame(); + var length = enumBugKeys.length; + while (length--) { delete NullProtoObject[PROTOTYPE][enumBugKeys[length]]; } + return NullProtoObject(); + }; + + hiddenKeys[IE_PROTO] = true; + + // `Object.create` method + // https://tc39.es/ecma262/#sec-object.create + var objectCreate = Object.create || function create(O, Properties) { + var result; + if (O !== null) { + EmptyConstructor[PROTOTYPE] = anObject(O); + result = new EmptyConstructor(); + EmptyConstructor[PROTOTYPE] = null; + // add "__proto__" for Object.getPrototypeOf polyfill + result[IE_PROTO] = O; + } else { result = NullProtoObject(); } + return Properties === undefined ? result : objectDefineProperties(result, Properties); + }; + + var UNSCOPABLES = wellKnownSymbol('unscopables'); + var ArrayPrototype = Array.prototype; + + // Array.prototype[@@unscopables] + // https://tc39.es/ecma262/#sec-array.prototype-@@unscopables + if (ArrayPrototype[UNSCOPABLES] == undefined) { + objectDefineProperty.f(ArrayPrototype, UNSCOPABLES, { + configurable: true, + value: objectCreate(null) + }); + } + + // add a key to Array.prototype[@@unscopables] + var addToUnscopables = function (key) { + ArrayPrototype[UNSCOPABLES][key] = true; + }; + + var defineProperty = Object.defineProperty; + var cache = {}; + + var thrower = function (it) { throw it; }; + + var arrayMethodUsesToLength = function (METHOD_NAME, options) { + if (has(cache, METHOD_NAME)) { return cache[METHOD_NAME]; } + if (!options) { options = {}; } + var method = [][METHOD_NAME]; + var ACCESSORS = has(options, 'ACCESSORS') ? options.ACCESSORS : false; + var argument0 = has(options, 0) ? options[0] : thrower; + var argument1 = has(options, 1) ? options[1] : undefined; + + return cache[METHOD_NAME] = !!method && !fails(function () { + if (ACCESSORS && !descriptors) { return true; } + var O = { length: -1 }; + + if (ACCESSORS) { defineProperty(O, 1, { enumerable: true, get: thrower }); } + else { O[1] = 1; } + + method.call(O, argument0, argument1); + }); + }; + + 'use strict'; + + var $includes = arrayIncludes.includes; + + + + var USES_TO_LENGTH = arrayMethodUsesToLength('indexOf', { ACCESSORS: true, 1: 0 }); + + // `Array.prototype.includes` method + // https://tc39.es/ecma262/#sec-array.prototype.includes + _export({ target: 'Array', proto: true, forced: !USES_TO_LENGTH }, { + includes: function includes(el /* , fromIndex = 0 */) { + return $includes(this, el, arguments.length > 1 ? arguments[1] : undefined); + } + }); + + // https://tc39.es/ecma262/#sec-array.prototype-@@unscopables + addToUnscopables('includes'); + + var es_array_includes = { + + }; + + var aFunction$1 = function (it) { + if (typeof it != 'function') { + throw TypeError(String(it) + ' is not a function'); + } return it; + }; + + // optional / simple context binding + var functionBindContext = function (fn, that, length) { + aFunction$1(fn); + if (that === undefined) { return fn; } + switch (length) { + case 0: return function () { + return fn.call(that); + }; + case 1: return function (a) { + return fn.call(that, a); + }; + case 2: return function (a, b) { + return fn.call(that, a, b); + }; + case 3: return function (a, b, c) { + return fn.call(that, a, b, c); + }; + } + return function (/* ...args */) { + return fn.apply(that, arguments); + }; + }; + + var call = Function.call; + + var entryUnbind = function (CONSTRUCTOR, METHOD, length) { + return functionBindContext(call, global_1[CONSTRUCTOR].prototype[METHOD], length); + }; + + var includes = entryUnbind('Array', 'includes'); + + var includes$1 = includes; + + // `ToObject` abstract operation + // https://tc39.es/ecma262/#sec-toobject + var toObject = function (argument) { + return Object(requireObjectCoercible(argument)); + }; + + // `IsArray` abstract operation + // https://tc39.es/ecma262/#sec-isarray + var isArray = Array.isArray || function isArray(arg) { + return classofRaw(arg) == 'Array'; + }; + + var SPECIES = wellKnownSymbol('species'); + + // `ArraySpeciesCreate` abstract operation + // https://tc39.es/ecma262/#sec-arrayspeciescreate + var arraySpeciesCreate = function (originalArray, length) { + var C; + if (isArray(originalArray)) { + C = originalArray.constructor; + // cross-realm fallback + if (typeof C == 'function' && (C === Array || isArray(C.prototype))) { C = undefined; } + else if (isObject(C)) { + C = C[SPECIES]; + if (C === null) { C = undefined; } + } + } return new (C === undefined ? Array : C)(length === 0 ? 0 : length); + }; + + var push = [].push; + + // `Array.prototype.{ forEach, map, filter, some, every, find, findIndex, filterOut }` methods implementation + var createMethod$1 = function (TYPE) { + var IS_MAP = TYPE == 1; + var IS_FILTER = TYPE == 2; + var IS_SOME = TYPE == 3; + var IS_EVERY = TYPE == 4; + var IS_FIND_INDEX = TYPE == 6; + var IS_FILTER_OUT = TYPE == 7; + var NO_HOLES = TYPE == 5 || IS_FIND_INDEX; + return function ($this, callbackfn, that, specificCreate) { + var O = toObject($this); + var self = indexedObject(O); + var boundFunction = functionBindContext(callbackfn, that, 3); + var length = toLength(self.length); + var index = 0; + var create = specificCreate || arraySpeciesCreate; + var target = IS_MAP ? create($this, length) : IS_FILTER || IS_FILTER_OUT ? create($this, 0) : undefined; + var value, result; + for (;length > index; index++) { if (NO_HOLES || index in self) { + value = self[index]; + result = boundFunction(value, index, O); + if (TYPE) { + if (IS_MAP) { target[index] = result; } // map + else if (result) { switch (TYPE) { + case 3: return true; // some + case 5: return value; // find + case 6: return index; // findIndex + case 2: push.call(target, value); // filter + } } else { switch (TYPE) { + case 4: return false; // every + case 7: push.call(target, value); // filterOut + } } + } + } } + return IS_FIND_INDEX ? -1 : IS_SOME || IS_EVERY ? IS_EVERY : target; + }; + }; + + var arrayIteration = { + // `Array.prototype.forEach` method + // https://tc39.es/ecma262/#sec-array.prototype.foreach + forEach: createMethod$1(0), + // `Array.prototype.map` method + // https://tc39.es/ecma262/#sec-array.prototype.map + map: createMethod$1(1), + // `Array.prototype.filter` method + // https://tc39.es/ecma262/#sec-array.prototype.filter + filter: createMethod$1(2), + // `Array.prototype.some` method + // https://tc39.es/ecma262/#sec-array.prototype.some + some: createMethod$1(3), + // `Array.prototype.every` method + // https://tc39.es/ecma262/#sec-array.prototype.every + every: createMethod$1(4), + // `Array.prototype.find` method + // https://tc39.es/ecma262/#sec-array.prototype.find + find: createMethod$1(5), + // `Array.prototype.findIndex` method + // https://tc39.es/ecma262/#sec-array.prototype.findIndex + findIndex: createMethod$1(6), + // `Array.prototype.filterOut` method + // https://github.com/tc39/proposal-array-filtering + filterOut: createMethod$1(7) + }; + var arrayIteration_1 = arrayIteration.forEach; + var arrayIteration_2 = arrayIteration.map; + var arrayIteration_3 = arrayIteration.filter; + var arrayIteration_4 = arrayIteration.some; + var arrayIteration_5 = arrayIteration.every; + var arrayIteration_6 = arrayIteration.find; + var arrayIteration_7 = arrayIteration.findIndex; + var arrayIteration_8 = arrayIteration.filterOut; + + 'use strict'; + + var $find = arrayIteration.find; + + + + var FIND = 'find'; + var SKIPS_HOLES = true; + + var USES_TO_LENGTH$1 = arrayMethodUsesToLength(FIND); + + // Shouldn't skip holes + if (FIND in []) { Array(1)[FIND](function () { SKIPS_HOLES = false; }); } + + // `Array.prototype.find` method + // https://tc39.es/ecma262/#sec-array.prototype.find + _export({ target: 'Array', proto: true, forced: SKIPS_HOLES || !USES_TO_LENGTH$1 }, { + find: function find(callbackfn /* , that = undefined */) { + return $find(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined); + } + }); + + // https://tc39.es/ecma262/#sec-array.prototype-@@unscopables + addToUnscopables(FIND); + + var es_array_find = { + + }; + + var find = entryUnbind('Array', 'find'); + + var find$1 = find; + + // `String.prototype.{ codePointAt, at }` methods implementation + var createMethod$2 = function (CONVERT_TO_STRING) { + return function ($this, pos) { + var S = String(requireObjectCoercible($this)); + var position = toInteger(pos); + var size = S.length; + var first, second; + if (position < 0 || position >= size) { return CONVERT_TO_STRING ? '' : undefined; } + first = S.charCodeAt(position); + return first < 0xD800 || first > 0xDBFF || position + 1 === size + || (second = S.charCodeAt(position + 1)) < 0xDC00 || second > 0xDFFF + ? CONVERT_TO_STRING ? S.charAt(position) : first + : CONVERT_TO_STRING ? S.slice(position, position + 2) : (first - 0xD800 << 10) + (second - 0xDC00) + 0x10000; + }; + }; + + var stringMultibyte = { + // `String.prototype.codePointAt` method + // https://tc39.es/ecma262/#sec-string.prototype.codepointat + codeAt: createMethod$2(false), + // `String.prototype.at` method + // https://github.com/mathiasbynens/String.prototype.at + charAt: createMethod$2(true) + }; + var stringMultibyte_1 = stringMultibyte.codeAt; + var stringMultibyte_2 = stringMultibyte.charAt; + + var correctPrototypeGetter = !fails(function () { + function F() { /* empty */ } + F.prototype.constructor = null; + return Object.getPrototypeOf(new F()) !== F.prototype; + }); + + var IE_PROTO$1 = sharedKey('IE_PROTO'); + var ObjectPrototype = Object.prototype; + + // `Object.getPrototypeOf` method + // https://tc39.es/ecma262/#sec-object.getprototypeof + var objectGetPrototypeOf = correctPrototypeGetter ? Object.getPrototypeOf : function (O) { + O = toObject(O); + if (has(O, IE_PROTO$1)) { return O[IE_PROTO$1]; } + if (typeof O.constructor == 'function' && O instanceof O.constructor) { + return O.constructor.prototype; + } return O instanceof Object ? ObjectPrototype : null; + }; + + 'use strict'; + + + + + + + + var ITERATOR = wellKnownSymbol('iterator'); + var BUGGY_SAFARI_ITERATORS = false; + + var returnThis = function () { return this; }; + + // `%IteratorPrototype%` object + // https://tc39.es/ecma262/#sec-%iteratorprototype%-object + var IteratorPrototype, PrototypeOfArrayIteratorPrototype, arrayIterator; + + if ([].keys) { + arrayIterator = [].keys(); + // Safari 8 has buggy iterators w/o `next` + if (!('next' in arrayIterator)) { BUGGY_SAFARI_ITERATORS = true; } + else { + PrototypeOfArrayIteratorPrototype = objectGetPrototypeOf(objectGetPrototypeOf(arrayIterator)); + if (PrototypeOfArrayIteratorPrototype !== Object.prototype) { IteratorPrototype = PrototypeOfArrayIteratorPrototype; } + } + } + + var NEW_ITERATOR_PROTOTYPE = IteratorPrototype == undefined || fails(function () { + var test = {}; + // FF44- legacy iterators case + return IteratorPrototype[ITERATOR].call(test) !== test; + }); + + if (NEW_ITERATOR_PROTOTYPE) { IteratorPrototype = {}; } + + // 25.1.2.1.1 %IteratorPrototype%[@@iterator]() + if ((!isPure || NEW_ITERATOR_PROTOTYPE) && !has(IteratorPrototype, ITERATOR)) { + createNonEnumerableProperty(IteratorPrototype, ITERATOR, returnThis); + } + + var iteratorsCore = { + IteratorPrototype: IteratorPrototype, + BUGGY_SAFARI_ITERATORS: BUGGY_SAFARI_ITERATORS + }; + var iteratorsCore_1 = iteratorsCore.IteratorPrototype; + var iteratorsCore_2 = iteratorsCore.BUGGY_SAFARI_ITERATORS; + + var defineProperty$1 = objectDefineProperty.f; + + + + var TO_STRING_TAG = wellKnownSymbol('toStringTag'); + + var setToStringTag = function (it, TAG, STATIC) { + if (it && !has(it = STATIC ? it : it.prototype, TO_STRING_TAG)) { + defineProperty$1(it, TO_STRING_TAG, { configurable: true, value: TAG }); + } + }; + + var iterators = {}; + + 'use strict'; + var IteratorPrototype$1 = iteratorsCore.IteratorPrototype; + + + + + + var returnThis$1 = function () { return this; }; + + var createIteratorConstructor = function (IteratorConstructor, NAME, next) { + var TO_STRING_TAG = NAME + ' Iterator'; + IteratorConstructor.prototype = objectCreate(IteratorPrototype$1, { next: createPropertyDescriptor(1, next) }); + setToStringTag(IteratorConstructor, TO_STRING_TAG, false, true); + iterators[TO_STRING_TAG] = returnThis$1; + return IteratorConstructor; + }; + + var aPossiblePrototype = function (it) { + if (!isObject(it) && it !== null) { + throw TypeError("Can't set " + String(it) + ' as a prototype'); + } return it; + }; + + // `Object.setPrototypeOf` method + // https://tc39.es/ecma262/#sec-object.setprototypeof + // Works with __proto__ only. Old v8 can't work with null proto objects. + /* eslint-disable no-proto */ + var objectSetPrototypeOf = Object.setPrototypeOf || ('__proto__' in {} ? function () { + var CORRECT_SETTER = false; + var test = {}; + var setter; + try { + setter = Object.getOwnPropertyDescriptor(Object.prototype, '__proto__').set; + setter.call(test, []); + CORRECT_SETTER = test instanceof Array; + } catch (error) { /* empty */ } + return function setPrototypeOf(O, proto) { + anObject(O); + aPossiblePrototype(proto); + if (CORRECT_SETTER) { setter.call(O, proto); } + else { O.__proto__ = proto; } + return O; + }; + }() : undefined); + + 'use strict'; + + + + + + + + + + + + + var IteratorPrototype$2 = iteratorsCore.IteratorPrototype; + var BUGGY_SAFARI_ITERATORS$1 = iteratorsCore.BUGGY_SAFARI_ITERATORS; + var ITERATOR$1 = wellKnownSymbol('iterator'); + var KEYS = 'keys'; + var VALUES = 'values'; + var ENTRIES = 'entries'; + + var returnThis$2 = function () { return this; }; + + var defineIterator = function (Iterable, NAME, IteratorConstructor, next, DEFAULT, IS_SET, FORCED) { + createIteratorConstructor(IteratorConstructor, NAME, next); + + var getIterationMethod = function (KIND) { + if (KIND === DEFAULT && defaultIterator) { return defaultIterator; } + if (!BUGGY_SAFARI_ITERATORS$1 && KIND in IterablePrototype) { return IterablePrototype[KIND]; } + switch (KIND) { + case KEYS: return function keys() { return new IteratorConstructor(this, KIND); }; + case VALUES: return function values() { return new IteratorConstructor(this, KIND); }; + case ENTRIES: return function entries() { return new IteratorConstructor(this, KIND); }; + } return function () { return new IteratorConstructor(this); }; + }; + + var TO_STRING_TAG = NAME + ' Iterator'; + var INCORRECT_VALUES_NAME = false; + var IterablePrototype = Iterable.prototype; + var nativeIterator = IterablePrototype[ITERATOR$1] + || IterablePrototype['@@iterator'] + || DEFAULT && IterablePrototype[DEFAULT]; + var defaultIterator = !BUGGY_SAFARI_ITERATORS$1 && nativeIterator || getIterationMethod(DEFAULT); + var anyNativeIterator = NAME == 'Array' ? IterablePrototype.entries || nativeIterator : nativeIterator; + var CurrentIteratorPrototype, methods, KEY; + + // fix native + if (anyNativeIterator) { + CurrentIteratorPrototype = objectGetPrototypeOf(anyNativeIterator.call(new Iterable())); + if (IteratorPrototype$2 !== Object.prototype && CurrentIteratorPrototype.next) { + if (!isPure && objectGetPrototypeOf(CurrentIteratorPrototype) !== IteratorPrototype$2) { + if (objectSetPrototypeOf) { + objectSetPrototypeOf(CurrentIteratorPrototype, IteratorPrototype$2); + } else if (typeof CurrentIteratorPrototype[ITERATOR$1] != 'function') { + createNonEnumerableProperty(CurrentIteratorPrototype, ITERATOR$1, returnThis$2); + } + } + // Set @@toStringTag to native iterators + setToStringTag(CurrentIteratorPrototype, TO_STRING_TAG, true, true); + if (isPure) { iterators[TO_STRING_TAG] = returnThis$2; } + } + } + + // fix Array#{values, @@iterator}.name in V8 / FF + if (DEFAULT == VALUES && nativeIterator && nativeIterator.name !== VALUES) { + INCORRECT_VALUES_NAME = true; + defaultIterator = function values() { return nativeIterator.call(this); }; + } + + // define iterator + if ((!isPure || FORCED) && IterablePrototype[ITERATOR$1] !== defaultIterator) { + createNonEnumerableProperty(IterablePrototype, ITERATOR$1, defaultIterator); + } + iterators[NAME] = defaultIterator; + + // export additional methods + if (DEFAULT) { + methods = { + values: getIterationMethod(VALUES), + keys: IS_SET ? defaultIterator : getIterationMethod(KEYS), + entries: getIterationMethod(ENTRIES) + }; + if (FORCED) { for (KEY in methods) { + if (BUGGY_SAFARI_ITERATORS$1 || INCORRECT_VALUES_NAME || !(KEY in IterablePrototype)) { + redefine(IterablePrototype, KEY, methods[KEY]); + } + } } else { _export({ target: NAME, proto: true, forced: BUGGY_SAFARI_ITERATORS$1 || INCORRECT_VALUES_NAME }, methods); } + } + + return methods; + }; + + 'use strict'; + var charAt = stringMultibyte.charAt; + + + + var STRING_ITERATOR = 'String Iterator'; + var setInternalState = internalState.set; + var getInternalState = internalState.getterFor(STRING_ITERATOR); + + // `String.prototype[@@iterator]` method + // https://tc39.es/ecma262/#sec-string.prototype-@@iterator + defineIterator(String, 'String', function (iterated) { + setInternalState(this, { + type: STRING_ITERATOR, + string: String(iterated), + index: 0 + }); + // `%StringIteratorPrototype%.next` method + // https://tc39.es/ecma262/#sec-%stringiteratorprototype%.next + }, function next() { + var state = getInternalState(this); + var string = state.string; + var index = state.index; + var point; + if (index >= string.length) { return { value: undefined, done: true }; } + point = charAt(string, index); + state.index += point.length; + return { value: point, done: false }; + }); + + var es_string_iterator = { + + }; + + var iteratorClose = function (iterator) { + var returnMethod = iterator['return']; + if (returnMethod !== undefined) { + return anObject(returnMethod.call(iterator)).value; + } + }; + + // call something on iterator step with safe closing on error + var callWithSafeIterationClosing = function (iterator, fn, value, ENTRIES) { + try { + return ENTRIES ? fn(anObject(value)[0], value[1]) : fn(value); + // 7.4.6 IteratorClose(iterator, completion) + } catch (error) { + iteratorClose(iterator); + throw error; + } + }; + + var ITERATOR$2 = wellKnownSymbol('iterator'); + var ArrayPrototype$1 = Array.prototype; + + // check on default Array iterator + var isArrayIteratorMethod = function (it) { + return it !== undefined && (iterators.Array === it || ArrayPrototype$1[ITERATOR$2] === it); + }; + + 'use strict'; + + + + + var createProperty = function (object, key, value) { + var propertyKey = toPrimitive(key); + if (propertyKey in object) { objectDefineProperty.f(object, propertyKey, createPropertyDescriptor(0, value)); } + else { object[propertyKey] = value; } + }; + + var TO_STRING_TAG$1 = wellKnownSymbol('toStringTag'); + var test = {}; + + test[TO_STRING_TAG$1] = 'z'; + + var toStringTagSupport = String(test) === '[object z]'; + + var TO_STRING_TAG$2 = wellKnownSymbol('toStringTag'); + // ES3 wrong here + var CORRECT_ARGUMENTS = classofRaw(function () { return arguments; }()) == 'Arguments'; + + // fallback for IE11 Script Access Denied error + var tryGet = function (it, key) { + try { + return it[key]; + } catch (error) { /* empty */ } + }; + + // getting tag from ES6+ `Object.prototype.toString` + var classof = toStringTagSupport ? classofRaw : function (it) { + var O, tag, result; + return it === undefined ? 'Undefined' : it === null ? 'Null' + // @@toStringTag case + : typeof (tag = tryGet(O = Object(it), TO_STRING_TAG$2)) == 'string' ? tag + // builtinTag case + : CORRECT_ARGUMENTS ? classofRaw(O) + // ES3 arguments fallback + : (result = classofRaw(O)) == 'Object' && typeof O.callee == 'function' ? 'Arguments' : result; + }; + + var ITERATOR$3 = wellKnownSymbol('iterator'); + + var getIteratorMethod = function (it) { + if (it != undefined) { return it[ITERATOR$3] + || it['@@iterator'] + || iterators[classof(it)]; } + }; + + 'use strict'; + + + + + + + + + // `Array.from` method implementation + // https://tc39.es/ecma262/#sec-array.from + var arrayFrom = function from(arrayLike /* , mapfn = undefined, thisArg = undefined */) { + var O = toObject(arrayLike); + var C = typeof this == 'function' ? this : Array; + var argumentsLength = arguments.length; + var mapfn = argumentsLength > 1 ? arguments[1] : undefined; + var mapping = mapfn !== undefined; + var iteratorMethod = getIteratorMethod(O); + var index = 0; + var length, result, step, iterator, next, value; + if (mapping) { mapfn = functionBindContext(mapfn, argumentsLength > 2 ? arguments[2] : undefined, 2); } + // if the target is not iterable or it's an array with the default iterator - use a simple case + if (iteratorMethod != undefined && !(C == Array && isArrayIteratorMethod(iteratorMethod))) { + iterator = iteratorMethod.call(O); + next = iterator.next; + result = new C(); + for (;!(step = next.call(iterator)).done; index++) { + value = mapping ? callWithSafeIterationClosing(iterator, mapfn, [step.value, index], true) : step.value; + createProperty(result, index, value); + } + } else { + length = toLength(O.length); + result = new C(length); + for (;length > index; index++) { + value = mapping ? mapfn(O[index], index) : O[index]; + createProperty(result, index, value); + } + } + result.length = index; + return result; + }; + + var ITERATOR$4 = wellKnownSymbol('iterator'); + var SAFE_CLOSING = false; + + try { + var called = 0; + var iteratorWithReturn = { + next: function () { + return { done: !!called++ }; + }, + 'return': function () { + SAFE_CLOSING = true; + } + }; + iteratorWithReturn[ITERATOR$4] = function () { + return this; + }; + // eslint-disable-next-line no-throw-literal + Array.from(iteratorWithReturn, function () { throw 2; }); + } catch (error) { /* empty */ } + + var checkCorrectnessOfIteration = function (exec, SKIP_CLOSING) { + if (!SKIP_CLOSING && !SAFE_CLOSING) { return false; } + var ITERATION_SUPPORT = false; + try { + var object = {}; + object[ITERATOR$4] = function () { + return { + next: function () { + return { done: ITERATION_SUPPORT = true }; + } + }; + }; + exec(object); + } catch (error) { /* empty */ } + return ITERATION_SUPPORT; + }; + + var INCORRECT_ITERATION = !checkCorrectnessOfIteration(function (iterable) { + Array.from(iterable); + }); + + // `Array.from` method + // https://tc39.es/ecma262/#sec-array.from + _export({ target: 'Array', stat: true, forced: INCORRECT_ITERATION }, { + from: arrayFrom + }); + + var es_array_from = { + + }; + + var from_1 = path.Array.from; + + var from_1$1 = from_1; + + 'use strict'; + + var $findIndex = arrayIteration.findIndex; + + + + var FIND_INDEX = 'findIndex'; + var SKIPS_HOLES$1 = true; + + var USES_TO_LENGTH$2 = arrayMethodUsesToLength(FIND_INDEX); + + // Shouldn't skip holes + if (FIND_INDEX in []) { Array(1)[FIND_INDEX](function () { SKIPS_HOLES$1 = false; }); } + + // `Array.prototype.findIndex` method + // https://tc39.es/ecma262/#sec-array.prototype.findindex + _export({ target: 'Array', proto: true, forced: SKIPS_HOLES$1 || !USES_TO_LENGTH$2 }, { + findIndex: function findIndex(callbackfn /* , that = undefined */) { + return $findIndex(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined); + } + }); + + // https://tc39.es/ecma262/#sec-array.prototype-@@unscopables + addToUnscopables(FIND_INDEX); + + var es_array_findIndex = { + + }; + + var findIndex = entryUnbind('Array', 'findIndex'); + + var findIndex$1 = findIndex; + + var base64 = createCommonjsModule(function (module, exports) { + (function() { + + /** + * version: 0.3.0 + * git://github.com/davidchambers/Base64.js.git + */ + + var object = 'object' != 'undefined' ? exports : this; // #8: web workers + var chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='; + + function InvalidCharacterError(message) { + this.message = message; + } + + InvalidCharacterError.prototype = new Error; + InvalidCharacterError.prototype.name = 'InvalidCharacterError'; + + // encoder + // [https://gist.github.com/999166] by [https://github.com/nignag] + object.btoa || ( + object.btoa = function(input) { + var str = String(input); + for ( + // initialize result and counter + var block, charCode, idx = 0, map = chars, output = ''; + // if the next str index does not exist: + // change the mapping table to "=" + // check if d has no fractional digits + str.charAt(idx | 0) || (map = '=', idx % 1); + // "8 - idx % 1 * 8" generates the sequence 2, 4, 6, 8 + output += map.charAt(63 & block >> 8 - idx % 1 * 8) + ) { + charCode = str.charCodeAt(idx += 3 / 4); + if (charCode > 0xFF) { + throw new InvalidCharacterError('\'btoa\' failed: The string to be encoded contains characters outside of the Latin1 range.'); + } + block = block << 8 | charCode; + } + return output; + }); + + // decoder + // [https://gist.github.com/1020396] by [https://github.com/atk] + object.atob || ( + object.atob = function(input) { + var str = String(input).replace(/=+$/, ''); + if (str.length % 4 == 1) { + throw new InvalidCharacterError('\'atob\' failed: The string to be decoded is not correctly encoded.'); + } + for ( + // initialize result and counters + var bc = 0, bs, buffer, idx = 0, output = ''; + // get next character + // eslint-disable-next-line no-cond-assign + buffer = str.charAt(idx++); + // character found in table? initialize bit storage and add its ascii value; + ~buffer && (bs = bc % 4 ? bs * 64 + buffer : buffer, + // and if not first of each 4 characters, + // convert the first 8 bits to one ascii character + bc++ % 4) ? output += String.fromCharCode(255 & bs >> (-2 * bc & 6)) : 0 + ) { + // try to find character in table (0-63, not found => -1) + buffer = chars.indexOf(buffer); + } + return output; + }); + + }()); + }); + + // `Number.isNaN` method + // https://tc39.es/ecma262/#sec-number.isnan + _export({ target: 'Number', stat: true }, { + isNaN: function isNaN(number) { + // eslint-disable-next-line no-self-compare + return number != number; + } + }); + + var es_number_isNan = { + + }; + + var isNan = path.Number.isNaN; + + var isNan$1 = isNan; + + var globalIsFinite = global_1.isFinite; + + // `Number.isFinite` method + // https://tc39.es/ecma262/#sec-number.isfinite + var numberIsFinite = Number.isFinite || function isFinite(it) { + return typeof it == 'number' && globalIsFinite(it); + }; + + // `Number.isFinite` method + // https://tc39.es/ecma262/#sec-number.isfinite + _export({ target: 'Number', stat: true }, { isFinite: numberIsFinite }); + + var es_number_isFinite = { + + }; + + var _isFinite = path.Number.isFinite; + + var _isFinite$1 = _isFinite; + + var MATCH = wellKnownSymbol('match'); + + // `IsRegExp` abstract operation + // https://tc39.es/ecma262/#sec-isregexp + var isRegexp = function (it) { + var isRegExp; + return isObject(it) && ((isRegExp = it[MATCH]) !== undefined ? !!isRegExp : classofRaw(it) == 'RegExp'); + }; + + var notARegexp = function (it) { + if (isRegexp(it)) { + throw TypeError("The method doesn't accept regular expressions"); + } return it; + }; + + var MATCH$1 = wellKnownSymbol('match'); + + var correctIsRegexpLogic = function (METHOD_NAME) { + var regexp = /./; + try { + '/./'[METHOD_NAME](regexp); + } catch (error1) { + try { + regexp[MATCH$1] = false; + return '/./'[METHOD_NAME](regexp); + } catch (error2) { /* empty */ } + } return false; + }; + + 'use strict'; + + + + + + // `String.prototype.includes` method + // https://tc39.es/ecma262/#sec-string.prototype.includes + _export({ target: 'String', proto: true, forced: !correctIsRegexpLogic('includes') }, { + includes: function includes(searchString /* , position = 0 */) { + return !!~String(requireObjectCoercible(this)) + .indexOf(notARegexp(searchString), arguments.length > 1 ? arguments[1] : undefined); + } + }); + + var es_string_includes = { + + }; + + var includes$2 = entryUnbind('String', 'includes'); + + var includes$3 = includes$2; + + 'use strict'; + + var getOwnPropertyDescriptor$2 = objectGetOwnPropertyDescriptor.f; + + + + + + + var nativeStartsWith = ''.startsWith; + var min$2 = Math.min; + + var CORRECT_IS_REGEXP_LOGIC = correctIsRegexpLogic('startsWith'); + // https://github.com/zloirock/core-js/pull/702 + var MDN_POLYFILL_BUG = !isPure && !CORRECT_IS_REGEXP_LOGIC && !!function () { + var descriptor = getOwnPropertyDescriptor$2(String.prototype, 'startsWith'); + return descriptor && !descriptor.writable; + }(); + + // `String.prototype.startsWith` method + // https://tc39.es/ecma262/#sec-string.prototype.startswith + _export({ target: 'String', proto: true, forced: !MDN_POLYFILL_BUG && !CORRECT_IS_REGEXP_LOGIC }, { + startsWith: function startsWith(searchString /* , position = 0 */) { + var that = String(requireObjectCoercible(this)); + notARegexp(searchString); + var index = toLength(min$2(arguments.length > 1 ? arguments[1] : undefined, that.length)); + var search = String(searchString); + return nativeStartsWith + ? nativeStartsWith.call(that, search, index) + : that.slice(index, index + search.length) === search; + } + }); + + var es_string_startsWith = { + + }; + + var startsWith = entryUnbind('String', 'startsWith'); + + var startsWith$1 = startsWith; + + (function() { + + if (typeof Uint8Array !== 'undefined' || typeof window === 'undefined') { + return; + } + + function subarray(start, end) { + return this.slice(start, end); + } + + function set_(array, offset) { + + if (arguments.length < 2) { + offset = 0; + } + for (var i = 0, n = array.length; i < n; ++i, ++offset) { + this[offset] = array[i] & 0xFF; + } + } + + // we need typed arrays + function TypedArray(arg1) { + + var result; + if (typeof arg1 === 'number') { + result = new Array(arg1); + for (var i = 0; i < arg1; ++i) { + result[i] = 0; + } + } else { + result = arg1.slice(0); + } + result.subarray = subarray; + result.buffer = result; + result.byteLength = result.length; + result.set = set_; + if (typeof arg1 === 'object' && arg1.buffer) { + result.buffer = arg1.buffer; + } + + return result; + } + + window.Uint8Array = TypedArray; + window.Uint32Array = TypedArray; + window.Int32Array = TypedArray; + })(); + + var props = { + x: 'x', + y: 'y', + width: 'w', + height: 'h', + minimum: 's', + maximum: 'l', + diagonal: 'd' + }; + var propsList = Object.keys(props).map(function (key) { return props[key]; }).join(''); + var numberPattern = '[-+]?[0-9]*\\.?[0-9]+(?:[eE][-+]?[0-9]+)?'; + var findSpacesRegex = /\s/g; + var parseExpressionRegExp = new RegExp(("^(" + numberPattern + "\\*)?([" + propsList + "])(/" + numberPattern + ")?([-+]{1,2}" + numberPattern + ")?$"), 'g'); + + function throwInvalid(expression) { + throw new Error(("Invalid calc() expression: " + expression)); + } + + function evalCalcExpression(expression, bbox) { + var match = parseExpressionRegExp.exec(expression.replace(findSpacesRegex, '')); + if (!match) { throwInvalid(expression); } + parseExpressionRegExp.lastIndex = 0; // reset regex results for the next run + var multiply = match[1]; + var property = match[2]; + var divide = match[3]; + var add = match[4]; + var x = bbox.x; + var y = bbox.y; + var width = bbox.width; + var height = bbox.height; + var value = 0; + switch (property) { + case props.width: { + value = width; + break; + } + case props.height: { + value = height; + break; + } + case props.x: { + value = x; + break; + } + case props.y: { + value = y; + break; + } + case props.minimum: { + value = Math.min(height, width); + break; + } + case props.maximum: { + value = Math.max(height, width); + break; + } + case props.diagonal: { + value = Math.sqrt((height * height) + (width * width)); + break; + } + } + if (multiply) { + // e.g "2*" + value *= parseFloat(multiply); + } + if (divide) { + // e.g "/2" + value /= parseFloat(divide.slice(1)); + } + if (add) { + value += evalAddExpression(add); + } + return value; + } + + function evalAddExpression(addExpression) { + if (!addExpression) { return 0; } + var sign = addExpression[0]; + switch (sign) { + case '+': { + return parseFloat(addExpression.substr(1)); + } + case '-': { + return -parseFloat(addExpression.substr(1)); + } + } + return parseFloat(addExpression); + } + + function isCalcAttribute(value) { + return typeof value === 'string' && value.includes('calc'); + } + + var calcStart = 'calc('; + var calcStartOffset = calcStart.length; + + function evalCalcAttribute(attributeValue, refBBox) { + var value = attributeValue; + var startSearchIndex = 0; + do { + var calcIndex = value.indexOf(calcStart, startSearchIndex); + if (calcIndex === -1) { return value; } + var calcEndIndex = calcIndex + calcStartOffset; + var brackets = 1; + findClosingBracket: do { + switch (value[calcEndIndex]) { + case '(': { + brackets++; + break; + } + case ')': { + brackets--; + if (brackets === 0) { break findClosingBracket; } + break; + } + case undefined: { + // Could not find the closing bracket. + throwInvalid(value); + } + } + calcEndIndex++; + } while (true); + // Get the calc() expression without nested calcs (recursion) + var expression = value.slice(calcIndex + calcStartOffset, calcEndIndex); + if (isCalcAttribute(expression)) { + expression = evalCalcAttribute(expression, refBBox); + } + // Eval the calc() expression without nested calcs. + var calcValue = String(evalCalcExpression(expression, refBBox)); + // Replace the calc() expression and continue search + value = value.slice(0, calcIndex) + calcValue + value.slice(calcEndIndex + 1); + startSearchIndex = calcIndex + calcValue.length; + } while (true); + } + + // Declare shorthands to the most used math functions. + var round = Math.round; + var floor$1 = Math.floor; + var PI = Math.PI; + + var scale = { + + // Return the `value` from the `domain` interval scaled to the `range` interval. + linear: function(domain, range, value) { + + var domainSpan = domain[1] - domain[0]; + var rangeSpan = range[1] - range[0]; + return (((value - domain[0]) / domainSpan) * rangeSpan + range[0]) || 0; + } + }; + + var normalizeAngle = function(angle) { + + return (angle % 360) + (angle < 0 ? 360 : 0); + }; + + var snapToGrid = function(value, gridSize) { + + return gridSize * round(value / gridSize); + }; + + var toDeg = function(rad) { + + return (180 * rad / PI) % 360; + }; + + var toRad = function(deg, over360) { + + over360 = over360 || false; + deg = over360 ? deg : (deg % 360); + return deg * PI / 180; + }; + + // Return a random integer from the interval [min,max], inclusive. + var random = function(min, max) { + + if (max === undefined) { + // use first argument as max, min is 0 + max = (min === undefined) ? 1 : min; + min = 0; + + } else if (max < min) { + // switch max and min + var temp = min; + min = max; + max = temp; + } + + return floor$1((Math.random() * (max - min + 1)) + min); + }; + + // @return the bearing (cardinal direction) of the line. For example N, W, or SE. + + var cos = Math.cos; + var sin = Math.sin; + var atan2 = Math.atan2; + + var bearing = function(p, q) { + + var lat1 = toRad(p.y); + var lat2 = toRad(q.y); + var lon1 = p.x; + var lon2 = q.x; + var dLon = toRad(lon2 - lon1); + var y = sin(dLon) * cos(lat2); + var x = cos(lat1) * sin(lat2) - sin(lat1) * cos(lat2) * cos(dLon); + var brng = toDeg(atan2(y, x)); + + var bearings = ['NE', 'E', 'SE', 'S', 'SW', 'W', 'NW', 'N']; + + var index = brng - 22.5; + if (index < 0) + { index += 360; } + index = parseInt(index / 45); + + return bearings[index]; + }; + + // @return {integer} length without sqrt + // @note for applications where the exact length is not necessary (e.g. compare only) + var squaredLength = function(start, end) { + + var x0 = start.x; + var y0 = start.y; + var x1 = end.x; + var y1 = end.y; + return (x0 -= x1) * x0 + (y0 -= y1) * y0; + }; + + var length = function(start, end) { + return Math.sqrt(squaredLength(start, end)); + }; + + var types = { + Point: 1, + Line: 2, + Ellipse: 3, + Rect: 4, + Polyline: 5, + Polygon: 6, + Curve: 7, + Path: 8 + }; + + /* + Point is the most basic object consisting of x/y coordinate. + + Possible instantiations are: + * `Point(10, 20)` + * `new Point(10, 20)` + * `Point('10 20')` + * `Point(Point(10, 20))` + */ + + var abs = Math.abs; + var cos$1 = Math.cos; + var sin$1 = Math.sin; + var sqrt = Math.sqrt; + var min$3 = Math.min; + var max$1 = Math.max; + var atan2$1 = Math.atan2; + var round$1 = Math.round; + var pow = Math.pow; + var PI$1 = Math.PI; + + var Point = function(x, y) { + + if (!(this instanceof Point)) { + return new Point(x, y); + } + + if (typeof x === 'string') { + var xy = x.split(x.indexOf('@') === -1 ? ' ' : '@'); + x = parseFloat(xy[0]); + y = parseFloat(xy[1]); + + } else if (Object(x) === x) { + y = x.y; + x = x.x; + } + + this.x = x === undefined ? 0 : x; + this.y = y === undefined ? 0 : y; + }; + + // Alternative constructor, from polar coordinates. + // @param {number} Distance. + // @param {number} Angle in radians. + // @param {point} [optional] Origin. + Point.fromPolar = function(distance, angle, origin) { + + origin = new Point(origin); + var x = abs(distance * cos$1(angle)); + var y = abs(distance * sin$1(angle)); + var deg = normalizeAngle(toDeg(angle)); + + if (deg < 90) { + y = -y; + + } else if (deg < 180) { + x = -x; + y = -y; + + } else if (deg < 270) { + x = -x; + } + + return new Point(origin.x + x, origin.y + y); + }; + + // Create a point with random coordinates that fall into the range `[x1, x2]` and `[y1, y2]`. + Point.random = function(x1, x2, y1, y2) { + + return new Point(random(x1, x2), random(y1, y2)); + }; + + Point.prototype = { + + type: types.Point, + + chooseClosest: function(points) { + + var n = points.length; + if (n === 1) { return new Point(points[0]); } + var closest = null; + var minSqrDistance = Infinity; + for (var i = 0; i < n; i++) { + var p = new Point(points[i]); + var sqrDistance = this.squaredDistance(p); + if (sqrDistance < minSqrDistance) { + closest = p; + minSqrDistance = sqrDistance; + } + } + return closest; + }, + + // If point lies outside rectangle `r`, return the nearest point on the boundary of rect `r`, + // otherwise return point itself. + // (see Squeak Smalltalk, Point>>adhereTo:) + adhereToRect: function(r) { + + if (r.containsPoint(this)) { + return this; + } + + this.x = min$3(max$1(this.x, r.x), r.x + r.width); + this.y = min$3(max$1(this.y, r.y), r.y + r.height); + return this; + }, + + // Compute the angle between vector from me to p1 and the vector from me to p2. + // ordering of points p1 and p2 is important! + // theta function's angle convention: + // returns angles between 0 and 180 when the angle is counterclockwise + // returns angles between 180 and 360 to convert clockwise angles into counterclockwise ones + // returns NaN if any of the points p1, p2 is coincident with this point + angleBetween: function(p1, p2) { + + var angleBetween = (this.equals(p1) || this.equals(p2)) ? NaN : (this.theta(p2) - this.theta(p1)); + + if (angleBetween < 0) { + angleBetween += 360; // correction to keep angleBetween between 0 and 360 + } + + return angleBetween; + }, + + // Return the bearing between me and the given point. + bearing: function(point) { + return bearing(this, point); + }, + + // Returns change in angle from my previous position (-dx, -dy) to my new position + // relative to ref point. + changeInAngle: function(dx, dy, ref) { + + // Revert the translation and measure the change in angle around x-axis. + return this.clone().offset(-dx, -dy).theta(ref) - this.theta(ref); + }, + + clone: function() { + + return new Point(this); + }, + + // Returns the cross product of this point relative to two other points + // this point is the common point + // point p1 lies on the first vector, point p2 lies on the second vector + // watch out for the ordering of points p1 and p2! + // positive result indicates a clockwise ("right") turn from first to second vector + // negative result indicates a counterclockwise ("left") turn from first to second vector + // zero indicates that the first and second vector are collinear + // note that the above directions are reversed from the usual answer on the Internet + // that is because we are in a left-handed coord system (because the y-axis points downward) + cross: function(p1, p2) { + + return (p1 && p2) ? (((p2.x - this.x) * (p1.y - this.y)) - ((p2.y - this.y) * (p1.x - this.x))) : NaN; + }, + + difference: function(dx, dy) { + + if ((Object(dx) === dx)) { + dy = dx.y; + dx = dx.x; + } + + return new Point(this.x - (dx || 0), this.y - (dy || 0)); + }, + + // Returns distance between me and point `p`. + distance: function(p) { + return length(this, p); + }, + + // Returns the dot product of this point with given other point + dot: function(p) { + + return p ? (this.x * p.x + this.y * p.y) : NaN; + }, + + equals: function(p) { + + return !!p && + this.x === p.x && + this.y === p.y; + }, + + // Linear interpolation + lerp: function(p, t) { + + var x = this.x; + var y = this.y; + return new Point((1 - t) * x + t * p.x, (1 - t) * y + t * p.y); + }, + + magnitude: function() { + + return sqrt((this.x * this.x) + (this.y * this.y)) || 0.01; + }, + + // Returns a manhattan (taxi-cab) distance between me and point `p`. + manhattanDistance: function(p) { + + return abs(p.x - this.x) + abs(p.y - this.y); + }, + + // Move point on line starting from ref ending at me by + // distance distance. + move: function(ref, distance) { + + var theta = toRad((new Point(ref)).theta(this)); + var offset = this.offset(cos$1(theta) * distance, -sin$1(theta) * distance); + return offset; + }, + + // Scales x and y such that the distance between the point and the origin (0,0) is equal to the given length. + normalize: function(length) { + + var scale = (length || 1) / this.magnitude(); + return this.scale(scale, scale); + }, + + // Offset me by the specified amount. + offset: function(dx, dy) { + + if ((Object(dx) === dx)) { + dy = dx.y; + dx = dx.x; + } + + this.x += dx || 0; + this.y += dy || 0; + return this; + }, + + // Returns a point that is the reflection of me with + // the center of inversion in ref point. + reflection: function(ref) { + + return (new Point(ref)).move(this, this.distance(ref)); + }, + + // Rotate point by angle around origin. + // Angle is flipped because this is a left-handed coord system (y-axis points downward). + rotate: function(origin, angle) { + + if (angle === 0) { return this; } + + origin = origin || new Point(0, 0); + + angle = toRad(normalizeAngle(-angle)); + var cosAngle = cos$1(angle); + var sinAngle = sin$1(angle); + + var x = (cosAngle * (this.x - origin.x)) - (sinAngle * (this.y - origin.y)) + origin.x; + var y = (sinAngle * (this.x - origin.x)) + (cosAngle * (this.y - origin.y)) + origin.y; + + this.x = x; + this.y = y; + return this; + }, + + round: function(precision) { + + var f = 1; // case 0 + if (precision) { + switch (precision) { + case 1: f = 10; break; + case 2: f = 100; break; + case 3: f = 1000; break; + default: f = pow(10, precision); break; + } + } + + this.x = round$1(this.x * f) / f; + this.y = round$1(this.y * f) / f; + return this; + }, + + // Scale point with origin. + scale: function(sx, sy, origin) { + + origin = (origin && new Point(origin)) || new Point(0, 0); + this.x = origin.x + sx * (this.x - origin.x); + this.y = origin.y + sy * (this.y - origin.y); + return this; + }, + + snapToGrid: function(gx, gy) { + + this.x = snapToGrid(this.x, gx); + this.y = snapToGrid(this.y, gy || gx); + return this; + }, + + squaredDistance: function(p) { + return squaredLength(this, p); + }, + + // Compute the angle between me and `p` and the x axis. + // (cartesian-to-polar coordinates conversion) + // Return theta angle in degrees. + theta: function(p) { + + p = new Point(p); + + // Invert the y-axis. + var y = -(p.y - this.y); + var x = p.x - this.x; + var rad = atan2$1(y, x); // defined for all 0 corner cases + + // Correction for III. and IV. quadrant. + if (rad < 0) { + rad = 2 * PI$1 + rad; + } + + return 180 * rad / PI$1; + }, + + toJSON: function() { + + return { x: this.x, y: this.y }; + }, + + // Converts rectangular to polar coordinates. + // An origin can be specified, otherwise it's 0@0. + toPolar: function(o) { + + o = (o && new Point(o)) || new Point(0, 0); + var x = this.x; + var y = this.y; + this.x = sqrt((x - o.x) * (x - o.x) + (y - o.y) * (y - o.y)); // r + this.y = toRad(o.theta(new Point(x, y))); + return this; + }, + + toString: function() { + + return this.x + '@' + this.y; + }, + + serialize: function() { + + return this.x + ',' + this.y; + }, + + update: function(x, y) { + + if ((Object(x) === x)) { + y = x.y; + x = x.x; + } + + this.x = x || 0; + this.y = y || 0; + return this; + }, + + // Compute the angle between the vector from 0,0 to me and the vector from 0,0 to p. + // Returns NaN if p is at 0,0. + vectorAngle: function(p) { + + var zero = new Point(0, 0); + return zero.angleBetween(this, p); + } + }; + + Point.prototype.translate = Point.prototype.offset; + + // For backwards compatibility: + var point = Point; + + var max$2 = Math.max; + var min$4 = Math.min; + + var Line = function(p1, p2) { + + if (!(this instanceof Line)) { + return new Line(p1, p2); + } + + if (p1 instanceof Line) { + return new Line(p1.start, p1.end); + } + + this.start = new Point(p1); + this.end = new Point(p2); + }; + + Line.prototype = { + + type: types.Line, + + // @returns the angle of incline of the line. + angle: function() { + + var horizontalPoint = new Point(this.start.x + 1, this.start.y); + return this.start.angleBetween(this.end, horizontalPoint); + }, + + bbox: function() { + + var left = min$4(this.start.x, this.end.x); + var top = min$4(this.start.y, this.end.y); + var right = max$2(this.start.x, this.end.x); + var bottom = max$2(this.start.y, this.end.y); + + return new Rect(left, top, (right - left), (bottom - top)); + }, + + // @return the bearing (cardinal direction) of the line. For example N, W, or SE. + // @returns {String} One of the following bearings : NE, E, SE, S, SW, W, NW, N. + bearing: function() { + return bearing(this.start, this.end); + }, + + clone: function() { + + return new Line(this.start, this.end); + }, + + // @return {point} the closest point on the line to point `p` + closestPoint: function(p) { + + return this.pointAt(this.closestPointNormalizedLength(p)); + }, + + closestPointLength: function(p) { + + return this.closestPointNormalizedLength(p) * this.length(); + }, + + // @return {number} the normalized length of the closest point on the line to point `p` + closestPointNormalizedLength: function(p) { + + var product = this.vector().dot((new Line(this.start, p)).vector()); + var cpNormalizedLength = min$4(1, max$2(0, product / this.squaredLength())); + + // cpNormalizedLength returns `NaN` if this line has zero length + // we can work with that - if `NaN`, return 0 + if (cpNormalizedLength !== cpNormalizedLength) { return 0; } // condition evaluates to `true` if and only if cpNormalizedLength is `NaN` + // (`NaN` is the only value that is not equal to itself) + + return cpNormalizedLength; + }, + + closestPointTangent: function(p) { + + return this.tangentAt(this.closestPointNormalizedLength(p)); + }, + + // Returns `true` if the point lies on the line. + containsPoint: function(p) { + + var start = this.start; + var end = this.end; + + if (start.cross(p, end) !== 0) { return false; } + // else: cross product of 0 indicates that this line and the vector to `p` are collinear + + var length = this.length(); + if ((new Line(start, p)).length() > length) { return false; } + if ((new Line(p, end)).length() > length) { return false; } + // else: `p` lies between start and end of the line + + return true; + }, + + // Divides the line into two at requested `ratio` between 0 and 1. + divideAt: function(ratio) { + + var dividerPoint = this.pointAt(ratio); + + // return array with two lines + return [ + new Line(this.start, dividerPoint), + new Line(dividerPoint, this.end) + ]; + }, + + // Divides the line into two at requested `length`. + divideAtLength: function(length) { + + var dividerPoint = this.pointAtLength(length); + + // return array with two new lines + return [ + new Line(this.start, dividerPoint), + new Line(dividerPoint, this.end) + ]; + }, + + equals: function(l) { + + return !!l && + this.start.x === l.start.x && + this.start.y === l.start.y && + this.end.x === l.end.x && + this.end.y === l.end.y; + }, + + // @return {point} Point where I'm intersecting a line. + // @return [point] Points where I'm intersecting a rectangle. + // @see Squeak Smalltalk, LineSegment>>intersectionWith: + intersect: function(shape, opt) { + + if (shape && shape.intersectionWithLine) { + var intersection = shape.intersectionWithLine(this, opt); + + // Backwards compatibility + if (intersection && (shape instanceof Line)) { + intersection = intersection[0]; + } + + return intersection; + } + + return null; + }, + + intersectionWithLine: function(line) { + + var pt1Dir = new Point(this.end.x - this.start.x, this.end.y - this.start.y); + var pt2Dir = new Point(line.end.x - line.start.x, line.end.y - line.start.y); + var det = (pt1Dir.x * pt2Dir.y) - (pt1Dir.y * pt2Dir.x); + var deltaPt = new Point(line.start.x - this.start.x, line.start.y - this.start.y); + var alpha = (deltaPt.x * pt2Dir.y) - (deltaPt.y * pt2Dir.x); + var beta = (deltaPt.x * pt1Dir.y) - (deltaPt.y * pt1Dir.x); + + if (det === 0 || alpha * det < 0 || beta * det < 0) { + // No intersection found. + return null; + } + + if (det > 0) { + if (alpha > det || beta > det) { + return null; + } + + } else { + if (alpha < det || beta < det) { + return null; + } + } + + return [new Point( + this.start.x + (alpha * pt1Dir.x / det), + this.start.y + (alpha * pt1Dir.y / det) + )]; + }, + + isDifferentiable: function() { + + return !this.start.equals(this.end); + }, + + // @return {double} length of the line + length: function() { + return length(this.start, this.end); + }, + + // @return {point} my midpoint + midpoint: function() { + + return new Point( + (this.start.x + this.end.x) / 2, + (this.start.y + this.end.y) / 2 + ); + }, + + parallel: function(distance) { + var l = this.clone(); + if (!this.isDifferentiable()) { return l; } + var start = l.start; + var end = l.end; + var eRef = start.clone().rotate(end, 270); + var sRef = end.clone().rotate(start, 90); + start.move(sRef, distance); + end.move(eRef, distance); + return l; + }, + + // @return {point} my point at 't' <0,1> + pointAt: function(t) { + + var start = this.start; + var end = this.end; + + if (t <= 0) { return start.clone(); } + if (t >= 1) { return end.clone(); } + + return start.lerp(end, t); + }, + + pointAtLength: function(length) { + + var start = this.start; + var end = this.end; + + var fromStart = true; + if (length < 0) { + fromStart = false; // negative lengths mean start calculation from end point + length = -length; // absolute value + } + + var lineLength = this.length(); + if (length >= lineLength) { return (fromStart ? end.clone() : start.clone()); } + + return this.pointAt((fromStart ? (length) : (lineLength - length)) / lineLength); + }, + + // @return {number} the offset of the point `p` from the line. + if the point `p` is on the right side of the line, - if on the left and 0 if on the line. + pointOffset: function(p) { + + // Find the sign of the determinant of vectors (start,end), where p is the query point. + p = new Point(p); + var start = this.start; + var end = this.end; + var determinant = ((end.x - start.x) * (p.y - start.y) - (end.y - start.y) * (p.x - start.x)); + + return determinant / this.length(); + }, + + rotate: function(origin, angle) { + + this.start.rotate(origin, angle); + this.end.rotate(origin, angle); + return this; + }, + + round: function(precision) { + + this.start.round(precision); + this.end.round(precision); + return this; + }, + + scale: function(sx, sy, origin) { + + this.start.scale(sx, sy, origin); + this.end.scale(sx, sy, origin); + return this; + }, + + // @return {number} scale the line so that it has the requested length + setLength: function(length) { + + var currentLength = this.length(); + if (!currentLength) { return this; } + + var scaleFactor = length / currentLength; + return this.scale(scaleFactor, scaleFactor, this.start); + }, + + // @return {integer} length without sqrt + // @note for applications where the exact length is not necessary (e.g. compare only) + squaredLength: function() { + return squaredLength(this.start, this.end); + }, + + tangentAt: function(t) { + + if (!this.isDifferentiable()) { return null; } + + var start = this.start; + var end = this.end; + + var tangentStart = this.pointAt(t); // constrains `t` between 0 and 1 + + var tangentLine = new Line(start, end); + tangentLine.translate(tangentStart.x - start.x, tangentStart.y - start.y); // move so that tangent line starts at the point requested + + return tangentLine; + }, + + tangentAtLength: function(length) { + + if (!this.isDifferentiable()) { return null; } + + var start = this.start; + var end = this.end; + + var tangentStart = this.pointAtLength(length); + + var tangentLine = new Line(start, end); + tangentLine.translate(tangentStart.x - start.x, tangentStart.y - start.y); // move so that tangent line starts at the point requested + + return tangentLine; + }, + + toString: function() { + + return this.start.toString() + ' ' + this.end.toString(); + }, + + serialize: function() { + + return this.start.serialize() + ' ' + this.end.serialize(); + }, + + translate: function(tx, ty) { + + this.start.translate(tx, ty); + this.end.translate(tx, ty); + return this; + }, + + // @return vector {point} of the line + vector: function() { + + return new Point(this.end.x - this.start.x, this.end.y - this.start.y); + } + }; + + // For backwards compatibility: + Line.prototype.intersection = Line.prototype.intersect; + + + // For backwards compatibility: + var line = Line; + + var sqrt$1 = Math.sqrt; + var round$2 = Math.round; + var pow$1 = Math.pow; + + var Ellipse = function(c, a, b) { + + if (!(this instanceof Ellipse)) { + return new Ellipse(c, a, b); + } + + if (c instanceof Ellipse) { + return new Ellipse(new Point(c.x, c.y), c.a, c.b); + } + + c = new Point(c); + this.x = c.x; + this.y = c.y; + this.a = a; + this.b = b; + }; + + Ellipse.fromRect = function(rect) { + + rect = new Rect(rect); + return new Ellipse(rect.center(), rect.width / 2, rect.height / 2); + }; + + Ellipse.prototype = { + + type: types.Ellipse, + + bbox: function() { + + return new Rect(this.x - this.a, this.y - this.b, 2 * this.a, 2 * this.b); + }, + + /** + * @returns {g.Point} + */ + center: function() { + + return new Point(this.x, this.y); + }, + + clone: function() { + + return new Ellipse(this); + }, + + /** + * @param {g.Point} p + * @returns {boolean} + */ + containsPoint: function(p) { + + return this.normalizedDistance(p) <= 1; + }, + + equals: function(ellipse) { + + return !!ellipse && + ellipse.x === this.x && + ellipse.y === this.y && + ellipse.a === this.a && + ellipse.b === this.b; + }, + + // inflate by dx and dy + // @param dx {delta_x} representing additional size to x + // @param dy {delta_y} representing additional size to y - + // dy param is not required -> in that case y is sized by dx + inflate: function(dx, dy) { + if (dx === undefined) { + dx = 0; + } + + if (dy === undefined) { + dy = dx; + } + + this.a += 2 * dx; + this.b += 2 * dy; + + return this; + }, + + intersectionWithLine: function(line) { + + var intersections = []; + var a1 = line.start; + var a2 = line.end; + var rx = this.a; + var ry = this.b; + var dir = line.vector(); + var diff = a1.difference(new Point(this)); + var mDir = new Point(dir.x / (rx * rx), dir.y / (ry * ry)); + var mDiff = new Point(diff.x / (rx * rx), diff.y / (ry * ry)); + + var a = dir.dot(mDir); + var b = dir.dot(mDiff); + var c = diff.dot(mDiff) - 1.0; + var d = b * b - a * c; + + if (d < 0) { + return null; + } else if (d > 0) { + var root = sqrt$1(d); + var ta = (-b - root) / a; + var tb = (-b + root) / a; + + if ((ta < 0 || 1 < ta) && (tb < 0 || 1 < tb)) { + // if ((ta < 0 && tb < 0) || (ta > 1 && tb > 1)) outside else inside + return null; + } else { + if (0 <= ta && ta <= 1) { intersections.push(a1.lerp(a2, ta)); } + if (0 <= tb && tb <= 1) { intersections.push(a1.lerp(a2, tb)); } + } + } else { + var t = -b / a; + if (0 <= t && t <= 1) { + intersections.push(a1.lerp(a2, t)); + } else { + // outside + return null; + } + } + + return intersections; + }, + + // Find point on me where line from my center to + // point p intersects my boundary. + // @param {number} angle If angle is specified, intersection with rotated ellipse is computed. + intersectionWithLineFromCenterToPoint: function(p, angle) { + + p = new Point(p); + + if (angle) { p.rotate(new Point(this.x, this.y), angle); } + + var dx = p.x - this.x; + var dy = p.y - this.y; + var result; + + if (dx === 0) { + result = this.bbox().pointNearestToPoint(p); + if (angle) { return result.rotate(new Point(this.x, this.y), -angle); } + return result; + } + + var m = dy / dx; + var mSquared = m * m; + var aSquared = this.a * this.a; + var bSquared = this.b * this.b; + + var x = sqrt$1(1 / ((1 / aSquared) + (mSquared / bSquared))); + x = dx < 0 ? -x : x; + + var y = m * x; + result = new Point(this.x + x, this.y + y); + + if (angle) { return result.rotate(new Point(this.x, this.y), -angle); } + return result; + }, + + /** + * @param {g.Point} point + * @returns {number} result < 1 - inside ellipse, result == 1 - on ellipse boundary, result > 1 - outside + */ + normalizedDistance: function(point) { + + var x0 = point.x; + var y0 = point.y; + var a = this.a; + var b = this.b; + var x = this.x; + var y = this.y; + + return ((x0 - x) * (x0 - x)) / (a * a) + ((y0 - y) * (y0 - y)) / (b * b); + }, + + round: function(precision) { + + var f = 1; // case 0 + if (precision) { + switch (precision) { + case 1: f = 10; break; + case 2: f = 100; break; + case 3: f = 1000; break; + default: f = pow$1(10, precision); break; + } + } + + this.x = round$2(this.x * f) / f; + this.y = round$2(this.y * f) / f; + this.a = round$2(this.a * f) / f; + this.b = round$2(this.b * f) / f; + return this; + }, + + /** Compute angle between tangent and x axis + * @param {g.Point} p Point of tangency, it has to be on ellipse boundaries. + * @returns {number} angle between tangent and x axis + */ + tangentTheta: function(p) { + + var refPointDelta = 30; + var x0 = p.x; + var y0 = p.y; + var a = this.a; + var b = this.b; + var center = this.bbox().center(); + var m = center.x; + var n = center.y; + + var q1 = x0 > center.x + a / 2; + var q3 = x0 < center.x - a / 2; + + var y, x; + if (q1 || q3) { + y = x0 > center.x ? y0 - refPointDelta : y0 + refPointDelta; + x = (a * a / (x0 - m)) - (a * a * (y0 - n) * (y - n)) / (b * b * (x0 - m)) + m; + + } else { + x = y0 > center.y ? x0 + refPointDelta : x0 - refPointDelta; + y = (b * b / (y0 - n)) - (b * b * (x0 - m) * (x - m)) / (a * a * (y0 - n)) + n; + } + + return (new Point(x, y)).theta(p); + + }, + + toString: function() { + + return (new Point(this.x, this.y)).toString() + ' ' + this.a + ' ' + this.b; + } + }; + + // For backwards compatibility: + var ellipse = Ellipse; + + var abs$1 = Math.abs; + var cos$2 = Math.cos; + var sin$2 = Math.sin; + var min$5 = Math.min; + var max$3 = Math.max; + var round$3 = Math.round; + var pow$2 = Math.pow; + + var Rect = function(x, y, w, h) { + + if (!(this instanceof Rect)) { + return new Rect(x, y, w, h); + } + + if ((Object(x) === x)) { + y = x.y; + w = x.width; + h = x.height; + x = x.x; + } + + this.x = x === undefined ? 0 : x; + this.y = y === undefined ? 0 : y; + this.width = w === undefined ? 0 : w; + this.height = h === undefined ? 0 : h; + }; + + Rect.fromEllipse = function(e) { + + e = new Ellipse(e); + return new Rect(e.x - e.a, e.y - e.b, 2 * e.a, 2 * e.b); + }; + + Rect.fromPointUnion = function() { + var points = [], len = arguments.length; + while ( len-- ) points[ len ] = arguments[ len ]; + + + if (points.length === 0) { return null; } + + var p = new Point(); + var minX, minY, maxX, maxY; + minX = minY = Infinity; + maxX = maxY = -Infinity; + + for (var i = 0; i < points.length; i++) { + p.update(points[i]); + var x = p.x; + var y = p.y; + + if (x < minX) { minX = x; } + if (x > maxX) { maxX = x; } + if (y < minY) { minY = y; } + if (y > maxY) { maxY = y; } + } + + return new Rect(minX, minY, maxX - minX, maxY - minY); + }; + + Rect.fromRectUnion = function() { + var rects = [], len = arguments.length; + while ( len-- ) rects[ len ] = arguments[ len ]; + + + if (rects.length === 0) { return null; } + + var r = new Rect(); + var minX, minY, maxX, maxY; + minX = minY = Infinity; + maxX = maxY = -Infinity; + + for (var i = 0; i < rects.length; i++) { + r.update(rects[i]); + var x = r.x; + var y = r.y; + var mX = x + r.width; + var mY = y + r.height; + + if (x < minX) { minX = x; } + if (mX > maxX) { maxX = mX; } + if (y < minY) { minY = y; } + if (mY > maxY) { maxY = mY; } + } + + return new Rect(minX, minY, maxX - minX, maxY - minY); + }; + + Rect.prototype = { + + type: types.Rect, + + // Find my bounding box when I'm rotated with the center of rotation in the center of me. + // @return r {rectangle} representing a bounding box + bbox: function(angle) { + return this.clone().rotateAroundCenter(angle); + }, + + rotateAroundCenter: function(angle) { + if (!angle) { return this; } + var ref = this; + var width = ref.width; + var height = ref.height; + var theta = toRad(angle); + var st = abs$1(sin$2(theta)); + var ct = abs$1(cos$2(theta)); + var w = width * ct + height * st; + var h = width * st + height * ct; + this.x += (width - w) / 2; + this.y += (height - h) / 2; + this.width = w; + this.height = h; + return this; + }, + + bottomLeft: function() { + + return new Point(this.x, this.y + this.height); + }, + + bottomLine: function() { + + return new Line(this.bottomLeft(), this.bottomRight()); + }, + + bottomMiddle: function() { + + return new Point(this.x + this.width / 2, this.y + this.height); + }, + + center: function() { + + return new Point(this.x + this.width / 2, this.y + this.height / 2); + }, + + clone: function() { + + return new Rect(this); + }, + + // @return {bool} true if point p is inside me. + containsPoint: function(p) { + p = new Point(p); + return p.x >= this.x && p.x <= this.x + this.width && p.y >= this.y && p.y <= this.y + this.height; + }, + + // @return {bool} true if rectangle `r` is inside me. + containsRect: function(r) { + + var r0 = new Rect(this).normalize(); + var r1 = new Rect(r).normalize(); + var w0 = r0.width; + var h0 = r0.height; + var w1 = r1.width; + var h1 = r1.height; + + if (!w0 || !h0 || !w1 || !h1) { + // At least one of the dimensions is 0 + return false; + } + + var x0 = r0.x; + var y0 = r0.y; + var x1 = r1.x; + var y1 = r1.y; + + w1 += x1; + w0 += x0; + h1 += y1; + h0 += y0; + + return x0 <= x1 && w1 <= w0 && y0 <= y1 && h1 <= h0; + }, + + corner: function() { + + return new Point(this.x + this.width, this.y + this.height); + }, + + // @return {boolean} true if rectangles are equal. + equals: function(r) { + + var mr = (new Rect(this)).normalize(); + var nr = (new Rect(r)).normalize(); + return mr.x === nr.x && mr.y === nr.y && mr.width === nr.width && mr.height === nr.height; + }, + + // inflate by dx and dy, recompute origin [x, y] + // @param dx {delta_x} representing additional size to x + // @param dy {delta_y} representing additional size to y - + // dy param is not required -> in that case y is sized by dx + inflate: function(dx, dy) { + + if (dx === undefined) { + dx = 0; + } + + if (dy === undefined) { + dy = dx; + } + + this.x -= dx; + this.y -= dy; + this.width += 2 * dx; + this.height += 2 * dy; + + return this; + }, + + // @return {rect} if rectangles intersect, {null} if not. + intersect: function(r) { + + var myOrigin = this.origin(); + var myCorner = this.corner(); + var rOrigin = r.origin(); + var rCorner = r.corner(); + + // No intersection found + if (rCorner.x <= myOrigin.x || + rCorner.y <= myOrigin.y || + rOrigin.x >= myCorner.x || + rOrigin.y >= myCorner.y) { return null; } + + var x = max$3(myOrigin.x, rOrigin.x); + var y = max$3(myOrigin.y, rOrigin.y); + + return new Rect(x, y, min$5(myCorner.x, rCorner.x) - x, min$5(myCorner.y, rCorner.y) - y); + }, + + intersectionWithLine: function(line) { + + var r = this; + var rectLines = [r.topLine(), r.rightLine(), r.bottomLine(), r.leftLine()]; + var points = []; + var dedupeArr = []; + var pt, i; + + var n = rectLines.length; + for (i = 0; i < n; i++) { + + pt = line.intersect(rectLines[i]); + if (pt !== null && dedupeArr.indexOf(pt.toString()) < 0) { + points.push(pt); + dedupeArr.push(pt.toString()); + } + } + + return points.length > 0 ? points : null; + }, + + // Find point on my boundary where line starting + // from my center ending in point p intersects me. + // @param {number} angle If angle is specified, intersection with rotated rectangle is computed. + intersectionWithLineFromCenterToPoint: function(p, angle) { + + p = new Point(p); + var center = new Point(this.x + this.width / 2, this.y + this.height / 2); + var result; + + if (angle) { p.rotate(center, angle); } + + // (clockwise, starting from the top side) + var sides = [ + this.topLine(), + this.rightLine(), + this.bottomLine(), + this.leftLine() + ]; + var connector = new Line(center, p); + + for (var i = sides.length - 1; i >= 0; --i) { + var intersection = sides[i].intersection(connector); + if (intersection !== null) { + result = intersection; + break; + } + } + if (result && angle) { result.rotate(center, -angle); } + return result; + }, + + leftLine: function() { + + return new Line(this.topLeft(), this.bottomLeft()); + }, + + leftMiddle: function() { + + return new Point(this.x, this.y + this.height / 2); + }, + + maxRectScaleToFit: function(rect, origin) { + + rect = new Rect(rect); + origin || (origin = rect.center()); + + var sx1, sx2, sx3, sx4, sy1, sy2, sy3, sy4; + var ox = origin.x; + var oy = origin.y; + + // Here we find the maximal possible scale for all corner points (for x and y axis) of the rectangle, + // so when the scale is applied the point is still inside the rectangle. + + sx1 = sx2 = sx3 = sx4 = sy1 = sy2 = sy3 = sy4 = Infinity; + + // Top Left + var p1 = rect.topLeft(); + if (p1.x < ox) { + sx1 = (this.x - ox) / (p1.x - ox); + } + if (p1.y < oy) { + sy1 = (this.y - oy) / (p1.y - oy); + } + // Bottom Right + var p2 = rect.bottomRight(); + if (p2.x > ox) { + sx2 = (this.x + this.width - ox) / (p2.x - ox); + } + if (p2.y > oy) { + sy2 = (this.y + this.height - oy) / (p2.y - oy); + } + // Top Right + var p3 = rect.topRight(); + if (p3.x > ox) { + sx3 = (this.x + this.width - ox) / (p3.x - ox); + } + if (p3.y < oy) { + sy3 = (this.y - oy) / (p3.y - oy); + } + // Bottom Left + var p4 = rect.bottomLeft(); + if (p4.x < ox) { + sx4 = (this.x - ox) / (p4.x - ox); + } + if (p4.y > oy) { + sy4 = (this.y + this.height - oy) / (p4.y - oy); + } + + return { + sx: min$5(sx1, sx2, sx3, sx4), + sy: min$5(sy1, sy2, sy3, sy4) + }; + }, + + maxRectUniformScaleToFit: function(rect, origin) { + + var scale = this.maxRectScaleToFit(rect, origin); + return min$5(scale.sx, scale.sy); + }, + + // Move and expand me. + // @param r {rectangle} representing deltas + moveAndExpand: function(r) { + + this.x += r.x || 0; + this.y += r.y || 0; + this.width += r.width || 0; + this.height += r.height || 0; + return this; + }, + + // Normalize the rectangle; i.e., make it so that it has a non-negative width and height. + // If width < 0 the function swaps the left and right corners, + // and it swaps the top and bottom corners if height < 0 + // like in http://qt-project.org/doc/qt-4.8/qrectf.html#normalized + normalize: function() { + + var newx = this.x; + var newy = this.y; + var newwidth = this.width; + var newheight = this.height; + if (this.width < 0) { + newx = this.x + this.width; + newwidth = -this.width; + } + if (this.height < 0) { + newy = this.y + this.height; + newheight = -this.height; + } + this.x = newx; + this.y = newy; + this.width = newwidth; + this.height = newheight; + return this; + }, + + // Offset me by the specified amount. + offset: function(dx, dy) { + + // pretend that this is a point and call offset() + // rewrites x and y according to dx and dy + return Point.prototype.offset.call(this, dx, dy); + }, + + origin: function() { + + return new Point(this.x, this.y); + }, + + // @return {point} a point on my boundary nearest to the given point. + // @see Squeak Smalltalk, Rectangle>>pointNearestTo: + pointNearestToPoint: function(point) { + + point = new Point(point); + if (this.containsPoint(point)) { + var side = this.sideNearestToPoint(point); + switch (side) { + case 'right': + return new Point(this.x + this.width, point.y); + case 'left': + return new Point(this.x, point.y); + case 'bottom': + return new Point(point.x, this.y + this.height); + case 'top': + return new Point(point.x, this.y); + } + } + return point.adhereToRect(this); + }, + + rightLine: function() { + + return new Line(this.topRight(), this.bottomRight()); + }, + + rightMiddle: function() { + + return new Point(this.x + this.width, this.y + this.height / 2); + }, + + round: function(precision) { + + var f = 1; // case 0 + if (precision) { + switch (precision) { + case 1: f = 10; break; + case 2: f = 100; break; + case 3: f = 1000; break; + default: f = pow$2(10, precision); break; + } + } + + this.x = round$3(this.x * f) / f; + this.y = round$3(this.y * f) / f; + this.width = round$3(this.width * f) / f; + this.height = round$3(this.height * f) / f; + return this; + }, + + // Scale rectangle with origin. + scale: function(sx, sy, origin) { + + origin = this.origin().scale(sx, sy, origin); + this.x = origin.x; + this.y = origin.y; + this.width *= sx; + this.height *= sy; + return this; + }, + + // @return {string} (left|right|top|bottom) side which is nearest to point + // @see Squeak Smalltalk, Rectangle>>sideNearestTo: + sideNearestToPoint: function(point) { + + point = new Point(point); + var distToLeft = point.x - this.x; + var distToRight = (this.x + this.width) - point.x; + var distToTop = point.y - this.y; + var distToBottom = (this.y + this.height) - point.y; + var closest = distToLeft; + var side = 'left'; + + if (distToRight < closest) { + closest = distToRight; + side = 'right'; + } + if (distToTop < closest) { + closest = distToTop; + side = 'top'; + } + if (distToBottom < closest) { + // closest = distToBottom; + side = 'bottom'; + } + return side; + }, + + snapToGrid: function(gx, gy) { + + var origin = this.origin().snapToGrid(gx, gy); + var corner = this.corner().snapToGrid(gx, gy); + this.x = origin.x; + this.y = origin.y; + this.width = corner.x - origin.x; + this.height = corner.y - origin.y; + return this; + }, + + toJSON: function() { + + return { x: this.x, y: this.y, width: this.width, height: this.height }; + }, + + topLine: function() { + + return new Line(this.topLeft(), this.topRight()); + }, + + topMiddle: function() { + + return new Point(this.x + this.width / 2, this.y); + }, + + topRight: function() { + + return new Point(this.x + this.width, this.y); + }, + + toString: function() { + + return this.origin().toString() + ' ' + this.corner().toString(); + }, + + // @return {rect} representing the union of both rectangles. + union: function(rect) { + + return Rect.fromRectUnion(this, rect); + }, + + update: function(x, y, w, h) { + + if ((Object(x) === x)) { + y = x.y; + w = x.width; + h = x.height; + x = x.x; + } + + this.x = x || 0; + this.y = y || 0; + this.width = w || 0; + this.height = h || 0; + return this; + } + }; + + Rect.prototype.bottomRight = Rect.prototype.corner; + + Rect.prototype.topLeft = Rect.prototype.origin; + + Rect.prototype.translate = Rect.prototype.offset; + + // For backwards compatibility: + var rect = Rect; + + function parsePoints(svgString) { + + // Step 1: Discard surrounding spaces + var trimmedString = svgString.trim(); + if (trimmedString === '') { return []; } + + var points = []; + + // Step 2: Split at commas (+ their surrounding spaces) or at multiple spaces + // ReDoS mitigation: Have an anchor at the beginning of each alternation + // Note: This doesn't simplify double (or more) commas - causes empty coords + // This regex is used by `split()`, so it doesn't need to use /g + var coords = trimmedString.split(/\b\s*,\s*|,\s*|\s+/); + + var numCoords = coords.length; + for (var i = 0; i < numCoords; i += 2) { + // Step 3: Convert each coord to number + // Note: If the coord cannot be converted to a number, it will be `NaN` + // Note: If the coord is empty ("", e.g. from ",," input), it will be `0` + // Note: If we end up with an odd number of coords, the last point's second coord will be `NaN` + points.push({ x: +coords[i], y: +coords[i + 1] }); + } + return points; + } + + function clonePoints(points) { + var numPoints = points.length; + if (numPoints === 0) { return []; } + var newPoints = []; + for (var i = 0; i < numPoints; i++) { + var point = points[i].clone(); + newPoints.push(point); + } + return newPoints; + } + + // Returns a convex-hull polyline from this polyline. + // Implements the Graham scan (https://en.wikipedia.org/wiki/Graham_scan). + // Output polyline starts at the first element of the original polyline that is on the hull, then continues clockwise. + // Minimal polyline is found (only vertices of the hull are reported, no collinear points). + function convexHull(points) { + + var abs = Math.abs; + + var i; + var n; + + var numPoints = points.length; + if (numPoints === 0) { return []; } // if points array is empty + + // step 1: find the starting point - point with the lowest y (if equality, highest x) + var startPoint; + for (i = 0; i < numPoints; i++) { + if (startPoint === undefined) { + // if this is the first point we see, set it as start point + startPoint = points[i]; + + } else if (points[i].y < startPoint.y) { + // start point should have lowest y from all points + startPoint = points[i]; + + } else if ((points[i].y === startPoint.y) && (points[i].x > startPoint.x)) { + // if two points have the lowest y, choose the one that has highest x + // there are no points to the right of startPoint - no ambiguity about theta 0 + // if there are several coincident start point candidates, first one is reported + startPoint = points[i]; + } + } + + // step 2: sort the list of points + // sorting by angle between line from startPoint to point and the x-axis (theta) + + // step 2a: create the point records = [point, originalIndex, angle] + var sortedPointRecords = []; + for (i = 0; i < numPoints; i++) { + + var angle = startPoint.theta(points[i]); + if (angle === 0) { + angle = 360; // give highest angle to start point + // the start point will end up at end of sorted list + // the start point will end up at beginning of hull points list + } + + var entry = [points[i], i, angle]; + sortedPointRecords.push(entry); + } + + // step 2b: sort the list in place + sortedPointRecords.sort(function(record1, record2) { + // returning a negative number here sorts record1 before record2 + // if first angle is smaller than second, first angle should come before second + + var sortOutput = record1[2] - record2[2]; // negative if first angle smaller + if (sortOutput === 0) { + // if the two angles are equal, sort by originalIndex + sortOutput = record2[1] - record1[1]; // negative if first index larger + // coincident points will be sorted in reverse-numerical order + // so the coincident points with lower original index will be considered first + } + + return sortOutput; + }); + + // step 2c: duplicate start record from the top of the stack to the bottom of the stack + if (sortedPointRecords.length > 2) { + var startPointRecord = sortedPointRecords[sortedPointRecords.length - 1]; + sortedPointRecords.unshift(startPointRecord); + } + + // step 3a: go through sorted points in order and find those with right turns + // we want to get our results in clockwise order + var insidePoints = {}; // dictionary of points with left turns - cannot be on the hull + var hullPointRecords = []; // stack of records with right turns - hull point candidates + + var currentPointRecord; + var currentPoint; + var lastHullPointRecord; + var lastHullPoint; + var secondLastHullPointRecord; + var secondLastHullPoint; + while (sortedPointRecords.length !== 0) { + + currentPointRecord = sortedPointRecords.pop(); + currentPoint = currentPointRecord[0]; + + // check if point has already been discarded + // keys for insidePoints are stored in the form 'point.x@point.y@@originalIndex' + if (insidePoints.hasOwnProperty(currentPointRecord[0] + '@@' + currentPointRecord[1])) { + // this point had an incorrect turn at some previous iteration of this loop + // this disqualifies it from possibly being on the hull + continue; + } + + var correctTurnFound = false; + while (!correctTurnFound) { + + if (hullPointRecords.length < 2) { + // not enough points for comparison, just add current point + hullPointRecords.push(currentPointRecord); + correctTurnFound = true; + + } else { + lastHullPointRecord = hullPointRecords.pop(); + lastHullPoint = lastHullPointRecord[0]; + secondLastHullPointRecord = hullPointRecords.pop(); + secondLastHullPoint = secondLastHullPointRecord[0]; + + var crossProduct = secondLastHullPoint.cross(lastHullPoint, currentPoint); + + if (crossProduct < 0) { + // found a right turn + hullPointRecords.push(secondLastHullPointRecord); + hullPointRecords.push(lastHullPointRecord); + hullPointRecords.push(currentPointRecord); + correctTurnFound = true; + + } else if (crossProduct === 0) { + // the three points are collinear + // three options: + // there may be a 180 or 0 degree angle at lastHullPoint + // or two of the three points are coincident + var THRESHOLD = 1e-10; // we have to take rounding errors into account + var angleBetween = lastHullPoint.angleBetween(secondLastHullPoint, currentPoint); + if (abs(angleBetween - 180) < THRESHOLD) { // rounding around 180 to 180 + // if the cross product is 0 because the angle is 180 degrees + // discard last hull point (add to insidePoints) + //insidePoints.unshift(lastHullPoint); + insidePoints[lastHullPointRecord[0] + '@@' + lastHullPointRecord[1]] = lastHullPoint; + // reenter second-to-last hull point (will be last at next iter) + hullPointRecords.push(secondLastHullPointRecord); + // do not do anything with current point + // correct turn not found + + } else if (lastHullPoint.equals(currentPoint) || secondLastHullPoint.equals(lastHullPoint)) { + // if the cross product is 0 because two points are the same + // discard last hull point (add to insidePoints) + //insidePoints.unshift(lastHullPoint); + insidePoints[lastHullPointRecord[0] + '@@' + lastHullPointRecord[1]] = lastHullPoint; + // reenter second-to-last hull point (will be last at next iter) + hullPointRecords.push(secondLastHullPointRecord); + // do not do anything with current point + // correct turn not found + + } else if (abs(((angleBetween + 1) % 360) - 1) < THRESHOLD) { // rounding around 0 and 360 to 0 + // if the cross product is 0 because the angle is 0 degrees + // remove last hull point from hull BUT do not discard it + // reenter second-to-last hull point (will be last at next iter) + hullPointRecords.push(secondLastHullPointRecord); + // put last hull point back into the sorted point records list + sortedPointRecords.push(lastHullPointRecord); + // we are switching the order of the 0deg and 180deg points + // correct turn not found + } + + } else { + // found a left turn + // discard last hull point (add to insidePoints) + //insidePoints.unshift(lastHullPoint); + insidePoints[lastHullPointRecord[0] + '@@' + lastHullPointRecord[1]] = lastHullPoint; + // reenter second-to-last hull point (will be last at next iter of loop) + hullPointRecords.push(secondLastHullPointRecord); + // do not do anything with current point + // correct turn not found + } + } + } + } + // at this point, hullPointRecords contains the output points in clockwise order + // the points start with lowest-y,highest-x startPoint, and end at the same point + + // step 3b: remove duplicated startPointRecord from the end of the array + if (hullPointRecords.length > 2) { + hullPointRecords.pop(); + } + + // step 4: find the lowest originalIndex record and put it at the beginning of hull + var lowestHullIndex; // the lowest originalIndex on the hull + var indexOfLowestHullIndexRecord = -1; // the index of the record with lowestHullIndex + n = hullPointRecords.length; + for (i = 0; i < n; i++) { + + var currentHullIndex = hullPointRecords[i][1]; + + if (lowestHullIndex === undefined || currentHullIndex < lowestHullIndex) { + lowestHullIndex = currentHullIndex; + indexOfLowestHullIndexRecord = i; + } + } + + var hullPointRecordsReordered = []; + if (indexOfLowestHullIndexRecord > 0) { + var newFirstChunk = hullPointRecords.slice(indexOfLowestHullIndexRecord); + var newSecondChunk = hullPointRecords.slice(0, indexOfLowestHullIndexRecord); + hullPointRecordsReordered = newFirstChunk.concat(newSecondChunk); + + } else { + hullPointRecordsReordered = hullPointRecords; + } + + var hullPoints = []; + n = hullPointRecordsReordered.length; + for (i = 0; i < n; i++) { + hullPoints.push(hullPointRecordsReordered[i][0]); + } + + return hullPoints; + } + + var Polyline = function(points) { + + if (!(this instanceof Polyline)) { + return new Polyline(points); + } + + if (typeof points === 'string') { + return new Polyline.parse(points); + } + + this.points = (Array.isArray(points) ? points.map(Point) : []); + }; + + Polyline.parse = function(svgString) { + return new Polyline(parsePoints(svgString)); + }; + + Polyline.fromRect = function(rect) { + return new Polyline([ + rect.topLeft(), + rect.topRight(), + rect.bottomRight(), + rect.bottomLeft(), + rect.topLeft() ]); + }; + + Polyline.prototype = { + + type: types.Polyline, + + bbox: function() { + + var x1 = Infinity; + var x2 = -Infinity; + var y1 = Infinity; + var y2 = -Infinity; + + var points = this.points; + var numPoints = points.length; + if (numPoints === 0) { return null; } // if points array is empty + + for (var i = 0; i < numPoints; i++) { + + var point = points[i]; + var x = point.x; + var y = point.y; + + if (x < x1) { x1 = x; } + if (x > x2) { x2 = x; } + if (y < y1) { y1 = y; } + if (y > y2) { y2 = y; } + } + + return new Rect(x1, y1, x2 - x1, y2 - y1); + }, + + clone: function() { + return new Polyline(clonePoints(this.points)); + }, + + closestPoint: function(p) { + + var cpLength = this.closestPointLength(p); + + return this.pointAtLength(cpLength); + }, + + closestPointLength: function(p) { + + var points = this.lengthPoints(); + var numPoints = points.length; + if (numPoints === 0) { return 0; } // if points array is empty + if (numPoints === 1) { return 0; } // if there is only one point + + var cpLength; + var minSqrDistance = Infinity; + var length = 0; + var n = numPoints - 1; + for (var i = 0; i < n; i++) { + + var line = new Line(points[i], points[i + 1]); + var lineLength = line.length(); + + var cpNormalizedLength = line.closestPointNormalizedLength(p); + var cp = line.pointAt(cpNormalizedLength); + + var sqrDistance = cp.squaredDistance(p); + if (sqrDistance < minSqrDistance) { + minSqrDistance = sqrDistance; + cpLength = length + (cpNormalizedLength * lineLength); + } + + length += lineLength; + } + + return cpLength; + }, + + closestPointNormalizedLength: function(p) { + + var cpLength = this.closestPointLength(p); + if (cpLength === 0) { return 0; } // shortcut + + var length = this.length(); + if (length === 0) { return 0; } // prevents division by zero + + return cpLength / length; + }, + + closestPointTangent: function(p) { + + var cpLength = this.closestPointLength(p); + + return this.tangentAtLength(cpLength); + }, + + // Returns `true` if the area surrounded by the polyline contains the point `p`. + // Implements the even-odd SVG algorithm (self-intersections are "outside"). + // (Uses horizontal rays to the right of `p` to look for intersections.) + // Closes open polylines (always imagines a final closing segment). + containsPoint: function(p) { + + var points = this.points; + var numPoints = points.length; + if (numPoints === 0) { return false; } // shortcut (this polyline has no points) + + var x = p.x; + var y = p.y; + + // initialize a final closing segment by creating one from last-first points on polyline + var startIndex = numPoints - 1; // start of current polyline segment + var endIndex = 0; // end of current polyline segment + var numIntersections = 0; + var segment = new Line(); + var ray = new Line(); + var rayEnd = new Point(); + for (; endIndex < numPoints; endIndex++) { + var start = points[startIndex]; + var end = points[endIndex]; + if (p.equals(start)) { return true; } // shortcut (`p` is a point on polyline) + // current polyline segment + segment.start = start; + segment.end = end; + if (segment.containsPoint(p)) { return true; } // shortcut (`p` lies on a polyline segment) + + // do we have an intersection? + if (((y <= start.y) && (y > end.y)) || ((y > start.y) && (y <= end.y))) { + // this conditional branch IS NOT entered when `segment` is collinear/coincident with `ray` + // (when `y === start.y === end.y`) + // this conditional branch IS entered when `segment` touches `ray` at only one point + // (e.g. when `y === start.y !== end.y`) + // since this branch is entered again for the following segment, the two touches cancel out + + var xDifference = (((start.x - x) > (end.x - x)) ? (start.x - x) : (end.x - x)); + if (xDifference >= 0) { + // segment lies at least partially to the right of `p` + rayEnd.x = x + xDifference; + rayEnd.y = y; // right + ray.start = p; + ray.end = rayEnd; + if (segment.intersect(ray)) { + // an intersection was detected to the right of `p` + numIntersections++; + } + } // else: `segment` lies completely to the left of `p` (i.e. no intersection to the right) + } + + // move to check the next polyline segment + startIndex = endIndex; + } + + // returns `true` for odd numbers of intersections (even-odd algorithm) + return ((numIntersections % 2) === 1); + }, + + close: function() { + var ref = this; + var start = ref.start; + var end = ref.end; + var points = ref.points; + if (start && end && !start.equals(end)) { + points.push(start.clone()); + } + return this; + }, + + lengthPoints: function() { + return this.points; + }, + + convexHull: function() { + return new Polyline(convexHull(this.points)); + }, + + // Checks whether two polylines are exactly the same. + // If `p` is undefined or null, returns false. + equals: function(p) { + + if (!p) { return false; } + + var points = this.points; + var otherPoints = p.points; + + var numPoints = points.length; + if (otherPoints.length !== numPoints) { return false; } // if the two polylines have different number of points, they cannot be equal + + for (var i = 0; i < numPoints; i++) { + + var point = points[i]; + var otherPoint = p.points[i]; + + // as soon as an inequality is found in points, return false + if (!point.equals(otherPoint)) { return false; } + } + + // if no inequality found in points, return true + return true; + }, + + intersectionWithLine: function(l) { + var line = new Line(l); + var intersections = []; + var points = this.lengthPoints(); + var l2 = new Line(); + for (var i = 0, n = points.length - 1; i < n; i++) { + l2.start = points[i]; + l2.end = points[i + 1]; + var int = line.intersectionWithLine(l2); + if (int) { intersections.push(int[0]); } + } + return (intersections.length > 0) ? intersections : null; + }, + + isDifferentiable: function() { + + var points = this.points; + var numPoints = points.length; + if (numPoints === 0) { return false; } + + var line = new Line(); + var n = numPoints - 1; + for (var i = 0; i < n; i++) { + line.start = points[i]; + line.end = points[i + 1]; + // as soon as a differentiable line is found between two points, return true + if (line.isDifferentiable()) { return true; } + } + + // if no differentiable line is found between pairs of points, return false + return false; + }, + + length: function() { + + var points = this.lengthPoints(); + var numPoints = points.length; + if (numPoints === 0) { return 0; } // if points array is empty + + var length = 0; + var n = numPoints - 1; + for (var i = 0; i < n; i++) { + length += points[i].distance(points[i + 1]); + } + + return length; + }, + + pointAt: function(ratio) { + + var points = this.lengthPoints(); + var numPoints = points.length; + if (numPoints === 0) { return null; } // if points array is empty + if (numPoints === 1) { return points[0].clone(); } // if there is only one point + + if (ratio <= 0) { return points[0].clone(); } + if (ratio >= 1) { return points[numPoints - 1].clone(); } + + var polylineLength = this.length(); + var length = polylineLength * ratio; + + return this.pointAtLength(length); + }, + + pointAtLength: function(length) { + + var points = this.lengthPoints(); + var numPoints = points.length; + if (numPoints === 0) { return null; } // if points array is empty + if (numPoints === 1) { return points[0].clone(); } // if there is only one point + + var fromStart = true; + if (length < 0) { + fromStart = false; // negative lengths mean start calculation from end point + length = -length; // absolute value + } + + var l = 0; + var n = numPoints - 1; + for (var i = 0; i < n; i++) { + var index = (fromStart ? i : (n - 1 - i)); + + var a = points[index]; + var b = points[index + 1]; + var line = new Line(a, b); + var d = a.distance(b); + + if (length <= (l + d)) { + return line.pointAtLength((fromStart ? 1 : -1) * (length - l)); + } + + l += d; + } + + // if length requested is higher than the length of the polyline, return last endpoint + var lastPoint = (fromStart ? points[numPoints - 1] : points[0]); + return lastPoint.clone(); + }, + + round: function(precision) { + + var points = this.points; + var numPoints = points.length; + + for (var i = 0; i < numPoints; i++) { + points[i].round(precision); + } + + return this; + }, + + scale: function(sx, sy, origin) { + + var points = this.points; + var numPoints = points.length; + + for (var i = 0; i < numPoints; i++) { + points[i].scale(sx, sy, origin); + } + + return this; + }, + + simplify: function(opt) { + if ( opt === void 0 ) opt = {}; + + + var points = this.points; + if (points.length < 3) { return this; } // we need at least 3 points + + // TODO: we may also accept startIndex and endIndex to specify where to start and end simplification + var threshold = opt.threshold || 0; // = max distance of middle point from chord to be simplified + + // start at the beginning of the polyline and go forward + var currentIndex = 0; + // we need at least one intermediate point (3 points) in every iteration + // as soon as that stops being true, we know we reached the end of the polyline + while (points[currentIndex + 2]) { + var firstIndex = currentIndex; + var middleIndex = (currentIndex + 1); + var lastIndex = (currentIndex + 2); + + var firstPoint = points[firstIndex]; + var middlePoint = points[middleIndex]; + var lastPoint = points[lastIndex]; + + var chord = new Line(firstPoint, lastPoint); // = connection between first and last point + var closestPoint = chord.closestPoint(middlePoint); // = closest point on chord from middle point + var closestPointDistance = closestPoint.distance(middlePoint); + if (closestPointDistance <= threshold) { + // middle point is close enough to the chord = simplify + // 1) remove middle point: + points.splice(middleIndex, 1); + // 2) in next iteration, investigate the newly-created triplet of points + // - do not change `currentIndex` + // = (first point stays, point after removed point becomes middle point) + } else { + // middle point is far from the chord + // 1) preserve middle point + // 2) in next iteration, move `currentIndex` by one step: + currentIndex += 1; + // = (point after first point becomes first point) + } + } + + // `points` array was modified in-place + return this; + }, + + tangentAt: function(ratio) { + + var points = this.lengthPoints(); + var numPoints = points.length; + if (numPoints === 0) { return null; } // if points array is empty + if (numPoints === 1) { return null; } // if there is only one point + + if (ratio < 0) { ratio = 0; } + if (ratio > 1) { ratio = 1; } + + var polylineLength = this.length(); + var length = polylineLength * ratio; + + return this.tangentAtLength(length); + }, + + tangentAtLength: function(length) { + + var points = this.lengthPoints(); + var numPoints = points.length; + if (numPoints === 0) { return null; } // if points array is empty + if (numPoints === 1) { return null; } // if there is only one point + + var fromStart = true; + if (length < 0) { + fromStart = false; // negative lengths mean start calculation from end point + length = -length; // absolute value + } + + var lastValidLine; // differentiable (with a tangent) + var l = 0; // length so far + var n = numPoints - 1; + for (var i = 0; i < n; i++) { + var index = (fromStart ? i : (n - 1 - i)); + + var a = points[index]; + var b = points[index + 1]; + var line = new Line(a, b); + var d = a.distance(b); + + if (line.isDifferentiable()) { // has a tangent line (line length is not 0) + if (length <= (l + d)) { + return line.tangentAtLength((fromStart ? 1 : -1) * (length - l)); + } + + lastValidLine = line; + } + + l += d; + } + + // if length requested is higher than the length of the polyline, return last valid endpoint + if (lastValidLine) { + var ratio = (fromStart ? 1 : 0); + return lastValidLine.tangentAt(ratio); + } + + // if no valid line, return null + return null; + }, + + toString: function() { + + return this.points + ''; + }, + + translate: function(tx, ty) { + + var points = this.points; + var numPoints = points.length; + + for (var i = 0; i < numPoints; i++) { + points[i].translate(tx, ty); + } + + return this; + }, + + // Return svgString that can be used to recreate this line. + serialize: function() { + + var points = this.points; + var numPoints = points.length; + if (numPoints === 0) { return ''; } // if points array is empty + + var output = ''; + for (var i = 0; i < numPoints; i++) { + + var point = points[i]; + output += point.x + ',' + point.y + ' '; + } + + return output.trim(); + } + }; + + Object.defineProperty(Polyline.prototype, 'start', { + // Getter for the first point of the polyline. + + configurable: true, + + enumerable: true, + + get: function() { + + var points = this.points; + var numPoints = points.length; + if (numPoints === 0) { return null; } // if points array is empty + + return this.points[0]; + }, + }); + + Object.defineProperty(Polyline.prototype, 'end', { + // Getter for the last point of the polyline. + + configurable: true, + + enumerable: true, + + get: function() { + + var points = this.points; + var numPoints = points.length; + if (numPoints === 0) { return null; } // if points array is empty + + return this.points[numPoints - 1]; + }, + }); + + var abs$2 = Math.abs; + var sqrt$2 = Math.sqrt; + var min$6 = Math.min; + var max$4 = Math.max; + var pow$3 = Math.pow; + + var Curve = function(p1, p2, p3, p4) { + + if (!(this instanceof Curve)) { + return new Curve(p1, p2, p3, p4); + } + + if (p1 instanceof Curve) { + return new Curve(p1.start, p1.controlPoint1, p1.controlPoint2, p1.end); + } + + this.start = new Point(p1); + this.controlPoint1 = new Point(p2); + this.controlPoint2 = new Point(p3); + this.end = new Point(p4); + }; + + // Curve passing through points. + // Ported from C# implementation by Oleg V. Polikarpotchkin and Peter Lee (http://www.codeproject.com/KB/graphics/BezierSpline.aspx). + // @param {array} points Array of points through which the smooth line will go. + // @return {array} curves. + Curve.throughPoints = (function() { + + // Get open-ended Bezier Spline Control Points. + // @param knots Input Knot Bezier spline points (At least two points!). + // @param firstControlPoints Output First Control points. Array of knots.length - 1 length. + // @param secondControlPoints Output Second Control points. Array of knots.length - 1 length. + function getCurveControlPoints(knots) { + + var firstControlPoints = []; + var secondControlPoints = []; + var n = knots.length - 1; + var i; + + // Special case: Bezier curve should be a straight line. + if (n == 1) { + // 3P1 = 2P0 + P3 + firstControlPoints[0] = new Point( + (2 * knots[0].x + knots[1].x) / 3, + (2 * knots[0].y + knots[1].y) / 3 + ); + + // P2 = 2P1 – P0 + secondControlPoints[0] = new Point( + 2 * firstControlPoints[0].x - knots[0].x, + 2 * firstControlPoints[0].y - knots[0].y + ); + + return [firstControlPoints, secondControlPoints]; + } + + // Calculate first Bezier control points. + // Right hand side vector. + var rhs = []; + + // Set right hand side X values. + for (i = 1; i < n - 1; i++) { + rhs[i] = 4 * knots[i].x + 2 * knots[i + 1].x; + } + + rhs[0] = knots[0].x + 2 * knots[1].x; + rhs[n - 1] = (8 * knots[n - 1].x + knots[n].x) / 2.0; + + // Get first control points X-values. + var x = getFirstControlPoints(rhs); + + // Set right hand side Y values. + for (i = 1; i < n - 1; ++i) { + rhs[i] = 4 * knots[i].y + 2 * knots[i + 1].y; + } + + rhs[0] = knots[0].y + 2 * knots[1].y; + rhs[n - 1] = (8 * knots[n - 1].y + knots[n].y) / 2.0; + + // Get first control points Y-values. + var y = getFirstControlPoints(rhs); + + // Fill output arrays. + for (i = 0; i < n; i++) { + // First control point. + firstControlPoints.push(new Point(x[i], y[i])); + + // Second control point. + if (i < n - 1) { + secondControlPoints.push(new Point( + 2 * knots [i + 1].x - x[i + 1], + 2 * knots[i + 1].y - y[i + 1] + )); + + } else { + secondControlPoints.push(new Point( + (knots[n].x + x[n - 1]) / 2, + (knots[n].y + y[n - 1]) / 2 + )); + } + } + + return [firstControlPoints, secondControlPoints]; + } + + // Solves a tridiagonal system for one of coordinates (x or y) of first Bezier control points. + // @param rhs Right hand side vector. + // @return Solution vector. + function getFirstControlPoints(rhs) { + + var n = rhs.length; + // `x` is a solution vector. + var x = []; + var tmp = []; + var b = 2.0; + + x[0] = rhs[0] / b; + + // Decomposition and forward substitution. + for (var i = 1; i < n; i++) { + tmp[i] = 1 / b; + b = (i < n - 1 ? 4.0 : 3.5) - tmp[i]; + x[i] = (rhs[i] - x[i - 1]) / b; + } + + for (i = 1; i < n; i++) { + // Backsubstitution. + x[n - i - 1] -= tmp[n - i] * x[n - i]; + } + + return x; + } + + return function(points) { + + if (!points || (Array.isArray(points) && points.length < 2)) { + throw new Error('At least 2 points are required'); + } + + var controlPoints = getCurveControlPoints(points); + + var curves = []; + var n = controlPoints[0].length; + for (var i = 0; i < n; i++) { + + var controlPoint1 = new Point(controlPoints[0][i].x, controlPoints[0][i].y); + var controlPoint2 = new Point(controlPoints[1][i].x, controlPoints[1][i].y); + + curves.push(new Curve(points[i], controlPoint1, controlPoint2, points[i + 1])); + } + + return curves; + }; + })(); + + Curve.prototype = { + + type: types.Curve, + + // Returns a bbox that tightly envelops the curve. + bbox: function() { + + var start = this.start; + var controlPoint1 = this.controlPoint1; + var controlPoint2 = this.controlPoint2; + var end = this.end; + + var x0 = start.x; + var y0 = start.y; + var x1 = controlPoint1.x; + var y1 = controlPoint1.y; + var x2 = controlPoint2.x; + var y2 = controlPoint2.y; + var x3 = end.x; + var y3 = end.y; + + var points = new Array(); // local extremes + var tvalues = new Array(); // t values of local extremes + var bounds = [new Array(), new Array()]; + + var a, b, c, t; + var t1, t2; + var b2ac, sqrtb2ac; + + for (var i = 0; i < 2; ++i) { + + if (i === 0) { + b = 6 * x0 - 12 * x1 + 6 * x2; + a = -3 * x0 + 9 * x1 - 9 * x2 + 3 * x3; + c = 3 * x1 - 3 * x0; + + } else { + b = 6 * y0 - 12 * y1 + 6 * y2; + a = -3 * y0 + 9 * y1 - 9 * y2 + 3 * y3; + c = 3 * y1 - 3 * y0; + } + + if (abs$2(a) < 1e-12) { // Numerical robustness + if (abs$2(b) < 1e-12) { // Numerical robustness + continue; + } + + t = -c / b; + if ((0 < t) && (t < 1)) { tvalues.push(t); } + + continue; + } + + b2ac = b * b - 4 * c * a; + sqrtb2ac = sqrt$2(b2ac); + + if (b2ac < 0) { continue; } + + t1 = (-b + sqrtb2ac) / (2 * a); + if ((0 < t1) && (t1 < 1)) { tvalues.push(t1); } + + t2 = (-b - sqrtb2ac) / (2 * a); + if ((0 < t2) && (t2 < 1)) { tvalues.push(t2); } + } + + var j = tvalues.length; + var jlen = j; + var mt; + var x, y; + + while (j--) { + t = tvalues[j]; + mt = 1 - t; + + x = (mt * mt * mt * x0) + (3 * mt * mt * t * x1) + (3 * mt * t * t * x2) + (t * t * t * x3); + bounds[0][j] = x; + + y = (mt * mt * mt * y0) + (3 * mt * mt * t * y1) + (3 * mt * t * t * y2) + (t * t * t * y3); + bounds[1][j] = y; + + points[j] = { X: x, Y: y }; + } + + tvalues[jlen] = 0; + tvalues[jlen + 1] = 1; + + points[jlen] = { X: x0, Y: y0 }; + points[jlen + 1] = { X: x3, Y: y3 }; + + bounds[0][jlen] = x0; + bounds[1][jlen] = y0; + + bounds[0][jlen + 1] = x3; + bounds[1][jlen + 1] = y3; + + tvalues.length = jlen + 2; + bounds[0].length = jlen + 2; + bounds[1].length = jlen + 2; + points.length = jlen + 2; + + var left = min$6.apply(null, bounds[0]); + var top = min$6.apply(null, bounds[1]); + var right = max$4.apply(null, bounds[0]); + var bottom = max$4.apply(null, bounds[1]); + + return new Rect(left, top, (right - left), (bottom - top)); + }, + + clone: function() { + + return new Curve(this.start, this.controlPoint1, this.controlPoint2, this.end); + }, + + // Returns the point on the curve closest to point `p` + closestPoint: function(p, opt) { + + return this.pointAtT(this.closestPointT(p, opt)); + }, + + closestPointLength: function(p, opt) { + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var subdivisions = (opt.subdivisions === undefined) ? this.getSubdivisions({ precision: precision }) : opt.subdivisions; + var localOpt = { precision: precision, subdivisions: subdivisions }; + + return this.lengthAtT(this.closestPointT(p, localOpt), localOpt); + }, + + closestPointNormalizedLength: function(p, opt) { + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var subdivisions = (opt.subdivisions === undefined) ? this.getSubdivisions({ precision: precision }) : opt.subdivisions; + var localOpt = { precision: precision, subdivisions: subdivisions }; + + var cpLength = this.closestPointLength(p, localOpt); + if (!cpLength) { return 0; } + + var length = this.length(localOpt); + if (length === 0) { return 0; } + + return cpLength / length; + }, + + // Returns `t` of the point on the curve closest to point `p` + closestPointT: function(p, opt) { + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var subdivisions = (opt.subdivisions === undefined) ? this.getSubdivisions({ precision: precision }) : opt.subdivisions; + // does not use localOpt + + // identify the subdivision that contains the point: + var investigatedSubdivision; + var investigatedSubdivisionStartT; // assume that subdivisions are evenly spaced + var investigatedSubdivisionEndT; + var distFromStart; // distance of point from start of baseline + var distFromEnd; // distance of point from end of baseline + var chordLength; // distance between start and end of the subdivision + var minSumDist; // lowest observed sum of the two distances + var n = subdivisions.length; + var subdivisionSize = (n ? (1 / n) : 0); + for (var i = 0; i < n; i++) { + + var currentSubdivision = subdivisions[i]; + + var startDist = currentSubdivision.start.distance(p); + var endDist = currentSubdivision.end.distance(p); + var sumDist = startDist + endDist; + + // check that the point is closest to current subdivision and not any other + if (!minSumDist || (sumDist < minSumDist)) { + investigatedSubdivision = currentSubdivision; + + investigatedSubdivisionStartT = i * subdivisionSize; + investigatedSubdivisionEndT = (i + 1) * subdivisionSize; + + distFromStart = startDist; + distFromEnd = endDist; + + chordLength = currentSubdivision.start.distance(currentSubdivision.end); + + minSumDist = sumDist; + } + } + + var precisionRatio = pow$3(10, -precision); + + // recursively divide investigated subdivision: + // until distance between baselinePoint and closest path endpoint is within 10^(-precision) + // then return the closest endpoint of that final subdivision + while (true) { + + // check if we have reached at least one required observed precision + // - calculated as: the difference in distances from point to start and end divided by the distance + // - note that this function is not monotonic = it doesn't converge stably but has "teeth" + // - the function decreases while one of the endpoints is fixed but "jumps" whenever we switch + // - this criterion works well for points lying far away from the curve + var startPrecisionRatio = (distFromStart ? (abs$2(distFromStart - distFromEnd) / distFromStart) : 0); + var endPrecisionRatio = (distFromEnd ? (abs$2(distFromStart - distFromEnd) / distFromEnd) : 0); + var hasRequiredPrecision = ((startPrecisionRatio < precisionRatio) || (endPrecisionRatio < precisionRatio)); + + // check if we have reached at least one required minimal distance + // - calculated as: the subdivision chord length multiplied by precisionRatio + // - calculation is relative so it will work for arbitrarily large/small curves and their subdivisions + // - this is a backup criterion that works well for points lying "almost at" the curve + var hasMinimalStartDistance = (distFromStart ? (distFromStart < (chordLength * precisionRatio)) : true); + var hasMinimalEndDistance = (distFromEnd ? (distFromEnd < (chordLength * precisionRatio)) : true); + var hasMinimalDistance = (hasMinimalStartDistance || hasMinimalEndDistance); + + // do we stop now? + if (hasRequiredPrecision || hasMinimalDistance) { + return ((distFromStart <= distFromEnd) ? investigatedSubdivisionStartT : investigatedSubdivisionEndT); + } + + // otherwise, set up for next iteration + var divided = investigatedSubdivision.divide(0.5); + subdivisionSize /= 2; + + var startDist1 = divided[0].start.distance(p); + var endDist1 = divided[0].end.distance(p); + var sumDist1 = startDist1 + endDist1; + + var startDist2 = divided[1].start.distance(p); + var endDist2 = divided[1].end.distance(p); + var sumDist2 = startDist2 + endDist2; + + if (sumDist1 <= sumDist2) { + investigatedSubdivision = divided[0]; + + investigatedSubdivisionEndT -= subdivisionSize; // subdivisionSize was already halved + + distFromStart = startDist1; + distFromEnd = endDist1; + + } else { + investigatedSubdivision = divided[1]; + + investigatedSubdivisionStartT += subdivisionSize; // subdivisionSize was already halved + + distFromStart = startDist2; + distFromEnd = endDist2; + } + } + }, + + closestPointTangent: function(p, opt) { + + return this.tangentAtT(this.closestPointT(p, opt)); + }, + + // Returns `true` if the area surrounded by the curve contains the point `p`. + // Implements the even-odd algorithm (self-intersections are "outside"). + // Closes open curves (always imagines a closing segment). + // Precision may be adjusted by passing an `opt` object. + containsPoint: function(p, opt) { + + var polyline = this.toPolyline(opt); + return polyline.containsPoint(p); + }, + + // Divides the curve into two at requested `ratio` between 0 and 1 with precision better than `opt.precision`; optionally using `opt.subdivisions` provided. + // For a function that uses `t`, use Curve.divideAtT(). + divideAt: function(ratio, opt) { + + if (ratio <= 0) { return this.divideAtT(0); } + if (ratio >= 1) { return this.divideAtT(1); } + + var t = this.tAt(ratio, opt); + + return this.divideAtT(t); + }, + + // Divides the curve into two at requested `length` with precision better than requested `opt.precision`; optionally using `opt.subdivisions` provided. + divideAtLength: function(length, opt) { + + var t = this.tAtLength(length, opt); + + return this.divideAtT(t); + }, + + // Divides the curve into two at point defined by `t` between 0 and 1. + // Using de Casteljau's algorithm (http://math.stackexchange.com/a/317867). + // Additional resource: https://pomax.github.io/bezierinfo/#decasteljau + divideAtT: function(t) { + + var start = this.start; + var controlPoint1 = this.controlPoint1; + var controlPoint2 = this.controlPoint2; + var end = this.end; + + // shortcuts for `t` values that are out of range + if (t <= 0) { + return [ + new Curve(start, start, start, start), + new Curve(start, controlPoint1, controlPoint2, end) + ]; + } + + if (t >= 1) { + return [ + new Curve(start, controlPoint1, controlPoint2, end), + new Curve(end, end, end, end) + ]; + } + + var dividerPoints = this.getSkeletonPoints(t); + + var startControl1 = dividerPoints.startControlPoint1; + var startControl2 = dividerPoints.startControlPoint2; + var divider = dividerPoints.divider; + var dividerControl1 = dividerPoints.dividerControlPoint1; + var dividerControl2 = dividerPoints.dividerControlPoint2; + + // return array with two new curves + return [ + new Curve(start, startControl1, startControl2, divider), + new Curve(divider, dividerControl1, dividerControl2, end) + ]; + }, + + // Returns the distance between the curve's start and end points. + endpointDistance: function() { + + return this.start.distance(this.end); + }, + + // Checks whether two curves are exactly the same. + equals: function(c) { + + return !!c && + this.start.x === c.start.x && + this.start.y === c.start.y && + this.controlPoint1.x === c.controlPoint1.x && + this.controlPoint1.y === c.controlPoint1.y && + this.controlPoint2.x === c.controlPoint2.x && + this.controlPoint2.y === c.controlPoint2.y && + this.end.x === c.end.x && + this.end.y === c.end.y; + }, + + // Returns five helper points necessary for curve division. + getSkeletonPoints: function(t) { + + var start = this.start; + var control1 = this.controlPoint1; + var control2 = this.controlPoint2; + var end = this.end; + + // shortcuts for `t` values that are out of range + if (t <= 0) { + return { + startControlPoint1: start.clone(), + startControlPoint2: start.clone(), + divider: start.clone(), + dividerControlPoint1: control1.clone(), + dividerControlPoint2: control2.clone() + }; + } + + if (t >= 1) { + return { + startControlPoint1: control1.clone(), + startControlPoint2: control2.clone(), + divider: end.clone(), + dividerControlPoint1: end.clone(), + dividerControlPoint2: end.clone() + }; + } + + var midpoint1 = (new Line(start, control1)).pointAt(t); + var midpoint2 = (new Line(control1, control2)).pointAt(t); + var midpoint3 = (new Line(control2, end)).pointAt(t); + + var subControl1 = (new Line(midpoint1, midpoint2)).pointAt(t); + var subControl2 = (new Line(midpoint2, midpoint3)).pointAt(t); + + var divider = (new Line(subControl1, subControl2)).pointAt(t); + + var output = { + startControlPoint1: midpoint1, + startControlPoint2: subControl1, + divider: divider, + dividerControlPoint1: subControl2, + dividerControlPoint2: midpoint3 + }; + + return output; + }, + + // Returns a list of curves whose flattened length is better than `opt.precision`. + // That is, observed difference in length between recursions is less than 10^(-3) = 0.001 = 0.1% + // (Observed difference is not real precision, but close enough as long as special cases are covered) + // (That is why skipping iteration 1 is important) + // As a rule of thumb, increasing `precision` by 1 requires two more division operations + // - Precision 0 (endpointDistance) - total of 2^0 - 1 = 0 operations (1 subdivision) + // - Precision 1 (<10% error) - total of 2^2 - 1 = 3 operations (4 subdivisions) + // - Precision 2 (<1% error) - total of 2^4 - 1 = 15 operations requires 4 division operations on all elements (15 operations total) (16 subdivisions) + // - Precision 3 (<0.1% error) - total of 2^6 - 1 = 63 operations - acceptable when drawing (64 subdivisions) + // - Precision 4 (<0.01% error) - total of 2^8 - 1 = 255 operations - high resolution, can be used to interpolate `t` (256 subdivisions) + // (Variation of 1 recursion worse or better is possible depending on the curve, doubling/halving the number of operations accordingly) + getSubdivisions: function(opt) { + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + // not using opt.subdivisions + // not using localOpt + + var subdivisions = [new Curve(this.start, this.controlPoint1, this.controlPoint2, this.end)]; + if (precision === 0) { return subdivisions; } + + var previousLength = this.endpointDistance(); + + var precisionRatio = pow$3(10, -precision); + + // recursively divide curve at `t = 0.5` + // until the difference between observed length at subsequent iterations is lower than precision + var iteration = 0; + while (true) { + iteration += 1; + + // divide all subdivisions + var newSubdivisions = []; + var numSubdivisions = subdivisions.length; + for (var i = 0; i < numSubdivisions; i++) { + + var currentSubdivision = subdivisions[i]; + var divided = currentSubdivision.divide(0.5); // dividing at t = 0.5 (not at middle length!) + newSubdivisions.push(divided[0], divided[1]); + } + + // measure new length + var length = 0; + var numNewSubdivisions = newSubdivisions.length; + for (var j = 0; j < numNewSubdivisions; j++) { + + var currentNewSubdivision = newSubdivisions[j]; + length += currentNewSubdivision.endpointDistance(); + } + + // check if we have reached required observed precision + // sine-like curves may have the same observed length in iteration 0 and 1 - skip iteration 1 + // not a problem for further iterations because cubic curves cannot have more than two local extrema + // (i.e. cubic curves cannot intersect the baseline more than once) + // therefore two subsequent iterations cannot produce sampling with equal length + var observedPrecisionRatio = ((length !== 0) ? ((length - previousLength) / length) : 0); + if (iteration > 1 && observedPrecisionRatio < precisionRatio) { + return newSubdivisions; + } + + // otherwise, set up for next iteration + subdivisions = newSubdivisions; + previousLength = length; + } + }, + + isDifferentiable: function() { + + var start = this.start; + var control1 = this.controlPoint1; + var control2 = this.controlPoint2; + var end = this.end; + + return !(start.equals(control1) && control1.equals(control2) && control2.equals(end)); + }, + + // Returns flattened length of the curve with precision better than `opt.precision`; or using `opt.subdivisions` provided. + length: function(opt) { + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; // opt.precision only used in getSubdivisions() call + var subdivisions = (opt.subdivisions === undefined) ? this.getSubdivisions({ precision: precision }) : opt.subdivisions; + // not using localOpt + + var length = 0; + var n = subdivisions.length; + for (var i = 0; i < n; i++) { + + var currentSubdivision = subdivisions[i]; + length += currentSubdivision.endpointDistance(); + } + + return length; + }, + + // Returns distance along the curve up to `t` with precision better than requested `opt.precision`. (Not using `opt.subdivisions`.) + lengthAtT: function(t, opt) { + + if (t <= 0) { return 0; } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + // not using opt.subdivisions + // not using localOpt + + var subCurve = this.divide(t)[0]; + var subCurveLength = subCurve.length({ precision: precision }); + + return subCurveLength; + }, + + // Returns point at requested `ratio` between 0 and 1 with precision better than `opt.precision`; optionally using `opt.subdivisions` provided. + // Mirrors Line.pointAt() function. + // For a function that tracks `t`, use Curve.pointAtT(). + pointAt: function(ratio, opt) { + + if (ratio <= 0) { return this.start.clone(); } + if (ratio >= 1) { return this.end.clone(); } + + var t = this.tAt(ratio, opt); + + return this.pointAtT(t); + }, + + // Returns point at requested `length` with precision better than requested `opt.precision`; optionally using `opt.subdivisions` provided. + pointAtLength: function(length, opt) { + + var t = this.tAtLength(length, opt); + + return this.pointAtT(t); + }, + + // Returns the point at provided `t` between 0 and 1. + // `t` does not track distance along curve as it does in Line objects. + // Non-linear relationship, speeds up and slows down as curve warps! + // For linear length-based solution, use Curve.pointAt(). + pointAtT: function(t) { + + if (t <= 0) { return this.start.clone(); } + if (t >= 1) { return this.end.clone(); } + + return this.getSkeletonPoints(t).divider; + }, + + // Default precision + PRECISION: 3, + + round: function(precision) { + + this.start.round(precision); + this.controlPoint1.round(precision); + this.controlPoint2.round(precision); + this.end.round(precision); + return this; + }, + + scale: function(sx, sy, origin) { + + this.start.scale(sx, sy, origin); + this.controlPoint1.scale(sx, sy, origin); + this.controlPoint2.scale(sx, sy, origin); + this.end.scale(sx, sy, origin); + return this; + }, + + // Returns a tangent line at requested `ratio` with precision better than requested `opt.precision`; or using `opt.subdivisions` provided. + tangentAt: function(ratio, opt) { + + if (!this.isDifferentiable()) { return null; } + + if (ratio < 0) { ratio = 0; } + else if (ratio > 1) { ratio = 1; } + + var t = this.tAt(ratio, opt); + + return this.tangentAtT(t); + }, + + // Returns a tangent line at requested `length` with precision better than requested `opt.precision`; or using `opt.subdivisions` provided. + tangentAtLength: function(length, opt) { + + if (!this.isDifferentiable()) { return null; } + + var t = this.tAtLength(length, opt); + + return this.tangentAtT(t); + }, + + // Returns a tangent line at requested `t`. + tangentAtT: function(t) { + + if (!this.isDifferentiable()) { return null; } + + if (t < 0) { t = 0; } + else if (t > 1) { t = 1; } + + var skeletonPoints = this.getSkeletonPoints(t); + + var p1 = skeletonPoints.startControlPoint2; + var p2 = skeletonPoints.dividerControlPoint1; + + var tangentStart = skeletonPoints.divider; + + var tangentLine = new Line(p1, p2); + tangentLine.translate(tangentStart.x - p1.x, tangentStart.y - p1.y); // move so that tangent line starts at the point requested + + return tangentLine; + }, + + // Returns `t` at requested `ratio` with precision better than requested `opt.precision`; optionally using `opt.subdivisions` provided. + tAt: function(ratio, opt) { + + if (ratio <= 0) { return 0; } + if (ratio >= 1) { return 1; } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var subdivisions = (opt.subdivisions === undefined) ? this.getSubdivisions({ precision: precision }) : opt.subdivisions; + var localOpt = { precision: precision, subdivisions: subdivisions }; + + var curveLength = this.length(localOpt); + var length = curveLength * ratio; + + return this.tAtLength(length, localOpt); + }, + + // Returns `t` at requested `length` with precision better than requested `opt.precision`; optionally using `opt.subdivisions` provided. + // Uses `precision` to approximate length within `precision` (always underestimates) + // Then uses a binary search to find the `t` of a subdivision endpoint that is close (within `precision`) to the `length`, if the curve was as long as approximated + // As a rule of thumb, increasing `precision` by 1 causes the algorithm to go 2^(precision - 1) deeper + // - Precision 0 (chooses one of the two endpoints) - 0 levels + // - Precision 1 (chooses one of 5 points, <10% error) - 1 level + // - Precision 2 (<1% error) - 3 levels + // - Precision 3 (<0.1% error) - 7 levels + // - Precision 4 (<0.01% error) - 15 levels + tAtLength: function(length, opt) { + + var fromStart = true; + if (length < 0) { + fromStart = false; // negative lengths mean start calculation from end point + length = -length; // absolute value + } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var subdivisions = (opt.subdivisions === undefined) ? this.getSubdivisions({ precision: precision }) : opt.subdivisions; + var localOpt = { precision: precision, subdivisions: subdivisions }; + + // identify the subdivision that contains the point at requested `length`: + var investigatedSubdivision; + var investigatedSubdivisionStartT; // assume that subdivisions are evenly spaced + var investigatedSubdivisionEndT; + //var baseline; // straightened version of subdivision to investigate + //var baselinePoint; // point on the baseline that is the requested distance away from start + var baselinePointDistFromStart; // distance of baselinePoint from start of baseline + var baselinePointDistFromEnd; // distance of baselinePoint from end of baseline + var l = 0; // length so far + var n = subdivisions.length; + var subdivisionSize = 1 / n; + for (var i = 0; i < n; i++) { + var index = (fromStart ? i : (n - 1 - i)); + + var currentSubdivision = subdivisions[i]; + var d = currentSubdivision.endpointDistance(); // length of current subdivision + + if (length <= (l + d)) { + investigatedSubdivision = currentSubdivision; + + investigatedSubdivisionStartT = index * subdivisionSize; + investigatedSubdivisionEndT = (index + 1) * subdivisionSize; + + baselinePointDistFromStart = (fromStart ? (length - l) : ((d + l) - length)); + baselinePointDistFromEnd = (fromStart ? ((d + l) - length) : (length - l)); + + break; + } + + l += d; + } + + if (!investigatedSubdivision) { return (fromStart ? 1 : 0); } // length requested is out of range - return maximum t + // note that precision affects what length is recorded + // (imprecise measurements underestimate length by up to 10^(-precision) of the precise length) + // e.g. at precision 1, the length may be underestimated by up to 10% and cause this function to return 1 + + var curveLength = this.length(localOpt); + + var precisionRatio = pow$3(10, -precision); + + // recursively divide investigated subdivision: + // until distance between baselinePoint and closest path endpoint is within 10^(-precision) + // then return the closest endpoint of that final subdivision + while (true) { + + // check if we have reached required observed precision + var observedPrecisionRatio; + + observedPrecisionRatio = ((curveLength !== 0) ? (baselinePointDistFromStart / curveLength) : 0); + if (observedPrecisionRatio < precisionRatio) { return investigatedSubdivisionStartT; } + observedPrecisionRatio = ((curveLength !== 0) ? (baselinePointDistFromEnd / curveLength) : 0); + if (observedPrecisionRatio < precisionRatio) { return investigatedSubdivisionEndT; } + + // otherwise, set up for next iteration + var newBaselinePointDistFromStart; + var newBaselinePointDistFromEnd; + + var divided = investigatedSubdivision.divide(0.5); + subdivisionSize /= 2; + + var baseline1Length = divided[0].endpointDistance(); + var baseline2Length = divided[1].endpointDistance(); + + if (baselinePointDistFromStart <= baseline1Length) { // point at requested length is inside divided[0] + investigatedSubdivision = divided[0]; + + investigatedSubdivisionEndT -= subdivisionSize; // sudivisionSize was already halved + + newBaselinePointDistFromStart = baselinePointDistFromStart; + newBaselinePointDistFromEnd = baseline1Length - newBaselinePointDistFromStart; + + } else { // point at requested length is inside divided[1] + investigatedSubdivision = divided[1]; + + investigatedSubdivisionStartT += subdivisionSize; // subdivisionSize was already halved + + newBaselinePointDistFromStart = baselinePointDistFromStart - baseline1Length; + newBaselinePointDistFromEnd = baseline2Length - newBaselinePointDistFromStart; + } + + baselinePointDistFromStart = newBaselinePointDistFromStart; + baselinePointDistFromEnd = newBaselinePointDistFromEnd; + } + }, + + // Returns an array of points that represents the curve when flattened, up to `opt.precision`; or using `opt.subdivisions` provided. + // Flattened length is no more than 10^(-precision) away from real curve length. + toPoints: function(opt) { + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; // opt.precision only used in getSubdivisions() call + var subdivisions = (opt.subdivisions === undefined) ? this.getSubdivisions({ precision: precision }) : opt.subdivisions; + // not using localOpt + + var points = [subdivisions[0].start.clone()]; + var n = subdivisions.length; + for (var i = 0; i < n; i++) { + + var currentSubdivision = subdivisions[i]; + points.push(currentSubdivision.end.clone()); + } + + return points; + }, + + // Returns a polyline that represents the curve when flattened, up to `opt.precision`; or using `opt.subdivisions` provided. + // Flattened length is no more than 10^(-precision) away from real curve length. + toPolyline: function(opt) { + + return new Polyline(this.toPoints(opt)); + }, + + toString: function() { + + return this.start + ' ' + this.controlPoint1 + ' ' + this.controlPoint2 + ' ' + this.end; + }, + + translate: function(tx, ty) { + + this.start.translate(tx, ty); + this.controlPoint1.translate(tx, ty); + this.controlPoint2.translate(tx, ty); + this.end.translate(tx, ty); + return this; + } + }; + + Curve.prototype.divide = Curve.prototype.divideAtT; + + // Local helper function. + // Add properties from arguments on top of properties from `obj`. + // This allows for rudimentary inheritance. + // - The `obj` argument acts as parent. + // - This function creates a new object that inherits all `obj` properties and adds/replaces those that are present in arguments. + // - A high-level example: calling `extend(Vehicle, Car)` would be akin to declaring `class Car extends Vehicle`. + function extend(obj) { + var arguments$1 = arguments; + + // In JavaScript, the combination of a constructor function (e.g. `g.Line = function(...) {...}`) and prototype (e.g. `g.Line.prototype = {...}) is akin to a C++ class. + // - When inheritance is not necessary, we can leave it at that. (This would be akin to calling extend with only `obj`.) + // - But, what if we wanted the `g.Line` quasiclass to inherit from another quasiclass (let's call it `g.GeometryObject`) in JavaScript? + // - First, realize that both of those quasiclasses would still have their own separate constructor function. + // - So what we are actually saying is that we want the `g.Line` prototype to inherit from `g.GeometryObject` prototype. + // - This method provides a way to do exactly that. + // - It copies parent prototype's properties, then adds extra ones from child prototype/overrides parent prototype properties with child prototype properties. + // - Therefore, to continue with the example above: + // - `g.Line.prototype = extend(g.GeometryObject.prototype, linePrototype)` + // - Where `linePrototype` is a properties object that looks just like `g.Line.prototype` does right now. + // - Then, `g.Line` would allow the programmer to access to all methods currently in `g.Line.Prototype`, plus any non-overridden methods from `g.GeometryObject.prototype`. + // - In that aspect, `g.GeometryObject` would then act like the parent of `g.Line`. + // - Multiple inheritance is also possible, if multiple arguments are provided. + // - What if we wanted to add another level of abstraction between `g.GeometryObject` and `g.Line` (let's call it `g.LinearObject`)? + // - `g.Line.prototype = extend(g.GeometryObject.prototype, g.LinearObject.prototype, linePrototype)` + // - The ancestors are applied in order of appearance. + // - That means that `g.Line` would have inherited from `g.LinearObject` that would have inherited from `g.GeometryObject`. + // - Any number of ancestors may be provided. + // - Note that neither `obj` nor any of the arguments need to actually be prototypes of any JavaScript quasiclass, that was just a simplified explanation. + // - We can create a new object composed from the properties of any number of other objects (since they do not have a constructor, we can think of those as interfaces). + // - `extend({ a: 1, b: 2 }, { b: 10, c: 20 }, { c: 100, d: 200 })` gives `{ a: 1, b: 10, c: 100, d: 200 }`. + // - Basically, with this function, we can emulate the `extends` keyword as well as the `implements` keyword. + // - Therefore, both of the following are valid: + // - `Lineto.prototype = extend(Line.prototype, segmentPrototype, linetoPrototype)` + // - `Moveto.prototype = extend(segmentPrototype, movetoPrototype)` + + var i; + var n; + + var args = []; + n = arguments.length; + for (i = 1; i < n; i++) { // skip over obj + args.push(arguments$1[i]); + } + + if (!obj) { throw new Error('Missing a parent object.'); } + var child = Object.create(obj); + + n = args.length; + for (i = 0; i < n; i++) { + + var src = args[i]; + + var inheritedProperty; + var key; + for (key in src) { + + if (src.hasOwnProperty(key)) { + delete child[key]; // delete property inherited from parent + inheritedProperty = Object.getOwnPropertyDescriptor(src, key); // get new definition of property from src + Object.defineProperty(child, key, inheritedProperty); // re-add property with new definition (includes getter/setter methods) + } + } + } + + return child; + } + + // Accepts path data string, array of segments, array of Curves and/or Lines, or a Polyline. + var Path = function(arg) { + + if (!(this instanceof Path)) { + return new Path(arg); + } + + if (typeof arg === 'string') { // create from a path data string + return new Path.parse(arg); + } + + this.segments = []; + + var i; + var n; + + if (!arg) { + // don't do anything + + } else if (Array.isArray(arg) && arg.length !== 0) { // if arg is a non-empty array + // flatten one level deep + // so we can chain arbitrary Path.createSegment results + arg = arg.reduce(function(acc, val) { + return acc.concat(val); + }, []); + + n = arg.length; + if (arg[0].isSegment) { // create from an array of segments + for (i = 0; i < n; i++) { + + var segment = arg[i]; + + this.appendSegment(segment); + } + + } else { // create from an array of Curves and/or Lines + var previousObj = null; + for (i = 0; i < n; i++) { + + var obj = arg[i]; + + if (!((obj instanceof Line) || (obj instanceof Curve))) { + throw new Error('Cannot construct a path segment from the provided object.'); + } + + if (i === 0) { this.appendSegment(Path.createSegment('M', obj.start)); } + + // if objects do not link up, moveto segments are inserted to cover the gaps + if (previousObj && !previousObj.end.equals(obj.start)) { this.appendSegment(Path.createSegment('M', obj.start)); } + + if (obj instanceof Line) { + this.appendSegment(Path.createSegment('L', obj.end)); + + } else if (obj instanceof Curve) { + this.appendSegment(Path.createSegment('C', obj.controlPoint1, obj.controlPoint2, obj.end)); + } + + previousObj = obj; + } + } + + } else if (arg.isSegment) { // create from a single segment + this.appendSegment(arg); + + } else if (arg instanceof Line) { // create from a single Line + this.appendSegment(Path.createSegment('M', arg.start)); + this.appendSegment(Path.createSegment('L', arg.end)); + + } else if (arg instanceof Curve) { // create from a single Curve + this.appendSegment(Path.createSegment('M', arg.start)); + this.appendSegment(Path.createSegment('C', arg.controlPoint1, arg.controlPoint2, arg.end)); + + } else if (arg instanceof Polyline) { // create from a Polyline + if (!(arg.points && (arg.points.length !== 0))) { return; } // if Polyline has no points, leave Path empty + + n = arg.points.length; + for (i = 0; i < n; i++) { + + var point = arg.points[i]; + + if (i === 0) { this.appendSegment(Path.createSegment('M', point)); } + else { this.appendSegment(Path.createSegment('L', point)); } + } + + } else { // unknown object + throw new Error('Cannot construct a path from the provided object.'); + } + }; + + // More permissive than V.normalizePathData and Path.prototype.serialize. + // Allows path data strings that do not start with a Moveto command (unlike SVG specification). + // Does not require spaces between elements; commas are allowed, separators may be omitted when unambiguous (e.g. 'ZM10,10', 'L1.6.8', 'M100-200'). + // Allows for command argument chaining. + // Throws an error if wrong number of arguments is provided with a command. + // Throws an error if an unrecognized path command is provided (according to Path.segmentTypes). Only a subset of SVG commands is currently supported (L, C, M, Z). + Path.parse = function(pathData) { + + if (!pathData) { return new Path(); } + + var path = new Path(); + + var commandRe = /(?:[a-zA-Z] *)(?:(?:-?\d+(?:\.\d+)?(?:e[-+]?\d+)? *,? *)|(?:-?\.\d+ *,? *))+|(?:[a-zA-Z] *)(?! |\d|-|\.)/g; + var commands = pathData.match(commandRe); + + var numCommands = commands.length; + for (var i = 0; i < numCommands; i++) { + + var command = commands[i]; + var argRe = /(?:[a-zA-Z])|(?:(?:-?\d+(?:\.\d+)?(?:e[-+]?\d+)?))|(?:(?:-?\.\d+))/g; + var args = command.match(argRe); + + var segment = Path.createSegment.apply(this, args); // args = [type, coordinate1, coordinate2...] + path.appendSegment(segment); + } + + return path; + }; + + // Create a segment or an array of segments. + // Accepts unlimited points/coords arguments after `type`. + Path.createSegment = function(type) { + var arguments$1 = arguments; + + + if (!type) { throw new Error('Type must be provided.'); } + + var segmentConstructor = Path.segmentTypes[type]; + if (!segmentConstructor) { throw new Error(type + ' is not a recognized path segment type.'); } + + var args = []; + var n = arguments.length; + for (var i = 1; i < n; i++) { // do not add first element (`type`) to args array + args.push(arguments$1[i]); + } + + return applyToNew(segmentConstructor, args); + }; + + Path.prototype = { + + type: types.Path, + + // Accepts one segment or an array of segments as argument. + // Throws an error if argument is not a segment or an array of segments. + appendSegment: function(arg) { + + var segments = this.segments; + var numSegments = segments.length; + // works even if path has no segments + + var currentSegment; + + var previousSegment = ((numSegments !== 0) ? segments[numSegments - 1] : null); // if we are appending to an empty path, previousSegment is null + var nextSegment = null; + + if (!Array.isArray(arg)) { // arg is a segment + if (!arg || !arg.isSegment) { throw new Error('Segment required.'); } + + currentSegment = this.prepareSegment(arg, previousSegment, nextSegment); + segments.push(currentSegment); + + } else { // arg is an array of segments + // flatten one level deep + // so we can chain arbitrary Path.createSegment results + arg = arg.reduce(function(acc, val) { + return acc.concat(val); + }, []); + + if (!arg[0].isSegment) { throw new Error('Segments required.'); } + + var n = arg.length; + for (var i = 0; i < n; i++) { + + var currentArg = arg[i]; + currentSegment = this.prepareSegment(currentArg, previousSegment, nextSegment); + segments.push(currentSegment); + previousSegment = currentSegment; + } + } + }, + + // Returns the bbox of the path. + // If path has no segments, returns null. + // If path has only invisible segments, returns bbox of the end point of last segment. + bbox: function() { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + var bbox; + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + if (segment.isVisible) { + var segmentBBox = segment.bbox(); + bbox = bbox ? bbox.union(segmentBBox) : segmentBBox; + } + } + + if (bbox) { return bbox; } + + // if the path has only invisible elements, return end point of last segment + var lastSegment = segments[numSegments - 1]; + return new Rect(lastSegment.end.x, lastSegment.end.y, 0, 0); + }, + + // Returns a new path that is a clone of this path. + clone: function() { + + var segments = this.segments; + var numSegments = segments.length; + // works even if path has no segments + + var path = new Path(); + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i].clone(); + path.appendSegment(segment); + } + + return path; + }, + + closestPoint: function(p, opt) { + + var t = this.closestPointT(p, opt); + if (!t) { return null; } + + return this.pointAtT(t); + }, + + closestPointLength: function(p, opt) { + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + var localOpt = { precision: precision, segmentSubdivisions: segmentSubdivisions }; + + var t = this.closestPointT(p, localOpt); + if (!t) { return 0; } + + return this.lengthAtT(t, localOpt); + }, + + closestPointNormalizedLength: function(p, opt) { + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + var localOpt = { precision: precision, segmentSubdivisions: segmentSubdivisions }; + + var cpLength = this.closestPointLength(p, localOpt); + if (cpLength === 0) { return 0; } // shortcut + + var length = this.length(localOpt); + if (length === 0) { return 0; } // prevents division by zero + + return cpLength / length; + }, + + // Private function. + closestPointT: function(p, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + // not using localOpt + + var closestPointT; + var minSquaredDistance = Infinity; + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + var subdivisions = segmentSubdivisions[i]; + + if (segment.isVisible) { + var segmentClosestPointT = segment.closestPointT(p, { + precision: precision, + subdivisions: subdivisions + }); + var segmentClosestPoint = segment.pointAtT(segmentClosestPointT); + var squaredDistance = (new Line(segmentClosestPoint, p)).squaredLength(); + + if (squaredDistance < minSquaredDistance) { + closestPointT = { segmentIndex: i, value: segmentClosestPointT }; + minSquaredDistance = squaredDistance; + } + } + } + + if (closestPointT) { return closestPointT; } + + // if no visible segment, return end of last segment + return { segmentIndex: numSegments - 1, value: 1 }; + }, + + closestPointTangent: function(p, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + // not using localOpt + + var closestPointTangent; + var minSquaredDistance = Infinity; + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + var subdivisions = segmentSubdivisions[i]; + + if (segment.isDifferentiable()) { + var segmentClosestPointT = segment.closestPointT(p, { + precision: precision, + subdivisions: subdivisions + }); + var segmentClosestPoint = segment.pointAtT(segmentClosestPointT); + var squaredDistance = (new Line(segmentClosestPoint, p)).squaredLength(); + + if (squaredDistance < minSquaredDistance) { + closestPointTangent = segment.tangentAtT(segmentClosestPointT); + minSquaredDistance = squaredDistance; + } + } + } + + if (closestPointTangent) { return closestPointTangent; } + + // if no valid segment, return null + return null; + }, + + // Returns `true` if the area surrounded by the path contains the point `p`. + // Implements the even-odd algorithm (self-intersections are "outside"). + // Closes open paths (always imagines a final closing segment). + // Precision may be adjusted by passing an `opt` object. + containsPoint: function(p, opt) { + + var polylines = this.toPolylines(opt); + if (!polylines) { return false; } // shortcut (this path has no polylines) + + var numPolylines = polylines.length; + + // how many component polylines does `p` lie within? + var numIntersections = 0; + for (var i = 0; i < numPolylines; i++) { + var polyline = polylines[i]; + if (polyline.containsPoint(p)) { + // `p` lies within this polyline + numIntersections++; + } + } + + // returns `true` for odd numbers of intersections (even-odd algorithm) + return ((numIntersections % 2) === 1); + }, + + // Divides the path into two at requested `ratio` between 0 and 1 with precision better than `opt.precision`; optionally using `opt.subdivisions` provided. + divideAt: function(ratio, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + if (ratio < 0) { ratio = 0; } + if (ratio > 1) { ratio = 1; } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + var localOpt = { precision: precision, segmentSubdivisions: segmentSubdivisions }; + + var pathLength = this.length(localOpt); + var length = pathLength * ratio; + + return this.divideAtLength(length, localOpt); + }, + + // Divides the path into two at requested `length` with precision better than requested `opt.precision`; optionally using `opt.subdivisions` provided. + divideAtLength: function(length, opt) { + + var numSegments = this.segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + var fromStart = true; + if (length < 0) { + fromStart = false; // negative lengths mean start calculation from end point + length = -length; // absolute value + } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + // not using localOpt + + var i; + var segment; + + // identify the segment to divide: + + var l = 0; // length so far + var divided; + var dividedSegmentIndex; + var lastValidSegment; // visible AND differentiable + var lastValidSegmentIndex; + var t; + for (i = 0; i < numSegments; i++) { + var index = (fromStart ? i : (numSegments - 1 - i)); + + segment = this.getSegment(index); + var subdivisions = segmentSubdivisions[index]; + var d = segment.length({ precision: precision, subdivisions: subdivisions }); + + if (segment.isDifferentiable()) { // segment is not just a point + lastValidSegment = segment; + lastValidSegmentIndex = index; + + if (length <= (l + d)) { + dividedSegmentIndex = index; + divided = segment.divideAtLength(((fromStart ? 1 : -1) * (length - l)), { + precision: precision, + subdivisions: subdivisions + }); + break; + } + } + + l += d; + } + + if (!lastValidSegment) { // no valid segment found + return null; + } + + // else: the path contains at least one valid segment + + if (!divided) { // the desired length is greater than the length of the path + dividedSegmentIndex = lastValidSegmentIndex; + t = (fromStart ? 1 : 0); + divided = lastValidSegment.divideAtT(t); + } + + // create a copy of this path and replace the identified segment with its two divided parts: + + var pathCopy = this.clone(); + pathCopy.replaceSegment(dividedSegmentIndex, divided); + + var divisionStartIndex = dividedSegmentIndex; + var divisionMidIndex = dividedSegmentIndex + 1; + var divisionEndIndex = dividedSegmentIndex + 2; + + // do not insert the part if it looks like a point + if (!divided[0].isDifferentiable()) { + pathCopy.removeSegment(divisionStartIndex); + divisionMidIndex -= 1; + divisionEndIndex -= 1; + } + + // insert a Moveto segment to ensure secondPath will be valid: + var movetoEnd = pathCopy.getSegment(divisionMidIndex).start; + pathCopy.insertSegment(divisionMidIndex, Path.createSegment('M', movetoEnd)); + divisionEndIndex += 1; + + // do not insert the part if it looks like a point + if (!divided[1].isDifferentiable()) { + pathCopy.removeSegment(divisionEndIndex - 1); + divisionEndIndex -= 1; + } + + // ensure that Closepath segments in secondPath will be assigned correct subpathStartSegment: + + var secondPathSegmentIndexConversion = divisionEndIndex - divisionStartIndex - 1; + for (i = divisionEndIndex; i < pathCopy.segments.length; i++) { + + var originalSegment = this.getSegment(i - secondPathSegmentIndexConversion); + segment = pathCopy.getSegment(i); + + if ((segment.type === 'Z') && !originalSegment.subpathStartSegment.end.equals(segment.subpathStartSegment.end)) { + // pathCopy segment's subpathStartSegment is different from original segment's one + // convert this Closepath segment to a Lineto and replace it in pathCopy + var convertedSegment = Path.createSegment('L', originalSegment.end); + pathCopy.replaceSegment(i, convertedSegment); + } + } + + // distribute pathCopy segments into two paths and return those: + + var firstPath = new Path(pathCopy.segments.slice(0, divisionMidIndex)); + var secondPath = new Path(pathCopy.segments.slice(divisionMidIndex)); + + return [firstPath, secondPath]; + }, + + // Checks whether two paths are exactly the same. + // If `p` is undefined or null, returns false. + equals: function(p) { + + if (!p) { return false; } + + var segments = this.segments; + var otherSegments = p.segments; + + var numSegments = segments.length; + if (otherSegments.length !== numSegments) { return false; } // if the two paths have different number of segments, they cannot be equal + + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + var otherSegment = otherSegments[i]; + + // as soon as an inequality is found in segments, return false + if ((segment.type !== otherSegment.type) || (!segment.equals(otherSegment))) { return false; } + } + + // if no inequality found in segments, return true + return true; + }, + + // Accepts negative indices. + // Throws an error if path has no segments. + // Throws an error if index is out of range. + getSegment: function(index) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { throw new Error('Path has no segments.'); } + + if (index < 0) { index = numSegments + index; } // convert negative indices to positive + if (index >= numSegments || index < 0) { throw new Error('Index out of range.'); } + + return segments[index]; + }, + + // Returns an array of segment subdivisions, with precision better than requested `opt.precision`. + getSegmentSubdivisions: function(opt) { + + var segments = this.segments; + var numSegments = segments.length; + // works even if path has no segments + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + // not using opt.segmentSubdivisions + // not using localOpt + + var segmentSubdivisions = []; + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + var subdivisions = segment.getSubdivisions({ precision: precision }); + segmentSubdivisions.push(subdivisions); + } + + return segmentSubdivisions; + }, + + // Returns an array of subpaths of this path. + // Invalid paths are validated first. + // Returns `[]` if path has no segments. + getSubpaths: function() { + + var validatedPath = this.clone().validate(); + + var segments = validatedPath.segments; + var numSegments = segments.length; + + var subpaths = []; + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + if (segment.isSubpathStart) { + // we encountered a subpath start segment + // create a new path for segment, and push it to list of subpaths + subpaths.push(new Path(segment)); + + } else { + // append current segment to the last subpath + subpaths[subpaths.length - 1].appendSegment(segment); + } + } + + return subpaths; + }, + + // Insert `arg` at given `index`. + // `index = 0` means insert at the beginning. + // `index = segments.length` means insert at the end. + // Accepts negative indices, from `-1` to `-(segments.length + 1)`. + // Accepts one segment or an array of segments as argument. + // Throws an error if index is out of range. + // Throws an error if argument is not a segment or an array of segments. + insertSegment: function(index, arg) { + + var segments = this.segments; + var numSegments = segments.length; + // works even if path has no segments + + // note that these are incremented compared to getSegments() + // we can insert after last element (note that this changes the meaning of index -1) + if (index < 0) { index = numSegments + index + 1; } // convert negative indices to positive + if (index > numSegments || index < 0) { throw new Error('Index out of range.'); } + + var currentSegment; + + var previousSegment = null; + var nextSegment = null; + + if (numSegments !== 0) { + if (index >= 1) { + previousSegment = segments[index - 1]; + nextSegment = previousSegment.nextSegment; // if we are inserting at end, nextSegment is null + + } else { // if index === 0 + // previousSegment is null + nextSegment = segments[0]; + } + } + + if (!Array.isArray(arg)) { + if (!arg || !arg.isSegment) { throw new Error('Segment required.'); } + + currentSegment = this.prepareSegment(arg, previousSegment, nextSegment); + segments.splice(index, 0, currentSegment); + + } else { + // flatten one level deep + // so we can chain arbitrary Path.createSegment results + arg = arg.reduce(function(acc, val) { + return acc.concat(val); + }, []); + + if (!arg[0].isSegment) { throw new Error('Segments required.'); } + + var n = arg.length; + for (var i = 0; i < n; i++) { + + var currentArg = arg[i]; + currentSegment = this.prepareSegment(currentArg, previousSegment, nextSegment); + segments.splice((index + i), 0, currentSegment); // incrementing index to insert subsequent segments after inserted segments + previousSegment = currentSegment; + } + } + }, + + intersectionWithLine: function(line, opt) { + + var intersection = null; + var polylines = this.toPolylines(opt); + if (!polylines) { return null; } + for (var i = 0, n = polylines.length; i < n; i++) { + var polyline = polylines[i]; + var polylineIntersection = line.intersect(polyline); + if (polylineIntersection) { + intersection || (intersection = []); + if (Array.isArray(polylineIntersection)) { + Array.prototype.push.apply(intersection, polylineIntersection); + } else { + intersection.push(polylineIntersection); + } + } + } + + return intersection; + }, + + isDifferentiable: function() { + + var segments = this.segments; + var numSegments = segments.length; + + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + // as soon as a differentiable segment is found in segments, return true + if (segment.isDifferentiable()) { return true; } + } + + // if no differentiable segment is found in segments, return false + return false; + }, + + // Checks whether current path segments are valid. + // Note that d is allowed to be empty - should disable rendering of the path. + isValid: function() { + + var segments = this.segments; + var isValid = (segments.length === 0) || (segments[0].type === 'M'); // either empty or first segment is a Moveto + return isValid; + }, + + // Returns length of the path, with precision better than requested `opt.precision`; or using `opt.segmentSubdivisions` provided. + // If path has no segments, returns 0. + length: function(opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return 0; } // if segments is an empty array + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; // opt.precision only used in getSegmentSubdivisions() call + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + // not using localOpt + + var length = 0; + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + var subdivisions = segmentSubdivisions[i]; + length += segment.length({ subdivisions: subdivisions }); + } + + return length; + }, + + // Private function. + lengthAtT: function(t, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return 0; } // if segments is an empty array + + var segmentIndex = t.segmentIndex; + if (segmentIndex < 0) { return 0; } // regardless of t.value + + var tValue = t.value; + if (segmentIndex >= numSegments) { + segmentIndex = numSegments - 1; + tValue = 1; + } else if (tValue < 0) { tValue = 0; } + else if (tValue > 1) { tValue = 1; } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + // not using localOpt + + var subdivisions; + var length = 0; + for (var i = 0; i < segmentIndex; i++) { + + var segment = segments[i]; + subdivisions = segmentSubdivisions[i]; + length += segment.length({ precisison: precision, subdivisions: subdivisions }); + } + + segment = segments[segmentIndex]; + subdivisions = segmentSubdivisions[segmentIndex]; + length += segment.lengthAtT(tValue, { precisison: precision, subdivisions: subdivisions }); + + return length; + }, + + // Returns point at requested `ratio` between 0 and 1, with precision better than requested `opt.precision`; optionally using `opt.segmentSubdivisions` provided. + pointAt: function(ratio, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + if (ratio <= 0) { return this.start.clone(); } + if (ratio >= 1) { return this.end.clone(); } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + var localOpt = { precision: precision, segmentSubdivisions: segmentSubdivisions }; + + var pathLength = this.length(localOpt); + var length = pathLength * ratio; + + return this.pointAtLength(length, localOpt); + }, + + // Returns point at requested `length`, with precision better than requested `opt.precision`; optionally using `opt.segmentSubdivisions` provided. + // Accepts negative length. + pointAtLength: function(length, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + if (length === 0) { return this.start.clone(); } + + var fromStart = true; + if (length < 0) { + fromStart = false; // negative lengths mean start calculation from end point + length = -length; // absolute value + } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + // not using localOpt + + var lastVisibleSegment; + var l = 0; // length so far + for (var i = 0; i < numSegments; i++) { + var index = (fromStart ? i : (numSegments - 1 - i)); + + var segment = segments[index]; + var subdivisions = segmentSubdivisions[index]; + var d = segment.length({ precision: precision, subdivisions: subdivisions }); + + if (segment.isVisible) { + if (length <= (l + d)) { + return segment.pointAtLength(((fromStart ? 1 : -1) * (length - l)), { + precision: precision, + subdivisions: subdivisions + }); + } + + lastVisibleSegment = segment; + } + + l += d; + } + + // if length requested is higher than the length of the path, return last visible segment endpoint + if (lastVisibleSegment) { return (fromStart ? lastVisibleSegment.end : lastVisibleSegment.start); } + + // if no visible segment, return last segment end point (no matter if fromStart or no) + var lastSegment = segments[numSegments - 1]; + return lastSegment.end.clone(); + }, + + // Private function. + pointAtT: function(t) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + var segmentIndex = t.segmentIndex; + if (segmentIndex < 0) { return segments[0].pointAtT(0); } + if (segmentIndex >= numSegments) { return segments[numSegments - 1].pointAtT(1); } + + var tValue = t.value; + if (tValue < 0) { tValue = 0; } + else if (tValue > 1) { tValue = 1; } + + return segments[segmentIndex].pointAtT(tValue); + }, + + // Default precision + PRECISION: 3, + + // Helper method for adding segments. + prepareSegment: function(segment, previousSegment, nextSegment) { + + // insert after previous segment and before previous segment's next segment + segment.previousSegment = previousSegment; + segment.nextSegment = nextSegment; + if (previousSegment) { previousSegment.nextSegment = segment; } + if (nextSegment) { nextSegment.previousSegment = segment; } + + var updateSubpathStart = segment; + if (segment.isSubpathStart) { + segment.subpathStartSegment = segment; // assign self as subpath start segment + updateSubpathStart = nextSegment; // start updating from next segment + } + + // assign previous segment's subpath start (or self if it is a subpath start) to subsequent segments + if (updateSubpathStart) { this.updateSubpathStartSegment(updateSubpathStart); } + + return segment; + }, + + // Remove the segment at `index`. + // Accepts negative indices, from `-1` to `-segments.length`. + // Throws an error if path has no segments. + // Throws an error if index is out of range. + removeSegment: function(index) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { throw new Error('Path has no segments.'); } + + if (index < 0) { index = numSegments + index; } // convert negative indices to positive + if (index >= numSegments || index < 0) { throw new Error('Index out of range.'); } + + var removedSegment = segments.splice(index, 1)[0]; + var previousSegment = removedSegment.previousSegment; + var nextSegment = removedSegment.nextSegment; + + // link the previous and next segments together (if present) + if (previousSegment) { previousSegment.nextSegment = nextSegment; } // may be null + if (nextSegment) { nextSegment.previousSegment = previousSegment; } // may be null + + // if removed segment used to start a subpath, update all subsequent segments until another subpath start segment is reached + if (removedSegment.isSubpathStart && nextSegment) { this.updateSubpathStartSegment(nextSegment); } + }, + + // Replace the segment at `index` with `arg`. + // Accepts negative indices, from `-1` to `-segments.length`. + // Accepts one segment or an array of segments as argument. + // Throws an error if path has no segments. + // Throws an error if index is out of range. + // Throws an error if argument is not a segment or an array of segments. + replaceSegment: function(index, arg) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { throw new Error('Path has no segments.'); } + + if (index < 0) { index = numSegments + index; } // convert negative indices to positive + if (index >= numSegments || index < 0) { throw new Error('Index out of range.'); } + + var currentSegment; + + var replacedSegment = segments[index]; + var previousSegment = replacedSegment.previousSegment; + var nextSegment = replacedSegment.nextSegment; + + var updateSubpathStart = replacedSegment.isSubpathStart; // boolean: is an update of subpath starts necessary? + + if (!Array.isArray(arg)) { + if (!arg || !arg.isSegment) { throw new Error('Segment required.'); } + + currentSegment = this.prepareSegment(arg, previousSegment, nextSegment); + segments.splice(index, 1, currentSegment); // directly replace + + if (updateSubpathStart && currentSegment.isSubpathStart) { updateSubpathStart = false; } // already updated by `prepareSegment` + + } else { + // flatten one level deep + // so we can chain arbitrary Path.createSegment results + arg = arg.reduce(function(acc, val) { + return acc.concat(val); + }, []); + + if (!arg[0].isSegment) { throw new Error('Segments required.'); } + + segments.splice(index, 1); + + var n = arg.length; + for (var i = 0; i < n; i++) { + + var currentArg = arg[i]; + currentSegment = this.prepareSegment(currentArg, previousSegment, nextSegment); + segments.splice((index + i), 0, currentSegment); // incrementing index to insert subsequent segments after inserted segments + previousSegment = currentSegment; + + if (updateSubpathStart && currentSegment.isSubpathStart) { updateSubpathStart = false; } // already updated by `prepareSegment` + } + } + + // if replaced segment used to start a subpath and no new subpath start was added, update all subsequent segments until another subpath start segment is reached + if (updateSubpathStart && nextSegment) { this.updateSubpathStartSegment(nextSegment); } + }, + + round: function(precision) { + + var segments = this.segments; + var numSegments = segments.length; + + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + segment.round(precision); + } + + return this; + }, + + scale: function(sx, sy, origin) { + + var segments = this.segments; + var numSegments = segments.length; + + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + segment.scale(sx, sy, origin); + } + + return this; + }, + + segmentAt: function(ratio, opt) { + + var index = this.segmentIndexAt(ratio, opt); + if (!index) { return null; } + + return this.getSegment(index); + }, + + // Accepts negative length. + segmentAtLength: function(length, opt) { + + var index = this.segmentIndexAtLength(length, opt); + if (!index) { return null; } + + return this.getSegment(index); + }, + + segmentIndexAt: function(ratio, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + if (ratio < 0) { ratio = 0; } + if (ratio > 1) { ratio = 1; } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + var localOpt = { precision: precision, segmentSubdivisions: segmentSubdivisions }; + + var pathLength = this.length(localOpt); + var length = pathLength * ratio; + + return this.segmentIndexAtLength(length, localOpt); + }, + + // Accepts negative length. + segmentIndexAtLength: function(length, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + var fromStart = true; + if (length < 0) { + fromStart = false; // negative lengths mean start calculation from end point + length = -length; // absolute value + } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + // not using localOpt + + var lastVisibleSegmentIndex = null; + var l = 0; // length so far + for (var i = 0; i < numSegments; i++) { + var index = (fromStart ? i : (numSegments - 1 - i)); + + var segment = segments[index]; + var subdivisions = segmentSubdivisions[index]; + var d = segment.length({ precision: precision, subdivisions: subdivisions }); + + if (segment.isVisible) { + if (length <= (l + d)) { return index; } + lastVisibleSegmentIndex = index; + } + + l += d; + } + + // if length requested is higher than the length of the path, return last visible segment index + // if no visible segment, return null + return lastVisibleSegmentIndex; + }, + + // Returns a string that can be used to reconstruct the path. + // Additional error checking compared to toString (must start with M segment). + serialize: function() { + + if (!this.isValid()) { throw new Error('Invalid path segments.'); } + + return this.toString(); + }, + + // Returns tangent line at requested `ratio` between 0 and 1, with precision better than requested `opt.precision`; optionally using `opt.segmentSubdivisions` provided. + tangentAt: function(ratio, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + if (ratio < 0) { ratio = 0; } + if (ratio > 1) { ratio = 1; } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + var localOpt = { precision: precision, segmentSubdivisions: segmentSubdivisions }; + + var pathLength = this.length(localOpt); + var length = pathLength * ratio; + + return this.tangentAtLength(length, localOpt); + }, + + // Returns tangent line at requested `length`, with precision better than requested `opt.precision`; optionally using `opt.segmentSubdivisions` provided. + // Accepts negative length. + tangentAtLength: function(length, opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + var fromStart = true; + if (length < 0) { + fromStart = false; // negative lengths mean start calculation from end point + length = -length; // absolute value + } + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + // not using localOpt + + var lastValidSegment; // visible AND differentiable (with a tangent) + var l = 0; // length so far + for (var i = 0; i < numSegments; i++) { + var index = (fromStart ? i : (numSegments - 1 - i)); + + var segment = segments[index]; + var subdivisions = segmentSubdivisions[index]; + var d = segment.length({ precision: precision, subdivisions: subdivisions }); + + if (segment.isDifferentiable()) { + if (length <= (l + d)) { + return segment.tangentAtLength(((fromStart ? 1 : -1) * (length - l)), { + precision: precision, + subdivisions: subdivisions + }); + } + + lastValidSegment = segment; + } + + l += d; + } + + // if length requested is higher than the length of the path, return tangent of endpoint of last valid segment + if (lastValidSegment) { + var t = (fromStart ? 1 : 0); + return lastValidSegment.tangentAtT(t); + } + + // if no valid segment, return null + return null; + }, + + // Private function. + tangentAtT: function(t) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + var segmentIndex = t.segmentIndex; + if (segmentIndex < 0) { return segments[0].tangentAtT(0); } + if (segmentIndex >= numSegments) { return segments[numSegments - 1].tangentAtT(1); } + + var tValue = t.value; + if (tValue < 0) { tValue = 0; } + else if (tValue > 1) { tValue = 1; } + + return segments[segmentIndex].tangentAtT(tValue); + }, + + toPoints: function(opt) { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } // if segments is an empty array + + opt = opt || {}; + var precision = (opt.precision === undefined) ? this.PRECISION : opt.precision; + var segmentSubdivisions = (opt.segmentSubdivisions === undefined) ? this.getSegmentSubdivisions({ precision: precision }) : opt.segmentSubdivisions; + + var points = []; + var partialPoints = []; + for (var i = 0; i < numSegments; i++) { + var segment = segments[i]; + if (segment.isVisible) { + var currentSegmentSubdivisions = segmentSubdivisions[i]; + if (currentSegmentSubdivisions.length > 0) { + var subdivisionPoints = currentSegmentSubdivisions.map(function(curve) { + return curve.start; + }); + Array.prototype.push.apply(partialPoints, subdivisionPoints); + } else { + partialPoints.push(segment.start); + } + } else if (partialPoints.length > 0) { + partialPoints.push(segments[i - 1].end); + points.push(partialPoints); + partialPoints = []; + } + } + + if (partialPoints.length > 0) { + partialPoints.push(this.end); + points.push(partialPoints); + } + return points; + }, + + toPolylines: function(opt) { + + var polylines = []; + var points = this.toPoints(opt); + if (!points) { return null; } + for (var i = 0, n = points.length; i < n; i++) { + polylines.push(new Polyline(points[i])); + } + + return polylines; + }, + + toString: function() { + + var segments = this.segments; + var numSegments = segments.length; + + var pathData = ''; + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + pathData += segment.serialize() + ' '; + } + + return pathData.trim(); + }, + + translate: function(tx, ty) { + + var segments = this.segments; + var numSegments = segments.length; + + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + segment.translate(tx, ty); + } + + return this; + }, + + // Helper method for updating subpath start of segments, starting with the one provided. + updateSubpathStartSegment: function(segment) { + + var previousSegment = segment.previousSegment; // may be null + while (segment && !segment.isSubpathStart) { + + // assign previous segment's subpath start segment to this segment + if (previousSegment) { segment.subpathStartSegment = previousSegment.subpathStartSegment; } // may be null + else { segment.subpathStartSegment = null; } // if segment had no previous segment, assign null - creates an invalid path! + + previousSegment = segment; + segment = segment.nextSegment; // move on to the segment after etc. + } + }, + + // If the path is not valid, insert M 0 0 at the beginning. + // Path with no segments is considered valid, so nothing is inserted. + validate: function() { + + if (!this.isValid()) { this.insertSegment(0, Path.createSegment('M', 0, 0)); } + return this; + } + }; + + Object.defineProperty(Path.prototype, 'start', { + // Getter for the first visible endpoint of the path. + + configurable: true, + + enumerable: true, + + get: function() { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } + + for (var i = 0; i < numSegments; i++) { + + var segment = segments[i]; + if (segment.isVisible) { return segment.start; } + } + + // if no visible segment, return last segment end point + return segments[numSegments - 1].end; + } + }); + + Object.defineProperty(Path.prototype, 'end', { + // Getter for the last visible endpoint of the path. + + configurable: true, + + enumerable: true, + + get: function() { + + var segments = this.segments; + var numSegments = segments.length; + if (numSegments === 0) { return null; } + + for (var i = numSegments - 1; i >= 0; i--) { + + var segment = segments[i]; + if (segment.isVisible) { return segment.end; } + } + + // if no visible segment, return last segment end point + return segments[numSegments - 1].end; + } + }); + + + // Local helper function. + // Use an array of arguments to call a constructor (function called with `new`). + // Adapted from https://stackoverflow.com/a/8843181/2263595 + // It is not necessary to use this function if the arguments can be passed separately (i.e. if the number of arguments is limited). + // - If that is the case, use `new constructor(arg1, arg2)`, for example. + // It is not necessary to use this function if the function that needs an array of arguments is not supposed to be used as a constructor. + // - If that is the case, use `f.apply(thisArg, [arg1, arg2...])`, for example. + function applyToNew(constructor, argsArray) { + // The `new` keyword can only be applied to functions that take a limited number of arguments. + // - We can fake that with .bind(). + // - It calls a function (`constructor`, here) with the arguments that were provided to it - effectively transforming an unlimited number of arguments into limited. + // - So `new (constructor.bind(thisArg, arg1, arg2...))` + // - `thisArg` can be anything (e.g. null) because `new` keyword resets context to the constructor object. + // We need to pass in a variable number of arguments to the bind() call. + // - We can use .apply(). + // - So `new (constructor.bind.apply(constructor, [thisArg, arg1, arg2...]))` + // - `thisArg` can still be anything because `new` overwrites it. + // Finally, to make sure that constructor.bind overwriting is not a problem, we switch to `Function.prototype.bind`. + // - So, the final version is `new (Function.prototype.bind.apply(constructor, [thisArg, arg1, arg2...]))` + + // The function expects `argsArray[0]` to be `thisArg`. + // - This means that whatever is sent as the first element will be ignored. + // - The constructor will only see arguments starting from argsArray[1]. + // - So, a new dummy element is inserted at the start of the array. + argsArray.unshift(null); + + return new (Function.prototype.bind.apply(constructor, argsArray)); + } + + // Path segment interface: + var segmentPrototype = { + + // virtual + bbox: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + clone: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + closestPoint: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + closestPointLength: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + closestPointNormalizedLength: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // Redirect calls to closestPointNormalizedLength() function if closestPointT() is not defined for segment. + closestPointT: function(p) { + + if (this.closestPointNormalizedLength) { return this.closestPointNormalizedLength(p); } + + throw new Error('Neither closestPointT() nor closestPointNormalizedLength() function is implemented.'); + }, + + // virtual + closestPointTangent: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + divideAt: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + divideAtLength: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // Redirect calls to divideAt() function if divideAtT() is not defined for segment. + divideAtT: function(t) { + + if (this.divideAt) { return this.divideAt(t); } + + throw new Error('Neither divideAtT() nor divideAt() function is implemented.'); + }, + + // virtual + equals: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + getSubdivisions: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + isDifferentiable: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + isSegment: true, + + isSubpathStart: false, // true for Moveto segments + + isVisible: true, // false for Moveto segments + + // virtual + length: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // Return a fraction of result of length() function if lengthAtT() is not defined for segment. + lengthAtT: function(t) { + + if (t <= 0) { return 0; } + + var length = this.length(); + + if (t >= 1) { return length; } + + return length * t; + }, + + nextSegment: null, // needed for subpath start segment updating + + // virtual + pointAt: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + pointAtLength: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // Redirect calls to pointAt() function if pointAtT() is not defined for segment. + pointAtT: function(t) { + + if (this.pointAt) { return this.pointAt(t); } + + throw new Error('Neither pointAtT() nor pointAt() function is implemented.'); + }, + + previousSegment: null, // needed to get segment start property + + // virtual + round: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + subpathStartSegment: null, // needed to get Closepath segment end property + + // virtual + scale: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + serialize: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + tangentAt: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + tangentAtLength: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // Redirect calls to tangentAt() function if tangentAtT() is not defined for segment. + tangentAtT: function(t) { + + if (this.tangentAt) { return this.tangentAt(t); } + + throw new Error('Neither tangentAtT() nor tangentAt() function is implemented.'); + }, + + // virtual + toString: function() { + + throw new Error('Declaration missing for virtual function.'); + }, + + // virtual + translate: function() { + + throw new Error('Declaration missing for virtual function.'); + } + }; + + // usually directly assigned + // getter for Closepath + Object.defineProperty(segmentPrototype, 'end', { + + configurable: true, + + enumerable: true, + + writable: true + }); + + // always a getter + // always throws error for Moveto + Object.defineProperty(segmentPrototype, 'start', { + // get a reference to the end point of previous segment + + configurable: true, + + enumerable: true, + + get: function() { + + if (!this.previousSegment) { throw new Error('Missing previous segment. (This segment cannot be the first segment of a path; OR segment has not yet been added to a path.)'); } + + return this.previousSegment.end; + } + }); + + // virtual + Object.defineProperty(segmentPrototype, 'type', { + + configurable: true, + + enumerable: true, + + get: function() { + + throw new Error('Bad segment declaration. No type specified.'); + } + }); + + // Path segment implementations: + var Lineto = function() { + var arguments$1 = arguments; + + + var args = []; + var n = arguments.length; + for (var i = 0; i < n; i++) { + args.push(arguments$1[i]); + } + + if (!(this instanceof Lineto)) { // switching context of `this` to Lineto when called without `new` + return applyToNew(Lineto, args); + } + + if (n === 0) { + throw new Error('Lineto constructor expects a line, 1 point, or 2 coordinates (none provided).'); + } + + var outputArray; + + if (args[0] instanceof Line) { // lines provided + if (n === 1) { + this.end = args[0].end.clone(); + return this; + + } else { + throw new Error('Lineto constructor expects a line, 1 point, or 2 coordinates (' + n + ' lines provided).'); + } + + } else if (typeof args[0] === 'string' || typeof args[0] === 'number') { // coordinates provided + if (n === 2) { + this.end = new Point(+args[0], +args[1]); + return this; + + } else if (n < 2) { + throw new Error('Lineto constructor expects a line, 1 point, or 2 coordinates (' + n + ' coordinates provided).'); + + } else { // this is a poly-line segment + var segmentCoords; + outputArray = []; + for (i = 0; i < n; i += 2) { // coords come in groups of two + + segmentCoords = args.slice(i, i + 2); // will send one coord if args.length not divisible by 2 + outputArray.push(applyToNew(Lineto, segmentCoords)); + } + return outputArray; + } + + } else { // points provided (needs to be last to also cover plain objects with x and y) + if (n === 1) { + this.end = new Point(args[0]); + return this; + + } else { // this is a poly-line segment + var segmentPoint; + outputArray = []; + for (i = 0; i < n; i += 1) { + + segmentPoint = args[i]; + outputArray.push(new Lineto(segmentPoint)); + } + return outputArray; + } + } + }; + + var linetoPrototype = { + + clone: function() { + + return new Lineto(this.end); + }, + + divideAt: function(ratio) { + + var line = new Line(this.start, this.end); + var divided = line.divideAt(ratio); + return [ + new Lineto(divided[0]), + new Lineto(divided[1]) + ]; + }, + + divideAtLength: function(length) { + + var line = new Line(this.start, this.end); + var divided = line.divideAtLength(length); + return [ + new Lineto(divided[0]), + new Lineto(divided[1]) + ]; + }, + + getSubdivisions: function() { + + return []; + }, + + isDifferentiable: function() { + + if (!this.previousSegment) { return false; } + + return !this.start.equals(this.end); + }, + + round: function(precision) { + + this.end.round(precision); + return this; + }, + + scale: function(sx, sy, origin) { + + this.end.scale(sx, sy, origin); + return this; + }, + + serialize: function() { + + var end = this.end; + return this.type + ' ' + end.x + ' ' + end.y; + }, + + toString: function() { + + return this.type + ' ' + this.start + ' ' + this.end; + }, + + translate: function(tx, ty) { + + this.end.translate(tx, ty); + return this; + } + }; + + Object.defineProperty(linetoPrototype, 'type', { + + configurable: true, + + enumerable: true, + + value: 'L' + }); + + Lineto.prototype = extend(segmentPrototype, Line.prototype, linetoPrototype); + + var Curveto = function() { + var arguments$1 = arguments; + + + var args = []; + var n = arguments.length; + for (var i = 0; i < n; i++) { + args.push(arguments$1[i]); + } + + if (!(this instanceof Curveto)) { // switching context of `this` to Curveto when called without `new` + return applyToNew(Curveto, args); + } + + if (n === 0) { + throw new Error('Curveto constructor expects a curve, 3 points, or 6 coordinates (none provided).'); + } + + var outputArray; + + if (args[0] instanceof Curve) { // curves provided + if (n === 1) { + this.controlPoint1 = args[0].controlPoint1.clone(); + this.controlPoint2 = args[0].controlPoint2.clone(); + this.end = args[0].end.clone(); + return this; + + } else { + throw new Error('Curveto constructor expects a curve, 3 points, or 6 coordinates (' + n + ' curves provided).'); + } + + } else if (typeof args[0] === 'string' || typeof args[0] === 'number') { // coordinates provided + if (n === 6) { + this.controlPoint1 = new Point(+args[0], +args[1]); + this.controlPoint2 = new Point(+args[2], +args[3]); + this.end = new Point(+args[4], +args[5]); + return this; + + } else if (n < 6) { + throw new Error('Curveto constructor expects a curve, 3 points, or 6 coordinates (' + n + ' coordinates provided).'); + + } else { // this is a poly-bezier segment + var segmentCoords; + outputArray = []; + for (i = 0; i < n; i += 6) { // coords come in groups of six + + segmentCoords = args.slice(i, i + 6); // will send fewer than six coords if args.length not divisible by 6 + outputArray.push(applyToNew(Curveto, segmentCoords)); + } + return outputArray; + } + + } else { // points provided (needs to be last to also cover plain objects with x and y) + if (n === 3) { + this.controlPoint1 = new Point(args[0]); + this.controlPoint2 = new Point(args[1]); + this.end = new Point(args[2]); + return this; + + } else if (n < 3) { + throw new Error('Curveto constructor expects a curve, 3 points, or 6 coordinates (' + n + ' points provided).'); + + } else { // this is a poly-bezier segment + var segmentPoints; + outputArray = []; + for (i = 0; i < n; i += 3) { // points come in groups of three + + segmentPoints = args.slice(i, i + 3); // will send fewer than three points if args.length is not divisible by 3 + outputArray.push(applyToNew(Curveto, segmentPoints)); + } + return outputArray; + } + } + }; + + var curvetoPrototype = { + + clone: function() { + + return new Curveto(this.controlPoint1, this.controlPoint2, this.end); + }, + + divideAt: function(ratio, opt) { + + var curve = new Curve(this.start, this.controlPoint1, this.controlPoint2, this.end); + var divided = curve.divideAt(ratio, opt); + return [ + new Curveto(divided[0]), + new Curveto(divided[1]) + ]; + }, + + divideAtLength: function(length, opt) { + + var curve = new Curve(this.start, this.controlPoint1, this.controlPoint2, this.end); + var divided = curve.divideAtLength(length, opt); + return [ + new Curveto(divided[0]), + new Curveto(divided[1]) + ]; + }, + + divideAtT: function(t) { + + var curve = new Curve(this.start, this.controlPoint1, this.controlPoint2, this.end); + var divided = curve.divideAtT(t); + return [ + new Curveto(divided[0]), + new Curveto(divided[1]) + ]; + }, + + isDifferentiable: function() { + + if (!this.previousSegment) { return false; } + + var start = this.start; + var control1 = this.controlPoint1; + var control2 = this.controlPoint2; + var end = this.end; + + return !(start.equals(control1) && control1.equals(control2) && control2.equals(end)); + }, + + round: function(precision) { + + this.controlPoint1.round(precision); + this.controlPoint2.round(precision); + this.end.round(precision); + return this; + }, + + scale: function(sx, sy, origin) { + + this.controlPoint1.scale(sx, sy, origin); + this.controlPoint2.scale(sx, sy, origin); + this.end.scale(sx, sy, origin); + return this; + }, + + serialize: function() { + + var c1 = this.controlPoint1; + var c2 = this.controlPoint2; + var end = this.end; + return this.type + ' ' + c1.x + ' ' + c1.y + ' ' + c2.x + ' ' + c2.y + ' ' + end.x + ' ' + end.y; + }, + + toString: function() { + + return this.type + ' ' + this.start + ' ' + this.controlPoint1 + ' ' + this.controlPoint2 + ' ' + this.end; + }, + + translate: function(tx, ty) { + + this.controlPoint1.translate(tx, ty); + this.controlPoint2.translate(tx, ty); + this.end.translate(tx, ty); + return this; + } + }; + + Object.defineProperty(curvetoPrototype, 'type', { + + configurable: true, + + enumerable: true, + + value: 'C' + }); + + Curveto.prototype = extend(segmentPrototype, Curve.prototype, curvetoPrototype); + + var Moveto = function() { + var arguments$1 = arguments; + + + var args = []; + var n = arguments.length; + for (var i = 0; i < n; i++) { + args.push(arguments$1[i]); + } + + if (!(this instanceof Moveto)) { // switching context of `this` to Moveto when called without `new` + return applyToNew(Moveto, args); + } + + if (n === 0) { + throw new Error('Moveto constructor expects a line, a curve, 1 point, or 2 coordinates (none provided).'); + } + + var outputArray; + + if (args[0] instanceof Line) { // lines provided + if (n === 1) { + this.end = args[0].end.clone(); + return this; + + } else { + throw new Error('Moveto constructor expects a line, a curve, 1 point, or 2 coordinates (' + n + ' lines provided).'); + } + + } else if (args[0] instanceof Curve) { // curves provided + if (n === 1) { + this.end = args[0].end.clone(); + return this; + + } else { + throw new Error('Moveto constructor expects a line, a curve, 1 point, or 2 coordinates (' + n + ' curves provided).'); + } + + } else if (typeof args[0] === 'string' || typeof args[0] === 'number') { // coordinates provided + if (n === 2) { + this.end = new Point(+args[0], +args[1]); + return this; + + } else if (n < 2) { + throw new Error('Moveto constructor expects a line, a curve, 1 point, or 2 coordinates (' + n + ' coordinates provided).'); + + } else { // this is a moveto-with-subsequent-poly-line segment + var segmentCoords; + outputArray = []; + for (i = 0; i < n; i += 2) { // coords come in groups of two + + segmentCoords = args.slice(i, i + 2); // will send one coord if args.length not divisible by 2 + if (i === 0) { outputArray.push(applyToNew(Moveto, segmentCoords)); } + else { outputArray.push(applyToNew(Lineto, segmentCoords)); } + } + return outputArray; + } + + } else { // points provided (needs to be last to also cover plain objects with x and y) + if (n === 1) { + this.end = new Point(args[0]); + return this; + + } else { // this is a moveto-with-subsequent-poly-line segment + var segmentPoint; + outputArray = []; + for (i = 0; i < n; i += 1) { // points come one by one + + segmentPoint = args[i]; + if (i === 0) { outputArray.push(new Moveto(segmentPoint)); } + else { outputArray.push(new Lineto(segmentPoint)); } + } + return outputArray; + } + } + }; + + var movetoPrototype = { + + bbox: function() { + + return null; + }, + + clone: function() { + + return new Moveto(this.end); + }, + + closestPoint: function() { + + return this.end.clone(); + }, + + closestPointNormalizedLength: function() { + + return 0; + }, + + closestPointLength: function() { + + return 0; + }, + + closestPointT: function() { + + return 1; + }, + + closestPointTangent: function() { + + return null; + }, + + divideAt: function() { + + return [ + this.clone(), + this.clone() + ]; + }, + + divideAtLength: function() { + + return [ + this.clone(), + this.clone() + ]; + }, + + equals: function(m) { + + return this.end.equals(m.end); + }, + + getSubdivisions: function() { + + return []; + }, + + isDifferentiable: function() { + + return false; + }, + + isSubpathStart: true, + + isVisible: false, + + length: function() { + + return 0; + }, + + lengthAtT: function() { + + return 0; + }, + + pointAt: function() { + + return this.end.clone(); + }, + + pointAtLength: function() { + + return this.end.clone(); + }, + + pointAtT: function() { + + return this.end.clone(); + }, + + round: function(precision) { + + this.end.round(precision); + return this; + }, + + scale: function(sx, sy, origin) { + + this.end.scale(sx, sy, origin); + return this; + }, + + serialize: function() { + + var end = this.end; + return this.type + ' ' + end.x + ' ' + end.y; + }, + + tangentAt: function() { + + return null; + }, + + tangentAtLength: function() { + + return null; + }, + + tangentAtT: function() { + + return null; + }, + + toString: function() { + + return this.type + ' ' + this.end; + }, + + translate: function(tx, ty) { + + this.end.translate(tx, ty); + return this; + } + }; + + Object.defineProperty(movetoPrototype, 'start', { + + configurable: true, + + enumerable: true, + + get: function() { + + throw new Error('Illegal access. Moveto segments should not need a start property.'); + } + }); + + Object.defineProperty(movetoPrototype, 'type', { + + configurable: true, + + enumerable: true, + + value: 'M' + }); + + Moveto.prototype = extend(segmentPrototype, movetoPrototype); // does not inherit from any other geometry object + + var Closepath = function() { + var arguments$1 = arguments; + + + var args = []; + var n = arguments.length; + for (var i = 0; i < n; i++) { + args.push(arguments$1[i]); + } + + if (!(this instanceof Closepath)) { // switching context of `this` to Closepath when called without `new` + return applyToNew(Closepath, args); + } + + if (n > 0) { + throw new Error('Closepath constructor expects no arguments.'); + } + + return this; + }; + + var closepathPrototype = { + + clone: function() { + + return new Closepath(); + }, + + divideAt: function(ratio) { + + var line = new Line(this.start, this.end); + var divided = line.divideAt(ratio); + return [ + // if we didn't actually cut into the segment, first divided part can stay as Z + (divided[1].isDifferentiable() ? new Lineto(divided[0]) : this.clone()), + new Lineto(divided[1]) + ]; + }, + + divideAtLength: function(length) { + + var line = new Line(this.start, this.end); + var divided = line.divideAtLength(length); + return [ + // if we didn't actually cut into the segment, first divided part can stay as Z + (divided[1].isDifferentiable() ? new Lineto(divided[0]) : this.clone()), + new Lineto(divided[1]) + ]; + }, + + getSubdivisions: function() { + + return []; + }, + + isDifferentiable: function() { + + if (!this.previousSegment || !this.subpathStartSegment) { return false; } + + return !this.start.equals(this.end); + }, + + round: function() { + + return this; + }, + + scale: function() { + + return this; + }, + + serialize: function() { + + return this.type; + }, + + toString: function() { + + return this.type + ' ' + this.start + ' ' + this.end; + }, + + translate: function() { + + return this; + } + }; + + Object.defineProperty(closepathPrototype, 'end', { + // get a reference to the end point of subpath start segment + + configurable: true, + + enumerable: true, + + get: function() { + + if (!this.subpathStartSegment) { throw new Error('Missing subpath start segment. (This segment needs a subpath start segment (e.g. Moveto); OR segment has not yet been added to a path.)'); } + + return this.subpathStartSegment.end; + } + }); + + Object.defineProperty(closepathPrototype, 'type', { + + configurable: true, + + enumerable: true, + + value: 'Z' + }); + + Closepath.prototype = extend(segmentPrototype, Line.prototype, closepathPrototype); + + var segmentTypes = Path.segmentTypes = { + L: Lineto, + C: Curveto, + M: Moveto, + Z: Closepath, + z: Closepath + }; + + Path.regexSupportedData = new RegExp('^[\\s\\d' + Object.keys(segmentTypes).join('') + ',.]*$'); + + Path.isDataSupported = function(data) { + + if (typeof data !== 'string') { return false; } + return this.regexSupportedData.test(data); + }; + + var bezier = { + + // Cubic Bezier curve path through points. + // @deprecated + // @param {array} points Array of points through which the smooth line will go. + // @return {array} SVG Path commands as an array + curveThroughPoints: function(points) { + + console.warn('deprecated'); + + return new Path(Curve.throughPoints(points)).serialize(); + }, + + // Get open-ended Bezier Spline Control Points. + // @deprecated + // @param knots Input Knot Bezier spline points (At least two points!). + // @param firstControlPoints Output First Control points. Array of knots.length - 1 length. + // @param secondControlPoints Output Second Control points. Array of knots.length - 1 length. + getCurveControlPoints: function(knots) { + + console.warn('deprecated'); + + var firstControlPoints = []; + var secondControlPoints = []; + var n = knots.length - 1; + var i; + + // Special case: Bezier curve should be a straight line. + if (n == 1) { + // 3P1 = 2P0 + P3 + firstControlPoints[0] = new Point( + (2 * knots[0].x + knots[1].x) / 3, + (2 * knots[0].y + knots[1].y) / 3 + ); + + // P2 = 2P1 – P0 + secondControlPoints[0] = new Point( + 2 * firstControlPoints[0].x - knots[0].x, + 2 * firstControlPoints[0].y - knots[0].y + ); + + return [firstControlPoints, secondControlPoints]; + } + + // Calculate first Bezier control points. + // Right hand side vector. + var rhs = []; + + // Set right hand side X values. + for (i = 1; i < n - 1; i++) { + rhs[i] = 4 * knots[i].x + 2 * knots[i + 1].x; + } + + rhs[0] = knots[0].x + 2 * knots[1].x; + rhs[n - 1] = (8 * knots[n - 1].x + knots[n].x) / 2.0; + + // Get first control points X-values. + var x = this.getFirstControlPoints(rhs); + + // Set right hand side Y values. + for (i = 1; i < n - 1; ++i) { + rhs[i] = 4 * knots[i].y + 2 * knots[i + 1].y; + } + + rhs[0] = knots[0].y + 2 * knots[1].y; + rhs[n - 1] = (8 * knots[n - 1].y + knots[n].y) / 2.0; + + // Get first control points Y-values. + var y = this.getFirstControlPoints(rhs); + + // Fill output arrays. + for (i = 0; i < n; i++) { + // First control point. + firstControlPoints.push(new Point(x[i], y[i])); + + // Second control point. + if (i < n - 1) { + secondControlPoints.push(new Point( + 2 * knots [i + 1].x - x[i + 1], + 2 * knots[i + 1].y - y[i + 1] + )); + + } else { + secondControlPoints.push(new Point( + (knots[n].x + x[n - 1]) / 2, + (knots[n].y + y[n - 1]) / 2) + ); + } + } + + return [firstControlPoints, secondControlPoints]; + }, + + // Divide a Bezier curve into two at point defined by value 't' <0,1>. + // Using deCasteljau algorithm. http://math.stackexchange.com/a/317867 + // @deprecated + // @param control points (start, control start, control end, end) + // @return a function that accepts t and returns 2 curves. + getCurveDivider: function(p0, p1, p2, p3) { + + console.warn('deprecated'); + + var curve = new Curve(p0, p1, p2, p3); + + return function divideCurve(t) { + + var divided = curve.divide(t); + + return [{ + p0: divided[0].start, + p1: divided[0].controlPoint1, + p2: divided[0].controlPoint2, + p3: divided[0].end + }, { + p0: divided[1].start, + p1: divided[1].controlPoint1, + p2: divided[1].controlPoint2, + p3: divided[1].end + }]; + }; + }, + + // Solves a tridiagonal system for one of coordinates (x or y) of first Bezier control points. + // @deprecated + // @param rhs Right hand side vector. + // @return Solution vector. + getFirstControlPoints: function(rhs) { + + console.warn('deprecated'); + + var n = rhs.length; + // `x` is a solution vector. + var x = []; + var tmp = []; + var b = 2.0; + + x[0] = rhs[0] / b; + + // Decomposition and forward substitution. + for (var i = 1; i < n; i++) { + tmp[i] = 1 / b; + b = (i < n - 1 ? 4.0 : 3.5) - tmp[i]; + x[i] = (rhs[i] - x[i - 1]) / b; + } + + for (i = 1; i < n; i++) { + // Backsubstitution. + x[n - i - 1] -= tmp[n - i] * x[n - i]; + } + + return x; + }, + + // Solves an inversion problem -- Given the (x, y) coordinates of a point which lies on + // a parametric curve x = x(t)/w(t), y = y(t)/w(t), find the parameter value t + // which corresponds to that point. + // @deprecated + // @param control points (start, control start, control end, end) + // @return a function that accepts a point and returns t. + getInversionSolver: function(p0, p1, p2, p3) { + + console.warn('deprecated'); + + var curve = new Curve(p0, p1, p2, p3); + + return function solveInversion(p) { + + return curve.closestPointT(p); + }; + } + }; + + var Polygon = function(points) { + + if (!(this instanceof Polygon)) { + return new Polygon(points); + } + + if (typeof points === 'string') { + return new Polygon.parse(points); + } + + this.points = (Array.isArray(points) ? points.map(Point) : []); + }; + + Polygon.parse = function(svgString) { + return new Polygon(parsePoints(svgString)); + }; + + Polygon.fromRect = function(rect) { + return new Polygon([ + rect.topLeft(), + rect.topRight(), + rect.bottomRight(), + rect.bottomLeft() + ]); + }; + + Polygon.prototype = extend(Polyline.prototype, { + + type: types.Polygon, + + clone: function() { + return new Polygon(clonePoints(this.points)); + }, + + convexHull: function() { + return new Polygon(convexHull(this.points)); + }, + + lengthPoints: function() { + var ref = this; + var start = ref.start; + var end = ref.end; + var points = ref.points; + if (points.length <= 1 || start.equals(end)) { return points; } + return points.concat( [start.clone()]); + } + + }); + + function exists(shape1, shape2, shape1opt, shape2opt) { + switch (shape1.type) { + case types.Line: { + switch (shape2.type) { + case types.Line: { + return lineWithLine(shape1, shape2); + } + } + break; + } + case types.Ellipse: { + switch (shape2.type) { + case types.Line: { + return ellipseWithLine(shape1, shape2); + } + case types.Ellipse: { + return ellipseWithEllipse(shape1, shape2); + } + } + break; + } + case types.Rect: { + switch (shape2.type) { + case types.Line: { + return rectWithLine(shape1, shape2); + } + case types.Ellipse: { + return rectWithEllipse(shape1, shape2); + } + case types.Rect: { + return rectWithRect(shape1, shape2); + } + } + break; + } + case types.Polyline: { + switch (shape2.type) { + case types.Line: { + return polylineWithLine(shape1, shape2); + } + case types.Ellipse: { + return polylineWithEllipse(shape1, shape2); + } + case types.Rect: { + return polylineWithRect(shape1, shape2); + } + case types.Polyline: { + return polylineWithPolyline(shape1, shape2); + } + } + break; + } + case types.Polygon: { + switch (shape2.type) { + case types.Line: { + return polygonWithLine(shape1, shape2); + } + case types.Ellipse: { + return polygonWithEllipse(shape1, shape2); + } + case types.Rect: { + return polygonWithRect(shape1, shape2); + } + case types.Polyline: { + return polygonWithPolyline(shape1, shape2); + } + case types.Polygon: { + return polygonWithPolygon(shape1, shape2); + } + } + break; + } + case types.Path: { + switch (shape2.type) { + case types.Line: { + return pathWithLine(shape1, shape2, shape1opt); + } + case types.Ellipse: { + return pathWithEllipse(shape1, shape2, shape1opt); + } + case types.Rect: { + return pathWithRect(shape1, shape2, shape1opt); + } + case types.Polyline: { + return pathWithPolyline(shape1, shape2, shape1opt); + } + case types.Polygon: { + return pathWithPolygon(shape1, shape2, shape1opt); + } + case types.Path: { + return pathWithPath(shape1, shape2, shape1opt, shape2opt); + } + } + break; + } + } + // None of the cases above + switch (shape2.type) { + case types.Ellipse: + case types.Rect: + case types.Polyline: + case types.Polygon: + case types.Path: { + return exists(shape2, shape1, shape2opt, shape1opt); + } + default: { + throw Error(("The intersection for " + shape1 + " and " + shape2 + " could not be found.")); + } + } + } + + /* Line */ + + function lineWithLine(line1, line2) { + var x1 = line1.start.x; + var y1 = line1.start.y; + var x2 = line1.end.x; + var y2 = line1.end.y; + var x3 = line2.start.x; + var y3 = line2.start.y; + var x4 = line2.end.x; + var y4 = line2.end.y; + var s1x = x2 - x1; + var s1y = y2 - y1; + var s2x = x4 - x3; + var s2y = y4 - y3; + var s3x = x1 - x3; + var s3y = y1 - y3; + var p = s1x * s2y - s2x * s1y; + var s = (s1x * s3y - s1y * s3x) / p; + var t = (s2x * s3y - s2y * s3x) / p; + return s >= 0 && s <= 1 && t >= 0 && t <= 1; + } + + /* Ellipse */ + + function ellipseWithLine(ellipse, line) { + var rex = ellipse.a; + var rey = ellipse.b; + var xe = ellipse.x; + var ye = ellipse.y; + var x1 = line.start.x - xe; + var x2 = line.end.x - xe; + var y1 = line.start.y - ye; + var y2 = line.end.y - ye; + var rex_2 = rex * rex; + var rey_2 = rey * rey; + var dx = x2 - x1; + var dy = y2 - y1; + var A = dx * dx / rex_2 + dy * dy / rey_2; + var B = 2 * x1 * dx / rex_2 + 2 * y1 * dy / rey_2; + var C = x1 * x1 / rex_2 + y1 * y1 / rey_2 - 1; + var D = B * B - 4 * A * C; + if (D === 0) { + var t = -B / 2 / A; + return t >= 0 && t <= 1; + } else if (D > 0) { + var sqrt = Math.sqrt(D); + var t1 = (-B + sqrt) / 2 / A; + var t2 = (-B - sqrt) / 2 / A; + return (t1 >= 0 && t1 <= 1) || (t2 >= 0 && t2 <= 1); + } + return false; + } + + function ellipseWithEllipse(ellipse1, ellipse2) { + return _ellipsesIntersection(ellipse1, 0, ellipse2, 0); + } + + /* Rect */ + + function rectWithLine(rect, line) { + var start = line.start; + var end = line.end; + var x = rect.x; + var y = rect.y; + var width = rect.width; + var height = rect.height; + if ( + (start.x > x + width && end.x > x + width) + || (start.x < x && end.x < x) + || (start.y > y + height && end.y > y + height) + || (start.y < y && end.y < y) + ) { + return false; + } + if (rect.containsPoint(line.start) || rect.containsPoint(line.end)) { + return true; + } + return lineWithLine(rect.topLine(), line) + || lineWithLine(rect.rightLine(), line) + || lineWithLine(rect.bottomLine(), line) + || lineWithLine(rect.leftLine(), line); + } + + function rectWithEllipse(rect, ellipse) { + if (!rectWithRect(rect, Rect.fromEllipse(ellipse))) { return false; } + return polygonWithEllipse(Polygon.fromRect(rect), ellipse); + } + + function rectWithRect(rect1, rect2) { + return rect1.x < rect2.x + rect2.width + && rect1.x + rect1.width > rect2.x + && rect1.y < rect2.y + rect2.height + && rect1.y + rect1.height > rect2.y; + } + + /* Polyline */ + + function polylineWithLine(polyline, line) { + return _polylineWithLine(polyline, line, { interior: false }); + } + + function polylineWithEllipse(polyline, ellipse) { + return _polylineWithEllipse(polyline, ellipse, { interior: false }); + } + + function polylineWithRect(polyline, rect) { + return _polylineWithRect(polyline, rect, { interior: false }); + } + + function polylineWithPolyline(polyline1, polyline2) { + return _polylineWithPolyline(polyline1, polyline2, { interior: false }); + } + + /* Polygon */ + + function polygonWithLine(polygon, line) { + return _polylineWithLine(polygon, line, { interior: true }); + } + + function polygonWithEllipse(polygon, ellipse) { + return _polylineWithEllipse(polygon, ellipse, { interior: true }); + } + + function polygonWithRect(polygon, rect) { + return _polylineWithRect(polygon, rect, { interior: true }); + } + + function polygonWithPolyline(polygon, polyline) { + return _polylineWithPolyline(polygon, polyline, { interior: true }); + } + + function polygonWithPolygon(polygon1, polygon2) { + return _polylineWithPolygon(polygon1, polygon2, { interior: true }); + } + + /* Path */ + + function pathWithLine(path, line, pathOpt) { + return path.getSubpaths().some(function (subpath) { + var ref = subpath.toPolylines(pathOpt); + var polyline = ref[0]; + var ref$1 = subpath.getSegment(-1); + var type = ref$1.type; + if (type === 'Z') { + return polygonWithLine(polyline, line); + } else { + return polylineWithLine(polyline, line); + } + }); + } + + function pathWithEllipse(path, ellipse, pathOpt) { + return path.getSubpaths().some(function (subpath) { + var ref = subpath.toPolylines(pathOpt); + var polyline = ref[0]; + var ref$1 = subpath.getSegment(-1); + var type = ref$1.type; + if (type === 'Z') { + return polygonWithEllipse(polyline, ellipse); + } else { + return polylineWithEllipse(polyline, ellipse); + } + }); + } + + function pathWithRect(path, rect, pathOpt) { + return pathWithPolygon(path, Polygon.fromRect(rect), pathOpt); + } + + function pathWithPolyline(path, polyline, pathOpt) { + return _pathWithPolyline(path, polyline, pathOpt, { interior: false }); + } + + function pathWithPolygon(path, polygon, pathOpt) { + return _pathWithPolyline(path, polygon, pathOpt, { interior: true }); + } + + function pathWithPath(path1, path2, pathOpt1, pathOpt2) { + return path1.getSubpaths().some(function (subpath) { + var ref = subpath.toPolylines(pathOpt1); + var polyline1 = ref[0]; + var ref$1 = subpath.getSegment(-1); + var type = ref$1.type; + if (type === 'Z') { + return pathWithPolygon(path2, polyline1, pathOpt2); + } else { + return pathWithPolyline(path2, polyline1, pathOpt2); + } + }); + } + + function _polylineWithLine(polyline, line, opt) { + if ( opt === void 0 ) opt = {}; + + var interior = opt.interior; if ( interior === void 0 ) interior = false; + var thisPoints; + if (interior) { + if (polyline.containsPoint(line.start)) { + // If any point of the polyline lies inside this polygon (interior = true) + // there is an intersection (we've chosen the start point) + return true; + } + var start = polyline.start; + var end = polyline.end; + var points = polyline.points; + thisPoints = end.equals(start) ? points : points.concat( [start]); + } else { + thisPoints = polyline.points; + } + var length = thisPoints.length; + var segment = new Line(); + for (var i = 0; i < length - 1; i++) { + segment.start = thisPoints[i]; + segment.end = thisPoints[i + 1]; + if (lineWithLine(line, segment)) { + return true; + } + } + return false; + } + + function _polylineWithEllipse(polyline, ellipse, opt) { + if ( opt === void 0 ) opt = {}; + + var start = polyline.start; + var end = polyline.end; + var points = polyline.points; + if (ellipse.containsPoint(start)) { + return true; + } + var thisPoints; + var interior = opt.interior; if ( interior === void 0 ) interior = false; + if (interior) { + if (polyline.containsPoint(ellipse.center())) { + // If any point of the ellipse lies inside this polygon (interior = true) + // there is an intersection (we've chosen the center point) + return true; + } + thisPoints = end.equals(start) ? points : points.concat( [start]); + } else { + thisPoints = points; + } + + var length = thisPoints.length; + var segment = new Line(); + for (var i = 0; i < length - 1; i++) { + segment.start = thisPoints[i]; + segment.end = thisPoints[i + 1]; + if (ellipseWithLine(ellipse, segment)) { + return true; + } + } + return false; + } + + function _polylineWithRect(polyline, rect, opt) { + var polygon = Polygon.fromRect(rect); + return _polylineWithPolygon(polyline, polygon, opt); + } + + function _pathWithPolyline(path, polyline1, pathOpt, opt) { + return path.getSubpaths().some(function (subpath) { + var ref = subpath.toPolylines(pathOpt); + var polyline2 = ref[0]; + var ref$1 = subpath.getSegment(-1); + var type = ref$1.type; + if (type === 'Z') { + return _polylineWithPolygon(polyline1, polyline2, opt); + } else { + return _polylineWithPolyline(polyline1, polyline2, opt); + } + }); + } + + function _polylineWithPolyline(polyline1, polyline2, opt) { + if ( opt === void 0 ) opt = {}; + + var interior = opt.interior; if ( interior === void 0 ) interior = false; + var thisPolyline; + if (interior) { + var start = polyline2.start; + if (polyline1.containsPoint(start)) { + // If any point of the polyline lies inside this polygon (interior = true) + // there is an intersection (we've chosen the start point) + return true; + } + thisPolyline = polyline1.clone().close(); + } else { + thisPolyline = polyline1; + } + var otherPoints = polyline2.points; + var length = otherPoints.length; + var segment = new Line(); + for (var i = 0; i < length - 1; i++) { + segment.start = otherPoints[i]; + segment.end = otherPoints[i + 1]; + if (polylineWithLine(thisPolyline, segment)) { + return true; + } + } + return false; + } + + function _polylineWithPolygon(polyline, polygon, opt) { + return polygon.containsPoint(polyline.start) || _polylineWithPolyline(polyline, polygon.clone().close(), opt); + } + + function _ellipsesIntersection(e1, w1, e2, w2) { + var cos = Math.cos; + var sin = Math.sin; + var sinW1 = sin(w1); + var cosW1 = cos(w1); + var sinW2 = sin(w2); + var cosW2 = cos(w2); + var sinW1s = sinW1 * sinW1; + var cosW1s = cosW1 * cosW1; + var sinCos1 = sinW1 * cosW1; + var sinW2s = sinW2 * sinW2; + var cosW2s = cosW2 * cosW2; + var sinCos2 = sinW2 * cosW2; + var a1s = e1.a * e1.a; + var b1s = e1.b * e1.b; + var a2s = e2.a * e2.a; + var b2s = e2.b * e2.b; + var A1 = a1s * sinW1s + b1s * cosW1s; + var A2 = a2s * sinW2s + b2s * cosW2s; + var B1 = a1s * cosW1s + b1s * sinW1s; + var B2 = a2s * cosW2s + b2s * sinW2s; + var C1 = 2 * (b1s - a1s) * sinCos1; + var C2 = 2 * (b2s - a2s) * sinCos2; + var D1 = (-2 * A1 * e1.x - C1 * e1.y); + var D2 = (-2 * A2 * e2.x - C2 * e2.y); + var E1 = (-C1 * e1.x - 2 * B1 * e1.y); + var E2 = (-C2 * e2.x - 2 * B2 * e2.y); + var F1 = A1 * e1.x * e1.x + B1 * e1.y * e1.y + C1 * e1.x * e1.y - a1s * b1s; + var F2 = A2 * e2.x * e2.x + B2 * e2.y * e2.y + C2 * e2.x * e2.y - a2s * b2s; + + C1 = C1 / 2; + C2 = C2 / 2; + D1 = D1 / 2; + D2 = D2 / 2; + E1 = E1 / 2; + E2 = E2 / 2; + + var l3 = det3([ + [A1, C1, D1], + [C1, B1, E1], + [D1, E1, F1] + ]); + var l0 = det3([ + [A2, C2, D2], + [C2, B2, E2], + [D2, E2, F2] + ]); + var l2 = 0.33333333 * (det3([ + [A2, C1, D1], + [C2, B1, E1], + [D2, E1, F1] + ]) + det3([ + [A1, C2, D1], + [C1, B2, E1], + [D1, E2, F1] + ]) + det3([ + [A1, C1, D2], + [C1, B1, E2], + [D1, E1, F2] + ])); + var l1 = 0.33333333 * (det3([ + [A1, C2, D2], + [C1, B2, E2], + [D1, E2, F2] + ]) + det3([ + [A2, C1, D2], + [C2, B1, E2], + [D2, E1, F2] + ]) + det3([ + [A2, C2, D1], + [C2, B2, E1], + [D2, E2, F1] + ])); + + var delta1 = det2([ + [l3, l2], + [l2, l1] + ]); + var delta2 = det2([ + [l3, l1], + [l2, l0] + ]); + var delta3 = det2([ + [l2, l1], + [l1, l0] + ]); + + var dP = det2([ + [2 * delta1, delta2], + [delta2, 2 * delta3] + ]); + + if (dP > 0 && (l1 > 0 || l2 > 0)) { + return false; + } + return true; + } + + function det2(m) { + return m[0][0] * m[1][1] - m[0][1] * m[1][0]; + } + + function det3(m) { + return m[0][0] * m[1][1] * m[2][2] - + m[0][0] * m[1][2] * m[2][1] - + m[0][1] * m[1][0] * m[2][2] + + m[0][1] * m[1][2] * m[2][0] + + m[0][2] * m[1][0] * m[2][1] - + m[0][2] * m[1][1] * m[2][0]; + } + + var _intersection = ({ + exists: exists, + lineWithLine: lineWithLine, + ellipseWithLine: ellipseWithLine, + ellipseWithEllipse: ellipseWithEllipse, + rectWithLine: rectWithLine, + rectWithEllipse: rectWithEllipse, + rectWithRect: rectWithRect, + polylineWithLine: polylineWithLine, + polylineWithEllipse: polylineWithEllipse, + polylineWithRect: polylineWithRect, + polylineWithPolyline: polylineWithPolyline, + polygonWithLine: polygonWithLine, + polygonWithEllipse: polygonWithEllipse, + polygonWithRect: polygonWithRect, + polygonWithPolyline: polygonWithPolyline, + polygonWithPolygon: polygonWithPolygon, + pathWithLine: pathWithLine, + pathWithEllipse: pathWithEllipse, + pathWithRect: pathWithRect, + pathWithPolyline: pathWithPolyline, + pathWithPolygon: pathWithPolygon, + pathWithPath: pathWithPath + }); + + // Geometry library. + var intersection = _intersection; + + var g = ({ + intersection: intersection, + scale: scale, + normalizeAngle: normalizeAngle, + snapToGrid: snapToGrid, + toDeg: toDeg, + toRad: toRad, + random: random, + bezier: bezier, + Curve: Curve, + Ellipse: Ellipse, + ellipse: ellipse, + Line: Line, + line: line, + Path: Path, + Point: Point, + point: point, + Polyline: Polyline, + Polygon: Polygon, + Rect: Rect, + rect: rect, + types: types + }); + + // Vectorizer. + + var V = (function() { + + var hasSvg = typeof window === 'object' && !!window.SVGAngle; + + // SVG support is required. + if (!hasSvg) { + + // Return a function that throws an error when it is used. + return function() { + throw new Error('SVG is required to use Vectorizer.'); + }; + } + + // XML namespaces. + var ns = { + svg: 'http://www.w3.org/2000/svg', + xmlns: 'http://www.w3.org/2000/xmlns/', + xml: 'http://www.w3.org/XML/1998/namespace', + xlink: 'http://www.w3.org/1999/xlink', + xhtml: 'http://www.w3.org/1999/xhtml' + }; + + var SVGVersion = '1.1'; + + // Declare shorthands to the most used math functions. + var math = Math; + var PI = math.PI; + var atan2 = math.atan2; + var sqrt = math.sqrt; + var min = math.min; + var max = math.max; + var cos = math.cos; + var sin = math.sin; + + var V = function(el, attrs, children) { + + // This allows using V() without the new keyword. + if (!(this instanceof V)) { + return V.apply(Object.create(V.prototype), arguments); + } + + if (!el) { return; } + + if (V.isV(el)) { + el = el.node; + } + + attrs = attrs || {}; + + if (V.isString(el)) { + + el = el.trim(); + + if (el.toLowerCase() === 'svg') { + + // Create a new SVG canvas. + el = V.createSvgDocument(); + + } else if (el[0] === '<') { + + // Create element from an SVG string. + // Allows constructs of type: `document.appendChild(V('').node)`. + + var svgDoc = V.createSvgDocument(el); + + // Note that `V()` might also return an array should the SVG string passed as + // the first argument contain more than one root element. + if (svgDoc.childNodes.length > 1) { + + // Map child nodes to `V`s. + var arrayOfVels = []; + var i, len; + + for (i = 0, len = svgDoc.childNodes.length; i < len; i++) { + + var childNode = svgDoc.childNodes[i]; + arrayOfVels.push(new V(document.importNode(childNode, true))); + } + + return arrayOfVels; + } + + el = document.importNode(svgDoc.firstChild, true); + + } else { + + el = document.createElementNS(ns.svg, el); + } + + V.ensureId(el); + } + + this.node = el; + + this.setAttributes(attrs); + + if (children) { + this.append(children); + } + + return this; + }; + + var VPrototype = V.prototype; + + Object.defineProperty(VPrototype, 'id', { + enumerable: true, + get: function() { + return this.node.id; + }, + set: function(id) { + this.node.id = id; + } + }); + + /** + * @param {SVGGElement} toElem + * @returns {SVGMatrix} + */ + VPrototype.getTransformToElement = function(target) { + var node = this.node; + if (V.isSVGGraphicsElement(target) && V.isSVGGraphicsElement(node)) { + var targetCTM = V.toNode(target).getScreenCTM(); + var nodeCTM = node.getScreenCTM(); + if (targetCTM && nodeCTM) { + return targetCTM.inverse().multiply(nodeCTM); + } + } + // Could not get actual transformation matrix + return V.createSVGMatrix(); + }; + + /** + * @param {SVGMatrix} matrix + * @param {Object=} opt + * @returns {Vectorizer|SVGMatrix} Setter / Getter + */ + VPrototype.transform = function(matrix, opt) { + + var node = this.node; + if (V.isUndefined(matrix)) { + return V.transformStringToMatrix(this.attr('transform')); + } + + if (opt && opt.absolute) { + return this.attr('transform', V.matrixToTransformString(matrix)); + } + + var svgTransform = V.createSVGTransform(matrix); + node.transform.baseVal.appendItem(svgTransform); + return this; + }; + + VPrototype.translate = function(tx, ty, opt) { + + opt = opt || {}; + ty = ty || 0; + + var transformAttr = this.attr('transform') || ''; + var transform = V.parseTransformString(transformAttr); + transformAttr = transform.value; + // Is it a getter? + if (V.isUndefined(tx)) { + return transform.translate; + } + + transformAttr = transformAttr.replace(/translate\([^)]*\)/g, '').trim(); + + var newTx = opt.absolute ? tx : transform.translate.tx + tx; + var newTy = opt.absolute ? ty : transform.translate.ty + ty; + var newTranslate = 'translate(' + newTx + ',' + newTy + ')'; + + // Note that `translate()` is always the first transformation. This is + // usually the desired case. + this.attr('transform', (newTranslate + ' ' + transformAttr).trim()); + return this; + }; + + VPrototype.rotate = function(angle, cx, cy, opt) { + + opt = opt || {}; + + var transformAttr = this.attr('transform') || ''; + var transform = V.parseTransformString(transformAttr); + transformAttr = transform.value; + + // Is it a getter? + if (V.isUndefined(angle)) { + return transform.rotate; + } + + transformAttr = transformAttr.replace(/rotate\([^)]*\)/g, '').trim(); + + angle %= 360; + + var newAngle = opt.absolute ? angle : transform.rotate.angle + angle; + var newOrigin = (cx !== undefined && cy !== undefined) ? ',' + cx + ',' + cy : ''; + var newRotate = 'rotate(' + newAngle + newOrigin + ')'; + + this.attr('transform', (transformAttr + ' ' + newRotate).trim()); + return this; + }; + + // Note that `scale` as the only transformation does not combine with previous values. + VPrototype.scale = function(sx, sy) { + + sy = V.isUndefined(sy) ? sx : sy; + + var transformAttr = this.attr('transform') || ''; + var transform = V.parseTransformString(transformAttr); + transformAttr = transform.value; + + // Is it a getter? + if (V.isUndefined(sx)) { + return transform.scale; + } + + transformAttr = transformAttr.replace(/scale\([^)]*\)/g, '').trim(); + + var newScale = 'scale(' + sx + ',' + sy + ')'; + + this.attr('transform', (transformAttr + ' ' + newScale).trim()); + return this; + }; + + // Get SVGRect that contains coordinates and dimension of the real bounding box, + // i.e. after transformations are applied. + // If `target` is specified, bounding box will be computed relatively to `target` element. + VPrototype.bbox = function(withoutTransformations, target) { + + var box; + var node = this.node; + var ownerSVGElement = node.ownerSVGElement; + + // If the element is not in the live DOM, it does not have a bounding box defined and + // so fall back to 'zero' dimension element. + if (!ownerSVGElement) { + return new Rect(0, 0, 0, 0); + } + + try { + + box = node.getBBox(); + + } catch (e) { + + // Fallback for IE. + box = { + x: node.clientLeft, + y: node.clientTop, + width: node.clientWidth, + height: node.clientHeight + }; + } + + if (withoutTransformations) { + return new Rect(box); + } + + var matrix = this.getTransformToElement(target || ownerSVGElement); + + return V.transformRect(box, matrix); + }; + + // Returns an SVGRect that contains coordinates and dimensions of the real bounding box, + // i.e. after transformations are applied. + // Fixes a browser implementation bug that returns incorrect bounding boxes for groups of svg elements. + // Takes an (Object) `opt` argument (optional) with the following attributes: + // (Object) `target` (optional): if not undefined, transform bounding boxes relative to `target`; if undefined, transform relative to this + // (Boolean) `recursive` (optional): if true, recursively enter all groups and get a union of element bounding boxes (svg bbox fix); if false or undefined, return result of native function this.node.getBBox(); + VPrototype.getBBox = function(opt) { + + var options = {}; + + var outputBBox; + var node = this.node; + var ownerSVGElement = node.ownerSVGElement; + + // If the element is not in the live DOM, it does not have a bounding box defined and + // so fall back to 'zero' dimension element. + // If the element is not an SVGGraphicsElement, we could not measure the bounding box either + if (!ownerSVGElement || !V.isSVGGraphicsElement(node)) { + return new Rect(0, 0, 0, 0); + } + + if (opt) { + if (opt.target) { // check if target exists + options.target = V.toNode(opt.target); // works for V objects, jquery objects, and node objects + } + if (opt.recursive) { + options.recursive = opt.recursive; + } + } + + if (!options.recursive) { + try { + outputBBox = node.getBBox(); + } catch (e) { + // Fallback for IE. + outputBBox = { + x: node.clientLeft, + y: node.clientTop, + width: node.clientWidth, + height: node.clientHeight + }; + } + + if (!options.target) { + // transform like this (that is, not at all) + return new Rect(outputBBox); + } else { + // transform like target + var matrix = this.getTransformToElement(options.target); + return V.transformRect(outputBBox, matrix); + } + } else { // if we want to calculate the bbox recursively + // browsers report correct bbox around svg elements (one that envelops the path lines tightly) + // but some browsers fail to report the same bbox when the elements are in a group (returning a looser bbox that also includes control points, like node.getClientRect()) + // this happens even if we wrap a single svg element into a group! + // this option setting makes the function recursively enter all the groups from this and deeper, get bboxes of the elements inside, then return a union of those bboxes + + var children = this.children(); + var n = children.length; + + if (n === 0) { + return this.getBBox({ target: options.target, recursive: false }); + } + + // recursion's initial pass-through setting: + // recursive passes-through just keep the target as whatever was set up here during the initial pass-through + if (!options.target) { + // transform children/descendants like this (their parent/ancestor) + options.target = this; + } // else transform children/descendants like target + + for (var i = 0; i < n; i++) { + var currentChild = children[i]; + + var childBBox; + + // if currentChild is not a group element, get its bbox with a nonrecursive call + if (currentChild.children().length === 0) { + childBBox = currentChild.getBBox({ target: options.target, recursive: false }); + } else { + // if currentChild is a group element (determined by checking the number of children), enter it with a recursive call + childBBox = currentChild.getBBox({ target: options.target, recursive: true }); + } + + if (!outputBBox) { + // if this is the first iteration + outputBBox = childBBox; + } else { + // make a new bounding box rectangle that contains this child's bounding box and previous bounding box + outputBBox = outputBBox.union(childBBox); + } + } + + return outputBBox; + } + }; + + // Text() helpers + + function createTextPathNode(attrs, vel) { + attrs || (attrs = {}); + var textPathElement = V('textPath'); + var d = attrs.d; + if (d && attrs['xlink:href'] === undefined) { + // If `opt.attrs` is a plain string, consider it to be directly the + // SVG path data for the text to go along (this is a shortcut). + // Otherwise if it is an object and contains the `d` property, then this is our path. + // Wrap the text in the SVG element that points + // to a path defined by `opt.attrs` inside the `` element. + var linkedPath = V('path').attr('d', d).appendTo(vel.defs()); + textPathElement.attr('xlink:href', '#' + linkedPath.id); + } + if (V.isObject(attrs)) { + // Set attributes on the ``. The most important one + // is the `xlink:href` that points to our newly created `` element in ``. + // Note that we also allow the following construct: + // `t.text('my text', { textPath: { 'xlink:href': '#my-other-path' } })`. + // In other words, one can completely skip the auto-creation of the path + // and use any other arbitrary path that is in the document. + textPathElement.attr(attrs); + } + return textPathElement.node; + } + + function annotateTextLine(lineNode, lineAnnotations, opt) { + opt || (opt = {}); + var includeAnnotationIndices = opt.includeAnnotationIndices; + var eol = opt.eol; + var lineHeight = opt.lineHeight; + var baseSize = opt.baseSize; + var maxFontSize = 0; + var fontMetrics = {}; + var lastJ = lineAnnotations.length - 1; + for (var j = 0; j <= lastJ; j++) { + var annotation = lineAnnotations[j]; + var fontSize = null; + if (V.isObject(annotation)) { + var annotationAttrs = annotation.attrs; + var vTSpan = V('tspan', annotationAttrs); + var tspanNode = vTSpan.node; + var t = annotation.t; + if (eol && j === lastJ) { t += eol; } + tspanNode.textContent = t; + // Per annotation className + var annotationClass = annotationAttrs['class']; + if (annotationClass) { vTSpan.addClass(annotationClass); } + // If `opt.includeAnnotationIndices` is `true`, + // set the list of indices of all the applied annotations + // in the `annotations` attribute. This list is a comma + // separated list of indices. + if (includeAnnotationIndices) { vTSpan.attr('annotations', annotation.annotations); } + // Check for max font size + fontSize = parseFloat(annotationAttrs['font-size']); + if (!isFinite(fontSize)) { fontSize = baseSize; } + if (fontSize && fontSize > maxFontSize) { maxFontSize = fontSize; } + } else { + if (eol && j === lastJ) { annotation += eol; } + tspanNode = document.createTextNode(annotation || ' '); + if (baseSize && baseSize > maxFontSize) { maxFontSize = baseSize; } + } + lineNode.appendChild(tspanNode); + } + + if (maxFontSize) { fontMetrics.maxFontSize = maxFontSize; } + if (lineHeight) { + fontMetrics.lineHeight = lineHeight; + } else if (maxFontSize) { + fontMetrics.lineHeight = (maxFontSize * 1.2); + } + return fontMetrics; + } + + var emRegex = /em$/; + + function convertEmToPx(em, fontSize) { + var numerical = parseFloat(em); + if (emRegex.test(em)) { return numerical * fontSize; } + return numerical; + } + + function calculateDY(alignment, linesMetrics, baseSizePx, lineHeight) { + if (!Array.isArray(linesMetrics)) { return 0; } + var n = linesMetrics.length; + if (!n) { return 0; } + var lineMetrics = linesMetrics[0]; + var flMaxFont = convertEmToPx(lineMetrics.maxFontSize, baseSizePx) || baseSizePx; + var rLineHeights = 0; + var lineHeightPx = convertEmToPx(lineHeight, baseSizePx); + for (var i = 1; i < n; i++) { + lineMetrics = linesMetrics[i]; + var iLineHeight = convertEmToPx(lineMetrics.lineHeight, baseSizePx) || lineHeightPx; + rLineHeights += iLineHeight; + } + var llMaxFont = convertEmToPx(lineMetrics.maxFontSize, baseSizePx) || baseSizePx; + var dy; + switch (alignment) { + case 'middle': + dy = (flMaxFont / 2) - (0.15 * llMaxFont) - (rLineHeights / 2); + break; + case 'bottom': + dy = -(0.25 * llMaxFont) - rLineHeights; + break; + default: + case 'top': + dy = (0.8 * flMaxFont); + break; + } + return dy; + } + + VPrototype.text = function(content, opt) { + + if (content && typeof content !== 'string') { throw new Error('Vectorizer: text() expects the first argument to be a string.'); } + + // Replace all spaces with the Unicode No-break space (http://www.fileformat.info/info/unicode/char/a0/index.htm). + // IE would otherwise collapse all spaces into one. + content = V.sanitizeText(content); + opt || (opt = {}); + // Should we allow the text to be selected? + var displayEmpty = opt.displayEmpty; + // End of Line character + var eol = opt.eol; + // Text along path + var textPath = opt.textPath; + // Vertical shift + var verticalAnchor = opt.textVerticalAnchor; + var namedVerticalAnchor = (verticalAnchor === 'middle' || verticalAnchor === 'bottom' || verticalAnchor === 'top'); + // Horizontal shift applied to all the lines but the first. + var x = opt.x; + if (x === undefined) { x = this.attr('x') || 0; } + // Annotations + var iai = opt.includeAnnotationIndices; + var annotations = opt.annotations; + if (annotations && !V.isArray(annotations)) { annotations = [annotations]; } + // Shift all the but first by one line (`1em`) + var defaultLineHeight = opt.lineHeight; + var autoLineHeight = (defaultLineHeight === 'auto'); + var lineHeight = (autoLineHeight) ? '1.5em' : (defaultLineHeight || '1em'); + // Clearing the element + this.empty(); + this.attr({ + // Preserve spaces. In other words, we do not want consecutive spaces to get collapsed to one. + 'xml:space': 'preserve', + // An empty text gets rendered into the DOM in webkit-based browsers. + // In order to unify this behaviour across all browsers + // we rather hide the text element when it's empty. + 'display': (content || displayEmpty) ? null : 'none' + }); + + // Set default font-size if none + var fontSize = parseFloat(this.attr('font-size')); + if (!fontSize) { + fontSize = 16; + if (namedVerticalAnchor || annotations) { this.attr('font-size', fontSize); } + } + + var doc = document; + var containerNode; + if (textPath) { + // Now all the ``s will be inside the ``. + if (typeof textPath === 'string') { textPath = { d: textPath }; } + containerNode = createTextPathNode(textPath, this); + } else { + containerNode = doc.createDocumentFragment(); + } + var offset = 0; + var lines = content.split('\n'); + var linesMetrics = []; + var annotatedY; + for (var i = 0, lastI = lines.length - 1; i <= lastI; i++) { + var dy = lineHeight; + var lineClassName = 'v-line'; + var lineNode = doc.createElementNS(ns.svg, 'tspan'); + var line = lines[i]; + var lineMetrics; + if (line) { + if (annotations) { + // Find the *compacted* annotations for this line. + var lineAnnotations = V.annotateString(line, annotations, { + offset: -offset, + includeAnnotationIndices: iai + }); + lineMetrics = annotateTextLine(lineNode, lineAnnotations, { + includeAnnotationIndices: iai, + eol: (i !== lastI && eol), + lineHeight: (autoLineHeight) ? null : lineHeight, + baseSize: fontSize + }); + // Get the line height based on the biggest font size in the annotations for this line. + var iLineHeight = lineMetrics.lineHeight; + if (iLineHeight && autoLineHeight && i !== 0) { dy = iLineHeight; } + if (i === 0) { annotatedY = lineMetrics.maxFontSize * 0.8; } + } else { + if (eol && i !== lastI) { line += eol; } + lineNode.textContent = line; + } + } else { + // Make sure the textContent is never empty. If it is, add a dummy + // character and make it invisible, making the following lines correctly + // relatively positioned. `dy=1em` won't work with empty lines otherwise. + lineNode.textContent = '-'; + lineClassName += ' v-empty-line'; + // 'opacity' needs to be specified with fill, stroke. Opacity without specification + // is not applied in Firefox + var lineNodeStyle = lineNode.style; + lineNodeStyle.fillOpacity = 0; + lineNodeStyle.strokeOpacity = 0; + if (annotations) { + // Empty line with annotations. + lineMetrics = {}; + lineAnnotations = V.findAnnotationsAtIndex(annotations, offset); + var lineFontSize = fontSize; + // Check if any of the annotations overrides the font size. + for (var j = lineAnnotations.length; j > 0; j--) { + var attrs = lineAnnotations[j - 1].attrs; + if (!attrs || !('font-size' in attrs)) { continue; } + var fs = parseFloat(attrs['font-size']); + if (isFinite(fs)) { + lineFontSize = fs; + break; + } + } + if (autoLineHeight) { + if (i > 0) { + dy = lineFontSize * 1.2; + } else { + annotatedY = lineFontSize * 0.8; + } + } + // The font size is important for the native selection box height. + lineNode.setAttribute('font-size', lineFontSize); + lineMetrics.maxFontSize = lineFontSize; + } + } + if (lineMetrics) { linesMetrics.push(lineMetrics); } + if (i > 0) { lineNode.setAttribute('dy', dy); } + // Firefox requires 'x' to be set on the first line when inside a text path + if (i > 0 || textPath) { lineNode.setAttribute('x', x); } + lineNode.className.baseVal = lineClassName; + containerNode.appendChild(lineNode); + offset += line.length + 1; // + 1 = newline character. + } + // Y Alignment calculation + if (namedVerticalAnchor) { + if (annotations) { + dy = calculateDY(verticalAnchor, linesMetrics, fontSize, lineHeight); + } else if (verticalAnchor === 'top') { + // A shortcut for top alignment. It does not depend on font-size nor line-height + dy = '0.8em'; + } else { + var rh; // remaining height + if (lastI > 0) { + rh = parseFloat(lineHeight) || 1; + rh *= lastI; + if (!emRegex.test(lineHeight)) { rh /= fontSize; } + } else { + // Single-line text + rh = 0; + } + switch (verticalAnchor) { + case 'middle': + dy = (0.3 - (rh / 2)) + 'em'; + break; + case 'bottom': + dy = (-rh - 0.3) + 'em'; + break; + } + } + } else { + if (verticalAnchor === 0) { + dy = '0em'; + } else if (verticalAnchor) { + dy = verticalAnchor; + } else { + // No vertical anchor is defined + dy = 0; + // Backwards compatibility - we change the `y` attribute instead of `dy`. + if (this.attr('y') === null) { this.attr('y', annotatedY || '0.8em'); } + } + } + containerNode.firstChild.setAttribute('dy', dy); + // Appending lines to the element. + this.append(containerNode); + return this; + }; + + /** + * @public + * @param {string} name + * @returns {Vectorizer} + */ + VPrototype.removeAttr = function(name) { + + var qualifiedName = V.qualifyAttr(name); + var el = this.node; + + if (qualifiedName.ns) { + if (el.hasAttributeNS(qualifiedName.ns, qualifiedName.local)) { + el.removeAttributeNS(qualifiedName.ns, qualifiedName.local); + } + } else if (el.hasAttribute(name)) { + el.removeAttribute(name); + } + return this; + }; + + VPrototype.attr = function(name, value) { + + if (V.isUndefined(name)) { + + // Return all attributes. + var attributes = this.node.attributes; + var attrs = {}; + + for (var i = 0; i < attributes.length; i++) { + attrs[attributes[i].name] = attributes[i].value; + } + + return attrs; + } + + if (V.isString(name) && V.isUndefined(value)) { + return this.node.getAttribute(name); + } + + if (typeof name === 'object') { + + for (var attrName in name) { + if (name.hasOwnProperty(attrName)) { + this.setAttribute(attrName, name[attrName]); + } + } + + } else { + + this.setAttribute(name, value); + } + + return this; + }; + + VPrototype.normalizePath = function() { + + var tagName = this.tagName(); + if (tagName === 'PATH') { + this.attr('d', V.normalizePathData(this.attr('d'))); + } + + return this; + }; + + VPrototype.remove = function() { + + if (this.node.parentNode) { + this.node.parentNode.removeChild(this.node); + } + + return this; + }; + + VPrototype.empty = function() { + + while (this.node.firstChild) { + this.node.removeChild(this.node.firstChild); + } + + return this; + }; + + /** + * @private + * @param {object} attrs + * @returns {Vectorizer} + */ + VPrototype.setAttributes = function(attrs) { + + for (var key in attrs) { + if (attrs.hasOwnProperty(key)) { + this.setAttribute(key, attrs[key]); + } + } + + return this; + }; + + VPrototype.append = function(els) { + + if (!V.isArray(els)) { + els = [els]; + } + + for (var i = 0, len = els.length; i < len; i++) { + this.node.appendChild(V.toNode(els[i])); // lgtm [js/xss-through-dom] + } + + return this; + }; + + VPrototype.prepend = function(els) { + + var child = this.node.firstChild; + return child ? V(child).before(els) : this.append(els); + }; + + VPrototype.before = function(els) { + + var node = this.node; + var parent = node.parentNode; + + if (parent) { + + if (!V.isArray(els)) { + els = [els]; + } + + for (var i = 0, len = els.length; i < len; i++) { + parent.insertBefore(V.toNode(els[i]), node); + } + } + + return this; + }; + + VPrototype.appendTo = function(node) { + V.toNode(node).appendChild(this.node); // lgtm [js/xss-through-dom] + return this; + }; + + VPrototype.svg = function() { + + return this.node instanceof window.SVGSVGElement ? this : V(this.node.ownerSVGElement); + }; + + VPrototype.tagName = function() { + + return this.node.tagName.toUpperCase(); + }; + + VPrototype.defs = function() { + var context = this.svg() || this; + var defsNode = context.node.getElementsByTagName('defs')[0]; + if (defsNode) { return V(defsNode); } + return V('defs').appendTo(context); + }; + + VPrototype.clone = function() { + + var clone = V(this.node.cloneNode(true/* deep */)); + // Note that clone inherits also ID. Therefore, we need to change it here. + clone.node.id = V.uniqueId(); + return clone; + }; + + VPrototype.findOne = function(selector) { + + var found = this.node.querySelector(selector); + return found ? V(found) : undefined; + }; + + VPrototype.find = function(selector) { + + var vels = []; + var nodes = this.node.querySelectorAll(selector); + + if (nodes) { + + // Map DOM elements to `V`s. + for (var i = 0; i < nodes.length; i++) { + vels.push(V(nodes[i])); + } + } + + return vels; + }; + + // Returns an array of V elements made from children of this.node. + VPrototype.children = function() { + + var children = this.node.childNodes; + + var outputArray = []; + for (var i = 0; i < children.length; i++) { + var currentChild = children[i]; + if (currentChild.nodeType === 1) { + outputArray.push(V(children[i])); + } + } + return outputArray; + }; + + // Returns the V element from parentNode of this.node. + VPrototype.parent = function() { + return V(this.node.parentNode) || null; + }, + + // Find an index of an element inside its container. + VPrototype.index = function() { + + var index = 0; + var node = this.node.previousSibling; + + while (node) { + // nodeType 1 for ELEMENT_NODE + if (node.nodeType === 1) { index++; } + node = node.previousSibling; + } + + return index; + }; + + VPrototype.findParentByClass = function(className, terminator) { + + var ownerSVGElement = this.node.ownerSVGElement; + var node = this.node.parentNode; + + while (node && node !== terminator && node !== ownerSVGElement) { + + var vel = V(node); + if (vel.hasClass(className)) { + return vel; + } + + node = node.parentNode; + } + + return null; + }; + + // https://jsperf.com/get-common-parent + VPrototype.contains = function(el) { + + var a = this.node; + var b = V.toNode(el); + var bup = b && b.parentNode; + + return (a === bup) || !!(bup && bup.nodeType === 1 && (a.compareDocumentPosition(bup) & 16)); + }; + + // Convert global point into the coordinate space of this element. + VPrototype.toLocalPoint = function(x, y) { + + var svg = this.svg().node; + + var p = svg.createSVGPoint(); + p.x = x; + p.y = y; + + try { + + var globalPoint = p.matrixTransform(svg.getScreenCTM().inverse()); + var globalToLocalMatrix = this.getTransformToElement(svg).inverse(); + + } catch (e) { + // IE9 throws an exception in odd cases. (`Unexpected call to method or property access`) + // We have to make do with the original coordianates. + return p; + } + + return globalPoint.matrixTransform(globalToLocalMatrix); + }; + + VPrototype.translateCenterToPoint = function(p) { + + var bbox = this.getBBox({ target: this.svg() }); + var center = bbox.center(); + + this.translate(p.x - center.x, p.y - center.y); + return this; + }; + + // Efficiently auto-orient an element. This basically implements the orient=auto attribute + // of markers. The easiest way of understanding on what this does is to imagine the element is an + // arrowhead. Calling this method on the arrowhead makes it point to the `position` point while + // being auto-oriented (properly rotated) towards the `reference` point. + // `target` is the element relative to which the transformations are applied. Usually a viewport. + VPrototype.translateAndAutoOrient = function(position, reference, target) { + + position = new Point(position); + reference = new Point(reference); + target || (target = this.svg()); + + // Clean-up previously set transformations except the scale. If we didn't clean up the + // previous transformations then they'd add up with the old ones. Scale is an exception as + // it doesn't add up, consider: `this.scale(2).scale(2).scale(2)`. The result is that the + // element is scaled by the factor 2, not 8. + var scale = this.scale(); + this.attr('transform', ''); + var bbox = this.getBBox({ target: target }).scale(scale.sx, scale.sy); + + // 1. Translate to origin. + var translateToOrigin = V.createSVGTransform(); + translateToOrigin.setTranslate(-bbox.x - bbox.width / 2, -bbox.y - bbox.height / 2); + + // 2. Rotate around origin. + var rotateAroundOrigin = V.createSVGTransform(); + var angle = position.angleBetween(reference, position.clone().offset(1, 0)); + if (angle) { rotateAroundOrigin.setRotate(angle, 0, 0); } + + // 3. Translate to the `position` + the offset (half my width) towards the `reference` point. + var translateFromOrigin = V.createSVGTransform(); + var finalPosition = position.clone().move(reference, bbox.width / 2); + translateFromOrigin.setTranslate(2 * position.x - finalPosition.x, 2 * position.y - finalPosition.y); + + // 4. Get the current transformation matrix of this node + var ctm = this.getTransformToElement(target); + + // 5. Apply transformations and the scale + var transform = V.createSVGTransform(); + transform.setMatrix( + translateFromOrigin.matrix.multiply( + rotateAroundOrigin.matrix.multiply( + translateToOrigin.matrix.multiply( + ctm.scale(scale.sx, scale.sy))))); + + this.attr('transform', V.matrixToTransformString(transform.matrix)); + + return this; + }; + + VPrototype.animateAlongPath = function(attrs, path) { + + path = V.toNode(path); + + var id = V.ensureId(path); + var animateMotion = V('animateMotion', attrs); + var mpath = V('mpath', { 'xlink:href': '#' + id }); + + animateMotion.append(mpath); + + this.append(animateMotion); + try { + animateMotion.node.beginElement(); + } catch (e) { + // Fallback for IE 9. + // Run the animation programmatically if FakeSmile (`http://leunen.me/fakesmile/`) present + if (document.documentElement.getAttribute('smiling') === 'fake') { + /* global getTargets:true, Animator:true, animators:true id2anim:true */ + // Register the animation. (See `https://answers.launchpad.net/smil/+question/203333`) + var animation = animateMotion.node; + animation.animators = []; + + var animationID = animation.getAttribute('id'); + if (animationID) { id2anim[animationID] = animation; } + + var targets = getTargets(animation); + for (var i = 0, len = targets.length; i < len; i++) { + var target = targets[i]; + var animator = new Animator(animation, target, i); + animators.push(animator); + animation.animators[i] = animator; + animator.register(); + } + } + } + return this; + }; + + + // Split a string into an array of tokens. + // https://infra.spec.whatwg.org/#ascii-whitespace + var noHTMLWhitespaceRegex = /[^\x20\t\r\n\f]+/g; + function getTokenList(str) { + if (!V.isString(str)) { return []; } + return str.trim().match(noHTMLWhitespaceRegex) || []; + } + + VPrototype.hasClass = function(className) { + if (!V.isString(className)) { return false; } + return this.node.classList.contains(className.trim()); + }; + + VPrototype.addClass = function(className) { + var ref; + + (ref = this.node.classList).add.apply(ref, getTokenList(className)); + return this; + }; + + VPrototype.removeClass = function(className) { + var ref; + + (ref = this.node.classList).remove.apply(ref, getTokenList(className)); + return this; + }; + + VPrototype.toggleClass = function(className, toAdd) { + var tokens = getTokenList(className); + for (var i = 0; i < tokens.length; i++) { + this.node.classList.toggle(tokens[i], toAdd); + } + return this; + }; + + // Interpolate path by discrete points. The precision of the sampling + // is controlled by `interval`. In other words, `sample()` will generate + // a point on the path starting at the beginning of the path going to the end + // every `interval` pixels. + // The sampler can be very useful for e.g. finding intersection between two + // paths (finding the two closest points from two samples). + VPrototype.sample = function(interval) { + + interval = interval || 1; + var node = this.node; + var length = node.getTotalLength(); + var samples = []; + var distance = 0; + var sample; + while (distance < length) { + sample = node.getPointAtLength(distance); + samples.push({ x: sample.x, y: sample.y, distance: distance }); + distance += interval; + } + return samples; + }; + + VPrototype.convertToPath = function() { + + var path = V('path'); + path.attr(this.attr()); + var d = this.convertToPathData(); + if (d) { + path.attr('d', d); + } + return path; + }; + + VPrototype.convertToPathData = function() { + + var tagName = this.tagName(); + + switch (tagName) { + case 'PATH': + return this.attr('d'); + case 'LINE': + return V.convertLineToPathData(this.node); + case 'POLYGON': + return V.convertPolygonToPathData(this.node); + case 'POLYLINE': + return V.convertPolylineToPathData(this.node); + case 'ELLIPSE': + return V.convertEllipseToPathData(this.node); + case 'CIRCLE': + return V.convertCircleToPathData(this.node); + case 'RECT': + return V.convertRectToPathData(this.node); + } + + throw new Error(tagName + ' cannot be converted to PATH.'); + }; + + V.prototype.toGeometryShape = function() { + var x, y, width, height, cx, cy, r, rx, ry, points, d, x1, x2, y1, y2; + switch (this.tagName()) { + + case 'RECT': + x = parseFloat(this.attr('x')) || 0; + y = parseFloat(this.attr('y')) || 0; + width = parseFloat(this.attr('width')) || 0; + height = parseFloat(this.attr('height')) || 0; + return new Rect(x, y, width, height); + + case 'CIRCLE': + cx = parseFloat(this.attr('cx')) || 0; + cy = parseFloat(this.attr('cy')) || 0; + r = parseFloat(this.attr('r')) || 0; + return new Ellipse({ x: cx, y: cy }, r, r); + + case 'ELLIPSE': + cx = parseFloat(this.attr('cx')) || 0; + cy = parseFloat(this.attr('cy')) || 0; + rx = parseFloat(this.attr('rx')) || 0; + ry = parseFloat(this.attr('ry')) || 0; + return new Ellipse({ x: cx, y: cy }, rx, ry); + + case 'POLYLINE': + points = V.getPointsFromSvgNode(this); + return new Polyline(points); + + case 'POLYGON': + points = V.getPointsFromSvgNode(this); + if (points.length > 1) { points.push(points[0]); } + return new Polyline(points); + + case 'PATH': + d = this.attr('d'); + if (!Path.isDataSupported(d)) { d = V.normalizePathData(d); } + return new Path(d); + + case 'LINE': + x1 = parseFloat(this.attr('x1')) || 0; + y1 = parseFloat(this.attr('y1')) || 0; + x2 = parseFloat(this.attr('x2')) || 0; + y2 = parseFloat(this.attr('y2')) || 0; + return new Line({ x: x1, y: y1 }, { x: x2, y: y2 }); + } + + // Anything else is a rectangle + return this.getBBox(); + }; + + // Find the intersection of a line starting in the center + // of the SVG `node` ending in the point `ref`. + // `target` is an SVG element to which `node`s transformations are relative to. + // Note that `ref` point must be in the coordinate system of the `target` for this function to work properly. + // Returns a point in the `target` coordinate system (the same system as `ref` is in) if + // an intersection is found. Returns `undefined` otherwise. + VPrototype.findIntersection = function(ref, target) { + + var svg = this.svg().node; + target = target || svg; + var bbox = this.getBBox({ target: target }); + var center = bbox.center(); + + if (!bbox.intersectionWithLineFromCenterToPoint(ref)) { return undefined; } + + var spot; + var tagName = this.tagName(); + + // Little speed up optimization for `` element. We do not do conversion + // to path element and sampling but directly calculate the intersection through + // a transformed geometrical rectangle. + if (tagName === 'RECT') { + + var gRect = new Rect( + parseFloat(this.attr('x') || 0), + parseFloat(this.attr('y') || 0), + parseFloat(this.attr('width')), + parseFloat(this.attr('height')) + ); + // Get the rect transformation matrix with regards to the SVG document. + var rectMatrix = this.getTransformToElement(target); + // Decompose the matrix to find the rotation angle. + var rectMatrixComponents = V.decomposeMatrix(rectMatrix); + // Now we want to rotate the rectangle back so that we + // can use `intersectionWithLineFromCenterToPoint()` passing the angle as the second argument. + var resetRotation = svg.createSVGTransform(); + resetRotation.setRotate(-rectMatrixComponents.rotation, center.x, center.y); + var rect = V.transformRect(gRect, resetRotation.matrix.multiply(rectMatrix)); + spot = (new Rect(rect)).intersectionWithLineFromCenterToPoint(ref, rectMatrixComponents.rotation); + + } else if (tagName === 'PATH' || tagName === 'POLYGON' || tagName === 'POLYLINE' || tagName === 'CIRCLE' || tagName === 'ELLIPSE') { + + var pathNode = (tagName === 'PATH') ? this : this.convertToPath(); + var samples = pathNode.sample(); + var minDistance = Infinity; + var closestSamples = []; + + var i, sample, gp, centerDistance, refDistance, distance; + + for (i = 0; i < samples.length; i++) { + + sample = samples[i]; + // Convert the sample point in the local coordinate system to the global coordinate system. + gp = V.createSVGPoint(sample.x, sample.y); + gp = gp.matrixTransform(this.getTransformToElement(target)); + sample = new Point(gp); + centerDistance = sample.distance(center); + // Penalize a higher distance to the reference point by 10%. + // This gives better results. This is due to + // inaccuracies introduced by rounding errors and getPointAtLength() returns. + refDistance = sample.distance(ref) * 1.1; + distance = centerDistance + refDistance; + + if (distance < minDistance) { + minDistance = distance; + closestSamples = [{ sample: sample, refDistance: refDistance }]; + } else if (distance < minDistance + 1) { + closestSamples.push({ sample: sample, refDistance: refDistance }); + } + } + + closestSamples.sort(function(a, b) { + return a.refDistance - b.refDistance; + }); + + if (closestSamples[0]) { + spot = closestSamples[0].sample; + } + } + + return spot; + }; + + /** + * @private + * @param {string} name + * @param {string} value + * @returns {Vectorizer} + */ + VPrototype.setAttribute = function(name, value) { + + var el = this.node; + + if (value === null) { + this.removeAttr(name); + return this; + } + + var qualifiedName = V.qualifyAttr(name); + + if (qualifiedName.ns) { + // Attribute names can be namespaced. E.g. `image` elements + // have a `xlink:href` attribute to set the source of the image. + el.setAttributeNS(qualifiedName.ns, name, value); + } else if (name === 'id') { + el.id = value; + } else { + el.setAttribute(name, value); + } + + return this; + }; + + // Create an SVG document element. + // If `content` is passed, it will be used as the SVG content of the `` root element. + V.createSvgDocument = function(content) { + + if (content) { + var XMLString = "" + content + ""; + var ref = V.parseXML(XMLString, { async: false }); + var documentElement = ref.documentElement; + return documentElement; + } + + var svg = document.createElementNS(ns.svg, 'svg'); + svg.setAttributeNS(ns.xmlns, 'xmlns:xlink', ns.xlink); + svg.setAttribute('version', SVGVersion); + return svg; + }; + + V.createSVGStyle = function(stylesheet) { + var ref = V('style', { type: 'text/css' }, [ + V.createCDATASection(stylesheet) + ]); + var node = ref.node; + return node; + }, + + V.createCDATASection = function(data) { + if ( data === void 0 ) data = ''; + + var xml = document.implementation.createDocument(null, 'xml', null); + return xml.createCDATASection(data); + }; + + V.idCounter = 0; + + // A function returning a unique identifier for this client session with every call. + V.uniqueId = function() { + + return 'v-' + (++V.idCounter); + }; + + V.toNode = function(el) { + + return V.isV(el) ? el.node : (el.nodeName && el || el[0]); + }; + + V.ensureId = function(node) { + + node = V.toNode(node); + return node.id || (node.id = V.uniqueId()); + }; + + // Replace all spaces with the Unicode No-break space (http://www.fileformat.info/info/unicode/char/a0/index.htm). + // IE would otherwise collapse all spaces into one. This is used in the text() method but it is + // also exposed so that the programmer can use it in case he needs to. This is useful e.g. in tests + // when you want to compare the actual DOM text content without having to add the unicode character in + // the place of all spaces. + V.sanitizeText = function(text) { + + return (text || '').replace(/ /g, '\u00A0'); + }; + + V.isUndefined = function(value) { + + return typeof value === 'undefined'; + }; + + V.isString = function(value) { + + return typeof value === 'string'; + }; + + V.isObject = function(value) { + + return value && (typeof value === 'object'); + }; + + V.isArray = Array.isArray; + + V.parseXML = function(data, opt) { + + opt = opt || {}; + + var xml; + + try { + var parser = new DOMParser(); + + if (!V.isUndefined(opt.async)) { + parser.async = opt.async; + } + + xml = parser.parseFromString(data, 'text/xml'); + } catch (error) { + xml = undefined; + } + + if (!xml || xml.getElementsByTagName('parsererror').length) { + throw new Error('Invalid XML: ' + data); + } + + return xml; + }; + + /** + * @param {string} name + * @returns {{ns: string|null, local: string}} namespace and attribute name + */ + V.qualifyAttr = function(name) { + + if (name.indexOf(':') !== -1) { + var combinedKey = name.split(':'); + return { + ns: ns[combinedKey[0]], + local: combinedKey[1] + }; + } + + return { + ns: null, + local: name + }; + }; + + // Note: This regex allows multiple commas as separator which is incorrect in SVG + // This regex is used by `split()`, so it doesn't need to use /g + V.transformSeparatorRegex = /[ ,]+/; + // Note: All following regexes are more restrictive than SVG specification + // ReDoS mitigation: Use an anchor at the beginning of the match + // ReDoS mitigation: Avoid backtracking (uses `[^()]+` instead of `.*?`) + // ReDoS mitigation: Don't match initial `(` inside repeated part + // The following regex needs to use /g (= cannot use capturing groups) + V.transformRegex = /\b\w+\([^()]+\)/g; + // The following regexes need to use capturing groups (= cannot use /g) + V.transformFunctionRegex = /\b(\w+)\(([^()]+)\)/; + V.transformTranslateRegex = /\btranslate\(([^()]+)\)/; + V.transformRotateRegex = /\brotate\(([^()]+)\)/; + V.transformScaleRegex = /\bscale\(([^()]+)\)/; + + V.transformStringToMatrix = function(transform) { + + // Initialize result matrix as identity matrix + var transformationMatrix = V.createSVGMatrix(); + + // Note: Multiple transform functions are allowed in `transform` string + // `match()` returns `null` if none found + var transformMatches = transform && transform.match(V.transformRegex); + if (!transformMatches) { + // Return identity matrix + return transformationMatrix; + } + + var numMatches = transformMatches.length; + for (var i = 0; i < numMatches; i++) { + + var transformMatch = transformMatches[i]; + // Use same regex as above, but with capturing groups + // `match()` returns values of capturing groups as `[1]`, `[2]` + var transformFunctionMatch = transformMatch.match(V.transformFunctionRegex); + if (transformFunctionMatch) { + + var sx = (void 0), sy = (void 0), tx = (void 0), ty = (void 0), angle = (void 0); + var ctm = V.createSVGMatrix(); + var transformFunction = transformFunctionMatch[1].toLowerCase(); + var args = transformFunctionMatch[2].split(V.transformSeparatorRegex); + switch (transformFunction) { + + case 'scale': + sx = parseFloat(args[0]); + sy = (args[1] === undefined) ? sx : parseFloat(args[1]); + ctm = ctm.scaleNonUniform(sx, sy); + break; + + case 'translate': + tx = parseFloat(args[0]); + ty = parseFloat(args[1]); + ctm = ctm.translate(tx, ty); + break; + + case 'rotate': + angle = parseFloat(args[0]); + tx = parseFloat(args[1]) || 0; + ty = parseFloat(args[2]) || 0; + if (tx !== 0 || ty !== 0) { + ctm = ctm.translate(tx, ty).rotate(angle).translate(-tx, -ty); + } else { + ctm = ctm.rotate(angle); + } + break; + + case 'skewx': + angle = parseFloat(args[0]); + ctm = ctm.skewX(angle); + break; + + case 'skewy': + angle = parseFloat(args[0]); + ctm = ctm.skewY(angle); + break; + + case 'matrix': + ctm.a = parseFloat(args[0]); + ctm.b = parseFloat(args[1]); + ctm.c = parseFloat(args[2]); + ctm.d = parseFloat(args[3]); + ctm.e = parseFloat(args[4]); + ctm.f = parseFloat(args[5]); + break; + + default: + continue; + } + + // Multiply current transformation into result matrix + transformationMatrix = transformationMatrix.multiply(ctm); + } + + } + return transformationMatrix; + }; + + V.matrixToTransformString = function(matrix) { + matrix || (matrix = true); + + return 'matrix(' + + (matrix.a !== undefined ? matrix.a : 1) + ',' + + (matrix.b !== undefined ? matrix.b : 0) + ',' + + (matrix.c !== undefined ? matrix.c : 0) + ',' + + (matrix.d !== undefined ? matrix.d : 1) + ',' + + (matrix.e !== undefined ? matrix.e : 0) + ',' + + (matrix.f !== undefined ? matrix.f : 0) + + ')'; + }; + + V.parseTransformString = function(transform) { + + var translate, rotate, scale; + + if (transform) { + + var separator = V.transformSeparatorRegex; + + // Special handling for `transform` with one or more matrix functions + if (transform.trim().indexOf('matrix') >= 0) { + + // Convert EVERYTHING in `transform` string to a matrix + // Will combine ALL matrixes * ALL translates * ALL scales * ALL rotates + // Note: In non-matrix case, we only take first one of each (if any) + var matrix = V.transformStringToMatrix(transform); + var decomposedMatrix = V.decomposeMatrix(matrix); + + // Extract `translate`, `scale`, `rotate` from matrix + translate = [decomposedMatrix.translateX, decomposedMatrix.translateY]; + scale = [decomposedMatrix.scaleX, decomposedMatrix.scaleY]; + rotate = [decomposedMatrix.rotation]; + + // Rewrite `transform` string in `translate scale rotate` format + var transformations = []; + if (translate[0] !== 0 || translate[1] !== 0) { + transformations.push('translate(' + translate + ')'); + } + if (scale[0] !== 1 || scale[1] !== 1) { + transformations.push('scale(' + scale + ')'); + } + if (rotate[0] !== 0) { + transformations.push('rotate(' + rotate + ')'); + } + transform = transformations.join(' '); + + } else { + + // Extract `translate`, `rotate`, `scale` functions from `transform` string + // Note: We only detect the first match of each (if any) + // `match()` returns value of capturing group as `[1]` + var translateMatch = transform.match(V.transformTranslateRegex); + if (translateMatch) { + translate = translateMatch[1].split(separator); + } + var rotateMatch = transform.match(V.transformRotateRegex); + if (rotateMatch) { + rotate = rotateMatch[1].split(separator); + } + var scaleMatch = transform.match(V.transformScaleRegex); + if (scaleMatch) { + scale = scaleMatch[1].split(separator); + } + } + } + + var sx = (scale && scale[0]) ? parseFloat(scale[0]) : 1; + + return { + value: transform, + translate: { + tx: (translate && translate[0]) ? parseInt(translate[0], 10) : 0, + ty: (translate && translate[1]) ? parseInt(translate[1], 10) : 0 + }, + rotate: { + angle: (rotate && rotate[0]) ? parseInt(rotate[0], 10) : 0, + cx: (rotate && rotate[1]) ? parseInt(rotate[1], 10) : undefined, + cy: (rotate && rotate[2]) ? parseInt(rotate[2], 10) : undefined + }, + scale: { + sx: sx, + sy: (scale && scale[1]) ? parseFloat(scale[1]) : sx + } + }; + }; + + V.deltaTransformPoint = function(matrix, point) { + + var dx = point.x * matrix.a + point.y * matrix.c + 0; + var dy = point.x * matrix.b + point.y * matrix.d + 0; + return { x: dx, y: dy }; + }; + + V.decomposeMatrix = function(matrix) { + + // @see https://gist.github.com/2052247 + + // calculate delta transform point + var px = V.deltaTransformPoint(matrix, { x: 0, y: 1 }); + var py = V.deltaTransformPoint(matrix, { x: 1, y: 0 }); + + // calculate skew + var skewX = ((180 / PI) * atan2(px.y, px.x) - 90); + var skewY = ((180 / PI) * atan2(py.y, py.x)); + + return { + + translateX: matrix.e, + translateY: matrix.f, + scaleX: sqrt(matrix.a * matrix.a + matrix.b * matrix.b), + scaleY: sqrt(matrix.c * matrix.c + matrix.d * matrix.d), + skewX: skewX, + skewY: skewY, + rotation: skewX // rotation is the same as skew x + }; + }; + + // Return the `scale` transformation from the following equation: + // `translate(tx, ty) . rotate(angle) . scale(sx, sy) === matrix(a,b,c,d,e,f)` + V.matrixToScale = function(matrix) { + + var a, b, c, d; + if (matrix) { + a = V.isUndefined(matrix.a) ? 1 : matrix.a; + d = V.isUndefined(matrix.d) ? 1 : matrix.d; + b = matrix.b; + c = matrix.c; + } else { + a = d = 1; + } + return { + sx: b ? sqrt(a * a + b * b) : a, + sy: c ? sqrt(c * c + d * d) : d + }; + }; + + // Return the `rotate` transformation from the following equation: + // `translate(tx, ty) . rotate(angle) . scale(sx, sy) === matrix(a,b,c,d,e,f)` + V.matrixToRotate = function(matrix) { + + var p = { x: 0, y: 1 }; + if (matrix) { + p = V.deltaTransformPoint(matrix, p); + } + + return { + angle: normalizeAngle(toDeg(atan2(p.y, p.x)) - 90) + }; + }; + + // Return the `translate` transformation from the following equation: + // `translate(tx, ty) . rotate(angle) . scale(sx, sy) === matrix(a,b,c,d,e,f)` + V.matrixToTranslate = function(matrix) { + + return { + tx: (matrix && matrix.e) || 0, + ty: (matrix && matrix.f) || 0 + }; + }; + + V.isV = function(object) { + + return object instanceof V; + }; + + // For backwards compatibility: + V.isVElement = V.isV; + + // Element implements `getBBox()`, `getCTM()` and `getScreenCTM()` + // https://developer.mozilla.org/en-US/docs/Web/API/SVGGraphicsElement + V.isSVGGraphicsElement = function(node) { + if (!node) { return false; } + node = V.toNode(node); + // IE/Edge does not implement SVGGraphicsElement interface, thus check for `getScreenCTM` below + return node instanceof SVGElement && typeof node.getScreenCTM === 'function'; + }; + + var svgDocument = V('svg').node; + + V.createSVGMatrix = function(matrix) { + + var svgMatrix = svgDocument.createSVGMatrix(); + for (var component in matrix) { + svgMatrix[component] = matrix[component]; + } + + return svgMatrix; + }; + + V.createSVGTransform = function(matrix) { + + if (!V.isUndefined(matrix)) { + + if (!(matrix instanceof SVGMatrix)) { + matrix = V.createSVGMatrix(matrix); + } + + return svgDocument.createSVGTransformFromMatrix(matrix); + } + + return svgDocument.createSVGTransform(); + }; + + V.createSVGPoint = function(x, y) { + + var p = svgDocument.createSVGPoint(); + p.x = x; + p.y = y; + return p; + }; + + V.transformRect = function(r, matrix) { + + var p = svgDocument.createSVGPoint(); + + p.x = r.x; + p.y = r.y; + var corner1 = p.matrixTransform(matrix); + + p.x = r.x + r.width; + p.y = r.y; + var corner2 = p.matrixTransform(matrix); + + p.x = r.x + r.width; + p.y = r.y + r.height; + var corner3 = p.matrixTransform(matrix); + + p.x = r.x; + p.y = r.y + r.height; + var corner4 = p.matrixTransform(matrix); + + var minX = min(corner1.x, corner2.x, corner3.x, corner4.x); + var maxX = max(corner1.x, corner2.x, corner3.x, corner4.x); + var minY = min(corner1.y, corner2.y, corner3.y, corner4.y); + var maxY = max(corner1.y, corner2.y, corner3.y, corner4.y); + + return new Rect(minX, minY, maxX - minX, maxY - minY); + }; + + V.transformPoint = function(p, matrix) { + + return new Point(V.createSVGPoint(p.x, p.y).matrixTransform(matrix)); + }; + + V.transformLine = function(l, matrix) { + + return new Line( + V.transformPoint(l.start, matrix), + V.transformPoint(l.end, matrix) + ); + }; + + V.transformPolyline = function(p, matrix) { + + var inPoints = (p instanceof Polyline) ? p.points : p; + if (!V.isArray(inPoints)) { inPoints = []; } + var outPoints = []; + for (var i = 0, n = inPoints.length; i < n; i++) { outPoints[i] = V.transformPoint(inPoints[i], matrix); } + return new Polyline(outPoints); + }; + + // Convert a style represented as string (e.g. `'fill="blue"; stroke="red"'`) to + // an object (`{ fill: 'blue', stroke: 'red' }`). + V.styleToObject = function(styleString) { + var ret = {}; + var styles = styleString.split(';'); + for (var i = 0; i < styles.length; i++) { + var style = styles[i]; + var pair = style.split('='); + ret[pair[0].trim()] = pair[1].trim(); + } + return ret; + }; + + // Inspired by d3.js https://github.com/mbostock/d3/blob/master/src/svg/arc.js + V.createSlicePathData = function(innerRadius, outerRadius, startAngle, endAngle) { + + var svgArcMax = 2 * PI - 1e-6; + var r0 = innerRadius; + var r1 = outerRadius; + var a0 = startAngle; + var a1 = endAngle; + var da = (a1 < a0 && (da = a0, a0 = a1, a1 = da), a1 - a0); + var df = da < PI ? '0' : '1'; + var c0 = cos(a0); + var s0 = sin(a0); + var c1 = cos(a1); + var s1 = sin(a1); + + return (da >= svgArcMax) + ? (r0 + ? 'M0,' + r1 + + 'A' + r1 + ',' + r1 + ' 0 1,1 0,' + (-r1) + + 'A' + r1 + ',' + r1 + ' 0 1,1 0,' + r1 + + 'M0,' + r0 + + 'A' + r0 + ',' + r0 + ' 0 1,0 0,' + (-r0) + + 'A' + r0 + ',' + r0 + ' 0 1,0 0,' + r0 + + 'Z' + : 'M0,' + r1 + + 'A' + r1 + ',' + r1 + ' 0 1,1 0,' + (-r1) + + 'A' + r1 + ',' + r1 + ' 0 1,1 0,' + r1 + + 'Z') + : (r0 + ? 'M' + r1 * c0 + ',' + r1 * s0 + + 'A' + r1 + ',' + r1 + ' 0 ' + df + ',1 ' + r1 * c1 + ',' + r1 * s1 + + 'L' + r0 * c1 + ',' + r0 * s1 + + 'A' + r0 + ',' + r0 + ' 0 ' + df + ',0 ' + r0 * c0 + ',' + r0 * s0 + + 'Z' + : 'M' + r1 * c0 + ',' + r1 * s0 + + 'A' + r1 + ',' + r1 + ' 0 ' + df + ',1 ' + r1 * c1 + ',' + r1 * s1 + + 'L0,0' + + 'Z'); + }; + + // Merge attributes from object `b` with attributes in object `a`. + // Note that this modifies the object `a`. + // Also important to note that attributes are merged but CSS classes are concatenated. + V.mergeAttrs = function(a, b) { + + for (var attr in b) { + + if (attr === 'class') { + // Concatenate classes. + a[attr] = a[attr] ? a[attr] + ' ' + b[attr] : b[attr]; + } else if (attr === 'style') { + // `style` attribute can be an object. + if (V.isObject(a[attr]) && V.isObject(b[attr])) { + // `style` stored in `a` is an object. + a[attr] = V.mergeAttrs(a[attr], b[attr]); + } else if (V.isObject(a[attr])) { + // `style` in `a` is an object but it's a string in `b`. + // Convert the style represented as a string to an object in `b`. + a[attr] = V.mergeAttrs(a[attr], V.styleToObject(b[attr])); + } else if (V.isObject(b[attr])) { + // `style` in `a` is a string, in `b` it's an object. + a[attr] = V.mergeAttrs(V.styleToObject(a[attr]), b[attr]); + } else { + // Both styles are strings. + a[attr] = V.mergeAttrs(V.styleToObject(a[attr]), V.styleToObject(b[attr])); + } + } else { + a[attr] = b[attr]; + } + } + + return a; + }; + + V.annotateString = function(t, annotations, opt) { + + annotations = annotations || []; + opt = opt || {}; + + var offset = opt.offset || 0; + var compacted = []; + var batch; + var ret = []; + var item; + var prev; + + for (var i = 0; i < t.length; i++) { + + item = ret[i] = t[i]; + + for (var j = 0; j < annotations.length; j++) { + + var annotation = annotations[j]; + var start = annotation.start + offset; + var end = annotation.end + offset; + + if (i >= start && i < end) { + // Annotation applies. + if (V.isObject(item)) { + // There is more than one annotation to be applied => Merge attributes. + item.attrs = V.mergeAttrs(V.mergeAttrs({}, item.attrs), annotation.attrs); + } else { + item = ret[i] = { t: t[i], attrs: annotation.attrs }; + } + if (opt.includeAnnotationIndices) { + (item.annotations || (item.annotations = [])).push(j); + } + } + } + + prev = ret[i - 1]; + + if (!prev) { + + batch = item; + + } else if (V.isObject(item) && V.isObject(prev)) { + // Both previous item and the current one are annotations. If the attributes + // didn't change, merge the text. + if (JSON.stringify(item.attrs) === JSON.stringify(prev.attrs)) { + batch.t += item.t; + } else { + compacted.push(batch); + batch = item; + } + + } else if (V.isObject(item)) { + // Previous item was a string, current item is an annotation. + compacted.push(batch); + batch = item; + + } else if (V.isObject(prev)) { + // Previous item was an annotation, current item is a string. + compacted.push(batch); + batch = item; + + } else { + // Both previous and current item are strings. + batch = (batch || '') + item; + } + } + + if (batch) { + compacted.push(batch); + } + + return compacted; + }; + + V.findAnnotationsAtIndex = function(annotations, index) { + + var found = []; + + if (annotations) { + + annotations.forEach(function(annotation) { + + if (annotation.start < index && index <= annotation.end) { + found.push(annotation); + } + }); + } + + return found; + }; + + V.findAnnotationsBetweenIndexes = function(annotations, start, end) { + + var found = []; + + if (annotations) { + + annotations.forEach(function(annotation) { + + if ((start >= annotation.start && start < annotation.end) || (end > annotation.start && end <= annotation.end) || (annotation.start >= start && annotation.end < end)) { + found.push(annotation); + } + }); + } + + return found; + }; + + // Shift all the text annotations after character `index` by `offset` positions. + V.shiftAnnotations = function(annotations, index, offset) { + + if (annotations) { + + annotations.forEach(function(annotation) { + + if (annotation.start < index && annotation.end >= index) { + annotation.end += offset; + } else if (annotation.start >= index) { + annotation.start += offset; + annotation.end += offset; + } + }); + } + + return annotations; + }; + + V.convertLineToPathData = function(line) { + + line = V(line); + var d = [ + 'M', line.attr('x1'), line.attr('y1'), + 'L', line.attr('x2'), line.attr('y2') + ].join(' '); + return d; + }; + + V.convertPolygonToPathData = function(polygon) { + + var points = V.getPointsFromSvgNode(polygon); + if (points.length === 0) { return null; } + + return V.svgPointsToPath(points) + ' Z'; + }; + + V.convertPolylineToPathData = function(polyline) { + + var points = V.getPointsFromSvgNode(polyline); + if (points.length === 0) { return null; } + + return V.svgPointsToPath(points); + }; + + V.svgPointsToPath = function(points) { + + for (var i = 0, n = points.length; i < n; i++) { + points[i] = points[i].x + ' ' + points[i].y; + } + + return 'M ' + points.join(' L'); + }; + + V.getPointsFromSvgNode = function(node) { + + node = V.toNode(node); + var points = []; + var nodePoints = node.points; + if (nodePoints) { + for (var i = 0, n = nodePoints.numberOfItems; i < n; i++) { + points.push(nodePoints.getItem(i)); + } + } + + return points; + }; + + V.KAPPA = 0.551784; + + V.convertCircleToPathData = function(circle) { + + circle = V(circle); + var cx = parseFloat(circle.attr('cx')) || 0; + var cy = parseFloat(circle.attr('cy')) || 0; + var r = parseFloat(circle.attr('r')); + var cd = r * V.KAPPA; // Control distance. + + var d = [ + 'M', cx, cy - r, // Move to the first point. + 'C', cx + cd, cy - r, cx + r, cy - cd, cx + r, cy, // I. Quadrant. + 'C', cx + r, cy + cd, cx + cd, cy + r, cx, cy + r, // II. Quadrant. + 'C', cx - cd, cy + r, cx - r, cy + cd, cx - r, cy, // III. Quadrant. + 'C', cx - r, cy - cd, cx - cd, cy - r, cx, cy - r, // IV. Quadrant. + 'Z' + ].join(' '); + return d; + }; + + V.convertEllipseToPathData = function(ellipse) { + + ellipse = V(ellipse); + var cx = parseFloat(ellipse.attr('cx')) || 0; + var cy = parseFloat(ellipse.attr('cy')) || 0; + var rx = parseFloat(ellipse.attr('rx')); + var ry = parseFloat(ellipse.attr('ry')) || rx; + var cdx = rx * V.KAPPA; // Control distance x. + var cdy = ry * V.KAPPA; // Control distance y. + + var d = [ + 'M', cx, cy - ry, // Move to the first point. + 'C', cx + cdx, cy - ry, cx + rx, cy - cdy, cx + rx, cy, // I. Quadrant. + 'C', cx + rx, cy + cdy, cx + cdx, cy + ry, cx, cy + ry, // II. Quadrant. + 'C', cx - cdx, cy + ry, cx - rx, cy + cdy, cx - rx, cy, // III. Quadrant. + 'C', cx - rx, cy - cdy, cx - cdx, cy - ry, cx, cy - ry, // IV. Quadrant. + 'Z' + ].join(' '); + return d; + }; + + V.convertRectToPathData = function(rect) { + + rect = V(rect); + + return V.rectToPath({ + x: parseFloat(rect.attr('x')) || 0, + y: parseFloat(rect.attr('y')) || 0, + width: parseFloat(rect.attr('width')) || 0, + height: parseFloat(rect.attr('height')) || 0, + rx: parseFloat(rect.attr('rx')) || 0, + ry: parseFloat(rect.attr('ry')) || 0 + }); + }; + + // Convert a rectangle to SVG path commands. `r` is an object of the form: + // `{ x: [number], y: [number], width: [number], height: [number], top-ry: [number], top-ry: [number], bottom-rx: [number], bottom-ry: [number] }`, + // where `x, y, width, height` are the usual rectangle attributes and [top-/bottom-]rx/ry allows for + // specifying radius of the rectangle for all its sides (as opposed to the built-in SVG rectangle + // that has only `rx` and `ry` attributes). + V.rectToPath = function(r) { + + var d; + var x = r.x; + var y = r.y; + var width = r.width; + var height = r.height; + var topRx = min(r.rx || r['top-rx'] || 0, width / 2); + var bottomRx = min(r.rx || r['bottom-rx'] || 0, width / 2); + var topRy = min(r.ry || r['top-ry'] || 0, height / 2); + var bottomRy = min(r.ry || r['bottom-ry'] || 0, height / 2); + + if (topRx || bottomRx || topRy || bottomRy) { + d = [ + 'M', x, y + topRy, + 'v', height - topRy - bottomRy, + 'a', bottomRx, bottomRy, 0, 0, 0, bottomRx, bottomRy, + 'h', width - 2 * bottomRx, + 'a', bottomRx, bottomRy, 0, 0, 0, bottomRx, -bottomRy, + 'v', -(height - bottomRy - topRy), + 'a', topRx, topRy, 0, 0, 0, -topRx, -topRy, + 'h', -(width - 2 * topRx), + 'a', topRx, topRy, 0, 0, 0, -topRx, topRy, + 'Z' + ]; + } else { + d = [ + 'M', x, y, + 'H', x + width, + 'V', y + height, + 'H', x, + 'V', y, + 'Z' + ]; + } + + return d.join(' '); + }; + + // Take a path data string + // Return a normalized path data string + // If data cannot be parsed, return 'M 0 0' + // Adapted from Rappid normalizePath polyfill + // Highly inspired by Raphael Library (www.raphael.com) + V.normalizePathData = (function() { + + var spaces = '\x09\x0a\x0b\x0c\x0d\x20\xa0\u1680\u180e\u2000\u2001\u2002\u2003\u2004\u2005\u2006\u2007\u2008\u2009\u200a\u202f\u205f\u3000\u2028\u2029'; + var pathCommand = new RegExp('([a-z])[' + spaces + ',]*((-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?[' + spaces + ']*,?[' + spaces + ']*)+)', 'ig'); + var pathValues = new RegExp('(-?\\d*\\.?\\d*(?:e[\\-+]?\\d+)?)[' + spaces + ']*,?[' + spaces + ']*', 'ig'); + + var math = Math; + var PI = math.PI; + var sin = math.sin; + var cos = math.cos; + var tan = math.tan; + var asin = math.asin; + var sqrt = math.sqrt; + var abs = math.abs; + + function q2c(x1, y1, ax, ay, x2, y2) { + + var _13 = 1 / 3; + var _23 = 2 / 3; + return [(_13 * x1) + (_23 * ax), (_13 * y1) + (_23 * ay), (_13 * x2) + (_23 * ax), (_13 * y2) + (_23 * ay), x2, y2]; + } + + function rotate(x, y, rad) { + + var X = (x * cos(rad)) - (y * sin(rad)); + var Y = (x * sin(rad)) + (y * cos(rad)); + return { x: X, y: Y }; + } + + function a2c(x1, y1, rx, ry, angle, large_arc_flag, sweep_flag, x2, y2, recursive) { + // for more information of where this math came from visit: + // http://www.w3.org/TR/SVG11/implnote.html#ArcImplementationNotes + var _120 = (PI * 120) / 180; + var rad = (PI / 180) * (+angle || 0); + var res = []; + var xy; + + if (!recursive) { + xy = rotate(x1, y1, -rad); + x1 = xy.x; + y1 = xy.y; + + xy = rotate(x2, y2, -rad); + x2 = xy.x; + y2 = xy.y; + + var x = (x1 - x2) / 2; + var y = (y1 - y2) / 2; + var h = ((x * x) / (rx * rx)) + ((y * y) / (ry * ry)); + + if (h > 1) { + h = sqrt(h); + rx = h * rx; + ry = h * ry; + } + + var rx2 = rx * rx; + var ry2 = ry * ry; + + var k = ((large_arc_flag == sweep_flag) ? -1 : 1) * sqrt(abs(((rx2 * ry2) - (rx2 * y * y) - (ry2 * x * x)) / ((rx2 * y * y) + (ry2 * x * x)))); + + var cx = ((k * rx * y) / ry) + ((x1 + x2) / 2); + var cy = ((k * -ry * x) / rx) + ((y1 + y2) / 2); + + var f1 = asin(((y1 - cy) / ry).toFixed(9)); + var f2 = asin(((y2 - cy) / ry).toFixed(9)); + + f1 = ((x1 < cx) ? (PI - f1) : f1); + f2 = ((x2 < cx) ? (PI - f2) : f2); + + if (f1 < 0) { f1 = (PI * 2) + f1; } + if (f2 < 0) { f2 = (PI * 2) + f2; } + + if (sweep_flag && (f1 > f2)) { f1 = f1 - (PI * 2); } + if (!sweep_flag && (f2 > f1)) { f2 = f2 - (PI * 2); } + + } else { + f1 = recursive[0]; + f2 = recursive[1]; + cx = recursive[2]; + cy = recursive[3]; + } + + var df = f2 - f1; + if (abs(df) > _120) { + var f2old = f2; + var x2old = x2; + var y2old = y2; + f2 = f1 + (_120 * ((sweep_flag && (f2 > f1)) ? 1 : -1)); + x2 = cx + (rx * cos(f2)); + y2 = cy + (ry * sin(f2)); + res = a2c(x2, y2, rx, ry, angle, 0, sweep_flag, x2old, y2old, [f2, f2old, cx, cy]); + } + + df = f2 - f1; + + var c1 = cos(f1); + var s1 = sin(f1); + var c2 = cos(f2); + var s2 = sin(f2); + var t = tan(df / 4); + var hx = (4 / 3) * (rx * t); + var hy = (4 / 3) * (ry * t); + var m1 = [x1, y1]; + var m2 = [x1 + (hx * s1), y1 - (hy * c1)]; + var m3 = [x2 + (hx * s2), y2 - (hy * c2)]; + var m4 = [x2, y2]; + + m2[0] = (2 * m1[0]) - m2[0]; + m2[1] = (2 * m1[1]) - m2[1]; + + if (recursive) { + return [m2, m3, m4].concat(res); + } else { + res = [m2, m3, m4].concat(res).join().split(','); + var newres = []; + var ii = res.length; + for (var i = 0; i < ii; i++) { + newres[i] = (i % 2) ? rotate(res[i - 1], res[i], rad).y : rotate(res[i], res[i + 1], rad).x; + } + return newres; + } + } + + function parsePathString(pathString) { + + if (!pathString) { return null; } + + var paramCounts = { a: 7, c: 6, h: 1, l: 2, m: 2, q: 4, s: 4, t: 2, v: 1, z: 0 }; + var data = []; + + String(pathString).replace(pathCommand, function(a, b, c) { + + var params = []; + var name = b.toLowerCase(); + c.replace(pathValues, function(a, b) { + if (b) { params.push(+b); } + }); + + if ((name === 'm') && (params.length > 2)) { + data.push([b].concat(params.splice(0, 2))); + name = 'l'; + b = ((b === 'm') ? 'l' : 'L'); + } + + while (params.length >= paramCounts[name]) { + data.push([b].concat(params.splice(0, paramCounts[name]))); + if (!paramCounts[name]) { break; } + } + }); + + return data; + } + + function pathToAbsolute(pathArray) { + + if (!Array.isArray(pathArray) || !Array.isArray(pathArray && pathArray[0])) { // rough assumption + pathArray = parsePathString(pathArray); + } + + // if invalid string, return 'M 0 0' + if (!pathArray || !pathArray.length) { return [['M', 0, 0]]; } + + var res = []; + var x = 0; + var y = 0; + var mx = 0; + var my = 0; + var start = 0; + var pa0; + + var ii = pathArray.length; + for (var i = start; i < ii; i++) { + + var r = []; + res.push(r); + + var pa = pathArray[i]; + pa0 = pa[0]; + + if (pa0 != pa0.toUpperCase()) { + r[0] = pa0.toUpperCase(); + + var jj; + var j; + switch (r[0]) { + case 'A': + r[1] = pa[1]; + r[2] = pa[2]; + r[3] = pa[3]; + r[4] = pa[4]; + r[5] = pa[5]; + r[6] = +pa[6] + x; + r[7] = +pa[7] + y; + break; + + case 'V': + r[1] = +pa[1] + y; + break; + + case 'H': + r[1] = +pa[1] + x; + break; + + case 'M': + mx = +pa[1] + x; + my = +pa[2] + y; + + jj = pa.length; + for (j = 1; j < jj; j++) { + r[j] = +pa[j] + ((j % 2) ? x : y); + } + break; + + default: + jj = pa.length; + for (j = 1; j < jj; j++) { + r[j] = +pa[j] + ((j % 2) ? x : y); + } + break; + } + } else { + var kk = pa.length; + for (var k = 0; k < kk; k++) { + r[k] = pa[k]; + } + } + + switch (r[0]) { + case 'Z': + x = +mx; + y = +my; + break; + + case 'H': + x = r[1]; + break; + + case 'V': + y = r[1]; + break; + + case 'M': + mx = r[r.length - 2]; + my = r[r.length - 1]; + x = r[r.length - 2]; + y = r[r.length - 1]; + break; + + default: + x = r[r.length - 2]; + y = r[r.length - 1]; + break; + } + } + + return res; + } + + function normalize(path) { + + var p = pathToAbsolute(path); + var attrs = { x: 0, y: 0, bx: 0, by: 0, X: 0, Y: 0, qx: null, qy: null }; + + function processPath(path, d, pcom) { + + var nx, ny; + + if (!path) { return ['C', d.x, d.y, d.x, d.y, d.x, d.y]; } + + if (!(path[0] in { T: 1, Q: 1 })) { + d.qx = null; + d.qy = null; + } + + switch (path[0]) { + case 'M': + d.X = path[1]; + d.Y = path[2]; + break; + + case 'A': + if (parseFloat(path[1]) === 0 || parseFloat(path[2]) === 0) { + // https://www.w3.org/TR/SVG/paths.html#ArcOutOfRangeParameters + // "If either rx or ry is 0, then this arc is treated as a + // straight line segment (a "lineto") joining the endpoints." + path = ['L', path[6], path[7]]; + } else { + path = ['C'].concat(a2c.apply(0, [d.x, d.y].concat(path.slice(1)))); + } + break; + + case 'S': + if (pcom === 'C' || pcom === 'S') { // In 'S' case we have to take into account, if the previous command is C/S. + nx = (d.x * 2) - d.bx; // And reflect the previous + ny = (d.y * 2) - d.by; // command's control point relative to the current point. + } else { // or some else or nothing + nx = d.x; + ny = d.y; + } + path = ['C', nx, ny].concat(path.slice(1)); + break; + + case 'T': + if (pcom === 'Q' || pcom === 'T') { // In 'T' case we have to take into account, if the previous command is Q/T. + d.qx = (d.x * 2) - d.qx; // And make a reflection similar + d.qy = (d.y * 2) - d.qy; // to case 'S'. + } else { // or something else or nothing + d.qx = d.x; + d.qy = d.y; + } + path = ['C'].concat(q2c(d.x, d.y, d.qx, d.qy, path[1], path[2])); + break; + + case 'Q': + d.qx = path[1]; + d.qy = path[2]; + path = ['C'].concat(q2c(d.x, d.y, path[1], path[2], path[3], path[4])); + break; + + case 'H': + path = ['L'].concat(path[1], d.y); + break; + + case 'V': + path = ['L'].concat(d.x, path[1]); + break; + + case 'L': + break; + + case 'Z': + break; + } + + return path; + } + + function fixArc(pp, i) { + + if (pp[i].length > 7) { + + pp[i].shift(); + var pi = pp[i]; + + while (pi.length) { + pcoms[i] = 'A'; // if created multiple 'C's, their original seg is saved + pp.splice(i++, 0, ['C'].concat(pi.splice(0, 6))); + } + + pp.splice(i, 1); + ii = p.length; + } + } + + var pcoms = []; // path commands of original path p + var pfirst = ''; // temporary holder for original path command + var pcom = ''; // holder for previous path command of original path + + var ii = p.length; + for (var i = 0; i < ii; i++) { + if (p[i]) { pfirst = p[i][0]; } // save current path command + + if (pfirst !== 'C') { // C is not saved yet, because it may be result of conversion + pcoms[i] = pfirst; // Save current path command + if (i > 0) { pcom = pcoms[i - 1]; } // Get previous path command pcom + } + + p[i] = processPath(p[i], attrs, pcom); // Previous path command is inputted to processPath + + if (pcoms[i] !== 'A' && pfirst === 'C') { pcoms[i] = 'C'; } // 'A' is the only command + // which may produce multiple 'C's + // so we have to make sure that 'C' is also 'C' in original path + + fixArc(p, i); // fixArc adds also the right amount of 'A's to pcoms + + var seg = p[i]; + var seglen = seg.length; + + attrs.x = seg[seglen - 2]; + attrs.y = seg[seglen - 1]; + + attrs.bx = parseFloat(seg[seglen - 4]) || attrs.x; + attrs.by = parseFloat(seg[seglen - 3]) || attrs.y; + } + + // make sure normalized path data string starts with an M segment + if (!p[0][0] || p[0][0] !== 'M') { + p.unshift(['M', 0, 0]); + } + + return p; + } + + return function(pathData) { + return normalize(pathData).join(',').split(',').join(' '); + }; + })(); + + V.namespace = ns; + + V.g = g; + + return V; + + })(); + + var config = { + // When set to `true` the cell selectors could be defined as CSS selectors. + // If not, only JSON Markup selectors are taken into account. + // export let useCSSSelectors = true; + useCSSSelectors: true, + // The class name prefix config is for advanced use only. + // Be aware that if you change the prefix, the JointJS CSS will no longer function properly. + // export let classNamePrefix = 'joint-'; + // export let defaultTheme = 'default'; + classNamePrefix: 'joint-', + defaultTheme: 'default', + // The maximum delay required for two consecutive touchend events to be interpreted + // as a double-tap. + doubleTapInterval: 300 + }; + + var addClassNamePrefix = function(className) { + + if (!className) { return className; } + + return className.toString().split(' ').map(function(_className) { + + if (_className.substr(0, config.classNamePrefix.length) !== config.classNamePrefix) { + _className = config.classNamePrefix + _className; + } + + return _className; + + }).join(' '); + }; + + var removeClassNamePrefix = function(className) { + + if (!className) { return className; } + + return className.toString().split(' ').map(function(_className) { + + if (_className.substr(0, config.classNamePrefix.length) === config.classNamePrefix) { + _className = _className.substr(config.classNamePrefix.length); + } + + return _className; + + }).join(' '); + }; + + var parseDOMJSON = function(json, namespace) { + + var selectors = {}; + var groupSelectors = {}; + var svgNamespace = V.namespace.svg; + + var ns = namespace || svgNamespace; + var fragment = document.createDocumentFragment(); + var queue = [json, fragment, ns]; + while (queue.length > 0) { + ns = queue.pop(); + var parentNode = queue.pop(); + var siblingsDef = queue.pop(); + for (var i = 0, n = siblingsDef.length; i < n; i++) { + var nodeDef = siblingsDef[i]; + // TagName + if (!nodeDef.hasOwnProperty('tagName')) { throw new Error('json-dom-parser: missing tagName'); } + var tagName = nodeDef.tagName; + // Namespace URI + if (nodeDef.hasOwnProperty('namespaceURI')) { ns = nodeDef.namespaceURI; } + var node = document.createElementNS(ns, tagName); + var svg = (ns === svgNamespace); + + var wrapper = (svg) ? V : $; + // Attributes + var attributes = nodeDef.attributes; + if (attributes) { wrapper(node).attr(attributes); } + // Style + var style = nodeDef.style; + if (style) { $(node).css(style); } + // ClassName + if (nodeDef.hasOwnProperty('className')) { + var className = nodeDef.className; + if (svg) { + node.className.baseVal = className; + } else { + node.className = className; + } + } + // TextContent + if (nodeDef.hasOwnProperty('textContent')) { + node.textContent = nodeDef.textContent; + } + // Selector + if (nodeDef.hasOwnProperty('selector')) { + var nodeSelector = nodeDef.selector; + if (selectors[nodeSelector]) { throw new Error('json-dom-parser: selector must be unique'); } + selectors[nodeSelector] = node; + wrapper(node).attr('joint-selector', nodeSelector); + } + // Groups + if (nodeDef.hasOwnProperty('groupSelector')) { + var nodeGroups = nodeDef.groupSelector; + if (!Array.isArray(nodeGroups)) { nodeGroups = [nodeGroups]; } + for (var j = 0, m = nodeGroups.length; j < m; j++) { + var nodeGroup = nodeGroups[j]; + var group = groupSelectors[nodeGroup]; + if (!group) { group = groupSelectors[nodeGroup] = []; } + group.push(node); + } + } + parentNode.appendChild(node); + // Children + var childrenDef = nodeDef.children; + if (Array.isArray(childrenDef)) { queue.push(childrenDef, node, ns); } + } + } + return { + fragment: fragment, + selectors: selectors, + groupSelectors: groupSelectors + }; + }; + + // Return a simple hash code from a string. See http://werxltd.com/wp/2010/05/13/javascript-implementation-of-javas-string-hashcode-method/. + var hashCode = function(str) { + + var hash = 0; + if (str.length === 0) { return hash; } + for (var i = 0; i < str.length; i++) { + var c = str.charCodeAt(i); + hash = ((hash << 5) - hash) + c; + hash = hash & hash; // Convert to 32bit integer + } + return hash; + }; + + var getByPath = function(obj, path, delimiter) { + + var keys = Array.isArray(path) ? path : path.split(delimiter || '/'); + var key; + var i = 0; + var length = keys.length; + while (i < length) { + key = keys[i++]; + if (Object(obj) === obj && key in obj) { + obj = obj[key]; + } else { + return undefined; + } + } + return obj; + }; + + var isGetSafe = function(obj, key) { + // Prevent prototype pollution + // https://snyk.io/vuln/SNYK-JS-JSON8MERGEPATCH-1038399 + if (typeof key !== 'string' && typeof key !== 'number') { + key = String(key); + } + if (key === 'constructor' && typeof obj[key] === 'function') { + return false; + } + if (key === '__proto__') { + return false; + } + return true; + }; + + var setByPath = function(obj, path, value, delimiter) { + + var keys = Array.isArray(path) ? path : path.split(delimiter || '/'); + var last = keys.length - 1; + var diver = obj; + var i = 0; + + for (; i < last; i++) { + var key = keys[i]; + if (!isGetSafe(diver, key)) { return obj; } + var value$1 = diver[key]; + // diver creates an empty object if there is no nested object under such a key. + // This means that one can populate an empty nested object with setByPath(). + diver = value$1 || (diver[key] = {}); + } + + diver[keys[last]] = value; + + return obj; + }; + + var unsetByPath = function(obj, path, delimiter) { + + var keys = Array.isArray(path) ? path : path.split(delimiter || '/'); + var last = keys.length - 1; + var diver = obj; + var i = 0; + + for (; i < last; i++) { + var key = keys[i]; + if (!isGetSafe(diver, key)) { return obj; } + var value = diver[key]; + if (!value) { return obj; } + diver = value; + } + + delete diver[keys[last]]; + + return obj; + }; + + var flattenObject = function(obj, delim, stop) { + + delim = delim || '/'; + var ret = {}; + + for (var key in obj) { + + if (!obj.hasOwnProperty(key)) { continue; } + + var shouldGoDeeper = typeof obj[key] === 'object'; + if (shouldGoDeeper && stop && stop(obj[key])) { + shouldGoDeeper = false; + } + + if (shouldGoDeeper) { + + var flatObject = flattenObject(obj[key], delim, stop); + + for (var flatKey in flatObject) { + if (!flatObject.hasOwnProperty(flatKey)) { continue; } + ret[key + delim + flatKey] = flatObject[flatKey]; + } + + } else { + + ret[key] = obj[key]; + } + } + + return ret; + }; + + var uuid = function() { + + // credit: http://stackoverflow.com/posts/2117523/revisions + + return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) { + var r = (Math.random() * 16) | 0; + var v = (c === 'x') ? r : (r & 0x3 | 0x8); + return v.toString(16); + }); + }; + + // Generates global unique id and stores it as a property of the object, if provided. + var guid = function(obj) { + + guid.id = guid.id || 1; + + if (obj === undefined) { + return 'j_' + guid.id++; + } + + obj.id = (obj.id === undefined ? 'j_' + guid.id++ : obj.id); + return obj.id; + }; + + var toKebabCase = function(string) { + + return string.replace(/[A-Z]/g, '-$&').toLowerCase(); + }; + + var normalizeEvent = function(evt) { + + var normalizedEvent = evt; + var touchEvt = evt.originalEvent && evt.originalEvent.changedTouches && evt.originalEvent.changedTouches[0]; + if (touchEvt) { + for (var property in evt) { + // copy all the properties from the input event that are not + // defined on the touch event (functions included). + if (touchEvt[property] === undefined) { + touchEvt[property] = evt[property]; + } + } + normalizedEvent = touchEvt; + } + + // IE: evt.target could be set to SVGElementInstance for SVGUseElement + var target = normalizedEvent.target; + if (target) { + var useElement = target.correspondingUseElement; + if (useElement) { normalizedEvent.target = useElement; } + } + + return normalizedEvent; + }; + + var normalizeWheel = function(evt) { + // Sane values derived empirically + var PIXEL_STEP = 10; + var LINE_HEIGHT = 40; + var PAGE_HEIGHT = 800; + + var sX = 0, sY = 0, pX = 0, pY = 0; + + // Legacy + if ('detail' in evt) { sY = evt.detail; } + if ('wheelDelta' in evt) { sY = -evt.wheelDelta / 120; } + if ('wheelDeltaY' in evt) { sY = -evt.wheelDeltaY / 120; } + if ('wheelDeltaX' in evt) { sX = -evt.wheelDeltaX / 120; } + + // side scrolling on FF with DOMMouseScroll + if ( 'axis' in evt && evt.axis === evt.HORIZONTAL_AXIS ) { + sX = sY; + sY = 0; + } + + pX = 'deltaX' in evt ? evt.deltaX : sX * PIXEL_STEP; + pY = 'deltaY' in evt ? evt.deltaY : sY * PIXEL_STEP; + + if ((pX || pY) && evt.deltaMode) { + if (evt.deltaMode == 1) { + pX *= LINE_HEIGHT; + pY *= LINE_HEIGHT; + } else { + pX *= PAGE_HEIGHT; + pY *= PAGE_HEIGHT; + } + } + + // macOS switches deltaX and deltaY automatically when scrolling with shift key, so this is needed in other cases + if (evt.deltaX === 0 && evt.deltaY !== 0 && evt.shiftKey) { + pX = pY; + pY = 0; + sX = sY; + sY = 0; + } + + // Fall-back if spin cannot be determined + if (pX && !sX) { sX = (pX < 1) ? -1 : 1; } + if (pY && !sY) { sY = (pY < 1) ? -1 : 1; } + + return { + spinX : sX, + spinY : sY, + deltaX : pX, + deltaY : pY, + }; + }; + + var cap = function(val, max) { + return val > max ? max : val < -max ? -max : val; + }; + + var nextFrame = (function() { + + var raf; + + if (typeof window !== 'undefined') { + + raf = window.requestAnimationFrame || + window.webkitRequestAnimationFrame || + window.mozRequestAnimationFrame || + window.oRequestAnimationFrame || + window.msRequestAnimationFrame; + } + + if (!raf) { + + var lastTime = 0; + + raf = function(callback) { + + var currTime = new Date().getTime(); + var timeToCall = Math.max(0, 16 - (currTime - lastTime)); + var id = setTimeout(function() { + callback(currTime + timeToCall); + }, timeToCall); + + lastTime = currTime + timeToCall; + + return id; + }; + } + + return function(callback, context) { + var rest = [], len = arguments.length - 2; + while ( len-- > 0 ) rest[ len ] = arguments[ len + 2 ]; + + return (context !== undefined) + ? raf(callback.bind.apply(callback, [ context ].concat( rest ))) + : raf(callback); + }; + + })(); + + var cancelFrame = (function() { + + var caf; + var client = typeof window != 'undefined'; + + if (client) { + + caf = window.cancelAnimationFrame || + window.webkitCancelAnimationFrame || + window.webkitCancelRequestAnimationFrame || + window.msCancelAnimationFrame || + window.msCancelRequestAnimationFrame || + window.oCancelAnimationFrame || + window.oCancelRequestAnimationFrame || + window.mozCancelAnimationFrame || + window.mozCancelRequestAnimationFrame; + } + + caf = caf || clearTimeout; + + return client ? caf.bind(window) : caf; + + })(); + + /** + * @deprecated + */ + var shapePerimeterConnectionPoint = function(linkView, view, magnet, reference) { + + var bbox; + var spot; + + if (!magnet) { + + // There is no magnet, try to make the best guess what is the + // wrapping SVG element. This is because we want this "smart" + // connection points to work out of the box without the + // programmer to put magnet marks to any of the subelements. + // For example, we want the function to work on basic.Path elements + // without any special treatment of such elements. + // The code below guesses the wrapping element based on + // one simple assumption. The wrapping elemnet is the + // first child of the scalable group if such a group exists + // or the first child of the rotatable group if not. + // This makese sense because usually the wrapping element + // is below any other sub element in the shapes. + var scalable = view.$('.scalable')[0]; + var rotatable = view.$('.rotatable')[0]; + + if (scalable && scalable.firstChild) { + + magnet = scalable.firstChild; + + } else if (rotatable && rotatable.firstChild) { + + magnet = rotatable.firstChild; + } + } + + if (magnet) { + + spot = V(magnet).findIntersection(reference, linkView.paper.cells); + if (!spot) { + bbox = V(magnet).getBBox({ target: linkView.paper.cells }); + } + + } else { + + bbox = view.model.getBBox(); + spot = bbox.intersectionWithLineFromCenterToPoint(reference); + } + return spot || bbox.center(); + }; + + var isPercentage = function(val) { + + return isString(val) && val.slice(-1) === '%'; + }; + + var parseCssNumeric = function(val, restrictUnits) { + + function getUnit(validUnitExp) { + + // one or more numbers, followed by + // any number of ( + // `.`, followed by + // one or more numbers + // ), followed by + // `validUnitExp`, followed by + // end of string + var matches = new RegExp('(?:\\d+(?:\\.\\d+)*)(' + validUnitExp + ')$').exec(val); + + if (!matches) { return null; } + return matches[1]; + } + + var number = parseFloat(val); + + // if `val` cannot be parsed as a number, return `null` + if (Number.isNaN(number)) { return null; } + + // else: we know `output.value` + var output = {}; + output.value = number; + + // determine the unit + var validUnitExp; + if (restrictUnits == null) { + // no restriction + // accept any unit, as well as no unit + validUnitExp = '[A-Za-z]*'; + + } else if (Array.isArray(restrictUnits)) { + // if this is an empty array, top restriction - return `null` + if (restrictUnits.length === 0) { return null; } + + // else: restriction - an array of valid unit strings + validUnitExp = restrictUnits.join('|'); + + } else if (isString(restrictUnits)) { + // restriction - a single valid unit string + validUnitExp = restrictUnits; + } + var unit = getUnit(validUnitExp); + + // if we found no matches for `restrictUnits`, return `null` + if (unit === null) { return null; } + + // else: we know the unit + output.unit = unit; + return output; + }; + + var NO_SPACE = 0; + + function splitWordWithEOL(word, eol) { + var eolWords = word.split(eol); + var n = 1; + for (var j = 0, jl = eolWords.length - 1; j < jl; j++) { + var replacement = []; + if (j > 0 || eolWords[0] !== '') { replacement.push(NO_SPACE); } + replacement.push(eol); + if (j < jl - 1 || eolWords[jl] !== '') { replacement.push(NO_SPACE); } + eolWords.splice.apply(eolWords, [ n, 0 ].concat( replacement )); + n += replacement.length + 1; + } + return eolWords.filter(function (word) { return word !== ''; }); + } + + var breakText = function(text, size, styles, opt) { + if ( styles === void 0 ) styles = {}; + if ( opt === void 0 ) opt = {}; + + + var width = size.width; + var height = size.height; + + var svgDocument = opt.svgDocument || V('svg').node; + var textSpan = V('tspan').node; + var textElement = V('text').attr(styles).append(textSpan).node; + var textNode = document.createTextNode(''); + + // Prevent flickering + textElement.style.opacity = 0; + // Prevent FF from throwing an uncaught exception when `getBBox()` + // called on element that is not in the render tree (is not measurable). + // .getComputedTextLength() returns always 0 in this case. + // Note that the `textElement` resp. `textSpan` can become hidden + // when it's appended to the DOM and a `display: none` CSS stylesheet + // rule gets applied. + textElement.style.display = 'block'; + textSpan.style.display = 'block'; + + textSpan.appendChild(textNode); + svgDocument.appendChild(textElement); // lgtm [js/xss-through-dom] + + if (!opt.svgDocument) { + + document.body.appendChild(svgDocument); + } + + var preserveSpaces = opt.preserveSpaces; + var space = ' '; + var separator = opt.separator || space; + var eol = opt.eol || '\n'; + var hyphen = opt.hyphen ? new RegExp(opt.hyphen) : /[^\w\d]/; + var maxLineCount = opt.maxLineCount; + if (!isNumber(maxLineCount)) { maxLineCount = Infinity; } + + var words = text.split(separator); + var full = []; + var lines = []; + var p, h; + var lineHeight; + + if (preserveSpaces) { + V(textSpan).attr('xml:space', 'preserve'); + } + + for (var i = 0, l = 0, len = words.length; i < len; i++) { + + var word = words[i]; + + if (!word && !preserveSpaces) { continue; } + if (typeof word !== 'string') { continue; } + + var isEol = false; + if (eol && word.indexOf(eol) >= 0) { + // word contains end-of-line character + if (word.length > 1) { + // separate word and continue cycle + var eolWords = splitWordWithEOL(words[i], eol); + words.splice.apply(words, [ i, 1 ].concat( eolWords )); + i--; + len = words.length; + continue; + } else { + // creates a new line + if (preserveSpaces && typeof words[i - 1] === 'string' ) { + words.splice(i, NO_SPACE, '', NO_SPACE); + len += 2; + i--; + continue; + } + lines[++l] = (!preserveSpaces || typeof words[i + 1] === 'string') ? '' : undefined; + isEol = true; + } + } + + if (!isEol) { + + var data = (void 0); + if (preserveSpaces) { + data = lines[l] !== undefined ? lines[l] + space + word : word; + } else { + data = lines[l] ? lines[l] + space + word : word; + } + + textNode.data = data; + + if (textSpan.getComputedTextLength() <= width) { + + // the current line fits + lines[l] = data; + + if (p || h) { + // We were partitioning. Put rest of the word onto next line + full[l++] = true; + + // cancel partitioning and splitting by hyphens + p = 0; + h = 0; + } + + } else { + + if (!lines[l] || p) { + + var partition = !!p; + + p = word.length - 1; + + if (partition || !p) { + + // word has only one character. + if (!p) { + + if (!lines[l]) { + + // we won't fit this text within our rect + lines = []; + + break; + } + + // partitioning didn't help on the non-empty line + // try again, but this time start with a new line + + // cancel partitions created + words.splice(i, 2, word + words[i + 1]); + + // adjust word length + len--; + + full[l++] = true; + i--; + + continue; + } + + // move last letter to the beginning of the next word + words[i] = word.substring(0, p); + words[i + 1] = word.substring(p) + (words[i + 1] === undefined ? '' : words[i + 1]); + + } else { + + if (h) { + // cancel splitting and put the words together again + words.splice(i, 2, words[i] + words[i + 1]); + h = 0; + } else { + var hyphenIndex = word.search(hyphen); + if (hyphenIndex > -1 && hyphenIndex !== word.length - 1 && hyphenIndex !== 0) { + h = hyphenIndex + 1; + p = 0; + } + + // We initiate partitioning or splitting + // split the long word into two words + words.splice(i, 1, word.substring(0, h || p), word.substring(h|| p)); + // adjust words length + len++; + + } + + if (l && !full[l - 1]) { + // if the previous line is not full, try to fit max part of + // the current word there + l--; + } + } + + if (!preserveSpaces || lines[l] !== '') { + i--; + } + + continue; + } + + l++; + i--; + } + } + var lastL = null; + + if (lines.length > maxLineCount) { + + lastL = maxLineCount - 1; + + } else if (height !== undefined) { + + // if size.height is defined we have to check whether the height of the entire + // text exceeds the rect height + + if (lineHeight === undefined && textNode.data !== '') { + + var heightValue; + + // use the same defaults as in V.prototype.text + if (styles.lineHeight === 'auto') { + heightValue = { value: 1.5, unit: 'em' }; + } else { + heightValue = parseCssNumeric(styles.lineHeight, ['em']) || { value: 1, unit: 'em' }; + } + + lineHeight = heightValue.value; + if (heightValue.unit === 'em') { + lineHeight *= textElement.getBBox().height; + } + } + + if (lineHeight * lines.length > height) { + + // remove overflowing lines + lastL = Math.floor(height / lineHeight) - 1; + } + } + + if (lastL !== null) { + + lines.splice(lastL + 1); + + // add ellipsis + var ellipsis = opt.ellipsis; + if (!ellipsis || lastL < 0) { break; } + if (typeof ellipsis !== 'string') { ellipsis = '\u2026'; } + + var lastLine = lines[lastL]; + if (!lastLine && !isEol) { break; } + var k = lastLine.length; + var lastLineWithOmission, lastChar, separatorChar; + do { + lastChar = lastLine[k]; + lastLineWithOmission = lastLine.substring(0, k); + if (!lastChar) { + separatorChar = (typeof separator === 'string') ? separator : ' '; + lastLineWithOmission += separatorChar; + } else if (lastChar.match(separator)) { + lastLineWithOmission += lastChar; + } + lastLineWithOmission += ellipsis; + textNode.data = lastLineWithOmission; + if (textSpan.getComputedTextLength() <= width) { + lines[lastL] = lastLineWithOmission; + break; + } + k--; + } while (k >= 0); + break; + } + } + + if (opt.svgDocument) { + + // svg document was provided, remove the text element only + svgDocument.removeChild(textElement); + + } else { + + // clean svg document + document.body.removeChild(svgDocument); + } + + return lines.join(eol); + }; + + // Sanitize HTML + // Based on https://gist.github.com/ufologist/5a0da51b2b9ef1b861c30254172ac3c9 + // Parses a string into an array of DOM nodes. + // Then outputs it back as a string. + var sanitizeHTML = function(html) { + + // Ignores tags that are invalid inside a
    tag (e.g. , ) + + // If documentContext (second parameter) is not specified or given as `null` or `undefined`, a new document is used. + // Inline events will not execute when the HTML is parsed; this includes, for example, sending GET requests for images. + + // If keepScripts (last parameter) is `false`, scripts are not executed. + var output = $($.parseHTML('
    ' + html + '
    ', null, false)); + + output.find('*').each(function() { // for all nodes + var currentNode = this; + + $.each(currentNode.attributes, function() { // for all attributes in each node + var currentAttribute = this; + + var attrName = currentAttribute.name; + var attrValue = currentAttribute.value; + + // Remove attribute names that start with "on" (e.g. onload, onerror...). + // Remove attribute values that start with "javascript:" pseudo protocol (e.g. `href="javascript:alert(1)"`). + if (attrName.startsWith('on') || attrValue.startsWith('javascript:') || attrValue.startsWith('data:') || attrValue.startsWith('vbscript:')) { + $(currentNode).removeAttr(attrName); + } + }); + }); + + return output.html(); + }; + + // Download `blob` as file with `fileName`. + // Does not work in IE9. + var downloadBlob = function(blob, fileName) { + + if (window.navigator.msSaveBlob) { // requires IE 10+ + // pulls up a save dialog + window.navigator.msSaveBlob(blob, fileName); + + } else { // other browsers + // downloads directly in Chrome and Safari + + // presents a save/open dialog in Firefox + // Firefox bug: `from` field in save dialog always shows `from:blob:` + // https://bugzilla.mozilla.org/show_bug.cgi?id=1053327 + + var url = window.URL.createObjectURL(blob); + var link = document.createElement('a'); + + link.href = url; + link.download = fileName; + document.body.appendChild(link); + + link.click(); + + document.body.removeChild(link); + window.URL.revokeObjectURL(url); // mark the url for garbage collection + } + }; + + // Download `dataUri` as file with `fileName`. + // Does not work in IE9. + var downloadDataUri = function(dataUri, fileName) { + + var blob = dataUriToBlob(dataUri); + downloadBlob(blob, fileName); + }; + + // Convert an uri-encoded data component (possibly also base64-encoded) to a blob. + var dataUriToBlob = function(dataUri) { + + // first, make sure there are no newlines in the data uri + dataUri = dataUri.replace(/\s/g, ''); + dataUri = decodeURIComponent(dataUri); + + var firstCommaIndex = dataUri.indexOf(','); // split dataUri as `dataTypeString`,`data` + + var dataTypeString = dataUri.slice(0, firstCommaIndex); // e.g. 'data:image/jpeg;base64' + var mimeString = dataTypeString.split(':')[1].split(';')[0]; // e.g. 'image/jpeg' + + var data = dataUri.slice(firstCommaIndex + 1); + var decodedString; + if (dataTypeString.indexOf('base64') >= 0) { // data may be encoded in base64 + decodedString = atob(data); // decode data + } else { + // convert the decoded string to UTF-8 + decodedString = unescape(encodeURIComponent(data)); + } + // write the bytes of the string to a typed array + var ia = new Uint8Array(decodedString.length); + for (var i = 0; i < decodedString.length; i++) { + ia[i] = decodedString.charCodeAt(i); + } + + return new Blob([ia], { type: mimeString }); // return the typed array as Blob + }; + + // Read an image at `url` and return it as base64-encoded data uri. + // The mime type of the image is inferred from the `url` file extension. + // If data uri is provided as `url`, it is returned back unchanged. + // `callback` is a method with `err` as first argument and `dataUri` as second argument. + // Works with IE9. + var imageToDataUri = function(url, callback) { + + if (!url || url.substr(0, 'data:'.length) === 'data:') { + // No need to convert to data uri if it is already in data uri. + + // This not only convenient but desired. For example, + // IE throws a security error if data:image/svg+xml is used to render + // an image to the canvas and an attempt is made to read out data uri. + // Now if our image is already in data uri, there is no need to render it to the canvas + // and so we can bypass this error. + + // Keep the async nature of the function. + return setTimeout(function() { + callback(null, url); + }, 0); + } + + // chrome, IE10+ + var modernHandler = function(xhr, callback) { + + if (xhr.status === 200) { + + var reader = new FileReader(); + + reader.onload = function(evt) { + var dataUri = evt.target.result; + callback(null, dataUri); + }; + + reader.onerror = function() { + callback(new Error('Failed to load image ' + url)); + }; + + reader.readAsDataURL(xhr.response); + } else { + callback(new Error('Failed to load image ' + url)); + } + }; + + var legacyHandler = function(xhr, callback) { + + var Uint8ToString = function(u8a) { + var CHUNK_SZ = 0x8000; + var c = []; + for (var i = 0; i < u8a.length; i += CHUNK_SZ) { + c.push(String.fromCharCode.apply(null, u8a.subarray(i, i + CHUNK_SZ))); + } + return c.join(''); + }; + + if (xhr.status === 200) { + + var bytes = new Uint8Array(xhr.response); + + var suffix = (url.split('.').pop()) || 'png'; + var map = { + 'svg': 'svg+xml' + }; + var meta = 'data:image/' + (map[suffix] || suffix) + ';base64,'; + var b64encoded = meta + btoa(Uint8ToString(bytes)); + callback(null, b64encoded); + } else { + callback(new Error('Failed to load image ' + url)); + } + }; + + var xhr = new XMLHttpRequest(); + + xhr.open('GET', url, true); + xhr.addEventListener('error', function() { + callback(new Error('Failed to load image ' + url)); + }); + + xhr.responseType = window.FileReader ? 'blob' : 'arraybuffer'; + + xhr.addEventListener('load', function() { + if (window.FileReader) { + modernHandler(xhr, callback); + } else { + legacyHandler(xhr, callback); + } + }); + + xhr.send(); + }; + + var getElementBBox = function(el) { + + var $el = $(el); + if ($el.length === 0) { + throw new Error('Element not found'); + } + + var element = $el[0]; + var doc = element.ownerDocument; + var clientBBox = element.getBoundingClientRect(); + + var strokeWidthX = 0; + var strokeWidthY = 0; + + // Firefox correction + if (element.ownerSVGElement) { + + var vel = V(element); + var bbox = vel.getBBox({ target: vel.svg() }); + + // if FF getBoundingClientRect includes stroke-width, getBBox doesn't. + // To unify this across all browsers we need to adjust the final bBox with `stroke-width` value. + strokeWidthX = (clientBBox.width - bbox.width); + strokeWidthY = (clientBBox.height - bbox.height); + } + + return { + x: clientBBox.left + window.pageXOffset - doc.documentElement.offsetLeft + strokeWidthX / 2, + y: clientBBox.top + window.pageYOffset - doc.documentElement.offsetTop + strokeWidthY / 2, + width: clientBBox.width - strokeWidthX, + height: clientBBox.height - strokeWidthY + }; + }; + + + // Highly inspired by the jquery.sortElements plugin by Padolsey. + // See http://james.padolsey.com/javascript/sorting-elements-with-jquery/. + var sortElements = function(elements, comparator) { + + var $elements = $(elements); + var placements = $elements.map(function() { + + var sortElement = this; + var parentNode = sortElement.parentNode; + // Since the element itself will change position, we have + // to have some way of storing it's original position in + // the DOM. The easiest way is to have a 'flag' node: + var nextSibling = parentNode.insertBefore(document.createTextNode(''), sortElement.nextSibling); + + return function() { + + if (parentNode === this) { + throw new Error('You can\'t sort elements if any one is a descendant of another.'); + } + + // Insert before flag: + parentNode.insertBefore(this, nextSibling); + // Remove flag: + parentNode.removeChild(nextSibling); + }; + }); + + return Array.prototype.sort.call($elements, comparator).each(function(i) { + placements[i].call(this); + }); + }; + + // Sets attributes on the given element and its descendants based on the selector. + // `attrs` object: { [SELECTOR1]: { attrs1 }, [SELECTOR2]: { attrs2}, ... } e.g. { 'input': { color : 'red' }} + var setAttributesBySelector = function(element, attrs) { + + var $element = $(element); + + forIn(attrs, function(attrs, selector) { + var $elements = $element.find(selector).addBack().filter(selector); + // Make a special case for setting classes. + // We do not want to overwrite any existing class. + if (has$2(attrs, 'class')) { + $elements.addClass(attrs['class']); + attrs = omit(attrs, 'class'); + } + $elements.attr(attrs); + }); + }; + + // Return a new object with all four sides (top, right, bottom, left) in it. + // Value of each side is taken from the given argument (either number or object). + // Default value for a side is 0. + // Examples: + // normalizeSides(5) --> { top: 5, right: 5, bottom: 5, left: 5 } + // normalizeSides({ horizontal: 5 }) --> { top: 0, right: 5, bottom: 0, left: 5 } + // normalizeSides({ left: 5 }) --> { top: 0, right: 0, bottom: 0, left: 5 } + // normalizeSides({ horizontal: 10, left: 5 }) --> { top: 0, right: 10, bottom: 0, left: 5 } + // normalizeSides({ horizontal: 0, left: 5 }) --> { top: 0, right: 0, bottom: 0, left: 5 } + var normalizeSides = function(box) { + + if (Object(box) !== box) { // `box` is not an object + var val = 0; // `val` left as 0 if `box` cannot be understood as finite number + if (isFinite(box)) { val = +box; } // actually also accepts string numbers (e.g. '100') + + return { top: val, right: val, bottom: val, left: val }; + } + + // `box` is an object + var top, right, bottom, left; + top = right = bottom = left = 0; + + if (isFinite(box.vertical)) { top = bottom = +box.vertical; } + if (isFinite(box.horizontal)) { right = left = +box.horizontal; } + + if (isFinite(box.top)) { top = +box.top; } // overwrite vertical + if (isFinite(box.right)) { right = +box.right; } // overwrite horizontal + if (isFinite(box.bottom)) { bottom = +box.bottom; } // overwrite vertical + if (isFinite(box.left)) { left = +box.left; } // overwrite horizontal + + return { top: top, right: right, bottom: bottom, left: left }; + }; + + var timing = { + + linear: function(t) { + return t; + }, + + quad: function(t) { + return t * t; + }, + + cubic: function(t) { + return t * t * t; + }, + + inout: function(t) { + if (t <= 0) { return 0; } + if (t >= 1) { return 1; } + var t2 = t * t; + var t3 = t2 * t; + return 4 * (t < .5 ? t3 : 3 * (t - t2) + t3 - .75); + }, + + exponential: function(t) { + return Math.pow(2, 10 * (t - 1)); + }, + + bounce: function(t) { + for (var a = 0, b = 1; 1; a += b, b /= 2) { + if (t >= (7 - 4 * a) / 11) { + var q = (11 - 6 * a - 11 * t) / 4; + return -q * q + b * b; + } + } + }, + + reverse: function(f) { + return function(t) { + return 1 - f(1 - t); + }; + }, + + reflect: function(f) { + return function(t) { + return .5 * (t < .5 ? f(2 * t) : (2 - f(2 - 2 * t))); + }; + }, + + clamp: function(f, n, x) { + n = n || 0; + x = x || 1; + return function(t) { + var r = f(t); + return r < n ? n : r > x ? x : r; + }; + }, + + back: function(s) { + if (!s) { s = 1.70158; } + return function(t) { + return t * t * ((s + 1) * t - s); + }; + }, + + elastic: function(x) { + if (!x) { x = 1.5; } + return function(t) { + return Math.pow(2, 10 * (t - 1)) * Math.cos(20 * Math.PI * x / 3 * t); + }; + } + }; + + var interpolate = { + + number: function(a, b) { + var d = b - a; + return function(t) { + return a + d * t; + }; + }, + + object: function(a, b) { + var s = Object.keys(a); + return function(t) { + var i, p; + var r = {}; + for (i = s.length - 1; i != -1; i--) { + p = s[i]; + r[p] = a[p] + (b[p] - a[p]) * t; + } + return r; + }; + }, + + hexColor: function(a, b) { + + var ca = parseInt(a.slice(1), 16); + var cb = parseInt(b.slice(1), 16); + var ra = ca & 0x0000ff; + var rd = (cb & 0x0000ff) - ra; + var ga = ca & 0x00ff00; + var gd = (cb & 0x00ff00) - ga; + var ba = ca & 0xff0000; + var bd = (cb & 0xff0000) - ba; + + return function(t) { + + var r = (ra + rd * t) & 0x000000ff; + var g = (ga + gd * t) & 0x0000ff00; + var b = (ba + bd * t) & 0x00ff0000; + + return '#' + (1 << 24 | r | g | b).toString(16).slice(1); + }; + }, + + unit: function(a, b) { + + var r = /(-?[0-9]*.[0-9]*)(px|em|cm|mm|in|pt|pc|%)/; + var ma = r.exec(a); + var mb = r.exec(b); + var p = mb[1].indexOf('.'); + var f = p > 0 ? mb[1].length - p - 1 : 0; + a = +ma[1]; + var d = +mb[1] - a; + var u = ma[2]; + + return function(t) { + return (a + d * t).toFixed(f) + u; + }; + } + }; + + // SVG filters. + // (values in parentheses are default values) + var filter = { + + // `color` ... outline color ('blue') + // `width`... outline width (1) + // `opacity` ... outline opacity (1) + // `margin` ... gap between outline and the element (2) + outline: function(args) { + + var tpl = ''; + + var margin = Number.isFinite(args.margin) ? args.margin : 2; + var width = Number.isFinite(args.width) ? args.width : 1; + + return template(tpl)({ + color: args.color || 'blue', + opacity: Number.isFinite(args.opacity) ? args.opacity : 1, + outerRadius: margin + width, + innerRadius: margin + }); + }, + + // `color` ... color ('red') + // `width`... width (1) + // `blur` ... blur (0) + // `opacity` ... opacity (1) + highlight: function(args) { + + var tpl = ''; + + return template(tpl)({ + color: args.color || 'red', + width: Number.isFinite(args.width) ? args.width : 1, + blur: Number.isFinite(args.blur) ? args.blur : 0, + opacity: Number.isFinite(args.opacity) ? args.opacity : 1 + }); + }, + + // `x` ... horizontal blur (2) + // `y` ... vertical blur (optional) + blur: function(args) { + + var x = Number.isFinite(args.x) ? args.x : 2; + + return template('')({ + stdDeviation: Number.isFinite(args.y) ? [x, args.y] : x + }); + }, + + // `dx` ... horizontal shift (0) + // `dy` ... vertical shift (0) + // `blur` ... blur (4) + // `color` ... color ('black') + // `opacity` ... opacity (1) + dropShadow: function(args) { + + var tpl = 'SVGFEDropShadowElement' in window + ? '' + : ''; + + return template(tpl)({ + dx: args.dx || 0, + dy: args.dy || 0, + opacity: Number.isFinite(args.opacity) ? args.opacity : 1, + color: args.color || 'black', + blur: Number.isFinite(args.blur) ? args.blur : 4 + }); + }, + + // `amount` ... the proportion of the conversion (1). A value of 1 (default) is completely grayscale. A value of 0 leaves the input unchanged. + grayscale: function(args) { + + var amount = Number.isFinite(args.amount) ? args.amount : 1; + + return template('')({ + a: 0.2126 + 0.7874 * (1 - amount), + b: 0.7152 - 0.7152 * (1 - amount), + c: 0.0722 - 0.0722 * (1 - amount), + d: 0.2126 - 0.2126 * (1 - amount), + e: 0.7152 + 0.2848 * (1 - amount), + f: 0.0722 - 0.0722 * (1 - amount), + g: 0.2126 - 0.2126 * (1 - amount), + h: 0.0722 + 0.9278 * (1 - amount) + }); + }, + + // `amount` ... the proportion of the conversion (1). A value of 1 (default) is completely sepia. A value of 0 leaves the input unchanged. + sepia: function(args) { + + var amount = Number.isFinite(args.amount) ? args.amount : 1; + + return template('')({ + a: 0.393 + 0.607 * (1 - amount), + b: 0.769 - 0.769 * (1 - amount), + c: 0.189 - 0.189 * (1 - amount), + d: 0.349 - 0.349 * (1 - amount), + e: 0.686 + 0.314 * (1 - amount), + f: 0.168 - 0.168 * (1 - amount), + g: 0.272 - 0.272 * (1 - amount), + h: 0.534 - 0.534 * (1 - amount), + i: 0.131 + 0.869 * (1 - amount) + }); + }, + + // `amount` ... the proportion of the conversion (1). A value of 0 is completely un-saturated. A value of 1 (default) leaves the input unchanged. + saturate: function(args) { + + var amount = Number.isFinite(args.amount) ? args.amount : 1; + + return template('')({ + amount: 1 - amount + }); + }, + + // `angle` ... the number of degrees around the color circle the input samples will be adjusted (0). + hueRotate: function(args) { + + return template('')({ + angle: args.angle || 0 + }); + }, + + // `amount` ... the proportion of the conversion (1). A value of 1 (default) is completely inverted. A value of 0 leaves the input unchanged. + invert: function(args) { + + var amount = Number.isFinite(args.amount) ? args.amount : 1; + + return template('')({ + amount: amount, + amount2: 1 - amount + }); + }, + + // `amount` ... proportion of the conversion (1). A value of 0 will create an image that is completely black. A value of 1 (default) leaves the input unchanged. + brightness: function(args) { + + return template('')({ + amount: Number.isFinite(args.amount) ? args.amount : 1 + }); + }, + + // `amount` ... proportion of the conversion (1). A value of 0 will create an image that is completely black. A value of 1 (default) leaves the input unchanged. + contrast: function(args) { + + var amount = Number.isFinite(args.amount) ? args.amount : 1; + + return template('')({ + amount: amount, + amount2: .5 - amount / 2 + }); + } + }; + + var format = { + + // Formatting numbers via the Python Format Specification Mini-language. + // See http://docs.python.org/release/3.1.3/library/string.html#format-specification-mini-language. + // Heavilly inspired by the D3.js library implementation. + number: function(specifier, value, locale) { + + locale = locale || { + + currency: ['$', ''], + decimal: '.', + thousands: ',', + grouping: [3] + }; + + // See Python format specification mini-language: http://docs.python.org/release/3.1.3/library/string.html#format-specification-mini-language. + // [[fill]align][sign][symbol][0][width][,][.precision][type] + var re = /(?:([^{])?([<>=^]))?([+\- ])?([$#])?(0)?(\d+)?(,)?(\.-?\d+)?([a-z%])?/i; + + var match = re.exec(specifier); + var fill = match[1] || ' '; + var align = match[2] || '>'; + var sign = match[3] || ''; + var symbol = match[4] || ''; + var zfill = match[5]; + var width = +match[6]; + var comma = match[7]; + var precision = match[8]; + var type = match[9]; + var scale = 1; + var prefix = ''; + var suffix = ''; + var integer = false; + + if (precision) { precision = +precision.substring(1); } + + if (zfill || fill === '0' && align === '=') { + zfill = fill = '0'; + align = '='; + if (comma) { width -= Math.floor((width - 1) / 4); } + } + + switch (type) { + case 'n': + comma = true; + type = 'g'; + break; + case '%': + scale = 100; + suffix = '%'; + type = 'f'; + break; + case 'p': + scale = 100; + suffix = '%'; + type = 'r'; + break; + case 'b': + case 'o': + case 'x': + case 'X': + if (symbol === '#') { prefix = '0' + type.toLowerCase(); } + break; + case 'c': + case 'd': + integer = true; + precision = 0; + break; + case 's': + scale = -1; + type = 'r'; + break; + } + + if (symbol === '$') { + prefix = locale.currency[0]; + suffix = locale.currency[1]; + } + + // If no precision is specified for `'r'`, fallback to general notation. + if (type == 'r' && !precision) { type = 'g'; } + + // Ensure that the requested precision is in the supported range. + if (precision != null) { + if (type == 'g') { precision = Math.max(1, Math.min(21, precision)); } + else if (type == 'e' || type == 'f') { precision = Math.max(0, Math.min(20, precision)); } + } + + var zcomma = zfill && comma; + + // Return the empty string for floats formatted as ints. + if (integer && (value % 1)) { return ''; } + + // Convert negative to positive, and record the sign prefix. + var negative = value < 0 || value === 0 && 1 / value < 0 ? (value = -value, '-') : sign; + + var fullSuffix = suffix; + + // Apply the scale, computing it from the value's exponent for si format. + // Preserve the existing suffix, if any, such as the currency symbol. + if (scale < 0) { + var unit = this.prefix(value, precision); + value = unit.scale(value); + fullSuffix = unit.symbol + suffix; + } else { + value *= scale; + } + + // Convert to the desired precision. + value = this.convert(type, value, precision); + + // Break the value into the integer part (before) and decimal part (after). + var i = value.lastIndexOf('.'); + var before = i < 0 ? value : value.substring(0, i); + var after = i < 0 ? '' : locale.decimal + value.substring(i + 1); + + function formatGroup(value) { + + var i = value.length; + var t = []; + var j = 0; + var g = locale.grouping[0]; + while (i > 0 && g > 0) { + t.push(value.substring(i -= g, i + g)); + g = locale.grouping[j = (j + 1) % locale.grouping.length]; + } + return t.reverse().join(locale.thousands); + } + + // If the fill character is not `'0'`, grouping is applied before padding. + if (!zfill && comma && locale.grouping) { + + before = formatGroup(before); + } + + var length = prefix.length + before.length + after.length + (zcomma ? 0 : negative.length); + var padding = length < width ? new Array(length = width - length + 1).join(fill) : ''; + + // If the fill character is `'0'`, grouping is applied after padding. + if (zcomma) { before = formatGroup(padding + before); } + + // Apply prefix. + negative += prefix; + + // Rejoin integer and decimal parts. + value = before + after; + + return (align === '<' ? negative + value + padding + : align === '>' ? padding + negative + value + : align === '^' ? padding.substring(0, length >>= 1) + negative + value + padding.substring(length) + : negative + (zcomma ? value : padding + value)) + fullSuffix; + }, + + // Formatting string via the Python Format string. + // See https://docs.python.org/2/library/string.html#format-string-syntax) + string: function(formatString, value) { + + var fieldDelimiterIndex; + var fieldDelimiter = '{'; + var endPlaceholder = false; + var formattedStringArray = []; + + while ((fieldDelimiterIndex = formatString.indexOf(fieldDelimiter)) !== -1) { + + var pieceFormattedString, formatSpec, fieldName; + + pieceFormattedString = formatString.slice(0, fieldDelimiterIndex); + + if (endPlaceholder) { + formatSpec = pieceFormattedString.split(':'); + fieldName = formatSpec.shift().split('.'); + pieceFormattedString = value; + + for (var i = 0; i < fieldName.length; i++) + { pieceFormattedString = pieceFormattedString[fieldName[i]]; } + + if (formatSpec.length) + { pieceFormattedString = this.number(formatSpec, pieceFormattedString); } + } + + formattedStringArray.push(pieceFormattedString); + + formatString = formatString.slice(fieldDelimiterIndex + 1); + endPlaceholder = !endPlaceholder; + fieldDelimiter = (endPlaceholder) ? '}' : '{'; + } + formattedStringArray.push(formatString); + + return formattedStringArray.join(''); + }, + + convert: function(type, value, precision) { + + switch (type) { + case 'b': + return value.toString(2); + case 'c': + return String.fromCharCode(value); + case 'o': + return value.toString(8); + case 'x': + return value.toString(16); + case 'X': + return value.toString(16).toUpperCase(); + case 'g': + return value.toPrecision(precision); + case 'e': + return value.toExponential(precision); + case 'f': + return value.toFixed(precision); + case 'r': + return (value = this.round(value, this.precision(value, precision))).toFixed(Math.max(0, Math.min(20, this.precision(value * (1 + 1e-15), precision)))); + default: + return value + ''; + } + }, + + round: function(value, precision) { + + return precision + ? Math.round(value * (precision = Math.pow(10, precision))) / precision + : Math.round(value); + }, + + precision: function(value, precision) { + + return precision - (value ? Math.ceil(Math.log(value) / Math.LN10) : 1); + }, + + prefix: function(value, precision) { + + var prefixes = ['y', 'z', 'a', 'f', 'p', 'n', 'µ', 'm', '', 'k', 'M', 'G', 'T', 'P', 'E', 'Z', 'Y'].map(function(d, i) { + var k = Math.pow(10, Math.abs(8 - i) * 3); + return { + scale: i > 8 ? function(d) { + return d / k; + } : function(d) { + return d * k; + }, + symbol: d + }; + }); + + var i = 0; + if (value) { + if (value < 0) { value *= -1; } + if (precision) { value = this.round(value, this.precision(value, precision)); } + i = 1 + Math.floor(1e-12 + Math.log(value) / Math.LN10); + i = Math.max(-24, Math.min(24, Math.floor((i <= 0 ? i + 1 : i - 1) / 3) * 3)); + } + return prefixes[8 + i / 3]; + } + }; + + /* + Pre-compile the HTML to be used as a template. + */ + var template = function(html) { + + /* + Must support the variation in templating syntax found here: + https://lodash.com/docs#template + */ + var regex = /<%= ([^ ]+) %>|\$\{ ?([^{} ]+) ?\}|\{\{([^{} ]+)\}\}/g; + + return function(data) { + + data = data || {}; + + return html.replace(regex, function(match) { + + var args = Array.from(arguments); + var attr = args.slice(1, 4).find(function(_attr) { + return !!_attr; + }); + + var attrArray = attr.split('.'); + var value = data[attrArray.shift()]; + + while (value !== undefined && attrArray.length) { + value = value[attrArray.shift()]; + } + + return value !== undefined ? value : ''; + }); + }; + }; + + /** + * @param {Element} el Element, which content is intent to display in full-screen mode, 'window.top.document.body' is default. + */ + var toggleFullScreen = function(el) { + + var topDocument = window.top.document; + el = el || topDocument.body; + + function prefixedResult(el, prop) { + + var prefixes = ['webkit', 'moz', 'ms', 'o', '']; + for (var i = 0; i < prefixes.length; i++) { + var prefix = prefixes[i]; + var propName = prefix ? (prefix + prop) : (prop.substr(0, 1).toLowerCase() + prop.substr(1)); + if (el[propName] !== undefined) { + return isFunction(el[propName]) ? el[propName]() : el[propName]; + } + } + } + + if (prefixedResult(topDocument, 'FullscreenElement') || prefixedResult(topDocument, 'FullScreenElement')) { + prefixedResult(topDocument, 'ExitFullscreen') || // Spec. + prefixedResult(topDocument, 'CancelFullScreen'); // Firefox + } else { + prefixedResult(el, 'RequestFullscreen') || // Spec. + prefixedResult(el, 'RequestFullScreen'); // Firefox + } + }; + + // Deprecated + // Copy all the properties to the first argument from the following arguments. + // All the properties will be overwritten by the properties from the following + // arguments. Inherited properties are ignored. + var mixin = _.assign; + + // Deprecated + // Copy all properties to the first argument from the following + // arguments only in case if they don't exists in the first argument. + // All the function propererties in the first argument will get + // additional property base pointing to the extenders same named + // property function's call method. + var supplement = _.defaults; + + // Same as `mixin()` but deep version. + var deepMixin = mixin; + + // Deprecated + // Same as `supplement()` but deep version. + var deepSupplement = _.defaultsDeep; + + // Replacements for deprecated functions + var assign = _.assign; + var defaults = _.defaults; + // no better-named replacement for `deepMixin` + var defaultsDeep = _.defaultsDeep; + + // Lodash 3 vs 4 incompatible + var invoke = _.invokeMap || _.invoke; + var sortedIndex = _.sortedIndexBy || _.sortedIndex; + var uniq = _.uniqBy || _.uniq; + + var clone = _.clone; + var cloneDeep = _.cloneDeep; + var isEmpty = _.isEmpty; + var isEqual = _.isEqual; + var isFunction = _.isFunction; + var isPlainObject = _.isPlainObject; + var toArray = _.toArray; + var debounce = _.debounce; + var groupBy = _.groupBy; + var sortBy = _.sortBy; + var flattenDeep = _.flattenDeep; + var without = _.without; + var difference = _.difference; + var intersection$1 = _.intersection; + var union = _.union; + var has$2 = _.has; + var result = _.result; + var omit = _.omit; + var pick = _.pick; + var bindAll = _.bindAll; + var forIn = _.forIn; + var camelCase = _.camelCase; + var uniqueId = _.uniqueId; + + var merge = function() { + if (_.mergeWith) { + var args = Array.from(arguments); + var last = args[args.length - 1]; + + var customizer = isFunction(last) ? last : noop; + args.push(function(a, b) { + var customResult = customizer(a, b); + if (customResult !== undefined) { + return customResult; + } + + if (Array.isArray(a) && !Array.isArray(b)) { + return b; + } + }); + + return _.mergeWith.apply(this, args); + } + return _.merge.apply(this, arguments); + }; + + var isBoolean = function(value) { + var toString = Object.prototype.toString; + return value === true || value === false || (!!value && typeof value === 'object' && toString.call(value) === '[object Boolean]'); + }; + + var isObject$1 = function(value) { + return !!value && (typeof value === 'object' || typeof value === 'function'); + }; + + var isNumber = function(value) { + var toString = Object.prototype.toString; + return typeof value === 'number' || (!!value && typeof value === 'object' && toString.call(value) === '[object Number]'); + }; + + var isString = function(value) { + var toString = Object.prototype.toString; + return typeof value === 'string' || (!!value && typeof value === 'object' && toString.call(value) === '[object String]'); + }; + + var noop = function() { + }; + + // Clone `cells` returning an object that maps the original cell ID to the clone. The number + // of clones is exactly the same as the `cells.length`. + // This function simply clones all the `cells`. However, it also reconstructs + // all the `source/target` and `parent/embed` references within the `cells`. + // This is the main difference from the `cell.clone()` method. The + // `cell.clone()` method works on one single cell only. + // For example, for a graph: `A --- L ---> B`, `cloneCells([A, L, B])` + // returns `[A2, L2, B2]` resulting to a graph: `A2 --- L2 ---> B2`, i.e. + // the source and target of the link `L2` is changed to point to `A2` and `B2`. + function cloneCells(cells) { + + cells = uniq(cells); + + // A map of the form [original cell ID] -> [clone] helping + // us to reconstruct references for source/target and parent/embeds. + // This is also the returned value. + var cloneMap = toArray(cells).reduce(function(map, cell) { + map[cell.id] = cell.clone(); + return map; + }, {}); + + toArray(cells).forEach(function(cell) { + + var clone = cloneMap[cell.id]; + // assert(clone exists) + + if (clone.isLink()) { + var source = clone.source(); + var target = clone.target(); + if (source.id && cloneMap[source.id]) { + // Source points to an element and the element is among the clones. + // => Update the source of the cloned link. + clone.prop('source/id', cloneMap[source.id].id); + } + if (target.id && cloneMap[target.id]) { + // Target points to an element and the element is among the clones. + // => Update the target of the cloned link. + clone.prop('target/id', cloneMap[target.id].id); + } + } + + // Find the parent of the original cell + var parent = cell.get('parent'); + if (parent && cloneMap[parent]) { + clone.set('parent', cloneMap[parent].id); + } + + // Find the embeds of the original cell + var embeds = toArray(cell.get('embeds')).reduce(function(newEmbeds, embed) { + // Embedded cells that are not being cloned can not be carried + // over with other embedded cells. + if (cloneMap[embed]) { + newEmbeds.push(cloneMap[embed].id); + } + return newEmbeds; + }, []); + + if (!isEmpty(embeds)) { + clone.set('embeds', embeds); + } + }); + + return cloneMap; + } + + function setWrapper(attrName, dimension) { + return function(value, refBBox) { + var isValuePercentage = isPercentage(value); + value = parseFloat(value); + if (isValuePercentage) { + value /= 100; + } + + var attrs = {}; + if (isFinite(value)) { + var attrValue = (isValuePercentage || value >= 0 && value <= 1) + ? value * refBBox[dimension] + : Math.max(value + refBBox[dimension], 0); + attrs[attrName] = attrValue; + } + + return attrs; + }; + } + + function positionWrapper(axis, dimension, origin) { + return function(value, refBBox) { + var valuePercentage = isPercentage(value); + value = parseFloat(value); + if (valuePercentage) { + value /= 100; + } + + var delta; + if (isFinite(value)) { + var refOrigin = refBBox[origin](); + if (valuePercentage || value > 0 && value < 1) { + delta = refOrigin[axis] + refBBox[dimension] * value; + } else { + delta = refOrigin[axis] + value; + } + } + + var point = Point(); + point[axis] = delta || 0; + return point; + }; + } + + function offsetWrapper(axis, dimension, corner) { + return function(value, nodeBBox) { + var delta; + if (value === 'middle') { + delta = nodeBBox[dimension] / 2; + } else if (value === corner) { + delta = nodeBBox[dimension]; + } else if (isFinite(value)) { + // TODO: or not to do a breaking change? + delta = (value > -1 && value < 1) ? (-nodeBBox[dimension] * value) : -value; + } else if (isPercentage(value)) { + delta = nodeBBox[dimension] * parseFloat(value) / 100; + } else { + delta = 0; + } + + var point = Point(); + point[axis] = -(nodeBBox[axis] + delta); + return point; + }; + } + + function shapeWrapper(shapeConstructor, opt) { + var cacheName = 'joint-shape'; + var resetOffset = opt && opt.resetOffset; + return function(value, refBBox, node) { + var $node = $(node); + var cache = $node.data(cacheName); + if (!cache || cache.value !== value) { + // only recalculate if value has changed + var cachedShape = shapeConstructor(value); + cache = { + value: value, + shape: cachedShape, + shapeBBox: cachedShape.bbox() + }; + $node.data(cacheName, cache); + } + + var shape = cache.shape.clone(); + var shapeBBox = cache.shapeBBox.clone(); + var shapeOrigin = shapeBBox.origin(); + var refOrigin = refBBox.origin(); + + shapeBBox.x = refOrigin.x; + shapeBBox.y = refOrigin.y; + + var fitScale = refBBox.maxRectScaleToFit(shapeBBox, refOrigin); + // `maxRectScaleToFit` can give Infinity if width or height is 0 + var sx = (shapeBBox.width === 0 || refBBox.width === 0) ? 1 : fitScale.sx; + var sy = (shapeBBox.height === 0 || refBBox.height === 0) ? 1 : fitScale.sy; + + shape.scale(sx, sy, shapeOrigin); + if (resetOffset) { + shape.translate(-shapeOrigin.x, -shapeOrigin.y); + } + + return shape; + }; + } + + // `d` attribute for SVGPaths + function dWrapper(opt) { + function pathConstructor(value) { + return new Path(V.normalizePathData(value)); + } + + var shape = shapeWrapper(pathConstructor, opt); + return function(value, refBBox, node) { + var path = shape(value, refBBox, node); + return { + d: path.serialize() + }; + }; + } + + // `points` attribute for SVGPolylines and SVGPolygons + function pointsWrapper(opt) { + var shape = shapeWrapper(Polyline, opt); + return function(value, refBBox, node) { + var polyline = shape(value, refBBox, node); + return { + points: polyline.serialize() + }; + }; + } + + function atConnectionWrapper(method, opt) { + var zeroVector = new Point(1, 0); + return function(value) { + var p, angle; + var tangent = this[method](value); + if (tangent) { + angle = (opt.rotate) ? tangent.vector().vectorAngle(zeroVector) : 0; + p = tangent.start; + } else { + p = this.path.start; + angle = 0; + } + if (angle === 0) { return { transform: 'translate(' + p.x + ',' + p.y + ')' }; } + return { transform: 'translate(' + p.x + ',' + p.y + ') rotate(' + angle + ')' }; + }; + } + + function setIfChangedWrapper(attribute) { + return function setIfChanged(value, _, node) { + var vel = V(node); + if (vel.attr(attribute) === value) { return; } + vel.attr(attribute, value); + }; + } + + function isTextInUse(_value, _node, attrs) { + return (attrs.text !== undefined); + } + + function isLinkView() { + return this.model.isLink(); + } + + function contextMarker(context) { + var marker = {}; + // Stroke + // The context 'fill' is disregared here. The usual case is to use the marker with a connection + // (for which 'fill' attribute is set to 'none'). + var stroke = context.stroke; + if (typeof stroke === 'string') { + marker['stroke'] = stroke; + marker['fill'] = stroke; + } + // Opacity + // Again the context 'fill-opacity' is ignored. + var strokeOpacity = context.strokeOpacity; + if (strokeOpacity === undefined) { strokeOpacity = context['stroke-opacity']; } + if (strokeOpacity === undefined) { strokeOpacity = context.opacity; } + if (strokeOpacity !== undefined) { + marker['stroke-opacity'] = strokeOpacity; + marker['fill-opacity'] = strokeOpacity; + } + return marker; + } + + function setPaintURL(def) { + var ref = this; + var paper = ref.paper; + var url = (def.type === 'pattern') + ? paper.definePattern(def) + : paper.defineGradient(def); + return ("url(#" + url + ")"); + } + + var attributesNS = { + + xlinkShow: { + set: 'xlink:show' + }, + + xlinkRole: { + set: 'xlink:role' + }, + + xlinkType: { + set: 'xlink:type' + }, + + xlinkArcrole: { + set: 'xlink:arcrole' + }, + + xlinkTitle: { + set: 'xlink:title' + }, + + xlinkActuate: { + set: 'xlink:actuate' + }, + + xmlSpace: { + set: 'xml:space' + }, + + xmlBase: { + set: 'xml:base' + }, + + xmlLang: { + set: 'xml:lang' + }, + + preserveAspectRatio: { + set: 'preserveAspectRatio' + }, + + requiredExtension: { + set: 'requiredExtension' + }, + + requiredFeatures: { + set: 'requiredFeatures' + }, + + systemLanguage: { + set: 'systemLanguage' + }, + + externalResourcesRequired: { + set: 'externalResourceRequired' + }, + + href: { + set: setIfChangedWrapper('href') + }, + + xlinkHref: { + set: setIfChangedWrapper('xlink:href') + }, + + filter: { + qualify: isPlainObject, + set: function(filter) { + return 'url(#' + this.paper.defineFilter(filter) + ')'; + } + }, + + fill: { + qualify: isPlainObject, + set: setPaintURL + }, + + stroke: { + qualify: isPlainObject, + set: setPaintURL + }, + + sourceMarker: { + qualify: isPlainObject, + set: function(marker, refBBox, node, attrs) { + marker = assign(contextMarker(attrs), marker); + return { 'marker-start': 'url(#' + this.paper.defineMarker(marker) + ')' }; + } + }, + + targetMarker: { + qualify: isPlainObject, + set: function(marker, refBBox, node, attrs) { + marker = assign(contextMarker(attrs), { 'transform': 'rotate(180)' }, marker); + return { 'marker-end': 'url(#' + this.paper.defineMarker(marker) + ')' }; + } + }, + + vertexMarker: { + qualify: isPlainObject, + set: function(marker, refBBox, node, attrs) { + marker = assign(contextMarker(attrs), marker); + return { 'marker-mid': 'url(#' + this.paper.defineMarker(marker) + ')' }; + } + }, + + text: { + qualify: function(_text, _node, attrs) { + return !attrs.textWrap || !isPlainObject(attrs.textWrap); + }, + set: function(text, refBBox, node, attrs) { + var $node = $(node); + var cacheName = 'joint-text'; + var cache = $node.data(cacheName); + var textAttrs = pick(attrs, 'lineHeight', 'annotations', 'textPath', 'x', 'textVerticalAnchor', 'eol', 'displayEmpty'); + // eval `x` if using calc() + var x = textAttrs.x; + if (isCalcAttribute(x)) { + textAttrs.x = evalCalcAttribute(x, refBBox); + } + + var fontSizeAttr = attrs['font-size'] || attrs['fontSize']; + if (isCalcAttribute(fontSizeAttr)) { + fontSizeAttr = evalCalcAttribute(fontSizeAttr, refBBox); + } + var fontSize = textAttrs.fontSize = fontSizeAttr; + var textHash = JSON.stringify([text, textAttrs]); + // Update the text only if there was a change in the string + // or any of its attributes. + if (cache === undefined || cache !== textHash) { + // Chrome bug: + // Tspans positions defined as `em` are not updated + // when container `font-size` change. + if (fontSize) { node.setAttribute('font-size', fontSize); } + // Text Along Path Selector + var textPath = textAttrs.textPath; + if (isObject$1(textPath)) { + var pathSelector = textPath.selector; + if (typeof pathSelector === 'string') { + var pathNode = this.findBySelector(pathSelector)[0]; + if (pathNode instanceof SVGPathElement) { + textAttrs.textPath = assign({ 'xlink:href': '#' + pathNode.id }, textPath); + } + } + } + V(node).text('' + text, textAttrs); + $node.data(cacheName, textHash); + } + } + }, + + textWrap: { + qualify: isPlainObject, + set: function(value, refBBox, node, attrs) { + var size = {}; + // option `width` + var width = value.width || 0; + if (isPercentage(width)) { + size.width = refBBox.width * parseFloat(width) / 100; + } else if (isCalcAttribute(width)) { + size.width = Number(evalCalcAttribute(width, refBBox)); + } else { + if (value.width === null) { + // breakText() requires width to be specified. + size.width = Infinity; + } else if (width <= 0) { + size.width = refBBox.width + width; + } else { + size.width = width; + } + } + // option `height` + var height = value.height || 0; + if (isPercentage(height)) { + size.height = refBBox.height * parseFloat(height) / 100; + } else if (isCalcAttribute(height)) { + size.height = Number(evalCalcAttribute(height, refBBox)); + } else { + if (value.height === null) { + // if height is not specified breakText() does not + // restrict the height of the text. + } else if (height <= 0) { + size.height = refBBox.height + height; + } else { + size.height = height; + } + } + // option `text` + var wrappedText; + var text = value.text; + if (text === undefined) { text = attrs.text; } + if (text !== undefined) { + var breakTextFn = value.breakText || breakText; + var fontSizeAttr = attrs['font-size'] || attrs.fontSize; + wrappedText = breakTextFn('' + text, size, { + 'font-weight': attrs['font-weight'] || attrs.fontWeight, + 'font-size': isCalcAttribute(fontSizeAttr) ? evalCalcAttribute(fontSizeAttr, refBBox) : fontSizeAttr, + 'font-family': attrs['font-family'] || attrs.fontFamily, + 'lineHeight': attrs.lineHeight, + 'letter-spacing': 'letter-spacing' in attrs ? attrs['letter-spacing'] : attrs.letterSpacing + }, { + // Provide an existing SVG Document here + // instead of creating a temporary one over again. + svgDocument: this.paper.svg, + ellipsis: value.ellipsis, + hyphen: value.hyphen, + maxLineCount: value.maxLineCount, + preserveSpaces: value.preserveSpaces + }); + } else { + wrappedText = ''; + } + attributesNS.text.set.call(this, wrappedText, refBBox, node, attrs); + } + }, + + title: { + qualify: function(title, node) { + // HTMLElement title is specified via an attribute (i.e. not an element) + return node instanceof SVGElement; + }, + set: function(title, refBBox, node) { + var $node = $(node); + var cacheName = 'joint-title'; + var cache = $node.data(cacheName); + if (cache === undefined || cache !== title) { + $node.data(cacheName, title); + // Generally element should be the first child element of its parent. + var firstChild = node.firstChild; + if (firstChild && firstChild.tagName.toUpperCase() === 'TITLE') { + // Update an existing title + firstChild.textContent = title; + } else { + // Create a new title + var titleNode = document.createElementNS(node.namespaceURI, 'title'); + titleNode.textContent = title; + node.insertBefore(titleNode, firstChild); + } + } + } + }, + + lineHeight: { + qualify: isTextInUse + }, + + textVerticalAnchor: { + qualify: isTextInUse + }, + + textPath: { + qualify: isTextInUse + }, + + annotations: { + qualify: isTextInUse + }, + + eol: { + qualify: isTextInUse + }, + + displayEmpty: { + qualify: isTextInUse + }, + + // `port` attribute contains the `id` of the port that the underlying magnet represents. + port: { + set: function(port) { + return (port === null || port.id === undefined) ? port : port.id; + } + }, + + // `style` attribute is special in the sense that it sets the CSS style of the subelement. + style: { + qualify: isPlainObject, + set: function(styles, refBBox, node) { + $(node).css(styles); + } + }, + + html: { + set: function(html, refBBox, node) { + $(node).html(html + ''); + } + }, + + ref: { + // We do not set `ref` attribute directly on an element. + // The attribute itself does not qualify for relative positioning. + }, + + // if `refX` is in [0, 1] then `refX` is a fraction of bounding box width + // if `refX` is < 0 then `refX`'s absolute values is the right coordinate of the bounding box + // otherwise, `refX` is the left coordinate of the bounding box + + refX: { + position: positionWrapper('x', 'width', 'origin') + }, + + refY: { + position: positionWrapper('y', 'height', 'origin') + }, + + // `ref-dx` and `ref-dy` define the offset of the subelement relative to the right and/or bottom + // coordinate of the reference element. + + refDx: { + position: positionWrapper('x', 'width', 'corner') + }, + + refDy: { + position: positionWrapper('y', 'height', 'corner') + }, + + // 'ref-width'/'ref-height' defines the width/height of the subelement relatively to + // the reference element size + // val in 0..1 ref-width = 0.75 sets the width to 75% of the ref. el. width + // val < 0 || val > 1 ref-height = -20 sets the height to the ref. el. height shorter by 20 + + refWidth: { + set: setWrapper('width', 'width') + }, + + refHeight: { + set: setWrapper('height', 'height') + }, + + refRx: { + set: setWrapper('rx', 'width') + }, + + refRy: { + set: setWrapper('ry', 'height') + }, + + refRInscribed: { + set: (function(attrName) { + var widthFn = setWrapper(attrName, 'width'); + var heightFn = setWrapper(attrName, 'height'); + return function(value, refBBox) { + var fn = (refBBox.height > refBBox.width) ? widthFn : heightFn; + return fn(value, refBBox); + }; + })('r') + }, + + refRCircumscribed: { + set: function(value, refBBox) { + var isValuePercentage = isPercentage(value); + value = parseFloat(value); + if (isValuePercentage) { + value /= 100; + } + + var diagonalLength = Math.sqrt((refBBox.height * refBBox.height) + (refBBox.width * refBBox.width)); + + var rValue; + if (isFinite(value)) { + if (isValuePercentage || value >= 0 && value <= 1) { rValue = value * diagonalLength; } + else { rValue = Math.max(value + diagonalLength, 0); } + } + + return { r: rValue }; + } + }, + + refCx: { + set: setWrapper('cx', 'width') + }, + + refCy: { + set: setWrapper('cy', 'height') + }, + + // `x-alignment` when set to `middle` causes centering of the subelement around its new x coordinate. + // `x-alignment` when set to `right` uses the x coordinate as referenced to the right of the bbox. + + xAlignment: { + offset: offsetWrapper('x', 'width', 'right') + }, + + // `y-alignment` when set to `middle` causes centering of the subelement around its new y coordinate. + // `y-alignment` when set to `bottom` uses the y coordinate as referenced to the bottom of the bbox. + + yAlignment: { + offset: offsetWrapper('y', 'height', 'bottom') + }, + + resetOffset: { + offset: function(val, nodeBBox) { + return (val) + ? { x: -nodeBBox.x, y: -nodeBBox.y } + : { x: 0, y: 0 }; + } + + }, + + refDResetOffset: { + set: dWrapper({ resetOffset: true }) + }, + + refDKeepOffset: { + set: dWrapper({ resetOffset: false }) + }, + + refPointsResetOffset: { + set: pointsWrapper({ resetOffset: true }) + }, + + refPointsKeepOffset: { + set: pointsWrapper({ resetOffset: false }) + }, + + // LinkView Attributes + + connection: { + qualify: isLinkView, + set: function(ref) { + var stubs = ref.stubs; if ( stubs === void 0 ) stubs = 0; + + var d; + if (isFinite(stubs) && stubs !== 0) { + var offset; + if (stubs < 0) { + offset = (this.getConnectionLength() + stubs) / 2; + } else { + offset = stubs; + } + var path = this.getConnection(); + var segmentSubdivisions = this.getConnectionSubdivisions(); + var sourceParts = path.divideAtLength(offset, { segmentSubdivisions: segmentSubdivisions }); + var targetParts = path.divideAtLength(-offset, { segmentSubdivisions: segmentSubdivisions }); + if (sourceParts && targetParts) { + d = (sourceParts[0].serialize()) + " " + (targetParts[1].serialize()); + } + } + + return { d: d || this.getSerializedConnection() }; + } + }, + + atConnectionLengthKeepGradient: { + qualify: isLinkView, + set: atConnectionWrapper('getTangentAtLength', { rotate: true }) + }, + + atConnectionLengthIgnoreGradient: { + qualify: isLinkView, + set: atConnectionWrapper('getTangentAtLength', { rotate: false }) + }, + + atConnectionRatioKeepGradient: { + qualify: isLinkView, + set: atConnectionWrapper('getTangentAtRatio', { rotate: true }) + }, + + atConnectionRatioIgnoreGradient: { + qualify: isLinkView, + set: atConnectionWrapper('getTangentAtRatio', { rotate: false }) + } + }; + + attributesNS['xlink:href'] = attributesNS.xlinkHref; + + // Support `calc()` with the following SVG attributes + [ + 'transform', // g + 'd', // path + 'points', // polyline / polygon + 'cx', 'cy', // circle / ellipse + 'x1', 'x2', 'y1', 'y2', // line + 'x', 'y', // rect / text / image + 'dx', 'dy' // text + ].forEach(function (attribute) { + attributesNS[attribute] = { + qualify: isCalcAttribute, + set: function setCalcAttribute(value, refBBox) { + var obj; + + return ( obj = {}, obj[attribute] = evalCalcAttribute(value, refBBox), obj ); + } + }; + }); + + // Prevent "A negative value is not valid" error. + [ + 'width', 'height', // rect / image + 'r', // circle + 'rx', 'ry', // rect / ellipse + 'font-size', // text + 'stroke-width' // elements + ].forEach(function (attribute) { + attributesNS[attribute] = { + qualify: isCalcAttribute, + set: function setCalcAttribute(value, refBBox) { + var obj; + + return ( obj = {}, obj[attribute] = Math.max(0, evalCalcAttribute(value, refBBox)), obj ); + } + }; + }); + + + // Aliases + attributesNS.refR = attributesNS.refRInscribed; + attributesNS.refD = attributesNS.refDResetOffset; + attributesNS.refPoints = attributesNS.refPointsResetOffset; + attributesNS.atConnectionLength = attributesNS.atConnectionLengthKeepGradient; + attributesNS.atConnectionRatio = attributesNS.atConnectionRatioKeepGradient; + attributesNS.fontSize = attributesNS['font-size']; + attributesNS.strokeWidth = attributesNS['stroke-width']; + + // This allows to combine both absolute and relative positioning + // refX: 50%, refX2: 20 + attributesNS.refX2 = attributesNS.refX; + attributesNS.refY2 = attributesNS.refY; + attributesNS.refWidth2 = attributesNS.refWidth; + attributesNS.refHeight2 = attributesNS.refHeight; + + // Aliases for backwards compatibility + attributesNS['ref-x'] = attributesNS.refX; + attributesNS['ref-y'] = attributesNS.refY; + attributesNS['ref-dy'] = attributesNS.refDy; + attributesNS['ref-dx'] = attributesNS.refDx; + attributesNS['ref-width'] = attributesNS.refWidth; + attributesNS['ref-height'] = attributesNS.refHeight; + attributesNS['x-alignment'] = attributesNS.xAlignment; + attributesNS['y-alignment'] = attributesNS.yAlignment; + + var attributes = attributesNS; + + // Cell base model. + // -------------------------- + + var Cell = Backbone.Model.extend({ + + // This is the same as Backbone.Model with the only difference that is uses util.merge + // instead of just _.extend. The reason is that we want to mixin attributes set in upper classes. + constructor: function(attributes, options) { + + var defaults; + var attrs = attributes || {}; + if (typeof this.preinitialize === 'function') { + // Check to support an older version of Backbone (prior v1.4) + this.preinitialize.apply(this, arguments); + } + this.cid = uniqueId('c'); + this.attributes = {}; + if (options && options.collection) { this.collection = options.collection; } + if (options && options.parse) { attrs = this.parse(attrs, options) || {}; } + if ((defaults = result(this, 'defaults'))) { + //<custom code> + // Replaced the call to _.defaults with util.merge. + attrs = merge({}, defaults, attrs); + //</custom code> + } + this.set(attrs, options); + this.changed = {}; + this.initialize.apply(this, arguments); + }, + + translate: function(dx, dy, opt) { + + throw new Error('Must define a translate() method.'); + }, + + toJSON: function() { + + var defaults = result(this.constructor.prototype, 'defaults'); + var defaultAttrs = defaults.attrs || {}; + var attrs = this.attributes.attrs; + var finalAttrs = {}; + + // Loop through all the attributes and + // omit the default attributes as they are implicitly reconstructible by the cell 'type'. + forIn(attrs, function(attr, selector) { + + var defaultAttr = defaultAttrs[selector]; + + forIn(attr, function(value, name) { + + // attr is mainly flat though it might have one more level (consider the `style` attribute). + // Check if the `value` is object and if yes, go one level deep. + if (isObject$1(value) && !Array.isArray(value)) { + + forIn(value, function(value2, name2) { + + if (!defaultAttr || !defaultAttr[name] || !isEqual(defaultAttr[name][name2], value2)) { + + finalAttrs[selector] = finalAttrs[selector] || {}; + (finalAttrs[selector][name] || (finalAttrs[selector][name] = {}))[name2] = value2; + } + }); + + } else if (!defaultAttr || !isEqual(defaultAttr[name], value)) { + // `value` is not an object, default attribute for such a selector does not exist + // or it is different than the attribute value set on the model. + + finalAttrs[selector] = finalAttrs[selector] || {}; + finalAttrs[selector][name] = value; + } + }); + }); + + var attributes = cloneDeep(omit(this.attributes, 'attrs')); + attributes.attrs = finalAttrs; + + return attributes; + }, + + initialize: function(options) { + + var idAttribute = this.getIdAttribute(); + if (!options || !(idAttribute in options)) { + this.set(idAttribute, this.generateId(), { silent: true }); + } + + this._transitionIds = {}; + this._scheduledTransitionIds = {}; + + // Collect ports defined in `attrs` and keep collecting whenever `attrs` object changes. + this.processPorts(); + this.on('change:attrs', this.processPorts, this); + }, + + getIdAttribute: function() { + return this.idAttribute || 'id'; + }, + + generateId: function() { + return uuid(); + }, + + /** + * @deprecated + */ + processPorts: function() { + + // Whenever `attrs` changes, we extract ports from the `attrs` object and store it + // in a more accessible way. Also, if any port got removed and there were links that had `target`/`source` + // set to that port, we remove those links as well (to follow the same behaviour as + // with a removed element). + + var previousPorts = this.ports; + + // Collect ports from the `attrs` object. + var ports = {}; + forIn(this.get('attrs'), function(attrs, selector) { + + if (attrs && attrs.port) { + + // `port` can either be directly an `id` or an object containing an `id` (and potentially other data). + if (attrs.port.id !== undefined) { + ports[attrs.port.id] = attrs.port; + } else { + ports[attrs.port] = { id: attrs.port }; + } + } + }); + + // Collect ports that have been removed (compared to the previous ports) - if any. + // Use hash table for quick lookup. + var removedPorts = {}; + forIn(previousPorts, function(port, id) { + + if (!ports[id]) { removedPorts[id] = true; } + }); + + // Remove all the incoming/outgoing links that have source/target port set to any of the removed ports. + if (this.graph && !isEmpty(removedPorts)) { + + var inboundLinks = this.graph.getConnectedLinks(this, { inbound: true }); + inboundLinks.forEach(function(link) { + + if (removedPorts[link.get('target').port]) { link.remove(); } + }); + + var outboundLinks = this.graph.getConnectedLinks(this, { outbound: true }); + outboundLinks.forEach(function(link) { + + if (removedPorts[link.get('source').port]) { link.remove(); } + }); + } + + // Update the `ports` object. + this.ports = ports; + }, + + remove: function(opt) { + if ( opt === void 0 ) opt = {}; + + + // Store the graph in a variable because `this.graph` won't be accessible + // after `this.trigger('remove', ...)` down below. + var ref = this; + var graph = ref.graph; + var collection = ref.collection; + if (!graph) { + // The collection is a common Backbone collection (not the graph collection). + if (collection) { collection.remove(this, opt); } + return this; + } + + graph.startBatch('remove'); + + // First, unembed this cell from its parent cell if there is one. + var parentCell = this.getParentCell(); + if (parentCell) { + parentCell.unembed(this, opt); + } + + // Remove also all the cells, which were embedded into this cell + var embeddedCells = this.getEmbeddedCells(); + for (var i = 0, n = embeddedCells.length; i < n; i++) { + var embed = embeddedCells[i]; + if (embed) { + embed.remove(opt); + } + } + + this.trigger('remove', this, graph.attributes.cells, opt); + + graph.stopBatch('remove'); + + return this; + }, + + toFront: function(opt) { + + var graph = this.graph; + if (graph) { + + opt = opt || {}; + + var z = graph.maxZIndex(); + + var cells; + + if (opt.deep) { + cells = this.getEmbeddedCells({ deep: true, breadthFirst: opt.breadthFirst !== false }); + cells.unshift(this); + } else { + cells = [this]; + } + + z = z - cells.length + 1; + + var collection = graph.get('cells'); + var shouldUpdate = (collection.indexOf(this) !== (collection.length - cells.length)); + if (!shouldUpdate) { + shouldUpdate = cells.some(function(cell, index) { + return cell.get('z') !== z + index; + }); + } + + if (shouldUpdate) { + this.startBatch('to-front'); + + z = z + cells.length; + + cells.forEach(function(cell, index) { + cell.set('z', z + index, opt); + }); + + this.stopBatch('to-front'); + } + } + + return this; + }, + + toBack: function(opt) { + + var graph = this.graph; + if (graph) { + + opt = opt || {}; + + var z = graph.minZIndex(); + + var cells; + + if (opt.deep) { + cells = this.getEmbeddedCells({ deep: true, breadthFirst: opt.breadthFirst !== false }); + cells.unshift(this); + } else { + cells = [this]; + } + + var collection = graph.get('cells'); + var shouldUpdate = (collection.indexOf(this) !== 0); + if (!shouldUpdate) { + shouldUpdate = cells.some(function(cell, index) { + return cell.get('z') !== z + index; + }); + } + + if (shouldUpdate) { + this.startBatch('to-back'); + + z -= cells.length; + + cells.forEach(function(cell, index) { + cell.set('z', z + index, opt); + }); + + this.stopBatch('to-back'); + } + } + + return this; + }, + + parent: function(parent, opt) { + + // getter + if (parent === undefined) { return this.get('parent'); } + // setter + return this.set('parent', parent, opt); + }, + + embed: function(cell, opt) { + var this$1 = this; + + var cells = Array.isArray(cell) ? cell : [cell]; + if (!this.canEmbed(cells)) { + throw new Error('Recursive embedding not allowed.'); + } + if (cells.some(function (c) { return c.isEmbedded() && this$1.id !== c.parent(); })) { + throw new Error('Embedding of already embedded cells is not allowed.'); + } + this._embedCells(cells, opt); + return this; + }, + + unembed: function(cell, opt) { + var cells = Array.isArray(cell) ? cell : [cell]; + this._unembedCells(cells, opt); + return this; + }, + + canEmbed: function(cell) { + var this$1 = this; + + var cells = Array.isArray(cell) ? cell : [cell]; + return cells.every(function (c) { return this$1 !== c && !this$1.isEmbeddedIn(c); }); + }, + + _embedCells: function(cells, opt) { + var this$1 = this; + + var batchName = 'embed'; + this.startBatch(batchName); + var embeds = assign([], this.get('embeds')); + cells.forEach(function (cell) { + // We keep all element ids after link ids. + embeds[cell.isLink() ? 'unshift' : 'push'](cell.id); + cell.parent(this$1.id, opt); + }); + this.set('embeds', uniq(embeds), opt); + this.stopBatch(batchName); + }, + + _unembedCells: function(cells, opt) { + var batchName = 'unembed'; + this.startBatch(batchName); + cells.forEach(function (cell) { return cell.unset('parent', opt); }); + this.set('embeds', without.apply(void 0, [ this.get('embeds') ].concat( cells.map(function (cell) { return cell.id; }) )), opt); + this.stopBatch(batchName); + }, + + getParentCell: function() { + + // unlike link.source/target, cell.parent stores id directly as a string + var parentId = this.parent(); + var graph = this.graph; + + return (parentId && graph && graph.getCell(parentId)) || null; + }, + + // Return an array of ancestor cells. + // The array is ordered from the parent of the cell + // to the most distant ancestor. + getAncestors: function() { + + var ancestors = []; + + if (!this.graph) { + return ancestors; + } + + var parentCell = this.getParentCell(); + while (parentCell) { + ancestors.push(parentCell); + parentCell = parentCell.getParentCell(); + } + + return ancestors; + }, + + getEmbeddedCells: function(opt) { + + opt = opt || {}; + + // Cell models can only be retrieved when this element is part of a collection. + // There is no way this element knows about other cells otherwise. + // This also means that calling e.g. `translate()` on an element with embeds before + // adding it to a graph does not translate its embeds. + if (this.graph) { + + var cells; + + if (opt.deep) { + + if (opt.breadthFirst) { + + // breadthFirst algorithm + cells = []; + var queue = this.getEmbeddedCells(); + + while (queue.length > 0) { + + var parent = queue.shift(); + cells.push(parent); + queue.push.apply(queue, parent.getEmbeddedCells()); + } + + } else { + + // depthFirst algorithm + cells = this.getEmbeddedCells(); + cells.forEach(function(cell) { + cells.push.apply(cells, cell.getEmbeddedCells(opt)); + }); + } + + } else { + + cells = toArray(this.get('embeds')).map(this.graph.getCell, this.graph); + } + + return cells; + } + return []; + }, + + isEmbeddedIn: function(cell, opt) { + + var cellId = isString(cell) ? cell : cell.id; + var parentId = this.parent(); + + opt = assign({ deep: true }, opt); + + // See getEmbeddedCells(). + if (this.graph && opt.deep) { + + while (parentId) { + if (parentId === cellId) { + return true; + } + parentId = this.graph.getCell(parentId).parent(); + } + + return false; + + } else { + + // When this cell is not part of a collection check + // at least whether it's a direct child of given cell. + return parentId === cellId; + } + }, + + // Whether or not the cell is embedded in any other cell. + isEmbedded: function() { + + return !!this.parent(); + }, + + // Isolated cloning. Isolated cloning has two versions: shallow and deep (pass `{ deep: true }` in `opt`). + // Shallow cloning simply clones the cell and returns a new cell with different ID. + // Deep cloning clones the cell and all its embedded cells recursively. + clone: function(opt) { + + opt = opt || {}; + + if (!opt.deep) { + // Shallow cloning. + + var clone = Backbone.Model.prototype.clone.apply(this, arguments); + // We don't want the clone to have the same ID as the original. + clone.set(this.getIdAttribute(), this.generateId()); + // A shallow cloned element does not carry over the original embeds. + clone.unset('embeds'); + // And can not be embedded in any cell + // as the clone is not part of the graph. + clone.unset('parent'); + + return clone; + + } else { + // Deep cloning. + + // For a deep clone, simply call `graph.cloneCells()` with the cell and all its embedded cells. + return toArray(cloneCells([this].concat(this.getEmbeddedCells({ deep: true })))); + } + }, + + // A convenient way to set nested properties. + // This method merges the properties you'd like to set with the ones + // stored in the cell and makes sure change events are properly triggered. + // You can either set a nested property with one object + // or use a property path. + // The most simple use case is: + // `cell.prop('name/first', 'John')` or + // `cell.prop({ name: { first: 'John' } })`. + // Nested arrays are supported too: + // `cell.prop('series/0/data/0/degree', 50)` or + // `cell.prop({ series: [ { data: [ { degree: 50 } ] } ] })`. + prop: function(props, value, opt) { + + var delim = '/'; + var _isString = isString(props); + + if (_isString || Array.isArray(props)) { + // Get/set an attribute by a special path syntax that delimits + // nested objects by the colon character. + + if (arguments.length > 1) { + + var path; + var pathArray; + + if (_isString) { + path = props; + pathArray = path.split('/'); + } else { + path = props.join(delim); + pathArray = props.slice(); + } + + var property = pathArray[0]; + var pathArrayLength = pathArray.length; + + opt = opt || {}; + opt.propertyPath = path; + opt.propertyValue = value; + opt.propertyPathArray = pathArray; + + if (pathArrayLength === 1) { + // Property is not nested. We can simply use `set()`. + return this.set(property, value, opt); + } + + var update = {}; + // Initialize the nested object. Subobjects are either arrays or objects. + // An empty array is created if the sub-key is an integer. Otherwise, an empty object is created. + // Note that this imposes a limitation on object keys one can use with Inspector. + // Pure integer keys will cause issues and are therefore not allowed. + var initializer = update; + var prevProperty = property; + + for (var i = 1; i < pathArrayLength; i++) { + var pathItem = pathArray[i]; + var isArrayIndex = Number.isFinite(_isString ? Number(pathItem) : pathItem); + initializer = initializer[prevProperty] = isArrayIndex ? [] : {}; + prevProperty = pathItem; + } + + // Fill update with the `value` on `path`. + update = setByPath(update, pathArray, value, '/'); + + var baseAttributes = merge({}, this.attributes); + // if rewrite mode enabled, we replace value referenced by path with + // the new one (we don't merge). + opt.rewrite && unsetByPath(baseAttributes, path, '/'); + + // Merge update with the model attributes. + var attributes = merge(baseAttributes, update); + // Finally, set the property to the updated attributes. + return this.set(property, attributes[property], opt); + + } else { + + return getByPath(this.attributes, props, delim); + } + } + + return this.set(merge({}, this.attributes, props), value); + }, + + // A convenient way to unset nested properties + removeProp: function(path, opt) { + + opt = opt || {}; + + var pathArray = Array.isArray(path) ? path : path.split('/'); + + // Once a property is removed from the `attrs` attribute + // the cellView will recognize a `dirty` flag and re-render itself + // in order to remove the attribute from SVG element. + var property = pathArray[0]; + if (property === 'attrs') { opt.dirty = true; } + + if (pathArray.length === 1) { + // A top level property + return this.unset(path, opt); + } + + // A nested property + var nestedPath = pathArray.slice(1); + var propertyValue = this.get(property); + if (propertyValue === undefined || propertyValue === null) { return this; } + propertyValue = cloneDeep(propertyValue); + + unsetByPath(propertyValue, nestedPath, '/'); + + return this.set(property, propertyValue, opt); + }, + + // A convenient way to set nested attributes. + attr: function(attrs, value, opt) { + + var args = Array.from(arguments); + if (args.length === 0) { + return this.get('attrs'); + } + + if (Array.isArray(attrs)) { + args[0] = ['attrs'].concat(attrs); + } else if (isString(attrs)) { + // Get/set an attribute by a special path syntax that delimits + // nested objects by the colon character. + args[0] = 'attrs/' + attrs; + + } else { + + args[0] = { 'attrs' : attrs }; + } + + return this.prop.apply(this, args); + }, + + // A convenient way to unset nested attributes + removeAttr: function(path, opt) { + + if (Array.isArray(path)) { + + return this.removeProp(['attrs'].concat(path)); + } + + return this.removeProp('attrs/' + path, opt); + }, + + transition: function(path, value, opt, delim) { + var this$1 = this; + + + delim = delim || '/'; + + var defaults = { + duration: 100, + delay: 10, + timingFunction: timing.linear, + valueFunction: interpolate.number + }; + + opt = assign(defaults, opt); + + var firstFrameTime = 0; + var interpolatingFunction; + + var setter = function(runtime) { + + var id, progress, propertyValue; + + firstFrameTime = firstFrameTime || runtime; + runtime -= firstFrameTime; + progress = runtime / opt.duration; + + if (progress < 1) { + this._transitionIds[path] = id = nextFrame(setter); + } else { + progress = 1; + delete this._transitionIds[path]; + } + + propertyValue = interpolatingFunction(opt.timingFunction(progress)); + + opt.transitionId = id; + + this.prop(path, propertyValue, opt); + + if (!id) { this.trigger('transition:end', this, path); } + + }.bind(this); + + var ref = this; + var _scheduledTransitionIds = ref._scheduledTransitionIds; + var initialId; + + var initiator = function (callback) { + + if (_scheduledTransitionIds[path]) { + _scheduledTransitionIds[path] = without(_scheduledTransitionIds[path], initialId); + if (_scheduledTransitionIds[path].length === 0) { + delete _scheduledTransitionIds[path]; + } + } + + this$1.stopPendingTransitions(path, delim); + + interpolatingFunction = opt.valueFunction(getByPath(this$1.attributes, path, delim), value); + + this$1._transitionIds[path] = nextFrame(callback); + + this$1.trigger('transition:start', this$1, path); + + }; + + initialId = setTimeout(initiator, opt.delay, setter); + + _scheduledTransitionIds[path] || (_scheduledTransitionIds[path] = []); + _scheduledTransitionIds[path].push(initialId); + + return initialId; + }, + + getTransitions: function() { + return union( + Object.keys(this._transitionIds), + Object.keys(this._scheduledTransitionIds) + ); + }, + + stopScheduledTransitions: function(path, delim) { + if ( delim === void 0 ) delim = '/'; + + var ref = this; + var _scheduledTransitionIds = ref._scheduledTransitionIds; if ( _scheduledTransitionIds === void 0 ) _scheduledTransitionIds = {}; + var transitions = Object.keys(_scheduledTransitionIds); + if (path) { + var pathArray = path.split(delim); + transitions = transitions.filter(function (key) { + return isEqual(pathArray, key.split(delim).slice(0, pathArray.length)); + }); + } + transitions.forEach(function (key) { + var transitionIds = _scheduledTransitionIds[key]; + // stop the initiator + transitionIds.forEach(function (transitionId) { return clearTimeout(transitionId); }); + delete _scheduledTransitionIds[key]; + // Note: we could trigger transition:cancel` event here + }); + return this; + }, + + stopPendingTransitions: function stopPendingTransitions(path, delim) { + var this$1 = this; + if ( delim === void 0 ) delim = '/'; + + var ref = this; + var _transitionIds = ref._transitionIds; if ( _transitionIds === void 0 ) _transitionIds = {}; + var transitions = Object.keys(_transitionIds); + if (path) { + var pathArray = path.split(delim); + transitions = transitions.filter(function (key) { + return isEqual(pathArray, key.split(delim).slice(0, pathArray.length)); + }); + } + transitions.forEach(function (key) { + var transitionId = _transitionIds[key]; + // stop the setter + cancelFrame(transitionId); + delete _transitionIds[key]; + this$1.trigger('transition:end', this$1, key); + }); + }, + + stopTransitions: function(path, delim) { + if ( delim === void 0 ) delim = '/'; + + this.stopScheduledTransitions(path, delim); + this.stopPendingTransitions(path, delim); + return this; + }, + + // A shorcut making it easy to create constructs like the following: + // `var el = (new joint.shapes.basic.Rect).addTo(graph)`. + addTo: function(graph, opt) { + + graph.addCell(this, opt); + return this; + }, + + // A shortcut for an equivalent call: `paper.findViewByModel(cell)` + // making it easy to create constructs like the following: + // `cell.findView(paper).highlight()` + findView: function(paper) { + + return paper.findViewByModel(this); + }, + + isElement: function() { + + return false; + }, + + isLink: function() { + + return false; + }, + + startBatch: function(name, opt) { + + if (this.graph) { this.graph.startBatch(name, assign({}, opt, { cell: this })); } + return this; + }, + + stopBatch: function(name, opt) { + + if (this.graph) { this.graph.stopBatch(name, assign({}, opt, { cell: this })); } + return this; + }, + + getChangeFlag: function(attributes) { + + var flag = 0; + if (!attributes) { return flag; } + for (var key in attributes) { + if (!attributes.hasOwnProperty(key) || !this.hasChanged(key)) { continue; } + flag |= attributes[key]; + } + return flag; + }, + + angle: function() { + + // To be overridden. + return 0; + }, + + position: function() { + + // To be overridden. + return new Point(0, 0); + }, + + getPointFromConnectedLink: function() { + + // To be overridden + return new Point(); + }, + + getBBox: function() { + + // To be overridden + return new Rect(0, 0, 0, 0); + }, + + getPointRotatedAroundCenter: function getPointRotatedAroundCenter(angle, x, y) { + var point = new Point(x, y); + if (angle) { point.rotate(this.getBBox().center(), angle); } + return point; + }, + + getAbsolutePointFromRelative: function getAbsolutePointFromRelative(x, y) { + // Rotate the position to take the model angle into account + return this.getPointRotatedAroundCenter( + -this.angle(), + // Transform the relative position to absolute + this.position().offset(x, y) + ); + }, + + getRelativePointFromAbsolute: function getRelativePointFromAbsolute(x, y) { + return this + // Rotate the coordinates to mitigate the element's rotation. + .getPointRotatedAroundCenter(this.angle(), x, y) + // Transform the absolute position into relative + .difference(this.position()); + } + + }, { + + getAttributeDefinition: function(attrName) { + + var defNS = this.attributes; + var globalDefNS = attributes; + return (defNS && defNS[attrName]) || globalDefNS[attrName]; + }, + + define: function(type, defaults, protoProps, staticProps) { + + protoProps = assign({ + defaults: defaultsDeep({ type: type }, defaults, this.prototype.defaults) + }, protoProps); + + var Cell = this.extend(protoProps, staticProps); + // es5 backward compatibility + /* eslint-disable no-undef */ + if (typeof joint !== 'undefined' && has$2(joint, 'shapes')) { + setByPath(joint.shapes, type, Cell, '.'); + } + /* eslint-enable no-undef */ + return Cell; + } + }); + + var wrapWith = function(object, methods, wrapper) { + + if (isString(wrapper)) { + + if (!wrappers[wrapper]) { + throw new Error('Unknown wrapper: "' + wrapper + '"'); + } + + wrapper = wrappers[wrapper]; + } + + if (!isFunction(wrapper)) { + throw new Error('Wrapper must be a function.'); + } + + toArray(methods).forEach(function(method) { + object[method] = wrapper(object[method]); + }); + }; + + var wrappers = { + + cells: function(fn) { + + return function() { + + var args = Array.from(arguments); + var n = args.length; + var cells = n > 0 && args[0] || []; + var opt = n > 1 && args[n - 1] || {}; + + if (!Array.isArray(cells)) { + + if (opt instanceof Cell) { + cells = args; + } else if (cells instanceof Cell) { + if (args.length > 1) { + args.pop(); + } + cells = args; + } + } + + if (opt instanceof Cell) { + opt = {}; + } + + return fn.call(this, cells, opt); + }; + } + + }; + + function svg(strings) { + var expressions = [], len = arguments.length - 1; + while ( len-- > 0 ) expressions[ len ] = arguments[ len + 1 ]; + + var svgParts = []; + strings.forEach(function (part, index) { + svgParts.push(part); + if (index in expressions) { + svgParts.push(expressions[index]); + } + }); + var markup = parseFromSVGString(svgParts.join('')); + return markup; + } + + function parseFromSVGString(str) { + var parser = new DOMParser(); + var markupString = "<svg>" + (str.trim()) + "</svg>"; + var xmldocument = parser.parseFromString(markupString.replace(/@/g, ''), 'application/xml'); + if (xmldocument.getElementsByTagName('parsererror')[0]) { + throw new Error('Invalid SVG markup'); + } + var document = parser.parseFromString(markupString, 'text/html'); + var svg = document.querySelector('svg'); + return build(svg); + } + + function build(root) { + var markup = []; + + Array.from(root.children).forEach(function (node) { + var markupNode = {}; + var tagName = node.tagName; + var attributes = node.attributes; + var textContent = node.textContent; + var namespaceURI = node.namespaceURI; + var style = node.style; + + markupNode.tagName = tagName; + markupNode.namespaceURI = namespaceURI; + + var stylesObject = {}; + for (var i = style.length; i--;) { + var nameString = style[i]; + stylesObject[nameString] = style.getPropertyValue(nameString); + } + markupNode.style = stylesObject; + + // selector fallbacks to tagName + var selectorAttribute = attributes.getNamedItem('@selector'); + if (selectorAttribute) { + markupNode.selector = selectorAttribute.value; + attributes.removeNamedItem('@selector'); + } + + var groupSelectorAttribute = attributes.getNamedItem('@group-selector'); + if (groupSelectorAttribute) { + var groupSelectors = groupSelectorAttribute.value.split(','); + markupNode.groupSelector = groupSelectors.map(function (s) { return s.trim(); }); + + attributes.removeNamedItem('@group-selector'); + } + + var className = attributes.getNamedItem('class'); + if (className) { + markupNode.className = className.value; + } + + if (textContent) { + markupNode.textContent = textContent; + } + + var nodeAttrs = {}; + + Array.from(attributes).forEach(function (nodeAttribute) { + var name = nodeAttribute.name; + var value = nodeAttribute.value; + nodeAttrs[name] = value; + }); + + if (Object.keys(nodeAttrs).length > 0) { + markupNode.attributes = nodeAttrs; + } + + if (node.childElementCount > 0) { + markupNode.children = build(node); + } + + markup.push(markupNode); + }); + + return markup; + } + + var Positions = { + TOP: 'top', + RIGHT: 'right', + BOTTOM: 'bottom', + LEFT: 'left', + TOP_LEFT: 'top-left', + TOP_RIGHT: 'top-right', + BOTTOM_LEFT: 'bottom-left', + BOTTOM_RIGHT: 'bottom-right', + CENTER: 'center', + }; + + function getRectPoint(rect, position) { + var r = new Rect(rect); + switch (position) { + case undefined: + throw new Error('Position required'); + + // Middle Points + case Positions.LEFT: + case 'leftMiddle': + return r.leftMiddle(); + + case Positions.RIGHT: + case 'rightMiddle': + return r.rightMiddle(); + + case Positions.TOP: + case 'topMiddle': + return r.topMiddle(); + + case Positions.BOTTOM: + case 'bottomMiddle': + return r.bottomMiddle(); + + // Corners + case Positions.TOP_LEFT: + case 'topLeft': + case 'origin': + return r.topLeft(); + + case Positions.TOP_RIGHT: + case 'topRight': + return r.topRight(); + + case Positions.BOTTOM_LEFT: + case 'bottomLeft': + return r.bottomLeft(); + + case Positions.BOTTOM_RIGHT: + case 'bottomRight': + case 'corner': + return r.bottomRight(); + + // Center + case Positions.CENTER: + return r.center(); + + // TODO: calc(), percentage etc. + default: + throw new Error(("Unknown position: " + position)); + } + } + + + + var index = ({ + getRectPoint: getRectPoint, + wrapWith: wrapWith, + wrappers: wrappers, + addClassNamePrefix: addClassNamePrefix, + removeClassNamePrefix: removeClassNamePrefix, + parseDOMJSON: parseDOMJSON, + hashCode: hashCode, + getByPath: getByPath, + setByPath: setByPath, + unsetByPath: unsetByPath, + flattenObject: flattenObject, + uuid: uuid, + guid: guid, + toKebabCase: toKebabCase, + normalizeEvent: normalizeEvent, + normalizeWheel: normalizeWheel, + cap: cap, + nextFrame: nextFrame, + cancelFrame: cancelFrame, + shapePerimeterConnectionPoint: shapePerimeterConnectionPoint, + isPercentage: isPercentage, + parseCssNumeric: parseCssNumeric, + breakText: breakText, + sanitizeHTML: sanitizeHTML, + downloadBlob: downloadBlob, + downloadDataUri: downloadDataUri, + dataUriToBlob: dataUriToBlob, + imageToDataUri: imageToDataUri, + getElementBBox: getElementBBox, + sortElements: sortElements, + setAttributesBySelector: setAttributesBySelector, + normalizeSides: normalizeSides, + timing: timing, + interpolate: interpolate, + filter: filter, + format: format, + template: template, + toggleFullScreen: toggleFullScreen, + mixin: mixin, + supplement: supplement, + deepMixin: deepMixin, + deepSupplement: deepSupplement, + assign: assign, + defaults: defaults, + defaultsDeep: defaultsDeep, + invoke: invoke, + sortedIndex: sortedIndex, + uniq: uniq, + clone: clone, + cloneDeep: cloneDeep, + isEmpty: isEmpty, + isEqual: isEqual, + isFunction: isFunction, + isPlainObject: isPlainObject, + toArray: toArray, + debounce: debounce, + groupBy: groupBy, + sortBy: sortBy, + flattenDeep: flattenDeep, + without: without, + difference: difference, + intersection: intersection$1, + union: union, + has: has$2, + result: result, + omit: omit, + pick: pick, + bindAll: bindAll, + forIn: forIn, + camelCase: camelCase, + uniqueId: uniqueId, + merge: merge, + isBoolean: isBoolean, + isObject: isObject$1, + isNumber: isNumber, + isString: isString, + noop: noop, + cloneCells: cloneCells, + svg: svg + }); + + function portTransformAttrs(point, angle, opt) { + + var trans = point.toJSON(); + + trans.angle = angle || 0; + + return defaults({}, opt, trans); + } + + function lineLayout(ports, p1, p2, elBBox) { + return ports.map(function(port, index, ports) { + var p = this.pointAt(((index + 0.5) / ports.length)); + // `dx`,`dy` per port offset option + if (port.dx || port.dy) { + p.offset(port.dx || 0, port.dy || 0); + } + return portTransformAttrs(p.round(), 0, argTransform(elBBox, port)); + }, line(p1, p2)); + } + + function ellipseLayout(ports, elBBox, startAngle, stepFn) { + + var center = elBBox.center(); + var ratio = elBBox.width / elBBox.height; + var p1 = elBBox.topMiddle(); + + var ellipse = Ellipse.fromRect(elBBox); + + return ports.map(function(port, index, ports) { + + var angle = startAngle + stepFn(index, ports.length); + var p2 = p1.clone() + .rotate(center, -angle) + .scale(ratio, 1, center); + + var theta = port.compensateRotation ? -ellipse.tangentTheta(p2) : 0; + + // `dx`,`dy` per port offset option + if (port.dx || port.dy) { + p2.offset(port.dx || 0, port.dy || 0); + } + + // `dr` delta radius option + if (port.dr) { + p2.move(center, port.dr); + } + + return portTransformAttrs(p2.round(), theta, argTransform(elBBox, port)); + }); + } + + + function argTransform(bbox, args) { + var x = args.x; + var y = args.y; + var angle = args.angle; + if (isPercentage(x)) { + x = parseFloat(x) / 100 * bbox.width; + } else if (isCalcAttribute(x)) { + x = Number(evalCalcAttribute(x, bbox)); + } + if (isPercentage(y)) { + y = parseFloat(y) / 100 * bbox.height; + } else if (isCalcAttribute(y)) { + y = Number(evalCalcAttribute(y, bbox)); + } + return { x: x, y: y, angle: angle }; + } + + // Creates a point stored in arguments + function argPoint(bbox, args) { + var ref = argTransform(bbox, args); + var x = ref.x; + var y = ref.y; + return new Point(x || 0, y || 0); + } + + + /** + * @param {Array<Object>} ports + * @param {g.Rect} elBBox + * @param {Object=} opt opt Group options + * @returns {Array<g.Point>} + */ + var absolute = function(ports, elBBox) { + return ports.map(function (port) { + var transformation = argPoint(elBBox, port).round().toJSON(); + transformation.angle = port.angle || 0; + return transformation; + }); + }; + + /** + * @param {Array<Object>} ports + * @param {g.Rect} elBBox + * @param {Object=} opt opt Group options + * @returns {Array<g.Point>} + */ + var fn = function(ports, elBBox, opt) { + return opt.fn(ports, elBBox, opt); + }; + + /** + * @param {Array<Object>} ports + * @param {g.Rect} elBBox + * @param {Object=} opt opt Group options + * @returns {Array<g.Point>} + */ + var line$1 = function(ports, elBBox, opt) { + + var start = argPoint(elBBox, opt.start || elBBox.origin()); + var end = argPoint(elBBox, opt.end || elBBox.corner()); + + return lineLayout(ports, start, end, elBBox); + }; + + /** + * @param {Array<Object>} ports + * @param {g.Rect} elBBox + * @param {Object=} opt opt Group options + * @returns {Array<g.Point>} + */ + var left = function(ports, elBBox, opt) { + return lineLayout(ports, elBBox.origin(), elBBox.bottomLeft(), elBBox); + }; + + /** + * @param {Array<Object>} ports + * @param {g.Rect} elBBox + * @param {Object=} opt opt Group options + * @returns {Array<g.Point>} + */ + var right = function(ports, elBBox, opt) { + return lineLayout(ports, elBBox.topRight(), elBBox.corner(), elBBox); + }; + + /** + * @param {Array<Object>} ports + * @param {g.Rect} elBBox + * @param {Object=} opt opt Group options + * @returns {Array<g.Point>} + */ + var top = function(ports, elBBox, opt) { + return lineLayout(ports, elBBox.origin(), elBBox.topRight(), elBBox); + }; + + /** + * @param {Array<Object>} ports + * @param {g.Rect} elBBox + * @param {Object=} opt opt Group options + * @returns {Array<g.Point>} + */ + var bottom = function(ports, elBBox, opt) { + return lineLayout(ports, elBBox.bottomLeft(), elBBox.corner(), elBBox); + }; + + /** + * @param {Array<Object>} ports + * @param {g.Rect} elBBox + * @param {Object=} opt Group options + * @returns {Array<g.Point>} + */ + var ellipseSpread = function(ports, elBBox, opt) { + + var startAngle = opt.startAngle || 0; + var stepAngle = opt.step || 360 / ports.length; + + return ellipseLayout(ports, elBBox, startAngle, function(index) { + return index * stepAngle; + }); + }; + + /** + * @param {Array<Object>} ports + * @param {g.Rect} elBBox + * @param {Object=} opt Group options + * @returns {Array<g.Point>} + */ + var ellipse$1 = function(ports, elBBox, opt) { + + var startAngle = opt.startAngle || 0; + var stepAngle = opt.step || 20; + + return ellipseLayout(ports, elBBox, startAngle, function(index, count) { + return (index + 0.5 - count / 2) * stepAngle; + }); + }; + + var Port = ({ + absolute: absolute, + fn: fn, + line: line$1, + left: left, + right: right, + top: top, + bottom: bottom, + ellipseSpread: ellipseSpread, + ellipse: ellipse$1 + }); + + function labelAttributes(opt1, opt2) { + + return defaultsDeep({}, opt1, opt2, { + x: 0, + y: 0, + angle: 0, + attrs: { + '.': { + y: '0', + 'text-anchor': 'start' + } + } + }); + } + + function outsideLayout(portPosition, elBBox, autoOrient, opt) { + + opt = defaults({}, opt, { offset: 15 }); + var angle = elBBox.center().theta(portPosition); + var x = getBBoxAngles(elBBox); + + var tx, ty, y, textAnchor; + var offset = opt.offset; + var orientAngle = 0; + + if (angle < x[1] || angle > x[2]) { + y = '.3em'; + tx = offset; + ty = 0; + textAnchor = 'start'; + } else if (angle < x[0]) { + y = '0'; + tx = 0; + ty = -offset; + if (autoOrient) { + orientAngle = -90; + textAnchor = 'start'; + } else { + textAnchor = 'middle'; + } + } else if (angle < x[3]) { + y = '.3em'; + tx = -offset; + ty = 0; + textAnchor = 'end'; + } else { + y = '.6em'; + tx = 0; + ty = offset; + if (autoOrient) { + orientAngle = 90; + textAnchor = 'start'; + } else { + textAnchor = 'middle'; + } + } + + var round = Math.round; + return labelAttributes({ + x: round(tx), + y: round(ty), + angle: orientAngle, + attrs: { + '.': { + y: y, + 'text-anchor': textAnchor + } + } + }); + } + + function getBBoxAngles(elBBox) { + + var center = elBBox.center(); + + var tl = center.theta(elBBox.origin()); + var bl = center.theta(elBBox.bottomLeft()); + var br = center.theta(elBBox.corner()); + var tr = center.theta(elBBox.topRight()); + + return [tl, tr, br, bl]; + } + + function insideLayout(portPosition, elBBox, autoOrient, opt) { + + var angle = elBBox.center().theta(portPosition); + opt = defaults({}, opt, { offset: 15 }); + + var tx, ty, y, textAnchor; + var offset = opt.offset; + var orientAngle = 0; + + var bBoxAngles = getBBoxAngles(elBBox); + + if (angle < bBoxAngles[1] || angle > bBoxAngles[2]) { + y = '.3em'; + tx = -offset; + ty = 0; + textAnchor = 'end'; + } else if (angle < bBoxAngles[0]) { + y = '.6em'; + tx = 0; + ty = offset; + if (autoOrient) { + orientAngle = 90; + textAnchor = 'start'; + } else { + textAnchor = 'middle'; + } + } else if (angle < bBoxAngles[3]) { + y = '.3em'; + tx = offset; + ty = 0; + textAnchor = 'start'; + } else { + y = '0em'; + tx = 0; + ty = -offset; + if (autoOrient) { + orientAngle = -90; + textAnchor = 'start'; + } else { + textAnchor = 'middle'; + } + } + + var round = Math.round; + return labelAttributes({ + x: round(tx), + y: round(ty), + angle: orientAngle, + attrs: { + '.': { + y: y, + 'text-anchor': textAnchor + } + } + }); + } + + function radialLayout(portCenterOffset, autoOrient, opt) { + + opt = defaults({}, opt, { offset: 20 }); + + var origin = point(0, 0); + var angle = -portCenterOffset.theta(origin); + var orientAngle = angle; + var offset = portCenterOffset.clone() + .move(origin, opt.offset) + .difference(portCenterOffset) + .round(); + + var y = '.3em'; + var textAnchor; + + if ((angle + 90) % 180 === 0) { + textAnchor = autoOrient ? 'end' : 'middle'; + if (!autoOrient && angle === -270) { + y = '0em'; + } + } else if (angle > -270 && angle < -90) { + textAnchor = 'start'; + orientAngle = angle - 180; + } else { + textAnchor = 'end'; + } + + var round = Math.round; + return labelAttributes({ + x: round(offset.x), + y: round(offset.y), + angle: autoOrient ? orientAngle : 0, + attrs: { + '.': { + y: y, + 'text-anchor': textAnchor + } + } + }); + } + + var manual = function(portPosition, elBBox, opt) { + return labelAttributes(opt, elBBox); + }; + + var left$1 = function(portPosition, elBBox, opt) { + return labelAttributes(opt, { x: -15, attrs: { '.': { y: '.3em', 'text-anchor': 'end' }}}); + }; + + var right$1 = function(portPosition, elBBox, opt) { + return labelAttributes(opt, { x: 15, attrs: { '.': { y: '.3em', 'text-anchor': 'start' }}}); + }; + + var top$1 = function(portPosition, elBBox, opt) { + return labelAttributes(opt, { y: -15, attrs: { '.': { 'text-anchor': 'middle' }}}); + }; + + var bottom$1 = function(portPosition, elBBox, opt) { + return labelAttributes(opt, { y: 15, attrs: { '.': { y: '.6em', 'text-anchor': 'middle' }}}); + }; + + var outsideOriented = function(portPosition, elBBox, opt) { + return outsideLayout(portPosition, elBBox, true, opt); + }; + + var outside = function(portPosition, elBBox, opt) { + return outsideLayout(portPosition, elBBox, false, opt); + }; + + var insideOriented = function(portPosition, elBBox, opt) { + return insideLayout(portPosition, elBBox, true, opt); + }; + + var inside = function(portPosition, elBBox, opt) { + return insideLayout(portPosition, elBBox, false, opt); + }; + + var radial = function(portPosition, elBBox, opt) { + return radialLayout(portPosition.difference(elBBox.center()), false, opt); + }; + + var radialOriented = function(portPosition, elBBox, opt) { + return radialLayout(portPosition.difference(elBBox.center()), true, opt); + }; + + var PortLabel = ({ + manual: manual, + left: left$1, + right: right$1, + top: top$1, + bottom: bottom$1, + outsideOriented: outsideOriented, + outside: outside, + insideOriented: insideOriented, + inside: inside, + radial: radial, + radialOriented: radialOriented + }); + + // Link base model. + // -------------------------- + + var Link = Cell.extend({ + + // The default markup for links. + markup: [ + '<path class="connection" stroke="black" d="M 0 0 0 0"/>', + '<path class="marker-source" fill="black" stroke="black" d="M 0 0 0 0"/>', + '<path class="marker-target" fill="black" stroke="black" d="M 0 0 0 0"/>', + '<path class="connection-wrap" d="M 0 0 0 0"/>', + '<g class="labels"/>', + '<g class="marker-vertices"/>', + '<g class="marker-arrowheads"/>', + '<g class="link-tools"/>' + ].join(''), + + toolMarkup: [ + '<g class="link-tool">', + '<g class="tool-remove" event="remove">', + '<circle r="11" />', + '<path transform="scale(.8) translate(-16, -16)" d="M24.778,21.419 19.276,15.917 24.777,10.415 21.949,7.585 16.447,13.087 10.945,7.585 8.117,10.415 13.618,15.917 8.116,21.419 10.946,24.248 16.447,18.746 21.948,24.248z" />', + '<title>Remove link.', + '', + '', + '', + '', + 'Link options.', + '', + '' + ].join(''), + + doubleToolMarkup: undefined, + + // The default markup for showing/removing vertices. These elements are the children of the .marker-vertices element (see `this.markup`). + // Only .marker-vertex and .marker-vertex-remove element have special meaning. The former is used for + // dragging vertices (changing their position). The latter is used for removing vertices. + vertexMarkup: [ + '', + '', + '', + '', + 'Remove vertex.', + '', + '' + ].join(''), + + arrowheadMarkup: [ + '', + '', + '' + ].join(''), + + // may be overwritten by user to change default label (its markup, attrs, position) + defaultLabel: undefined, + + // deprecated + // may be overwritten by user to change default label markup + // lower priority than defaultLabel.markup + labelMarkup: undefined, + + // private + _builtins: { + defaultLabel: { + // builtin default markup: + // used if neither defaultLabel.markup + // nor label.markup is set + markup: [ + { + tagName: 'rect', + selector: 'rect' // faster than tagName CSS selector + }, { + tagName: 'text', + selector: 'text' // faster than tagName CSS selector + } + ], + // builtin default attributes: + // applied only if builtin default markup is used + attrs: { + text: { + fill: '#000000', + fontSize: 14, + textAnchor: 'middle', + yAlignment: 'middle', + pointerEvents: 'none' + }, + rect: { + ref: 'text', + fill: '#ffffff', + rx: 3, + ry: 3, + refWidth: 1, + refHeight: 1, + refX: 0, + refY: 0 + } + }, + // builtin default position: + // used if neither defaultLabel.position + // nor label.position is set + position: { + distance: 0.5 + } + } + }, + + defaults: { + type: 'link', + source: {}, + target: {} + }, + + isLink: function() { + + return true; + }, + + disconnect: function(opt) { + + return this.set({ + source: { x: 0, y: 0 }, + target: { x: 0, y: 0 } + }, opt); + }, + + source: function(source, args, opt) { + + // getter + if (source === undefined) { + return clone(this.get('source')); + } + + // setter + var setSource; + var setOpt; + + // `source` is a cell + // take only its `id` and combine with `args` + var isCellProvided = source instanceof Cell; + if (isCellProvided) { // three arguments + setSource = clone(args) || {}; + setSource.id = source.id; + setOpt = opt; + return this.set('source', setSource, setOpt); + } + + // `source` is a point-like object + // for example, a g.Point + // take only its `x` and `y` and combine with `args` + var isPointProvided = !isPlainObject(source); + if (isPointProvided) { // three arguments + setSource = clone(args) || {}; + setSource.x = source.x; + setSource.y = source.y; + setOpt = opt; + return this.set('source', setSource, setOpt); + } + + // `source` is an object + // no checking + // two arguments + setSource = source; + setOpt = args; + return this.set('source', setSource, setOpt); + }, + + target: function(target, args, opt) { + + // getter + if (target === undefined) { + return clone(this.get('target')); + } + + // setter + var setTarget; + var setOpt; + + // `target` is a cell + // take only its `id` argument and combine with `args` + var isCellProvided = target instanceof Cell; + if (isCellProvided) { // three arguments + setTarget = clone(args) || {}; + setTarget.id = target.id; + setOpt = opt; + return this.set('target', setTarget, setOpt); + } + + // `target` is a point-like object + // for example, a g.Point + // take only its `x` and `y` and combine with `args` + var isPointProvided = !isPlainObject(target); + if (isPointProvided) { // three arguments + setTarget = clone(args) || {}; + setTarget.x = target.x; + setTarget.y = target.y; + setOpt = opt; + return this.set('target', setTarget, setOpt); + } + + // `target` is an object + // no checking + // two arguments + setTarget = target; + setOpt = args; + return this.set('target', setTarget, setOpt); + }, + + router: function(name, args, opt) { + + // getter + if (name === undefined) { + var router = this.get('router'); + if (!router) { + if (this.get('manhattan')) { return { name: 'orthogonal' }; } // backwards compatibility + return null; + } + if (typeof router === 'object') { return clone(router); } + return router; // e.g. a function + } + + // setter + var isRouterProvided = ((typeof name === 'object') || (typeof name === 'function')); + var localRouter = isRouterProvided ? name : { name: name, args: args }; + var localOpt = isRouterProvided ? args : opt; + + return this.set('router', localRouter, localOpt); + }, + + connector: function(name, args, opt) { + + // getter + if (name === undefined) { + var connector = this.get('connector'); + if (!connector) { + if (this.get('smooth')) { return { name: 'smooth' }; } // backwards compatibility + return null; + } + if (typeof connector === 'object') { return clone(connector); } + return connector; // e.g. a function + } + + // setter + var isConnectorProvided = ((typeof name === 'object' || typeof name === 'function')); + var localConnector = isConnectorProvided ? name : { name: name, args: args }; + var localOpt = isConnectorProvided ? args : opt; + + return this.set('connector', localConnector, localOpt); + }, + + // Labels API + + // A convenient way to set labels. Currently set values will be mixined with `value` if used as a setter. + label: function(idx, label, opt) { + + var labels = this.labels(); + + idx = (isFinite(idx) && idx !== null) ? (idx | 0) : 0; + if (idx < 0) { idx = labels.length + idx; } + + // getter + if (arguments.length <= 1) { return this.prop(['labels', idx]); } + // setter + return this.prop(['labels', idx], label, opt); + }, + + labels: function(labels, opt) { + + // getter + if (arguments.length === 0) { + labels = this.get('labels'); + if (!Array.isArray(labels)) { return []; } + return labels.slice(); + } + // setter + if (!Array.isArray(labels)) { labels = []; } + return this.set('labels', labels, opt); + }, + + hasLabels: function() { + var ref = this.attributes; + var labels = ref.labels; + return Array.isArray(labels) && labels.length > 0; + }, + + insertLabel: function(idx, label, opt) { + + if (!label) { throw new Error('dia.Link: no label provided'); } + + var labels = this.labels(); + var n = labels.length; + idx = (isFinite(idx) && idx !== null) ? (idx | 0) : n; + if (idx < 0) { idx = n + idx + 1; } + + labels.splice(idx, 0, label); + return this.labels(labels, opt); + }, + + // convenience function + // add label to end of labels array + appendLabel: function(label, opt) { + + return this.insertLabel(-1, label, opt); + }, + + removeLabel: function(idx, opt) { + + var labels = this.labels(); + idx = (isFinite(idx) && idx !== null) ? (idx | 0) : -1; + + labels.splice(idx, 1); + return this.labels(labels, opt); + }, + + // Vertices API + + vertex: function(idx, vertex, opt) { + + var vertices = this.vertices(); + + idx = (isFinite(idx) && idx !== null) ? (idx | 0) : 0; + if (idx < 0) { idx = vertices.length + idx; } + + // getter + if (arguments.length <= 1) { return this.prop(['vertices', idx]); } + + // setter + var setVertex = this._normalizeVertex(vertex); + return this.prop(['vertices', idx], setVertex, opt); + }, + + vertices: function(vertices, opt) { + + // getter + if (arguments.length === 0) { + vertices = this.get('vertices'); + if (!Array.isArray(vertices)) { return []; } + return vertices.slice(); + } + + // setter + if (!Array.isArray(vertices)) { vertices = []; } + var setVertices = []; + for (var i = 0; i < vertices.length; i++) { + var vertex = vertices[i]; + var setVertex = this._normalizeVertex(vertex); + setVertices.push(setVertex); + } + return this.set('vertices', setVertices, opt); + }, + + insertVertex: function(idx, vertex, opt) { + + if (!vertex) { throw new Error('dia.Link: no vertex provided'); } + + var vertices = this.vertices(); + var n = vertices.length; + idx = (isFinite(idx) && idx !== null) ? (idx | 0) : n; + if (idx < 0) { idx = n + idx + 1; } + + var setVertex = this._normalizeVertex(vertex); + vertices.splice(idx, 0, setVertex); + return this.vertices(vertices, opt); + }, + + removeVertex: function(idx, opt) { + + var vertices = this.vertices(); + idx = (isFinite(idx) && idx !== null) ? (idx | 0) : -1; + + vertices.splice(idx, 1); + return this.vertices(vertices, opt); + }, + + _normalizeVertex: function(vertex) { + + // is vertex a point-like object? + // for example, a g.Point + var isPointProvided = !isPlainObject(vertex); + if (isPointProvided) { return { x: vertex.x, y: vertex.y }; } + + // else: return vertex unchanged + return vertex; + }, + + // Transformations + + translate: function(tx, ty, opt) { + + // enrich the option object + opt = opt || {}; + opt.translateBy = opt.translateBy || this.id; + opt.tx = tx; + opt.ty = ty; + + return this.applyToPoints(function(p) { + return { x: (p.x || 0) + tx, y: (p.y || 0) + ty }; + }, opt); + }, + + scale: function(sx, sy, origin, opt) { + + return this.applyToPoints(function(p) { + return Point(p).scale(sx, sy, origin).toJSON(); + }, opt); + }, + + applyToPoints: function(fn, opt) { + + if (!isFunction(fn)) { + throw new TypeError('dia.Link: applyToPoints expects its first parameter to be a function.'); + } + + var attrs = {}; + + var ref = this.attributes; + var source = ref.source; + var target = ref.target; + if (!source.id) { + attrs.source = fn(source); + } + if (!target.id) { + attrs.target = fn(target); + } + + var vertices = this.vertices(); + if (vertices.length > 0) { + attrs.vertices = vertices.map(fn); + } + + return this.set(attrs, opt); + }, + + getSourcePoint: function() { + var sourceCell = this.getSourceCell(); + if (!sourceCell) { return new Point(this.source()); } + return sourceCell.getPointFromConnectedLink(this, 'source'); + }, + + getTargetPoint: function() { + var targetCell = this.getTargetCell(); + if (!targetCell) { return new Point(this.target()); } + return targetCell.getPointFromConnectedLink(this, 'target'); + }, + + getPointFromConnectedLink: function(/* link, endType */) { + return this.getPolyline().pointAt(0.5); + }, + + getPolyline: function() { + var points = [ + this.getSourcePoint() ].concat( this.vertices().map(Point), + [this.getTargetPoint()] + ); + return new Polyline(points); + }, + + getBBox: function() { + return this.getPolyline().bbox(); + }, + + reparent: function(opt) { + + var newParent; + + if (this.graph) { + + var source = this.getSourceElement(); + var target = this.getTargetElement(); + var prevParent = this.getParentCell(); + + if (source && target) { + if (source === target || source.isEmbeddedIn(target)) { + newParent = target; + } else if (target.isEmbeddedIn(source)) { + newParent = source; + } else { + newParent = this.graph.getCommonAncestor(source, target); + } + } + + if (prevParent && (!newParent || newParent.id !== prevParent.id)) { + // Unembed the link if source and target has no common ancestor + // or common ancestor changed + prevParent.unembed(this, opt); + } + + if (newParent) { + newParent.embed(this, opt); + } + } + + return newParent; + }, + + hasLoop: function(opt) { + + opt = opt || {}; + + var ref = this.attributes; + var source = ref.source; + var target = ref.target; + var sourceId = source.id; + var targetId = target.id; + + if (!sourceId || !targetId) { + // Link "pinned" to the paper does not have a loop. + return false; + } + + var loop = sourceId === targetId; + + // Note that there in the deep mode a link can have a loop, + // even if it connects only a parent and its embed. + // A loop "target equals source" is valid in both shallow and deep mode. + if (!loop && opt.deep && this.graph) { + + var sourceElement = this.getSourceCell(); + var targetElement = this.getTargetCell(); + + loop = sourceElement.isEmbeddedIn(targetElement) || targetElement.isEmbeddedIn(sourceElement); + } + + return loop; + }, + + // unlike source(), this method returns null if source is a point + getSourceCell: function() { + + var ref = this; + var graph = ref.graph; + var attributes = ref.attributes; + var source = attributes.source; + return (source && source.id && graph && graph.getCell(source.id)) || null; + }, + + getSourceElement: function() { + var cell = this; + var visited = {}; + do { + if (visited[cell.id]) { return null; } + visited[cell.id] = true; + cell = cell.getSourceCell(); + } while (cell && cell.isLink()); + return cell; + }, + + // unlike target(), this method returns null if target is a point + getTargetCell: function() { + + var ref = this; + var graph = ref.graph; + var attributes = ref.attributes; + var target = attributes.target; + return (target && target.id && graph && graph.getCell(target.id)) || null; + }, + + getTargetElement: function() { + var cell = this; + var visited = {}; + do { + if (visited[cell.id]) { return null; } + visited[cell.id] = true; + cell = cell.getTargetCell(); + } while (cell && cell.isLink()); + return cell; + }, + + // Returns the common ancestor for the source element, + // target element and the link itself. + getRelationshipAncestor: function() { + + var connectionAncestor; + + if (this.graph) { + + var cells = [ + this, + this.getSourceElement(), // null if source is a point + this.getTargetElement() // null if target is a point + ].filter(function(item) { + return !!item; + }); + + connectionAncestor = this.graph.getCommonAncestor.apply(this.graph, cells); + } + + return connectionAncestor || null; + }, + + // Is source, target and the link itself embedded in a given cell? + isRelationshipEmbeddedIn: function(cell) { + + var cellId = (isString(cell) || isNumber(cell)) ? cell : cell.id; + var ancestor = this.getRelationshipAncestor(); + + return !!ancestor && (ancestor.id === cellId || ancestor.isEmbeddedIn(cellId)); + }, + + // Get resolved default label. + _getDefaultLabel: function() { + + var defaultLabel = this.get('defaultLabel') || this.defaultLabel || {}; + + var label = {}; + label.markup = defaultLabel.markup || this.get('labelMarkup') || this.labelMarkup; + label.position = defaultLabel.position; + label.attrs = defaultLabel.attrs; + label.size = defaultLabel.size; + + return label; + } + }, { + + endsEqual: function(a, b) { + + var portsEqual = a.port === b.port || !a.port && !b.port; + return a.id === b.id && portsEqual; + } + }); + + var PortData = function(data) { + + var clonedData = cloneDeep(data) || {}; + this.ports = []; + this.groups = {}; + this.portLayoutNamespace = Port; + this.portLabelLayoutNamespace = PortLabel; + + this._init(clonedData); + }; + + PortData.prototype = { + + getPorts: function() { + return this.ports; + }, + + getGroup: function(name) { + return this.groups[name] || {}; + }, + + getPortsByGroup: function(groupName) { + + return this.ports.filter(function(port) { + return port.group === groupName; + }); + }, + + getGroupPortsMetrics: function(groupName, elBBox) { + + var group = this.getGroup(groupName); + var ports = this.getPortsByGroup(groupName); + + var groupPosition = group.position || {}; + var groupPositionName = groupPosition.name; + var namespace = this.portLayoutNamespace; + if (!namespace[groupPositionName]) { + groupPositionName = 'left'; + } + + var groupArgs = groupPosition.args || {}; + var portsArgs = ports.map(function(port) { + return port && port.position && port.position.args; + }); + var groupPortTransformations = namespace[groupPositionName](portsArgs, elBBox, groupArgs); + + var accumulator = { + ports: ports, + result: [] + }; + + toArray(groupPortTransformations).reduce(function(res, portTransformation, index) { + var port = res.ports[index]; + res.result.push({ + portId: port.id, + portTransformation: portTransformation, + labelTransformation: this._getPortLabelLayout(port, Point(portTransformation), elBBox), + portAttrs: port.attrs, + portSize: port.size, + labelSize: port.label.size + }); + return res; + }.bind(this), accumulator); + + return accumulator.result; + }, + + _getPortLabelLayout: function(port, portPosition, elBBox) { + + var namespace = this.portLabelLayoutNamespace; + var labelPosition = port.label.position.name || 'left'; + + if (namespace[labelPosition]) { + return namespace[labelPosition](portPosition, elBBox, port.label.position.args); + } + + return null; + }, + + _init: function(data) { + + // prepare groups + if (isObject$1(data.groups)) { + var groups = Object.keys(data.groups); + for (var i = 0, n = groups.length; i < n; i++) { + var key = groups[i]; + this.groups[key] = this._evaluateGroup(data.groups[key]); + } + } + + // prepare ports + var ports = toArray(data.items); + for (var j = 0, m = ports.length; j < m; j++) { + this.ports.push(this._evaluatePort(ports[j])); + } + }, + + _evaluateGroup: function(group) { + + return merge(group, { + position: this._getPosition(group.position, true), + label: this._getLabel(group, true) + }); + }, + + _evaluatePort: function(port) { + + var evaluated = assign({}, port); + + var group = this.getGroup(port.group); + + evaluated.markup = evaluated.markup || group.markup; + evaluated.attrs = merge({}, group.attrs, evaluated.attrs); + evaluated.position = this._createPositionNode(group, evaluated); + evaluated.label = merge({}, group.label, this._getLabel(evaluated)); + evaluated.z = this._getZIndex(group, evaluated); + evaluated.size = assign({}, group.size, evaluated.size); + + return evaluated; + }, + + _getZIndex: function(group, port) { + + if (isNumber(port.z)) { + return port.z; + } + if (isNumber(group.z) || group.z === 'auto') { + return group.z; + } + return 'auto'; + }, + + _createPositionNode: function(group, port) { + + return merge({ + name: 'left', + args: {} + }, group.position, { args: port.args }); + }, + + _getPosition: function(position, setDefault) { + + var args = {}; + var positionName; + + if (isFunction(position)) { + positionName = 'fn'; + args.fn = position; + } else if (isString(position)) { + positionName = position; + } else if (position === undefined) { + positionName = setDefault ? 'left' : null; + } else if (Array.isArray(position)) { + positionName = 'absolute'; + args.x = position[0]; + args.y = position[1]; + } else if (isObject$1(position)) { + positionName = position.name; + assign(args, position.args); + } + + var result = { args: args }; + + if (positionName) { + result.name = positionName; + } + return result; + }, + + _getLabel: function(item, setDefaults) { + + var label = item.label || {}; + + var ret = label; + ret.position = this._getPosition(label.position, setDefaults); + + return ret; + } + }; + + var elementPortPrototype = { + + _initializePorts: function() { + + this._createPortData(); + this.on('change:ports', function() { + + this._processRemovedPort(); + this._createPortData(); + }, this); + }, + + /** + * remove links tied wiht just removed element + * @private + */ + _processRemovedPort: function() { + + var current = this.get('ports') || {}; + var currentItemsMap = {}; + + toArray(current.items).forEach(function(item) { + currentItemsMap[item.id] = true; + }); + + var previous = this.previous('ports') || {}; + var removed = {}; + + toArray(previous.items).forEach(function(item) { + if (!currentItemsMap[item.id]) { + removed[item.id] = true; + } + }); + + var graph = this.graph; + if (graph && !isEmpty(removed)) { + + var inboundLinks = graph.getConnectedLinks(this, { inbound: true }); + inboundLinks.forEach(function(link) { + + if (removed[link.get('target').port]) { link.remove(); } + }); + + var outboundLinks = graph.getConnectedLinks(this, { outbound: true }); + outboundLinks.forEach(function(link) { + + if (removed[link.get('source').port]) { link.remove(); } + }); + } + }, + + /** + * @returns {boolean} + */ + hasPorts: function() { + + var ports = this.prop('ports/items'); + return Array.isArray(ports) && ports.length > 0; + }, + + /** + * @param {string} id + * @returns {boolean} + */ + hasPort: function(id) { + + return this.getPortIndex(id) !== -1; + }, + + /** + * @returns {Array} + */ + getPorts: function() { + + return cloneDeep(this.prop('ports/items')) || []; + }, + + /** + * @returns {Array} + */ + getGroupPorts: function(groupName) { + var groupPorts = toArray(this.prop(['ports','items'])).filter(function (port) { return port.group === groupName; }); + return cloneDeep(groupPorts); + }, + + /** + * @param {string} id + * @returns {object} + */ + getPort: function(id) { + + return cloneDeep(toArray(this.prop('ports/items')).find(function(port) { + return port.id && port.id === id; + })); + }, + + /** + * @param {string} groupName + * @returns {Object} + */ + getPortsPositions: function(groupName) { + + var portsMetrics = this._portSettingsData.getGroupPortsMetrics(groupName, Rect(this.size())); + + return portsMetrics.reduce(function(positions, metrics) { + var transformation = metrics.portTransformation; + positions[metrics.portId] = { + x: transformation.x, + y: transformation.y, + angle: transformation.angle + }; + return positions; + }, {}); + }, + + /** + * @param {string|Port} port port id or port + * @returns {number} port index + */ + getPortIndex: function(port) { + + var id = isObject$1(port) ? port.id : port; + + if (!this._isValidPortId(id)) { + return -1; + } + + return toArray(this.prop('ports/items')).findIndex(function(item) { + return item.id === id; + }); + }, + + /** + * @param {object} port + * @param {object} [opt] + * @returns {joint.dia.Element} + */ + addPort: function(port, opt) { + + if (!isObject$1(port) || Array.isArray(port)) { + throw new Error('Element: addPort requires an object.'); + } + + var ports = assign([], this.prop('ports/items')); + ports.push(port); + this.prop('ports/items', ports, opt); + + return this; + }, + + /** + * @param {string|Port|number} before + * @param {object} port + * @param {object} [opt] + * @returns {joint.dia.Element} + */ + insertPort: function(before, port, opt) { + var index$1 = (typeof before === 'number') ? before : this.getPortIndex(before); + + if (!isObject$1(port) || Array.isArray(port)) { + throw new Error('dia.Element: insertPort requires an object.'); + } + + var ports = assign([], this.prop('ports/items')); + ports.splice(index$1, 0, port); + this.prop('ports/items', ports, opt); + + return this; + }, + + /** + * @param {string} portId + * @param {string|object=} path + * @param {*=} value + * @param {object=} opt + * @returns {joint.dia.Element} + */ + portProp: function(portId, path, value, opt) { + + var index$1 = this.getPortIndex(portId); + + if (index$1 === -1) { + throw new Error('Element: unable to find port with id ' + portId); + } + + var args = Array.prototype.slice.call(arguments, 1); + if (Array.isArray(path)) { + args[0] = ['ports', 'items', index$1].concat(path); + } else if (isString(path)) { + + // Get/set an attribute by a special path syntax that delimits + // nested objects by the colon character. + args[0] = ['ports/items/', index$1, '/', path].join(''); + + } else { + + args = ['ports/items/' + index$1]; + if (isPlainObject(path)) { + args.push(path); + args.push(value); + } + } + + return this.prop.apply(this, args); + }, + + _validatePorts: function() { + + var portsAttr = this.get('ports') || {}; + + var errorMessages = []; + portsAttr = portsAttr || {}; + var ports = toArray(portsAttr.items); + + ports.forEach(function(p) { + + if (typeof p !== 'object') { + errorMessages.push('Element: invalid port ', p); + } + + if (!this._isValidPortId(p.id)) { + p.id = this.generatePortId(); + } + }, this); + + if (uniq(ports, 'id').length !== ports.length) { + errorMessages.push('Element: found id duplicities in ports.'); + } + + return errorMessages; + }, + + generatePortId: function() { + return this.generateId(); + }, + + /** + * @param {string} id port id + * @returns {boolean} + * @private + */ + _isValidPortId: function(id) { + + return id !== null && id !== undefined && !isObject$1(id); + }, + + addPorts: function(ports, opt) { + + if (ports.length) { + this.prop('ports/items', assign([], this.prop('ports/items')).concat(ports), opt); + } + + return this; + }, + + removePort: function(port, opt) { + var options = opt || {}; + var index$1 = this.getPortIndex(port); + if (index$1 !== -1) { + var ports = assign([], this.prop(['ports', 'items'])); + ports.splice(index$1, 1); + options.rewrite = true; + this.startBatch('port-remove'); + this.prop(['ports', 'items'], ports, options); + this.stopBatch('port-remove'); + } + return this; + }, + + removePorts: function(portsForRemoval, opt) { + var options, newPorts; + if (Array.isArray(portsForRemoval)) { + options = opt || {}; + if (portsForRemoval.length === 0) { return this.this; } + var currentPorts = assign([], this.prop(['ports', 'items'])); + newPorts = currentPorts.filter(function(cp) { + return !portsForRemoval.some(function(rp) { + var rpId = isObject$1(rp) ? rp.id : rp; + return cp.id === rpId; + }); + }); + } else { + options = portsForRemoval || {}; + newPorts = []; + } + this.startBatch('port-remove'); + options.rewrite = true; + this.prop(['ports', 'items'], newPorts, options); + this.stopBatch('port-remove'); + return this; + }, + + /** + * @private + */ + _createPortData: function() { + + var err = this._validatePorts(); + + if (err.length > 0) { + this.set('ports', this.previous('ports')); + throw new Error(err.join(' ')); + } + + var prevPortData; + + if (this._portSettingsData) { + + prevPortData = this._portSettingsData.getPorts(); + } + + this._portSettingsData = new PortData(this.get('ports')); + + var curPortData = this._portSettingsData.getPorts(); + + if (prevPortData) { + + var added = curPortData.filter(function(item) { + if (!prevPortData.find(function(prevPort) { + return prevPort.id === item.id; + })) { + return item; + } + }); + + var removed = prevPortData.filter(function(item) { + if (!curPortData.find(function(curPort) { + return curPort.id === item.id; + })) { + return item; + } + }); + + if (removed.length > 0) { + this.trigger('ports:remove', this, removed); + } + + if (added.length > 0) { + this.trigger('ports:add', this, added); + } + } + } + }; + + var elementViewPortPrototype = { + + portContainerMarkup: 'g', + portMarkup: [{ + tagName: 'circle', + selector: 'circle', + attributes: { + 'r': 10, + 'fill': '#FFFFFF', + 'stroke': '#000000' + } + }], + portLabelMarkup: [{ + tagName: 'text', + selector: 'text', + attributes: { + 'fill': '#000000' + } + }], + /** @type {Object} */ + _portElementsCache: null, + + /** + * @private + */ + _initializePorts: function() { + this._cleanPortsCache(); + }, + + /** + * @typedef {Object} Port + * + * @property {string} id + * @property {Object} position + * @property {Object} label + * @property {Object} attrs + * @property {string} markup + * @property {string} group + */ + + /** + * @private + */ + _refreshPorts: function() { + + this._removePorts(); + this._cleanPortsCache(); + this._renderPorts(); + }, + + _cleanPortsCache: function() { + this._portElementsCache = {}; + }, + + /** + * @private + */ + _renderPorts: function() { + + // references to rendered elements without z-index + var elementReferences = []; + var elem = this._getContainerElement(); + + for (var i = 0, count = elem.node.childNodes.length; i < count; i++) { + elementReferences.push(elem.node.childNodes[i]); + } + + var portsGropsByZ = groupBy(this.model._portSettingsData.getPorts(), 'z'); + var withoutZKey = 'auto'; + + // render non-z first + toArray(portsGropsByZ[withoutZKey]).forEach(function(port) { + var portElement = this._getPortElement(port); + elem.append(portElement); + elementReferences.push(portElement); + }, this); + + var groupNames = Object.keys(portsGropsByZ); + for (var k = 0; k < groupNames.length; k++) { + var groupName = groupNames[k]; + if (groupName !== withoutZKey) { + var z = parseInt(groupName, 10); + this._appendPorts(portsGropsByZ[groupName], z, elementReferences); + } + } + + this._updatePorts(); + }, + + /** + * @returns {V} + * @private + */ + _getContainerElement: function() { + + return this.rotatableNode || this.vel; + }, + + /** + * @param {Array}ports + * @param {number} z + * @param refs + * @private + */ + _appendPorts: function(ports, z, refs) { + + var containerElement = this._getContainerElement(); + var portElements = toArray(ports).map(this._getPortElement, this); + + if (refs[z] || z < 0) { + V(refs[Math.max(z, 0)]).before(portElements); + } else { + containerElement.append(portElements); + } + }, + + /** + * Try to get element from cache, + * @param port + * @returns {*} + * @private + */ + _getPortElement: function(port) { + + if (this._portElementsCache[port.id]) { + return this._portElementsCache[port.id].portElement; + } + return this._createPortElement(port); + }, + + findPortNode: function(portId, selector) { + var portCache = this._portElementsCache[portId]; + if (!portCache) { return null; } + if (!selector) { return portCache.portContentElement.node; } + var portRoot = portCache.portElement.node; + var portSelectors = portCache.portSelectors; + var ref = this.findBySelector(selector, portRoot, portSelectors); + var node = ref[0]; if ( node === void 0 ) node = null; + return node; + }, + + /** + * @private + */ + _updatePorts: function() { + + // layout ports without group + this._updatePortGroup(undefined); + // layout ports with explicit group + var groupsNames = Object.keys(this.model._portSettingsData.groups); + groupsNames.forEach(this._updatePortGroup, this); + }, + + /** + * @private + */ + _removePorts: function() { + invoke(this._portElementsCache, 'portElement.remove'); + }, + + /** + * @param {Port} port + * @returns {V} + * @private + */ + _createPortElement: function(port) { + + var portElement; + var labelElement; + var labelSelectors; + var portSelectors; + + var portContainerElement = V(this.portContainerMarkup).addClass('joint-port'); + + var portMarkup = this._getPortMarkup(port); + if (Array.isArray(portMarkup)) { + var portDoc = this.parseDOMJSON(portMarkup, portContainerElement.node); + var portFragment = portDoc.fragment; + if (portFragment.childNodes.length > 1) { + portElement = V('g').append(portFragment); + } else { + portElement = V(portFragment.firstChild); + } + portSelectors = portDoc.selectors; + } else { + portElement = V(portMarkup); + if (Array.isArray(portElement)) { + portElement = V('g').append(portElement); + } + } + + if (!portElement) { + throw new Error('ElementView: Invalid port markup.'); + } + + portElement.attr({ + 'port': port.id, + 'port-group': port.group + }); + + var labelMarkupDef = this._getPortLabelMarkup(port.label); + if (Array.isArray(labelMarkupDef)) { + // JSON Markup + var ref = this.parseDOMJSON(labelMarkupDef, portContainerElement.node); + var fragment = ref.fragment; + var selectors = ref.selectors; + var childCount = fragment.childNodes.length; + if (childCount > 0) { + labelSelectors = selectors; + labelElement = (childCount === 1) ? V(fragment.firstChild) : V('g').append(fragment); + } + } else { + // String Markup + labelElement = V(labelMarkupDef); + if (Array.isArray(labelElement)) { + labelElement = V('g').append(labelElement); + } + } + + var portContainerSelectors; + if (portSelectors && labelSelectors) { + for (var key in labelSelectors) { + if (portSelectors[key] && key !== this.selector) { throw new Error('ElementView: selectors within port must be unique.'); } + } + portContainerSelectors = assign({}, portSelectors, labelSelectors); + } else { + portContainerSelectors = portSelectors || labelSelectors || {}; + } + + var portRootSelector = 'portRoot'; + if (!(portRootSelector in portContainerSelectors)) { + portContainerSelectors[portRootSelector] = portElement.node; + } + + var labelRootSelector = 'labelRoot'; + if (labelElement && !(labelRootSelector in portContainerSelectors)) { + portContainerSelectors[labelRootSelector] = labelElement.node; + } + + portContainerElement.append(portElement.addClass('joint-port-body')); + if (labelElement) { + portContainerElement.append(labelElement.addClass('joint-port-label')); + } + + this._portElementsCache[port.id] = { + portElement: portContainerElement, + portLabelElement: labelElement, + portSelectors: portContainerSelectors, + portLabelSelectors: labelSelectors, + portContentElement: portElement, + portContentSelectors: portSelectors + }; + + return portContainerElement; + }, + + /** + * @param {string=} groupName + * @private + */ + _updatePortGroup: function(groupName) { + + var elementBBox = Rect(this.model.size()); + var portsMetrics = this.model._portSettingsData.getGroupPortsMetrics(groupName, elementBBox); + + for (var i = 0, n = portsMetrics.length; i < n; i++) { + var metrics = portsMetrics[i]; + var portId = metrics.portId; + var cached = this._portElementsCache[portId] || {}; + var portTransformation = metrics.portTransformation; + this.applyPortTransform(cached.portElement, portTransformation); + this.updateDOMSubtreeAttributes(cached.portElement.node, metrics.portAttrs, { + rootBBox: new Rect(metrics.portSize), + selectors: cached.portSelectors + }); + + var labelTransformation = metrics.labelTransformation; + if (labelTransformation && cached.portLabelElement) { + this.applyPortTransform(cached.portLabelElement, labelTransformation, (-portTransformation.angle || 0)); + this.updateDOMSubtreeAttributes(cached.portLabelElement.node, labelTransformation.attrs, { + rootBBox: new Rect(metrics.labelSize), + selectors: cached.portLabelSelectors + }); + } + } + }, + + /** + * @param {Vectorizer} element + * @param {{dx:number, dy:number, angle: number, attrs: Object, x:number: y:number}} transformData + * @param {number=} initialAngle + * @constructor + */ + applyPortTransform: function(element, transformData, initialAngle) { + + var matrix = V.createSVGMatrix() + .rotate(initialAngle || 0) + .translate(transformData.x || 0, transformData.y || 0) + .rotate(transformData.angle || 0); + + element.transform(matrix, { absolute: true }); + }, + + /** + * @param {Port} port + * @returns {string} + * @private + */ + _getPortMarkup: function(port) { + + return port.markup || this.model.get('portMarkup') || this.model.portMarkup || this.portMarkup; + }, + + /** + * @param {Object} label + * @returns {string} + * @private + */ + _getPortLabelMarkup: function(label) { + + return label.markup || this.model.get('portLabelMarkup') || this.model.portLabelMarkup || this.portLabelMarkup; + } + }; + + // Element base model. + // ----------------------------- + + var Element$1 = Cell.extend({ + + defaults: { + position: { x: 0, y: 0 }, + size: { width: 1, height: 1 }, + angle: 0 + }, + + initialize: function() { + + this._initializePorts(); + Cell.prototype.initialize.apply(this, arguments); + }, + + /** + * @abstract + */ + _initializePorts: function() { + // implemented in ports.js + }, + + _refreshPorts: function() { + // implemented in ports.js + }, + + isElement: function() { + + return true; + }, + + position: function(x, y, opt) { + + var isSetter = isNumber(y); + opt = (isSetter ? opt : x) || {}; + var parentRelative = opt.parentRelative; + var deep = opt.deep; + var restrictedArea = opt.restrictedArea; + + + // option `parentRelative` for setting the position relative to the element's parent. + var parentPosition; + if (parentRelative) { + + // Getting the parent's position requires the collection. + // Cell.parent() holds cell id only. + if (!this.graph) { throw new Error('Element must be part of a graph.'); } + + var parent = this.getParentCell(); + if (parent && !parent.isLink()) { + parentPosition = parent.get('position'); + } + } + + if (isSetter) { + + if (parentPosition) { + x += parentPosition.x; + y += parentPosition.y; + } + + if (deep || restrictedArea) { + var ref = this.get('position'); + var x0 = ref.x; + var y0 = ref.y; + this.translate(x - x0, y - y0, opt); + } else { + this.set('position', { x: x, y: y }, opt); + } + + return this; + + } else { // Getter returns a geometry point. + + var elementPosition = Point(this.get('position')); + return parentRelative + ? elementPosition.difference(parentPosition) + : elementPosition; + } + }, + + translate: function(tx, ty, opt) { + + tx = tx || 0; + ty = ty || 0; + + if (tx === 0 && ty === 0) { + // Like nothing has happened. + return this; + } + + opt = opt || {}; + // Pass the initiator of the translation. + opt.translateBy = opt.translateBy || this.id; + + var position = this.get('position') || { x: 0, y: 0 }; + var ra = opt.restrictedArea; + if (ra && opt.translateBy === this.id) { + + if (typeof ra === 'function') { + + var newPosition = ra.call(this, position.x + tx, position.y + ty, opt); + + tx = newPosition.x - position.x; + ty = newPosition.y - position.y; + + } else { + // We are restricting the translation for the element itself only. We get + // the bounding box of the element including all its embeds. + // All embeds have to be translated the exact same way as the element. + var bbox = this.getBBox({ deep: true }); + //- - - - - - - - - - - - -> ra.x + ra.width + // - - - -> position.x | + // -> bbox.x + // ▓▓▓▓▓▓▓ | + // ░░░░░░░▓▓▓▓▓▓▓ + // ░░░░░░░░░ | + // ▓▓▓▓▓▓▓▓░░░░░░░ + // ▓▓▓▓▓▓▓▓ | + // <-dx-> | restricted area right border + // <-width-> | ░ translated element + // <- - bbox.width - -> ▓ embedded element + var dx = position.x - bbox.x; + var dy = position.y - bbox.y; + // Find the maximal/minimal coordinates that the element can be translated + // while complies the restrictions. + var x = Math.max(ra.x + dx, Math.min(ra.x + ra.width + dx - bbox.width, position.x + tx)); + var y = Math.max(ra.y + dy, Math.min(ra.y + ra.height + dy - bbox.height, position.y + ty)); + // recalculate the translation taking the restrictions into account. + tx = x - position.x; + ty = y - position.y; + } + } + + var translatedPosition = { + x: position.x + tx, + y: position.y + ty + }; + + // To find out by how much an element was translated in event 'change:position' handlers. + opt.tx = tx; + opt.ty = ty; + + if (opt.transition) { + + if (!isObject$1(opt.transition)) { opt.transition = {}; } + + this.transition('position', translatedPosition, assign({}, opt.transition, { + valueFunction: interpolate.object + })); + + // Recursively call `translate()` on all the embeds cells. + invoke(this.getEmbeddedCells(), 'translate', tx, ty, opt); + + } else { + + this.startBatch('translate', opt); + this.set('position', translatedPosition, opt); + invoke(this.getEmbeddedCells(), 'translate', tx, ty, opt); + this.stopBatch('translate', opt); + } + + return this; + }, + + size: function(width, height, opt) { + + var currentSize = this.get('size'); + // Getter + // () signature + if (width === undefined) { + return { + width: currentSize.width, + height: currentSize.height + }; + } + // Setter + // (size, opt) signature + if (isObject$1(width)) { + opt = height; + height = isNumber(width.height) ? width.height : currentSize.height; + width = isNumber(width.width) ? width.width : currentSize.width; + } + + return this.resize(width, height, opt); + }, + + resize: function(width, height, opt) { + + opt = opt || {}; + + this.startBatch('resize', opt); + + if (opt.direction) { + + var currentSize = this.get('size'); + + switch (opt.direction) { + + case 'left': + case 'right': + // Don't change height when resizing horizontally. + height = currentSize.height; + break; + + case 'top': + case 'bottom': + // Don't change width when resizing vertically. + width = currentSize.width; + break; + } + + // Get the angle and clamp its value between 0 and 360 degrees. + var angle = normalizeAngle(this.get('angle') || 0); + + // This is a rectangle in size of the un-rotated element. + var bbox = this.getBBox(); + + var origin; + + if (angle) { + + var quadrant = { + 'top-right': 0, + 'right': 0, + 'top-left': 1, + 'top': 1, + 'bottom-left': 2, + 'left': 2, + 'bottom-right': 3, + 'bottom': 3 + }[opt.direction]; + + if (opt.absolute) { + + // We are taking the element's rotation into account + quadrant += Math.floor((angle + 45) / 90); + quadrant %= 4; + } + + // Pick the corner point on the element, which meant to stay on its place before and + // after the rotation. + var fixedPoint = bbox[['bottomLeft', 'corner', 'topRight', 'origin'][quadrant]](); + + // Find an image of the previous indent point. This is the position, where is the + // point actually located on the screen. + var imageFixedPoint = Point(fixedPoint).rotate(bbox.center(), -angle); + + // Every point on the element rotates around a circle with the centre of rotation + // in the middle of the element while the whole element is being rotated. That means + // that the distance from a point in the corner of the element (supposed its always rect) to + // the center of the element doesn't change during the rotation and therefore it equals + // to a distance on un-rotated element. + // We can find the distance as DISTANCE = (ELEMENTWIDTH/2)^2 + (ELEMENTHEIGHT/2)^2)^0.5. + var radius = Math.sqrt((width * width) + (height * height)) / 2; + + // Now we are looking for an angle between x-axis and the line starting at image of fixed point + // and ending at the center of the element. We call this angle `alpha`. + + // The image of a fixed point is located in n-th quadrant. For each quadrant passed + // going anti-clockwise we have to add 90 degrees. Note that the first quadrant has index 0. + // + // 3 | 2 + // --c-- Quadrant positions around the element's center `c` + // 0 | 1 + // + var alpha = quadrant * Math.PI / 2; + + // Add an angle between the beginning of the current quadrant (line parallel with x-axis or y-axis + // going through the center of the element) and line crossing the indent of the fixed point and the center + // of the element. This is the angle we need but on the un-rotated element. + alpha += Math.atan(quadrant % 2 == 0 ? height / width : width / height); + + // Lastly we have to deduct the original angle the element was rotated by and that's it. + alpha -= toRad(angle); + + // With this angle and distance we can easily calculate the centre of the un-rotated element. + // Note that fromPolar constructor accepts an angle in radians. + var center = Point.fromPolar(radius, alpha, imageFixedPoint); + + // The top left corner on the un-rotated element has to be half a width on the left + // and half a height to the top from the center. This will be the origin of rectangle + // we were looking for. + origin = Point(center).offset(width / -2, height / -2); + + } else { + // calculation for the origin Point when there is no rotation of the element + origin = bbox.topLeft(); + + switch (opt.direction) { + case 'top': + case 'top-right': + origin.offset(0, bbox.height - height); + break; + case 'left': + case 'bottom-left': + origin.offset(bbox.width -width, 0); + break; + case 'top-left': + origin.offset(bbox.width - width, bbox.height - height); + break; + } + } + + // Resize the element (before re-positioning it). + this.set('size', { width: width, height: height }, opt); + + // Finally, re-position the element. + this.position(origin.x, origin.y, opt); + + } else { + + // Resize the element. + this.set('size', { width: width, height: height }, opt); + } + + this.stopBatch('resize', opt); + + return this; + }, + + scale: function(sx, sy, origin, opt) { + + var scaledBBox = this.getBBox().scale(sx, sy, origin); + this.startBatch('scale', opt); + this.position(scaledBBox.x, scaledBBox.y, opt); + this.resize(scaledBBox.width, scaledBBox.height, opt); + this.stopBatch('scale'); + return this; + }, + + fitEmbeds: function(opt) { + if ( opt === void 0 ) opt = {}; + + + // Getting the children's size and position requires the collection. + // Cell.get('embeds') helds an array of cell ids only. + var ref = this; + var graph = ref.graph; + if (!graph) { throw new Error('Element must be part of a graph.'); } + + var embeddedCells = this.getEmbeddedCells().filter(function (cell) { return cell.isElement(); }); + if (embeddedCells.length === 0) { return this; } + + this.startBatch('fit-embeds', opt); + + if (opt.deep) { + // Recursively apply fitEmbeds on all embeds first. + invoke(embeddedCells, 'fitEmbeds', opt); + } + + // Compute cell's size and position based on the children bbox + // and given padding. + var ref$1 = normalizeSides(opt.padding); + var left = ref$1.left; + var right = ref$1.right; + var top = ref$1.top; + var bottom = ref$1.bottom; + var ref$2 = graph.getCellsBBox(embeddedCells); + var x = ref$2.x; + var y = ref$2.y; + var width = ref$2.width; + var height = ref$2.height; + // Apply padding computed above to the bbox. + x -= left; + y -= top; + width += left + right; + height += bottom + top; + + // Set new element dimensions finally. + this.set({ + position: { x: x, y: y }, + size: { width: width, height: height } + }, opt); + + this.stopBatch('fit-embeds'); + + return this; + }, + + // Rotate element by `angle` degrees, optionally around `origin` point. + // If `origin` is not provided, it is considered to be the center of the element. + // If `absolute` is `true`, the `angle` is considered is absolute, i.e. it is not + // the difference from the previous angle. + rotate: function(angle, absolute, origin, opt) { + + if (origin) { + + var center = this.getBBox().center(); + var size = this.get('size'); + var position = this.get('position'); + center.rotate(origin, this.get('angle') - angle); + var dx = center.x - size.width / 2 - position.x; + var dy = center.y - size.height / 2 - position.y; + this.startBatch('rotate', { angle: angle, absolute: absolute, origin: origin }); + this.position(position.x + dx, position.y + dy, opt); + this.rotate(angle, absolute, null, opt); + this.stopBatch('rotate'); + + } else { + + this.set('angle', absolute ? angle : (this.get('angle') + angle) % 360, opt); + } + + return this; + }, + + angle: function() { + return normalizeAngle(this.get('angle') || 0); + }, + + getBBox: function(opt) { + if ( opt === void 0 ) opt = {}; + + + var ref = this; + var graph = ref.graph; + var attributes = ref.attributes; + var deep = opt.deep; + var rotate = opt.rotate; + + if (deep && graph) { + // Get all the embedded elements using breadth first algorithm. + var elements = this.getEmbeddedCells({ deep: true, breadthFirst: true }); + // Add the model itself. + elements.push(this); + // Note: the default of getCellsBBox() is rotate=true and can't be + // changed without a breaking change + return graph.getCellsBBox(elements, opt); + } + + var angle = attributes.angle; if ( angle === void 0 ) angle = 0; + var attributes_position = attributes.position; + var x = attributes_position.x; + var y = attributes_position.y; + var attributes_size = attributes.size; + var width = attributes_size.width; + var height = attributes_size.height; + var bbox = new Rect(x, y, width, height); + if (rotate) { + bbox.rotateAroundCenter(angle); + } + return bbox; + }, + + getPointFromConnectedLink: function(link, endType) { + // Center of the model + var bbox = this.getBBox(); + var center = bbox.center(); + // Center of a port + var endDef = link.get(endType); + if (!endDef) { return center; } + var portId = endDef.port; + if (!portId || !this.hasPort(portId)) { return center; } + var portGroup = this.portProp(portId, ['group']); + var portsPositions = this.getPortsPositions(portGroup); + var portCenter = new Point(portsPositions[portId]).offset(bbox.origin()); + var angle = this.angle(); + if (angle) { portCenter.rotate(center, -angle); } + return portCenter; + } + }); + + assign(Element$1.prototype, elementPortPrototype); + + var GraphCells = Backbone.Collection.extend({ + + initialize: function(models, opt) { + + // Set the optional namespace where all model classes are defined. + if (opt.cellNamespace) { + this.cellNamespace = opt.cellNamespace; + } else { + /* eslint-disable no-undef */ + this.cellNamespace = typeof joint !== 'undefined' && has$2(joint, 'shapes') ? joint.shapes : null; + /* eslint-enable no-undef */ + } + + + this.graph = opt.graph; + }, + + model: function(attrs, opt) { + + var collection = opt.collection; + var namespace = collection.cellNamespace; + + // Find the model class in the namespace or use the default one. + var ModelClass = (attrs.type === 'link') + ? Link + : getByPath(namespace, attrs.type, '.') || Element$1; + + var cell = new ModelClass(attrs, opt); + // Add a reference to the graph. It is necessary to do this here because this is the earliest place + // where a new model is created from a plain JS object. For other objects, see `joint.dia.Graph>>_prepareCell()`. + if (!opt.dry) { + cell.graph = collection.graph; + } + + return cell; + }, + + // `comparator` makes it easy to sort cells based on their `z` index. + comparator: function(model) { + + return model.get('z') || 0; + } + }); + + + var Graph = Backbone.Model.extend({ + + initialize: function(attrs, opt) { + + opt = opt || {}; + + // Passing `cellModel` function in the options object to graph allows for + // setting models based on attribute objects. This is especially handy + // when processing JSON graphs that are in a different than JointJS format. + var cells = new GraphCells([], { + model: opt.cellModel, + cellNamespace: opt.cellNamespace, + graph: this + }); + Backbone.Model.prototype.set.call(this, 'cells', cells); + + // Make all the events fired in the `cells` collection available. + // to the outside world. + cells.on('all', this.trigger, this); + + // Backbone automatically doesn't trigger re-sort if models attributes are changed later when + // they're already in the collection. Therefore, we're triggering sort manually here. + this.on('change:z', this._sortOnChangeZ, this); + + // `joint.dia.Graph` keeps an internal data structure (an adjacency list) + // for fast graph queries. All changes that affect the structure of the graph + // must be reflected in the `al` object. This object provides fast answers to + // questions such as "what are the neighbours of this node" or "what + // are the sibling links of this link". + + // Outgoing edges per node. Note that we use a hash-table for the list + // of outgoing edges for a faster lookup. + // [nodeId] -> Object [edgeId] -> true + this._out = {}; + // Ingoing edges per node. + // [nodeId] -> Object [edgeId] -> true + this._in = {}; + // `_nodes` is useful for quick lookup of all the elements in the graph, without + // having to go through the whole cells array. + // [node ID] -> true + this._nodes = {}; + // `_edges` is useful for quick lookup of all the links in the graph, without + // having to go through the whole cells array. + // [edgeId] -> true + this._edges = {}; + + this._batches = {}; + + cells.on('add', this._restructureOnAdd, this); + cells.on('remove', this._restructureOnRemove, this); + cells.on('reset', this._restructureOnReset, this); + cells.on('change:source', this._restructureOnChangeSource, this); + cells.on('change:target', this._restructureOnChangeTarget, this); + cells.on('remove', this._removeCell, this); + }, + + _sortOnChangeZ: function() { + + this.get('cells').sort(); + }, + + _restructureOnAdd: function(cell) { + + if (cell.isLink()) { + this._edges[cell.id] = true; + var ref = cell.attributes; + var source = ref.source; + var target = ref.target; + if (source.id) { + (this._out[source.id] || (this._out[source.id] = {}))[cell.id] = true; + } + if (target.id) { + (this._in[target.id] || (this._in[target.id] = {}))[cell.id] = true; + } + } else { + this._nodes[cell.id] = true; + } + }, + + _restructureOnRemove: function(cell) { + + if (cell.isLink()) { + delete this._edges[cell.id]; + var ref = cell.attributes; + var source = ref.source; + var target = ref.target; + if (source.id && this._out[source.id] && this._out[source.id][cell.id]) { + delete this._out[source.id][cell.id]; + } + if (target.id && this._in[target.id] && this._in[target.id][cell.id]) { + delete this._in[target.id][cell.id]; + } + } else { + delete this._nodes[cell.id]; + } + }, + + _restructureOnReset: function(cells) { + + // Normalize into an array of cells. The original `cells` is GraphCells Backbone collection. + cells = cells.models; + + this._out = {}; + this._in = {}; + this._nodes = {}; + this._edges = {}; + + cells.forEach(this._restructureOnAdd, this); + }, + + _restructureOnChangeSource: function(link) { + + var prevSource = link.previous('source'); + if (prevSource.id && this._out[prevSource.id]) { + delete this._out[prevSource.id][link.id]; + } + var source = link.attributes.source; + if (source.id) { + (this._out[source.id] || (this._out[source.id] = {}))[link.id] = true; + } + }, + + _restructureOnChangeTarget: function(link) { + + var prevTarget = link.previous('target'); + if (prevTarget.id && this._in[prevTarget.id]) { + delete this._in[prevTarget.id][link.id]; + } + var target = link.get('target'); + if (target.id) { + (this._in[target.id] || (this._in[target.id] = {}))[link.id] = true; + } + }, + + // Return all outbound edges for the node. Return value is an object + // of the form: [edgeId] -> true + getOutboundEdges: function(node) { + + return (this._out && this._out[node]) || {}; + }, + + // Return all inbound edges for the node. Return value is an object + // of the form: [edgeId] -> true + getInboundEdges: function(node) { + + return (this._in && this._in[node]) || {}; + }, + + toJSON: function() { + + // Backbone does not recursively call `toJSON()` on attributes that are themselves models/collections. + // It just clones the attributes. Therefore, we must call `toJSON()` on the cells collection explicitly. + var json = Backbone.Model.prototype.toJSON.apply(this, arguments); + json.cells = this.get('cells').toJSON(); + return json; + }, + + fromJSON: function(json, opt) { + + if (!json.cells) { + + throw new Error('Graph JSON must contain cells array.'); + } + + return this.set(json, opt); + }, + + set: function(key, val, opt) { + + var attrs; + + // Handle both `key`, value and {key: value} style arguments. + if (typeof key === 'object') { + attrs = key; + opt = val; + } else { + (attrs = {})[key] = val; + } + + // Make sure that `cells` attribute is handled separately via resetCells(). + if (attrs.hasOwnProperty('cells')) { + this.resetCells(attrs.cells, opt); + attrs = omit(attrs, 'cells'); + } + + // The rest of the attributes are applied via original set method. + return Backbone.Model.prototype.set.call(this, attrs, opt); + }, + + clear: function(opt) { + + opt = assign({}, opt, { clear: true }); + + var collection = this.get('cells'); + + if (collection.length === 0) { return this; } + + this.startBatch('clear', opt); + + // The elements come after the links. + var cells = collection.sortBy(function(cell) { + return cell.isLink() ? 1 : 2; + }); + + do { + + // Remove all the cells one by one. + // Note that all the links are removed first, so it's + // safe to remove the elements without removing the connected + // links first. + cells.shift().remove(opt); + + } while (cells.length > 0); + + this.stopBatch('clear'); + + return this; + }, + + _prepareCell: function(cell, opt) { + + var attrs; + if (cell instanceof Backbone.Model) { + attrs = cell.attributes; + if (!cell.graph && (!opt || !opt.dry)) { + // An element can not be member of more than one graph. + // A cell stops being the member of the graph after it's explicitly removed. + cell.graph = this; + } + } else { + // In case we're dealing with a plain JS object, we have to set the reference + // to the `graph` right after the actual model is created. This happens in the `model()` function + // of `joint.dia.GraphCells`. + attrs = cell; + } + + if (!isString(attrs.type)) { + throw new TypeError('dia.Graph: cell type must be a string.'); + } + + return cell; + }, + + minZIndex: function() { + + var firstCell = this.get('cells').first(); + return firstCell ? (firstCell.get('z') || 0) : 0; + }, + + maxZIndex: function() { + + var lastCell = this.get('cells').last(); + return lastCell ? (lastCell.get('z') || 0) : 0; + }, + + addCell: function(cell, opt) { + + if (Array.isArray(cell)) { + + return this.addCells(cell, opt); + } + + if (cell instanceof Backbone.Model) { + + if (!cell.has('z')) { + cell.set('z', this.maxZIndex() + 1); + } + + } else if (cell.z === undefined) { + + cell.z = this.maxZIndex() + 1; + } + + this.get('cells').add(this._prepareCell(cell, opt), opt || {}); + + return this; + }, + + addCells: function(cells, opt) { + + if (cells.length === 0) { return this; } + + cells = flattenDeep(cells); + opt.maxPosition = opt.position = cells.length - 1; + + this.startBatch('add', opt); + cells.forEach(function(cell) { + this.addCell(cell, opt); + opt.position--; + }, this); + this.stopBatch('add', opt); + + return this; + }, + + // When adding a lot of cells, it is much more efficient to + // reset the entire cells collection in one go. + // Useful for bulk operations and optimizations. + resetCells: function(cells, opt) { + + var preparedCells = toArray(cells).map(function(cell) { + return this._prepareCell(cell, opt); + }, this); + this.get('cells').reset(preparedCells, opt); + + return this; + }, + + removeCells: function(cells, opt) { + + if (cells.length) { + + this.startBatch('remove'); + invoke(cells, 'remove', opt); + this.stopBatch('remove'); + } + + return this; + }, + + _removeCell: function(cell, collection, options) { + + options = options || {}; + + if (!options.clear) { + // Applications might provide a `disconnectLinks` option set to `true` in order to + // disconnect links when a cell is removed rather then removing them. The default + // is to remove all the associated links. + if (options.disconnectLinks) { + + this.disconnectLinks(cell, options); + + } else { + + this.removeLinks(cell, options); + } + } + // Silently remove the cell from the cells collection. Silently, because + // `joint.dia.Cell.prototype.remove` already triggers the `remove` event which is + // then propagated to the graph model. If we didn't remove the cell silently, two `remove` events + // would be triggered on the graph model. + this.get('cells').remove(cell, { silent: true }); + + if (cell.graph === this) { + // Remove the element graph reference only if the cell is the member of this graph. + cell.graph = null; + } + }, + + // Get a cell by `id`. + getCell: function(id) { + + return this.get('cells').get(id); + }, + + getCells: function() { + + return this.get('cells').toArray(); + }, + + getElements: function() { + + return this.get('cells').filter(function (cell) { return cell.isElement(); }); + }, + + getLinks: function() { + + return this.get('cells').filter(function (cell) { return cell.isLink(); }); + }, + + getFirstCell: function() { + + return this.get('cells').first(); + }, + + getLastCell: function() { + + return this.get('cells').last(); + }, + + // Get all inbound and outbound links connected to the cell `model`. + getConnectedLinks: function(model, opt) { + + opt = opt || {}; + + var indirect = opt.indirect; + var inbound = opt.inbound; + var outbound = opt.outbound; + if ((inbound === undefined) && (outbound === undefined)) { + inbound = outbound = true; + } + + // the final array of connected link models + var links = []; + // a hash table of connected edges of the form: [edgeId] -> true + // used for quick lookups to check if we already added a link + var edges = {}; + + if (outbound) { + addOutbounds(this, model); + } + if (inbound) { + addInbounds(this, model); + } + + function addOutbounds(graph, model) { + forIn(graph.getOutboundEdges(model.id), function(_, edge) { + // skip links that were already added + // (those must be self-loop links) + // (because they are inbound and outbound edges of the same two elements) + if (edges[edge]) { return; } + var link = graph.getCell(edge); + links.push(link); + edges[edge] = true; + if (indirect) { + if (inbound) { addInbounds(graph, link); } + if (outbound) { addOutbounds(graph, link); } + } + }.bind(graph)); + if (indirect && model.isLink()) { + var outCell = model.getTargetCell(); + if (outCell && outCell.isLink()) { + if (!edges[outCell.id]) { + links.push(outCell); + addOutbounds(graph, outCell); + } + } + } + } + + function addInbounds(graph, model) { + forIn(graph.getInboundEdges(model.id), function(_, edge) { + // skip links that were already added + // (those must be self-loop links) + // (because they are inbound and outbound edges of the same two elements) + if (edges[edge]) { return; } + var link = graph.getCell(edge); + links.push(link); + edges[edge] = true; + if (indirect) { + if (inbound) { addInbounds(graph, link); } + if (outbound) { addOutbounds(graph, link); } + } + }.bind(graph)); + if (indirect && model.isLink()) { + var inCell = model.getSourceCell(); + if (inCell && inCell.isLink()) { + if (!edges[inCell.id]) { + links.push(inCell); + addInbounds(graph, inCell); + } + } + } + } + + // if `deep` option is `true`, check also all the links that are connected to any of the descendant cells + if (opt.deep) { + + var embeddedCells = model.getEmbeddedCells({ deep: true }); + + // in the first round, we collect all the embedded elements + var embeddedElements = {}; + embeddedCells.forEach(function(cell) { + if (cell.isElement()) { + embeddedElements[cell.id] = true; + } + }); + + embeddedCells.forEach(function(cell) { + if (cell.isLink()) { return; } + if (outbound) { + forIn(this.getOutboundEdges(cell.id), function(exists, edge) { + if (!edges[edge]) { + var edgeCell = this.getCell(edge); + var ref = edgeCell.attributes; + var source = ref.source; + var target = ref.target; + var sourceId = source.id; + var targetId = target.id; + + // if `includeEnclosed` option is falsy, skip enclosed links + if (!opt.includeEnclosed + && (sourceId && embeddedElements[sourceId]) + && (targetId && embeddedElements[targetId])) { + return; + } + + links.push(this.getCell(edge)); + edges[edge] = true; + } + }.bind(this)); + } + if (inbound) { + forIn(this.getInboundEdges(cell.id), function(exists, edge) { + if (!edges[edge]) { + var edgeCell = this.getCell(edge); + var ref = edgeCell.attributes; + var source = ref.source; + var target = ref.target; + var sourceId = source.id; + var targetId = target.id; + + // if `includeEnclosed` option is falsy, skip enclosed links + if (!opt.includeEnclosed + && (sourceId && embeddedElements[sourceId]) + && (targetId && embeddedElements[targetId])) { + return; + } + + links.push(this.getCell(edge)); + edges[edge] = true; + } + }.bind(this)); + } + }, this); + } + + return links; + }, + + getNeighbors: function(model, opt) { + + opt || (opt = {}); + + var inbound = opt.inbound; + var outbound = opt.outbound; + if (inbound === undefined && outbound === undefined) { + inbound = outbound = true; + } + + var neighbors = this.getConnectedLinks(model, opt).reduce(function(res, link) { + + var ref = link.attributes; + var source = ref.source; + var target = ref.target; + var loop = link.hasLoop(opt); + + // Discard if it is a point, or if the neighbor was already added. + if (inbound && has$2(source, 'id') && !res[source.id]) { + + var sourceElement = this.getCell(source.id); + if (sourceElement.isElement()) { + if (loop || (sourceElement && sourceElement !== model && (!opt.deep || !sourceElement.isEmbeddedIn(model)))) { + res[source.id] = sourceElement; + } + } + } + + // Discard if it is a point, or if the neighbor was already added. + if (outbound && has$2(target, 'id') && !res[target.id]) { + + var targetElement = this.getCell(target.id); + if (targetElement.isElement()) { + if (loop || (targetElement && targetElement !== model && (!opt.deep || !targetElement.isEmbeddedIn(model)))) { + res[target.id] = targetElement; + } + } + } + + return res; + }.bind(this), {}); + + if (model.isLink()) { + if (inbound) { + var sourceCell = model.getSourceCell(); + if (sourceCell && sourceCell.isElement() && !neighbors[sourceCell.id]) { + neighbors[sourceCell.id] = sourceCell; + } + } + if (outbound) { + var targetCell = model.getTargetCell(); + if (targetCell && targetCell.isElement() && !neighbors[targetCell.id]) { + neighbors[targetCell.id] = targetCell; + } + } + } + + return toArray(neighbors); + }, + + getCommonAncestor: function(/* cells */) { + + var cellsAncestors = Array.from(arguments).map(function(cell) { + + var ancestors = []; + var parentId = cell.get('parent'); + + while (parentId) { + + ancestors.push(parentId); + parentId = this.getCell(parentId).get('parent'); + } + + return ancestors; + + }, this); + + cellsAncestors = cellsAncestors.sort(function(a, b) { + return a.length - b.length; + }); + + var commonAncestor = toArray(cellsAncestors.shift()).find(function(ancestor) { + return cellsAncestors.every(function(cellAncestors) { + return cellAncestors.includes(ancestor); + }); + }); + + return this.getCell(commonAncestor); + }, + + // Find the whole branch starting at `element`. + // If `opt.deep` is `true`, take into account embedded elements too. + // If `opt.breadthFirst` is `true`, use the Breadth-first search algorithm, otherwise use Depth-first search. + getSuccessors: function(element, opt) { + + opt = opt || {}; + var res = []; + // Modify the options so that it includes the `outbound` neighbors only. In other words, search forwards. + this.search(element, function(el) { + if (el !== element) { + res.push(el); + } + }, assign({}, opt, { outbound: true })); + return res; + }, + + cloneCells: cloneCells, + // Clone the whole subgraph (including all the connected links whose source/target is in the subgraph). + // If `opt.deep` is `true`, also take into account all the embedded cells of all the subgraph cells. + // Return a map of the form: [original cell ID] -> [clone]. + cloneSubgraph: function(cells, opt) { + + var subgraph = this.getSubgraph(cells, opt); + return this.cloneCells(subgraph); + }, + + // Return `cells` and all the connected links that connect cells in the `cells` array. + // If `opt.deep` is `true`, return all the cells including all their embedded cells + // and all the links that connect any of the returned cells. + // For example, for a single shallow element, the result is that very same element. + // For two elements connected with a link: `A --- L ---> B`, the result for + // `getSubgraph([A, B])` is `[A, L, B]`. The same goes for `getSubgraph([L])`, the result is again `[A, L, B]`. + getSubgraph: function(cells, opt) { + + opt = opt || {}; + + var subgraph = []; + // `cellMap` is used for a quick lookup of existence of a cell in the `cells` array. + var cellMap = {}; + var elements = []; + var links = []; + + toArray(cells).forEach(function(cell) { + if (!cellMap[cell.id]) { + subgraph.push(cell); + cellMap[cell.id] = cell; + if (cell.isLink()) { + links.push(cell); + } else { + elements.push(cell); + } + } + + if (opt.deep) { + var embeds = cell.getEmbeddedCells({ deep: true }); + embeds.forEach(function(embed) { + if (!cellMap[embed.id]) { + subgraph.push(embed); + cellMap[embed.id] = embed; + if (embed.isLink()) { + links.push(embed); + } else { + elements.push(embed); + } + } + }); + } + }); + + links.forEach(function(link) { + // For links, return their source & target (if they are elements - not points). + var ref = link.attributes; + var source = ref.source; + var target = ref.target; + if (source.id && !cellMap[source.id]) { + var sourceElement = this.getCell(source.id); + subgraph.push(sourceElement); + cellMap[sourceElement.id] = sourceElement; + elements.push(sourceElement); + } + if (target.id && !cellMap[target.id]) { + var targetElement = this.getCell(target.id); + subgraph.push(this.getCell(target.id)); + cellMap[targetElement.id] = targetElement; + elements.push(targetElement); + } + }, this); + + elements.forEach(function(element) { + // For elements, include their connected links if their source/target is in the subgraph; + var links = this.getConnectedLinks(element, opt); + links.forEach(function(link) { + var ref = link.attributes; + var source = ref.source; + var target = ref.target; + if (!cellMap[link.id] && source.id && cellMap[source.id] && target.id && cellMap[target.id]) { + subgraph.push(link); + cellMap[link.id] = link; + } + }); + }, this); + + return subgraph; + }, + + // Find all the predecessors of `element`. This is a reverse operation of `getSuccessors()`. + // If `opt.deep` is `true`, take into account embedded elements too. + // If `opt.breadthFirst` is `true`, use the Breadth-first search algorithm, otherwise use Depth-first search. + getPredecessors: function(element, opt) { + + opt = opt || {}; + var res = []; + // Modify the options so that it includes the `inbound` neighbors only. In other words, search backwards. + this.search(element, function(el) { + if (el !== element) { + res.push(el); + } + }, assign({}, opt, { inbound: true })); + return res; + }, + + // Perform search on the graph. + // If `opt.breadthFirst` is `true`, use the Breadth-first Search algorithm, otherwise use Depth-first search. + // By setting `opt.inbound` to `true`, you can reverse the direction of the search. + // If `opt.deep` is `true`, take into account embedded elements too. + // `iteratee` is a function of the form `function(element) {}`. + // If `iteratee` explicitly returns `false`, the searching stops. + search: function(element, iteratee, opt) { + + opt = opt || {}; + if (opt.breadthFirst) { + this.bfs(element, iteratee, opt); + } else { + this.dfs(element, iteratee, opt); + } + }, + + // Breadth-first search. + // If `opt.deep` is `true`, take into account embedded elements too. + // If `opt.inbound` is `true`, reverse the search direction (it's like reversing all the link directions). + // `iteratee` is a function of the form `function(element, distance) {}`. + // where `element` is the currently visited element and `distance` is the distance of that element + // from the root `element` passed the `bfs()`, i.e. the element we started the search from. + // Note that the `distance` is not the shortest or longest distance, it is simply the number of levels + // crossed till we visited the `element` for the first time. It is especially useful for tree graphs. + // If `iteratee` explicitly returns `false`, the searching stops. + bfs: function(element, iteratee, opt) { + if ( opt === void 0 ) opt = {}; + + + var visited = {}; + var distance = {}; + var queue = []; + + queue.push(element); + distance[element.id] = 0; + + while (queue.length > 0) { + var next = queue.shift(); + if (visited[next.id]) { continue; } + visited[next.id] = true; + if (iteratee.call(this, next, distance[next.id]) === false) { continue; } + var neighbors = this.getNeighbors(next, opt); + for (var i = 0, n = neighbors.length; i < n; i++) { + var neighbor = neighbors[i]; + distance[neighbor.id] = distance[next.id] + 1; + queue.push(neighbor); + } + } + }, + + // Depth-first search. + // If `opt.deep` is `true`, take into account embedded elements too. + // If `opt.inbound` is `true`, reverse the search direction (it's like reversing all the link directions). + // `iteratee` is a function of the form `function(element, distance) {}`. + // If `iteratee` explicitly returns `false`, the search stops. + dfs: function(element, iteratee, opt) { + if ( opt === void 0 ) opt = {}; + + + var visited = {}; + var distance = {}; + var queue = []; + + queue.push(element); + distance[element.id] = 0; + + while (queue.length > 0) { + var next = queue.pop(); + if (visited[next.id]) { continue; } + visited[next.id] = true; + if (iteratee.call(this, next, distance[next.id]) === false) { continue; } + var neighbors = this.getNeighbors(next, opt); + var lastIndex = queue.length; + for (var i = 0, n = neighbors.length; i < n; i++) { + var neighbor = neighbors[i]; + distance[neighbor.id] = distance[next.id] + 1; + queue.splice(lastIndex, 0, neighbor); + } + } + }, + + // Get all the roots of the graph. Time complexity: O(|V|). + getSources: function() { + + var sources = []; + forIn(this._nodes, function(exists, node) { + if (!this._in[node] || isEmpty(this._in[node])) { + sources.push(this.getCell(node)); + } + }.bind(this)); + return sources; + }, + + // Get all the leafs of the graph. Time complexity: O(|V|). + getSinks: function() { + + var sinks = []; + forIn(this._nodes, function(exists, node) { + if (!this._out[node] || isEmpty(this._out[node])) { + sinks.push(this.getCell(node)); + } + }.bind(this)); + return sinks; + }, + + // Return `true` if `element` is a root. Time complexity: O(1). + isSource: function(element) { + + return !this._in[element.id] || isEmpty(this._in[element.id]); + }, + + // Return `true` if `element` is a leaf. Time complexity: O(1). + isSink: function(element) { + + return !this._out[element.id] || isEmpty(this._out[element.id]); + }, + + // Return `true` is `elementB` is a successor of `elementA`. Return `false` otherwise. + isSuccessor: function(elementA, elementB) { + + var isSuccessor = false; + this.search(elementA, function(element) { + if (element === elementB && element !== elementA) { + isSuccessor = true; + return false; + } + }, { outbound: true }); + return isSuccessor; + }, + + // Return `true` is `elementB` is a predecessor of `elementA`. Return `false` otherwise. + isPredecessor: function(elementA, elementB) { + + var isPredecessor = false; + this.search(elementA, function(element) { + if (element === elementB && element !== elementA) { + isPredecessor = true; + return false; + } + }, { inbound: true }); + return isPredecessor; + }, + + // Return `true` is `elementB` is a neighbor of `elementA`. Return `false` otherwise. + // `opt.deep` controls whether to take into account embedded elements as well. See `getNeighbors()` + // for more details. + // If `opt.outbound` is set to `true`, return `true` only if `elementB` is a successor neighbor. + // Similarly, if `opt.inbound` is set to `true`, return `true` only if `elementB` is a predecessor neighbor. + isNeighbor: function(elementA, elementB, opt) { + + opt = opt || {}; + + var inbound = opt.inbound; + var outbound = opt.outbound; + if ((inbound === undefined) && (outbound === undefined)) { + inbound = outbound = true; + } + + var isNeighbor = false; + + this.getConnectedLinks(elementA, opt).forEach(function(link) { + + var ref = link.attributes; + var source = ref.source; + var target = ref.target; + + // Discard if it is a point. + if (inbound && has$2(source, 'id') && (source.id === elementB.id)) { + isNeighbor = true; + return false; + } + + // Discard if it is a point, or if the neighbor was already added. + if (outbound && has$2(target, 'id') && (target.id === elementB.id)) { + isNeighbor = true; + return false; + } + }); + + return isNeighbor; + }, + + // Disconnect links connected to the cell `model`. + disconnectLinks: function(model, opt) { + + this.getConnectedLinks(model).forEach(function(link) { + + link.set((link.attributes.source.id === model.id ? 'source' : 'target'), { x: 0, y: 0 }, opt); + }); + }, + + // Remove links connected to the cell `model` completely. + removeLinks: function(model, opt) { + + invoke(this.getConnectedLinks(model), 'remove', opt); + }, + + // Find all elements at given point + findModelsFromPoint: function(p) { + return this.getElements().filter(function (el) { return el.getBBox({ rotate: true }).containsPoint(p); }); + }, + + // Find all elements in given area + findModelsInArea: function(rect, opt) { + if ( opt === void 0 ) opt = {}; + + var r = new Rect(rect); + var strict = opt.strict; if ( strict === void 0 ) strict = false; + var method = strict ? 'containsRect' : 'intersect'; + return this.getElements().filter(function (el) { return r[method](el.getBBox({ rotate: true })); }); + }, + + // Find all elements under the given element. + findModelsUnderElement: function(element, opt) { + if ( opt === void 0 ) opt = {}; + + var searchBy = opt.searchBy; if ( searchBy === void 0 ) searchBy = 'bbox'; + var bbox = element.getBBox().rotateAroundCenter(element.angle()); + var elements = (searchBy === 'bbox') + ? this.findModelsInArea(bbox) + : this.findModelsFromPoint(getRectPoint(bbox, searchBy)); + // don't account element itself or any of its descendants + return elements.filter(function (el) { return element.id !== el.id && !el.isEmbeddedIn(element); }); + }, + + // Return bounding box of all elements. + getBBox: function() { + + return this.getCellsBBox(this.getCells()); + }, + + // Return the bounding box of all cells in array provided. + getCellsBBox: function(cells, opt) { + if ( opt === void 0 ) opt = {}; + + var rotate = opt.rotate; if ( rotate === void 0 ) rotate = true; + return toArray(cells).reduce(function(memo, cell) { + var rect = cell.getBBox({ rotate: rotate }); + if (!rect) { return memo; } + if (memo) { + return memo.union(rect); + } + return rect; + }, null); + }, + + translate: function(dx, dy, opt) { + + // Don't translate cells that are embedded in any other cell. + var cells = this.getCells().filter(function(cell) { + return !cell.isEmbedded(); + }); + + invoke(cells, 'translate', dx, dy, opt); + + return this; + }, + + resize: function(width, height, opt) { + + return this.resizeCells(width, height, this.getCells(), opt); + }, + + resizeCells: function(width, height, cells, opt) { + + // `getBBox` method returns `null` if no elements provided. + // i.e. cells can be an array of links + var bbox = this.getCellsBBox(cells); + if (bbox) { + var sx = Math.max(width / bbox.width, 0); + var sy = Math.max(height / bbox.height, 0); + invoke(cells, 'scale', sx, sy, bbox.origin(), opt); + } + + return this; + }, + + startBatch: function(name, data) { + + data = data || {}; + this._batches[name] = (this._batches[name] || 0) + 1; + + return this.trigger('batch:start', assign({}, data, { batchName: name })); + }, + + stopBatch: function(name, data) { + + data = data || {}; + this._batches[name] = (this._batches[name] || 0) - 1; + + return this.trigger('batch:stop', assign({}, data, { batchName: name })); + }, + + hasActiveBatch: function(name) { + + var batches = this._batches; + var names; + + if (arguments.length === 0) { + names = Object.keys(batches); + } else if (Array.isArray(name)) { + names = name; + } else { + names = [name]; + } + + return names.some(function (batch) { return batches[batch] > 0; }); + } + + }, { + + validations: { + + multiLinks: function(graph, link) { + + // Do not allow multiple links to have the same source and target. + var ref = link.attributes; + var source = ref.source; + var target = ref.target; + + if (source.id && target.id) { + + var sourceModel = link.getSourceCell(); + if (sourceModel) { + + var connectedLinks = graph.getConnectedLinks(sourceModel, { outbound: true }); + var sameLinks = connectedLinks.filter(function(_link) { + + var ref = _link.attributes; + var _source = ref.source; + var _target = ref.target; + return _source && _source.id === source.id && + (!_source.port || (_source.port === source.port)) && + _target && _target.id === target.id && + (!_target.port || (_target.port === target.port)); + + }); + + if (sameLinks.length > 1) { + return false; + } + } + } + + return true; + }, + + linkPinning: function(_graph, link) { + var ref = link.attributes; + var source = ref.source; + var target = ref.target; + return source.id && target.id; + } + } + + }); + + wrapWith(Graph.prototype, ['resetCells', 'addCells', 'removeCells'], wrappers.cells); + + var views = {}; + + var View = Backbone.View.extend({ + + options: {}, + theme: null, + themeClassNamePrefix: addClassNamePrefix('theme-'), + requireSetThemeOverride: false, + defaultTheme: config.defaultTheme, + children: null, + childNodes: null, + + DETACHABLE: true, + UPDATE_PRIORITY: 2, + FLAG_INSERT: 1<<30, + FLAG_REMOVE: 1<<29, + + constructor: function(options) { + + this.requireSetThemeOverride = options && !!options.theme; + this.options = assign({}, this.options, options); + + Backbone.View.call(this, options); + }, + + initialize: function() { + + views[this.cid] = this; + + this.setTheme(this.options.theme || this.defaultTheme); + this.init(); + }, + + unmount: function() { + if (this.svgElement) { + this.vel.remove(); + } else { + this.$el.remove(); + } + }, + + renderChildren: function(children) { + children || (children = result(this, 'children')); + if (children) { + var isSVG = this.svgElement; + var namespace = V.namespace[isSVG ? 'svg' : 'xhtml']; + var doc = parseDOMJSON(children, namespace); + (isSVG ? this.vel : this.$el).empty().append(doc.fragment); + this.childNodes = doc.selectors; + } + return this; + }, + + findAttribute: function(attributeName, node) { + + var currentNode = node; + + while (currentNode && currentNode.nodeType === 1) { + var attributeValue = currentNode.getAttribute(attributeName); + // attribute found + if (attributeValue) { return attributeValue; } + // do not climb up the DOM + if (currentNode === this.el) { return null; } + // try parent node + currentNode = currentNode.parentNode; + } + + return null; + }, + + // Override the Backbone `_ensureElement()` method in order to create an + // svg element (e.g., ``) node that wraps all the nodes of the Cell view. + // Expose class name setter as a separate method. + _ensureElement: function() { + if (!this.el) { + var tagName = result(this, 'tagName'); + var attrs = assign({}, result(this, 'attributes')); + var style = assign({}, result(this, 'style')); + if (this.id) { attrs.id = result(this, 'id'); } + this.setElement(this._createElement(tagName)); + this._setAttributes(attrs); + this._setStyle(style); + } else { + this.setElement(result(this, 'el')); + } + this._ensureElClassName(); + }, + + _setAttributes: function(attrs) { + if (this.svgElement) { + this.vel.attr(attrs); + } else { + this.$el.attr(attrs); + } + }, + + _setStyle: function(style) { + this.$el.css(style); + }, + + _createElement: function(tagName) { + if (this.svgElement) { + return document.createElementNS(V.namespace.svg, tagName); + } else { + return document.createElement(tagName); + } + }, + + // Utilize an alternative DOM manipulation API by + // adding an element reference wrapped in Vectorizer. + _setElement: function(el) { + this.$el = el instanceof Backbone.$ ? el : Backbone.$(el); + this.el = this.$el[0]; + if (this.svgElement) { this.vel = V(this.el); } + }, + + _ensureElClassName: function() { + var className = result(this, 'className'); + if (!className) { return; } + var prefixedClassName = addClassNamePrefix(className); + // Note: className removal here kept for backwards compatibility only + if (this.svgElement) { + this.vel.removeClass(className).addClass(prefixedClassName); + } else { + this.$el.removeClass(className).addClass(prefixedClassName); + } + }, + + init: function() { + // Intentionally empty. + // This method is meant to be overridden. + }, + + onRender: function() { + // Intentionally empty. + // This method is meant to be overridden. + }, + + confirmUpdate: function() { + // Intentionally empty. + // This method is meant to be overridden. + return 0; + }, + + setTheme: function(theme, opt) { + + opt = opt || {}; + + // Theme is already set, override is required, and override has not been set. + // Don't set the theme. + if (this.theme && this.requireSetThemeOverride && !opt.override) { + return this; + } + + this.removeThemeClassName(); + this.addThemeClassName(theme); + this.onSetTheme(this.theme/* oldTheme */, theme/* newTheme */); + this.theme = theme; + + return this; + }, + + addThemeClassName: function(theme) { + + theme = theme || this.theme; + if (!theme) { return this; } + + var className = this.themeClassNamePrefix + theme; + + if (this.svgElement) { + this.vel.addClass(className); + } else { + this.$el.addClass(className); + } + + return this; + }, + + removeThemeClassName: function(theme) { + + theme = theme || this.theme; + + var className = this.themeClassNamePrefix + theme; + + if (this.svgElement) { + this.vel.removeClass(className); + } else { + this.$el.removeClass(className); + } + + return this; + }, + + onSetTheme: function(oldTheme, newTheme) { + // Intentionally empty. + // This method is meant to be overridden. + }, + + remove: function() { + + this.onRemove(); + this.undelegateDocumentEvents(); + + views[this.cid] = null; + + Backbone.View.prototype.remove.apply(this, arguments); + + return this; + }, + + onRemove: function() { + // Intentionally empty. + // This method is meant to be overridden. + }, + + getEventNamespace: function() { + // Returns a per-session unique namespace + return '.joint-event-ns-' + this.cid; + }, + + delegateElementEvents: function(element, events, data) { + if (!events) { return this; } + data || (data = {}); + var eventNS = this.getEventNamespace(); + for (var eventName in events) { + var method = events[eventName]; + if (typeof method !== 'function') { method = this[method]; } + if (!method) { continue; } + $(element).on(eventName + eventNS, data, method.bind(this)); + } + return this; + }, + + undelegateElementEvents: function(element) { + $(element).off(this.getEventNamespace()); + return this; + }, + + delegateDocumentEvents: function(events, data) { + events || (events = result(this, 'documentEvents')); + return this.delegateElementEvents(document, events, data); + }, + + undelegateDocumentEvents: function() { + return this.undelegateElementEvents(document); + }, + + eventData: function(evt, data) { + if (!evt) { throw new Error('eventData(): event object required.'); } + var currentData = evt.data; + var key = '__' + this.cid + '__'; + if (data === undefined) { + if (!currentData) { return {}; } + return currentData[key] || {}; + } + currentData || (currentData = evt.data = {}); + currentData[key] || (currentData[key] = {}); + assign(currentData[key], data); + return this; + }, + + stopPropagation: function(evt) { + this.eventData(evt, { propagationStopped: true }); + return this; + }, + + isPropagationStopped: function(evt) { + return !!this.eventData(evt).propagationStopped; + } + + }, { + + extend: function() { + + var args = Array.from(arguments); + + // Deep clone the prototype and static properties objects. + // This prevents unexpected behavior where some properties are overwritten outside of this function. + var protoProps = args[0] && assign({}, args[0]) || {}; + var staticProps = args[1] && assign({}, args[1]) || {}; + + // Need the real render method so that we can wrap it and call it later. + var renderFn = protoProps.render || (this.prototype && this.prototype.render) || null; + + /* + Wrap the real render method so that: + .. `onRender` is always called. + .. `this` is always returned. + */ + protoProps.render = function() { + + if (typeof renderFn === 'function') { + // Call the original render method. + renderFn.apply(this, arguments); + } + + if (this.render.__render__ === renderFn) { + // Should always call onRender() method. + // Should call it only once when renderFn is actual prototype method i.e. not the wrapper + this.onRender(); + } + + // Should always return itself. + return this; + }; + + protoProps.render.__render__ = renderFn; + + return Backbone.View.extend.call(this, protoProps, staticProps); + } + }); + + var DoubleTapEventName = 'dbltap'; + if ($.event && !(DoubleTapEventName in $.event.special)) { + var maxDelay = config.doubleTapInterval; + var minDelay = 30; + $.event.special[DoubleTapEventName] = { + bindType: 'touchend', + delegateType: 'touchend', + handle: function(event) { + var ref; + + var args = [], len = arguments.length - 1; + while ( len-- > 0 ) args[ len ] = arguments[ len + 1 ]; + var handleObj = event.handleObj; + var target = event.target; + var targetData = $.data(target); + var now = new Date().getTime(); + var delta = 'lastTouch' in targetData ? now - targetData.lastTouch : 0; + if (delta < maxDelay && delta > minDelay) { + targetData.lastTouch = null; + event.type = handleObj.origType; + // let jQuery handle the triggering of "dbltap" event handlers + (ref = handleObj.handler).call.apply(ref, [ this, event ].concat( args )); + } else { + targetData.lastTouch = now; + } + } + }; + } + + var Listener = function Listener() { + var callbackArguments = [], len = arguments.length; + while ( len-- ) callbackArguments[ len ] = arguments[ len ]; + + this.callbackArguments = callbackArguments; + }; + + Listener.prototype.listenTo = function listenTo (object, evt) { + var this$1 = this; + var args = [], len = arguments.length - 2; + while ( len-- > 0 ) args[ len ] = arguments[ len + 2 ]; + + var ref = this; + var callbackArguments = ref.callbackArguments; + // signature 1 - (object, eventHashMap, context) + if (V.isObject(evt)) { + var context = args[0]; if ( context === void 0 ) context = null; + Object.entries(evt).forEach(function (ref) { + var eventName = ref[0]; + var cb = ref[1]; + + if (typeof cb !== 'function') { return; } + // Invoke the callback with callbackArguments passed first + if (context || callbackArguments.length > 0) { cb = cb.bind.apply(cb, [ context ].concat( callbackArguments )); } + Backbone.Events.listenTo.call(this$1, object, eventName, cb); + }); + } + // signature 2 - (object, event, callback, context) + else if (typeof evt === 'string' && typeof args[0] === 'function') { + var cb = args[0]; + var context$1 = args[1]; if ( context$1 === void 0 ) context$1 = null; + // Invoke the callback with callbackArguments passed first + if (context$1 || callbackArguments.length > 0) { cb = cb.bind.apply(cb, [ context$1 ].concat( callbackArguments )); } + Backbone.Events.listenTo.call(this, object, evt, cb); + } + }; + + Listener.prototype.stopListening = function stopListening () { + Backbone.Events.stopListening.call(this); + }; + + + + var index$1 = ({ + views: views, + View: View, + Listener: Listener + }); + + var LayersNames = { + CELLS: 'cells', + BACK: 'back', + FRONT: 'front', + TOOLS: 'tools', + LABELS: 'labels' + }; + + var PaperLayer = View.extend({ + + tagName: 'g', + svgElement: true, + pivotNodes: null, + defaultTheme: null, + + options: { + name: '' + }, + + className: function() { + return addClassNamePrefix(((this.options.name) + "-layer")); + }, + + init: function() { + this.pivotNodes = {}; + }, + + insertSortedNode: function(node, z) { + this.el.insertBefore(node, this.insertPivot(z)); + }, + + insertNode: function(node) { + var ref = this; + var el = ref.el; + if (node.parentNode !== el) { + el.appendChild(node); + } + }, + + insertPivot: function(z) { + var ref = this; + var el = ref.el; + var pivotNodes = ref.pivotNodes; + z = +z; + z || (z = 0); + var pivotNode = pivotNodes[z]; + if (pivotNode) { return pivotNode; } + pivotNode = pivotNodes[z] = document.createComment('z-index:' + (z + 1)); + var neighborZ = -Infinity; + for (var currentZ in pivotNodes) { + currentZ = +currentZ; + if (currentZ < z && currentZ > neighborZ) { + neighborZ = currentZ; + if (neighborZ === z - 1) { continue; } + } + } + if (neighborZ !== -Infinity) { + var neighborPivot = pivotNodes[neighborZ]; + // Insert After + el.insertBefore(pivotNode, neighborPivot.nextSibling); + } else { + // First Child + el.insertBefore(pivotNode, el.firstChild); + } + return pivotNode; + }, + + removePivots: function() { + var ref = this; + var el = ref.el; + var pivotNodes = ref.pivotNodes; + for (var z in pivotNodes) { el.removeChild(pivotNodes[z]); } + this.pivotNodes = {}; + } + + }); + + function toArray$1(obj) { + if (!obj) { return []; } + if (Array.isArray(obj)) { return obj; } + return [obj]; + } + + var HighlighterView = View.extend({ + + tagName: 'g', + svgElement: true, + className: 'highlight', + + HIGHLIGHT_FLAG: 1, + UPDATE_PRIORITY: 3, + DETACHABLE: false, + UPDATABLE: true, + MOUNTABLE: true, + + cellView: null, + nodeSelector: null, + node: null, + updateRequested: false, + transformGroup: null, + + requestUpdate: function requestUpdate(cellView, nodeSelector) { + var paper = cellView.paper; + this.cellView = cellView; + this.nodeSelector = nodeSelector; + if (paper) { + this.updateRequested = true; + paper.requestViewUpdate(this, this.HIGHLIGHT_FLAG, this.UPDATE_PRIORITY); + } + }, + + confirmUpdate: function confirmUpdate() { + // The cellView is now rendered/updated since it has a higher update priority. + this.updateRequested = false; + var ref = this; + var cellView = ref.cellView; + var nodeSelector = ref.nodeSelector; + this.update(cellView, nodeSelector); + this.mount(); + this.transform(); + return 0; + }, + + findNode: function findNode(cellView, nodeSelector) { + var assign, assign$1; + + if ( nodeSelector === void 0 ) nodeSelector = null; + var el; + if (typeof nodeSelector === 'string') { + (assign = cellView.findBySelector(nodeSelector), el = assign[0]); + } else if (isPlainObject(nodeSelector)) { + var isLink = cellView.model.isLink(); + var label = nodeSelector.label; if ( label === void 0 ) label = null; + var port = nodeSelector.port; + var selector = nodeSelector.selector; + if (isLink && label !== null) { + // Link Label Selector + el = cellView.findLabelNode(label, selector); + } else if (!isLink && port) { + // Element Port Selector + el = cellView.findPortNode(port, selector); + } else { + // Cell Selector + (assign$1 = cellView.findBySelector(selector), el = assign$1[0]); + } + } else if (nodeSelector) { + el = V.toNode(nodeSelector); + if (!(el instanceof SVGElement)) { el = null; } + } + return el ? el : null; + }, + + getNodeMatrix: function getNodeMatrix(cellView, node) { + var ref = this; + var options = ref.options; + var layer = options.layer; + var rotatableNode = cellView.rotatableNode; + var nodeMatrix = cellView.getNodeMatrix(node); + if (rotatableNode) { + if (layer) { + if (rotatableNode.contains(node)) { + return nodeMatrix; + } + // The node is outside of the rotatable group. + // Compensate the rotation set by transformGroup. + return cellView.getRootRotateMatrix().inverse().multiply(nodeMatrix); + } else { + return cellView.getNodeRotateMatrix(node).multiply(nodeMatrix); + } + } + return nodeMatrix; + }, + + mount: function mount() { + var ref = this; + var MOUNTABLE = ref.MOUNTABLE; + var cellView = ref.cellView; + var el = ref.el; + var options = ref.options; + var transformGroup = ref.transformGroup; + if (!MOUNTABLE || transformGroup) { return; } + var cellViewRoot = cellView.vel; + var paper = cellView.paper; + var layerName = options.layer; + if (layerName) { + var vGroup = this.transformGroup = V('g').addClass('highlight-transform').append(el); + paper.getLayerView(layerName).insertSortedNode(vGroup.node, options.z); + } else { + // TODO: prepend vs append + if (!el.parentNode || el.nextSibling) { + // Not appended yet or not the last child + cellViewRoot.append(el); + } + } + }, + + unmount: function unmount() { + var ref = this; + var MOUNTABLE = ref.MOUNTABLE; + var transformGroup = ref.transformGroup; + var vel = ref.vel; + if (!MOUNTABLE) { return; } + if (transformGroup) { + this.transformGroup = null; + transformGroup.remove(); + } else { + vel.remove(); + } + }, + + transform: function transform() { + var ref = this; + var transformGroup = ref.transformGroup; + var cellView = ref.cellView; + var updateRequested = ref.updateRequested; + if (!transformGroup || cellView.model.isLink() || updateRequested) { return; } + var translateMatrix = cellView.getRootTranslateMatrix(); + var rotateMatrix = cellView.getRootRotateMatrix(); + var transformMatrix = translateMatrix.multiply(rotateMatrix); + transformGroup.attr('transform', V.matrixToTransformString(transformMatrix)); + }, + + update: function update() { + var ref = this; + var prevNode = ref.node; + var cellView = ref.cellView; + var nodeSelector = ref.nodeSelector; + var updateRequested = ref.updateRequested; + var id = ref.id; + if (updateRequested) { return; } + var node = this.node = this.findNode(cellView, nodeSelector); + if (prevNode) { + this.unhighlight(cellView, prevNode); + } + if (node) { + this.highlight(cellView, node); + this.mount(); + } else { + this.unmount(); + cellView.notify('cell:highlight:invalid', id, this); + } + }, + + onRemove: function onRemove() { + var ref = this; + var node = ref.node; + var cellView = ref.cellView; + var id = ref.id; + var constructor = ref.constructor; + if (node) { + this.unhighlight(cellView, node); + } + this.unmount(); + constructor._removeRef(cellView, id); + }, + + highlight: function highlight(_cellView, _node) { + // to be overridden + }, + + unhighlight: function unhighlight(_cellView, _node) { + // to be overridden + }, + + // Update Attributes + + listenToUpdateAttributes: function listenToUpdateAttributes(cellView) { + var attributes = result(this, 'UPDATE_ATTRIBUTES'); + if (!Array.isArray(attributes) || attributes.length === 0) { return; } + this.listenTo(cellView.model, 'change', this.onCellAttributeChange); + }, + + onCellAttributeChange: function onCellAttributeChange() { + var ref = this; + var cellView = ref.cellView; + if (!cellView) { return; } + var model = cellView.model; + var paper = cellView.paper; + var attributes = result(this, 'UPDATE_ATTRIBUTES'); + if (!attributes.some(function (attribute) { return model.hasChanged(attribute); })) { return; } + paper.requestViewUpdate(this, this.HIGHLIGHT_FLAG, this.UPDATE_PRIORITY); + } + + }, { + + _views: {}, + + // Used internally by CellView highlight() + highlight: function(cellView, node, opt) { + var id = this.uniqueId(node, opt); + this.add(cellView, node, id, opt); + }, + + // Used internally by CellView unhighlight() + unhighlight: function(cellView, node, opt) { + var id = this.uniqueId(node, opt); + this.remove(cellView, id); + }, + + get: function get(cellView, id) { + if ( id === void 0 ) id = null; + + var cid = cellView.cid; + var ref$2 = this; + var _views = ref$2._views; + var refs = _views[cid]; + if (id === null) { + // all highlighters + var views = []; + if (!refs) { return views; } + for (var hid in refs) { + var ref = refs[hid]; + if (ref instanceof this) { + views.push(ref); + } + } + return views; + } else { + // single highlighter + if (!refs) { return null; } + if (id in refs) { + var ref$1 = refs[id]; + if (ref$1 instanceof this) { return ref$1; } + } + return null; + } + }, + + add: function add(cellView, nodeSelector, id, opt) { + if ( opt === void 0 ) opt = {}; + + if (!id) { throw new Error('dia.HighlighterView: An ID required.'); } + // Search the existing view amongst all the highlighters + var previousView = HighlighterView.get(cellView, id); + if (previousView) { previousView.remove(); } + var view = new this(opt); + view.id = id; + this._addRef(cellView, id, view); + view.requestUpdate(cellView, nodeSelector); + view.listenToUpdateAttributes(cellView); + return view; + }, + + _addRef: function _addRef(cellView, id, view) { + var cid = cellView.cid; + var ref = this; + var _views = ref._views; + var refs = _views[cid]; + if (!refs) { refs = _views[cid] = {}; } + refs[id] = view; + }, + + _removeRef: function _removeRef(cellView, id) { + var cid = cellView.cid; + var ref = this; + var _views = ref._views; + var refs = _views[cid]; + if (!refs) { return; } + if (id) { delete refs[id]; } + for (var _ in refs) { return; } + delete _views[cid]; + }, + + remove: function remove(cellView, id) { + if ( id === void 0 ) id = null; + + toArray$1(this.get(cellView, id)).forEach(function (view) { + view.remove(); + }); + }, + + removeAll: function removeAll(paper, id) { + if ( id === void 0 ) id = null; + + var ref = this; + var _views = ref._views; + + for (var cid in _views) { + for (var hid in _views[cid]) { + var view = _views[cid][hid]; + + if (view.cellView.paper === paper && view instanceof this && (id === null || hid === id)) { + view.remove(); + } + } + } + }, + + update: function update(cellView, id, dirty) { + if ( id === void 0 ) id = null; + if ( dirty === void 0 ) dirty = false; + + toArray$1(this.get(cellView, id)).forEach(function (view) { + if (dirty || view.UPDATABLE) { view.update(); } + }); + }, + + transform: function transform(cellView, id) { + if ( id === void 0 ) id = null; + + toArray$1(this.get(cellView, id)).forEach(function (view) { + if (view.UPDATABLE) { view.transform(); } + }); + }, + + uniqueId: function uniqueId(node, opt) { + if ( opt === void 0 ) opt = ''; + + return V.ensureId(node) + JSON.stringify(opt); + } + + }); + + var HighlightingTypes = { + DEFAULT: 'default', + EMBEDDING: 'embedding', + CONNECTING: 'connecting', + MAGNET_AVAILABILITY: 'magnetAvailability', + ELEMENT_AVAILABILITY: 'elementAvailability' + }; + + // CellView base view and controller. + // -------------------------------------------- + + // This is the base view and controller for `ElementView` and `LinkView`. + var CellView = View.extend({ + + tagName: 'g', + + svgElement: true, + + selector: 'root', + + metrics: null, + + className: function() { + + var classNames = ['cell']; + var type = this.model.get('type'); + + if (type) { + + type.toLowerCase().split('.').forEach(function(value, index, list) { + classNames.push('type-' + list.slice(0, index + 1).join('-')); + }); + } + + return classNames.join(' '); + }, + + _presentationAttributes: null, + _flags: null, + + setFlags: function() { + var flags = {}; + var attributes = {}; + var shift = 0; + var i, n, label; + var presentationAttributes = result(this, 'presentationAttributes'); + for (var attribute in presentationAttributes) { + if (!presentationAttributes.hasOwnProperty(attribute)) { continue; } + var labels = presentationAttributes[attribute]; + if (!Array.isArray(labels)) { labels = [labels]; } + for (i = 0, n = labels.length; i < n; i++) { + label = labels[i]; + var flag = flags[label]; + if (!flag) { + flag = flags[label] = 1<<(shift++); + } + attributes[attribute] |= flag; + } + } + var initFlag = result(this, 'initFlag'); + if (!Array.isArray(initFlag)) { initFlag = [initFlag]; } + for (i = 0, n = initFlag.length; i < n; i++) { + label = initFlag[i]; + if (!flags[label]) { flags[label] = 1<<(shift++); } + } + + // 26 - 30 are reserved for paper flags + // 31+ overflows maximal number + if (shift > 25) { throw new Error('dia.CellView: Maximum number of flags exceeded.'); } + + this._flags = flags; + this._presentationAttributes = attributes; + }, + + hasFlag: function(flag, label) { + return flag & this.getFlag(label); + }, + + removeFlag: function(flag, label) { + return flag ^ (flag & this.getFlag(label)); + }, + + getFlag: function(label) { + var flags = this._flags; + if (!flags) { return 0; } + var flag = 0; + if (Array.isArray(label)) { + for (var i = 0, n = label.length; i < n; i++) { flag |= flags[label[i]]; } + } else { + flag |= flags[label]; + } + return flag; + }, + + attributes: function() { + var cell = this.model; + return { + 'model-id': cell.id, + 'data-type': cell.attributes.type + }; + }, + + constructor: function(options) { + + // Make sure a global unique id is assigned to this view. Store this id also to the properties object. + // The global unique id makes sure that the same view can be rendered on e.g. different machines and + // still be associated to the same object among all those clients. This is necessary for real-time + // collaboration mechanism. + options.id = options.id || guid(this); + + View.call(this, options); + }, + + initialize: function() { + + this.setFlags(); + + View.prototype.initialize.apply(this, arguments); + + this.cleanNodesCache(); + + // Store reference to this to the DOM element so that the view is accessible through the DOM tree. + this.$el.data('view', this); + + this.startListening(); + }, + + onMount: function onMount() { + // To be overridden + }, + + startListening: function() { + this.listenTo(this.model, 'change', this.onAttributesChange); + }, + + onAttributesChange: function(model, opt) { + var flag = model.getChangeFlag(this._presentationAttributes); + if (opt.updateHandled || !flag) { return; } + if (opt.dirty && this.hasFlag(flag, 'UPDATE')) { flag |= this.getFlag('RENDER'); } + // TODO: tool changes does not need to be sync + // Fix Segments tools + if (opt.tool) { opt.async = false; } + this.requestUpdate(flag, opt); + }, + + requestUpdate: function(flags, opt) { + var ref = this; + var paper = ref.paper; + if (paper && flags > 0) { + paper.requestViewUpdate(this, flags, this.UPDATE_PRIORITY, opt); + } + }, + + parseDOMJSON: function(markup, root) { + + var doc = parseDOMJSON(markup); + var selectors = doc.selectors; + var groups = doc.groupSelectors; + for (var group in groups) { + if (selectors[group]) { throw new Error('dia.CellView: ambiguous group selector'); } + selectors[group] = groups[group]; + } + if (root) { + var rootSelector = this.selector; + if (selectors[rootSelector]) { throw new Error('dia.CellView: ambiguous root selector.'); } + selectors[rootSelector] = root; + } + return { fragment: doc.fragment, selectors: selectors }; + }, + + // Return `true` if cell link is allowed to perform a certain UI `feature`. + // Example: `can('vertexMove')`, `can('labelMove')`. + can: function(feature) { + + var interactive = isFunction(this.options.interactive) + ? this.options.interactive(this) + : this.options.interactive; + + return (isObject$1(interactive) && interactive[feature] !== false) || + (isBoolean(interactive) && interactive !== false); + }, + + findBySelector: function(selector, root, selectors) { + + root || (root = this.el); + selectors || (selectors = this.selectors); + + // These are either descendants of `this.$el` of `this.$el` itself. + // `.` is a special selector used to select the wrapping `` element. + if (!selector || selector === '.') { return [root]; } + if (selectors) { + var nodes = selectors[selector]; + if (nodes) { + if (Array.isArray(nodes)) { return nodes; } + return [nodes]; + } + } + + // Maintaining backwards compatibility + // e.g. `circle:first` would fail with querySelector() call + if (config.useCSSSelectors) { return $(root).find(selector).toArray(); } + + return []; + }, + + notify: function(eventName) { + + if (this.paper) { + + var args = Array.prototype.slice.call(arguments, 1); + + // Trigger the event on both the element itself and also on the paper. + this.trigger.apply(this, [eventName].concat(args)); + + // Paper event handlers receive the view object as the first argument. + this.paper.trigger.apply(this.paper, [eventName, this].concat(args)); + } + }, + + getBBox: function(opt) { + + var bbox; + if (opt && opt.useModelGeometry) { + var model = this.model; + bbox = model.getBBox().bbox(model.angle()); + } else { + bbox = this.getNodeBBox(this.el); + } + + return this.paper.localToPaperRect(bbox); + }, + + getNodeBBox: function(magnet) { + + var rect = this.getNodeBoundingRect(magnet); + var transformMatrix = this.getRootTranslateMatrix().multiply(this.getNodeRotateMatrix(magnet)); + var magnetMatrix = this.getNodeMatrix(magnet); + return V.transformRect(rect, transformMatrix.multiply(magnetMatrix)); + }, + + getNodeRotateMatrix: function getNodeRotateMatrix(node) { + if (!this.rotatableNode || this.rotatableNode.contains(node)) { + // Rotate transformation is applied to all nodes when no rotatableGroup + // is present or to nodes inside the rotatableGroup only. + return this.getRootRotateMatrix(); + } + // Nodes outside the rotatable group + return V.createSVGMatrix(); + }, + + getNodeUnrotatedBBox: function(magnet) { + + var rect = this.getNodeBoundingRect(magnet); + var magnetMatrix = this.getNodeMatrix(magnet); + var translateMatrix = this.getRootTranslateMatrix(); + return V.transformRect(rect, translateMatrix.multiply(magnetMatrix)); + }, + + getRootTranslateMatrix: function() { + + var model = this.model; + var position = model.position(); + var mt = V.createSVGMatrix().translate(position.x, position.y); + return mt; + }, + + getRootRotateMatrix: function() { + + var mr = V.createSVGMatrix(); + var model = this.model; + var angle = model.angle(); + if (angle) { + var bbox = model.getBBox(); + var cx = bbox.width / 2; + var cy = bbox.height / 2; + mr = mr.translate(cx, cy).rotate(angle).translate(-cx, -cy); + } + return mr; + }, + + _notifyHighlight: function(eventName, el, opt) { + var assign, assign$1; + + if ( opt === void 0 ) opt = {}; + var ref = this; + var rootNode = ref.el; + var node; + if (typeof el === 'string') { + (assign = this.findBySelector(el), node = assign[0], node = node === void 0 ? rootNode : node); + } else { + (assign$1 = this.$(el), node = assign$1[0], node = node === void 0 ? rootNode : node); + } + // set partial flag if the highlighted element is not the entire view. + opt.partial = (node !== rootNode); + // translate type flag into a type string + if (opt.type === undefined) { + var type; + switch (true) { + case opt.embedding: + type = HighlightingTypes.EMBEDDING; + break; + case opt.connecting: + type = HighlightingTypes.CONNECTING; + break; + case opt.magnetAvailability: + type = HighlightingTypes.MAGNET_AVAILABILITY; + break; + case opt.elementAvailability: + type = HighlightingTypes.ELEMENT_AVAILABILITY; + break; + default: + type = HighlightingTypes.DEFAULT; + break; + } + opt.type = type; + } + this.notify(eventName, node, opt); + return this; + }, + + highlight: function(el, opt) { + return this._notifyHighlight('cell:highlight', el, opt); + }, + + unhighlight: function(el, opt) { + if ( opt === void 0 ) opt = {}; + + return this._notifyHighlight('cell:unhighlight', el, opt); + }, + + // Find the closest element that has the `magnet` attribute set to `true`. If there was not such + // an element found, return the root element of the cell view. + findMagnet: function(el) { + + var root = this.el; + var magnet = this.$(el)[0]; + if (!magnet) { + magnet = root; + } + + do { + var magnetAttribute = magnet.getAttribute('magnet'); + var isMagnetRoot = (magnet === root); + if ((magnetAttribute || isMagnetRoot) && magnetAttribute !== 'false') { + return magnet; + } + if (isMagnetRoot) { + // If the overall cell has set `magnet === false`, then return `undefined` to + // announce there is no magnet found for this cell. + // This is especially useful to set on cells that have 'ports'. In this case, + // only the ports have set `magnet === true` and the overall element has `magnet === false`. + return undefined; + } + magnet = magnet.parentNode; + } while (magnet); + + return undefined; + }, + + findProxyNode: function(el, type) { + el || (el = this.el); + var nodeSelector = el.getAttribute((type + "-selector")); + if (nodeSelector) { + var ref = this.findBySelector(nodeSelector); + var proxyNode = ref[0]; + if (proxyNode) { return proxyNode; } + } + return el; + }, + + // Construct a unique selector for the `el` element within this view. + // `prevSelector` is being collected through the recursive call. + // No value for `prevSelector` is expected when using this method. + getSelector: function(el, prevSelector) { + + var selector; + + if (el === this.el) { + if (typeof prevSelector === 'string') { selector = '> ' + prevSelector; } + return selector; + } + + if (el) { + + var nthChild = V(el).index() + 1; + selector = el.tagName + ':nth-child(' + nthChild + ')'; + + if (prevSelector) { + selector += ' > ' + prevSelector; + } + + selector = this.getSelector(el.parentNode, selector); + } + + return selector; + }, + + addLinkFromMagnet: function(magnet, x, y) { + + var paper = this.paper; + var graph = paper.model; + + var link = paper.getDefaultLink(this, magnet); + link.set({ + source: this.getLinkEnd(magnet, x, y, link, 'source'), + target: { x: x, y: y } + }).addTo(graph, { + async: false, + ui: true + }); + + return link.findView(paper); + }, + + getLinkEnd: function(magnet) { + var ref; + + var args = [], len = arguments.length - 1; + while ( len-- > 0 ) args[ len ] = arguments[ len + 1 ]; + + var model = this.model; + var id = model.id; + var port = this.findAttribute('port', magnet); + // Find a unique `selector` of the element under pointer that is a magnet. + var selector = magnet.getAttribute('joint-selector'); + + var end = { id: id }; + if (selector != null) { end.magnet = selector; } + if (port != null) { + end.port = port; + if (!model.hasPort(port) && !selector) { + // port created via the `port` attribute (not API) + end.selector = this.getSelector(magnet); + } + } else if (selector == null && this.el !== magnet) { + end.selector = this.getSelector(magnet); + } + + return (ref = this).customizeLinkEnd.apply(ref, [ end, magnet ].concat( args )); + }, + + customizeLinkEnd: function(end, magnet, x, y, link, endType) { + var ref = this; + var paper = ref.paper; + var ref$1 = paper.options; + var connectionStrategy = ref$1.connectionStrategy; + if (typeof connectionStrategy === 'function') { + var strategy = connectionStrategy.call(paper, end, this, magnet, new Point(x, y), link, endType, paper); + if (strategy) { return strategy; } + } + return end; + }, + + getMagnetFromLinkEnd: function(end) { + + var root = this.el; + var port = end.port; + var selector = end.magnet; + var model = this.model; + var magnet; + if (port != null && model.isElement() && model.hasPort(port)) { + magnet = this.findPortNode(port, selector) || root; + } else { + if (!selector) { selector = end.selector; } + if (!selector && port != null) { + // link end has only `id` and `port` property referencing + // a port created via the `port` attribute (not API). + selector = '[port="' + port + '"]'; + } + magnet = this.findBySelector(selector, root, this.selectors)[0]; + } + + return this.findProxyNode(magnet, 'magnet'); + }, + + dragLinkStart: function(evt, magnet, x, y) { + this.model.startBatch('add-link'); + var linkView = this.addLinkFromMagnet(magnet, x, y); + // backwards compatibility events + linkView.notifyPointerdown(evt, x, y); + linkView.eventData(evt, linkView.startArrowheadMove('target', { whenNotAllowed: 'remove' })); + this.eventData(evt, { linkView: linkView }); + }, + + dragLink: function(evt, x, y) { + var data = this.eventData(evt); + var linkView = data.linkView; + if (linkView) { + linkView.pointermove(evt, x, y); + } else { + var paper = this.paper; + var magnetThreshold = paper.options.magnetThreshold; + var currentTarget = this.getEventTarget(evt); + var targetMagnet = data.targetMagnet; + if (magnetThreshold === 'onleave') { + // magnetThreshold when the pointer leaves the magnet + if (targetMagnet === currentTarget || V(targetMagnet).contains(currentTarget)) { return; } + } else { + // magnetThreshold defined as a number of movements + if (paper.eventData(evt).mousemoved <= magnetThreshold) { return; } + } + this.dragLinkStart(evt, targetMagnet, x, y); + } + }, + + dragLinkEnd: function(evt, x, y) { + var data = this.eventData(evt); + var linkView = data.linkView; + if (!linkView) { return; } + linkView.pointerup(evt, x, y); + this.model.stopBatch('add-link'); + }, + + getAttributeDefinition: function(attrName) { + + return this.model.constructor.getAttributeDefinition(attrName); + }, + + setNodeAttributes: function(node, attrs) { + + if (!isEmpty(attrs)) { + if (node instanceof SVGElement) { + V(node).attr(attrs); + } else { + $(node).attr(attrs); + } + } + }, + + processNodeAttributes: function(node, attrs) { + + var attrName, attrVal, def, i, n; + var normalAttrs, setAttrs, positionAttrs, offsetAttrs; + var relatives = []; + // divide the attributes between normal and special + for (attrName in attrs) { + if (!attrs.hasOwnProperty(attrName)) { continue; } + attrVal = attrs[attrName]; + def = this.getAttributeDefinition(attrName); + if (def && (!isFunction(def.qualify) || def.qualify.call(this, attrVal, node, attrs, this))) { + if (isString(def.set)) { + normalAttrs || (normalAttrs = {}); + normalAttrs[def.set] = attrVal; + } + if (attrVal !== null) { + relatives.push(attrName, def); + } + } else { + normalAttrs || (normalAttrs = {}); + normalAttrs[toKebabCase(attrName)] = attrVal; + } + } + + // handle the rest of attributes via related method + // from the special attributes namespace. + for (i = 0, n = relatives.length; i < n; i+=2) { + attrName = relatives[i]; + def = relatives[i+1]; + attrVal = attrs[attrName]; + if (isFunction(def.set)) { + setAttrs || (setAttrs = {}); + setAttrs[attrName] = attrVal; + } + if (isFunction(def.position)) { + positionAttrs || (positionAttrs = {}); + positionAttrs[attrName] = attrVal; + } + if (isFunction(def.offset)) { + offsetAttrs || (offsetAttrs = {}); + offsetAttrs[attrName] = attrVal; + } + } + + return { + raw: attrs, + normal: normalAttrs, + set: setAttrs, + position: positionAttrs, + offset: offsetAttrs + }; + }, + + updateRelativeAttributes: function(node, attrs, refBBox, opt) { + + opt || (opt = {}); + + var attrName, attrVal, def; + var rawAttrs = attrs.raw || {}; + var nodeAttrs = attrs.normal || {}; + var setAttrs = attrs.set; + var positionAttrs = attrs.position; + var offsetAttrs = attrs.offset; + + for (attrName in setAttrs) { + attrVal = setAttrs[attrName]; + def = this.getAttributeDefinition(attrName); + // SET - set function should return attributes to be set on the node, + // which will affect the node dimensions based on the reference bounding + // box. e.g. `width`, `height`, `d`, `rx`, `ry`, `points + var setResult = def.set.call(this, attrVal, refBBox.clone(), node, rawAttrs, this); + if (isObject$1(setResult)) { + assign(nodeAttrs, setResult); + } else if (setResult !== undefined) { + nodeAttrs[attrName] = setResult; + } + } + + if (node instanceof HTMLElement) { + // TODO: setting the `transform` attribute on HTMLElements + // via `node.style.transform = 'matrix(...)';` would introduce + // a breaking change (e.g. basic.TextBlock). + this.setNodeAttributes(node, nodeAttrs); + return; + } + + // The final translation of the subelement. + var nodeTransform = nodeAttrs.transform; + var nodeMatrix = V.transformStringToMatrix(nodeTransform); + var nodePosition = Point(nodeMatrix.e, nodeMatrix.f); + if (nodeTransform) { + nodeAttrs = omit(nodeAttrs, 'transform'); + nodeMatrix.e = nodeMatrix.f = 0; + } + + // Calculate node scale determined by the scalable group + // only if later needed. + var sx, sy, translation; + if (positionAttrs || offsetAttrs) { + var nodeScale = this.getNodeScale(node, opt.scalableNode); + sx = nodeScale.sx; + sy = nodeScale.sy; + } + + var positioned = false; + for (attrName in positionAttrs) { + attrVal = positionAttrs[attrName]; + def = this.getAttributeDefinition(attrName); + // POSITION - position function should return a point from the + // reference bounding box. The default position of the node is x:0, y:0 of + // the reference bounding box or could be further specify by some + // SVG attributes e.g. `x`, `y` + translation = def.position.call(this, attrVal, refBBox.clone(), node, rawAttrs, this); + if (translation) { + nodePosition.offset(Point(translation).scale(sx, sy)); + positioned || (positioned = true); + } + } + + // The node bounding box could depend on the `size` set from the previous loop. + // Here we know, that all the size attributes have been already set. + this.setNodeAttributes(node, nodeAttrs); + + var offseted = false; + if (offsetAttrs) { + // Check if the node is visible + var nodeBoundingRect = this.getNodeBoundingRect(node); + if (nodeBoundingRect.width > 0 && nodeBoundingRect.height > 0) { + var nodeBBox = V.transformRect(nodeBoundingRect, nodeMatrix).scale(1 / sx, 1 / sy); + for (attrName in offsetAttrs) { + attrVal = offsetAttrs[attrName]; + def = this.getAttributeDefinition(attrName); + // OFFSET - offset function should return a point from the element + // bounding box. The default offset point is x:0, y:0 (origin) or could be further + // specify with some SVG attributes e.g. `text-anchor`, `cx`, `cy` + translation = def.offset.call(this, attrVal, nodeBBox, node, rawAttrs, this); + if (translation) { + nodePosition.offset(Point(translation).scale(sx, sy)); + offseted || (offseted = true); + } + } + } + } + + // Do not touch node's transform attribute if there is no transformation applied. + if (nodeTransform !== undefined || positioned || offseted) { + // Round the coordinates to 1 decimal point. + nodePosition.round(1); + nodeMatrix.e = nodePosition.x; + nodeMatrix.f = nodePosition.y; + node.setAttribute('transform', V.matrixToTransformString(nodeMatrix)); + // TODO: store nodeMatrix metrics? + } + }, + + getNodeScale: function(node, scalableNode) { + + // Check if the node is a descendant of the scalable group. + var sx, sy; + if (scalableNode && scalableNode.contains(node)) { + var scale = scalableNode.scale(); + sx = 1 / scale.sx; + sy = 1 / scale.sy; + } else { + sx = 1; + sy = 1; + } + + return { sx: sx, sy: sy }; + }, + + cleanNodesCache: function() { + this.metrics = {}; + }, + + nodeCache: function(magnet) { + + var metrics = this.metrics; + // Don't use cache? It most likely a custom view with overridden update. + if (!metrics) { return {}; } + var id = V.ensureId(magnet); + var value = metrics[id]; + if (!value) { value = metrics[id] = {}; } + return value; + }, + + getNodeData: function(magnet) { + + var metrics = this.nodeCache(magnet); + if (!metrics.data) { metrics.data = {}; } + return metrics.data; + }, + + getNodeBoundingRect: function(magnet) { + + var metrics = this.nodeCache(magnet); + if (metrics.boundingRect === undefined) { metrics.boundingRect = V(magnet).getBBox(); } + return new Rect(metrics.boundingRect); + }, + + getNodeMatrix: function(magnet) { + + var metrics = this.nodeCache(magnet); + if (metrics.magnetMatrix === undefined) { + var ref = this; + var rotatableNode = ref.rotatableNode; + var el = ref.el; + var target; + if (rotatableNode && rotatableNode.contains(magnet)) { + target = rotatableNode; + } else { + target = el; + } + metrics.magnetMatrix = V(magnet).getTransformToElement(target); + } + return V.createSVGMatrix(metrics.magnetMatrix); + }, + + getNodeShape: function(magnet) { + + var metrics = this.nodeCache(magnet); + if (metrics.geometryShape === undefined) { metrics.geometryShape = V(magnet).toGeometryShape(); } + return metrics.geometryShape.clone(); + }, + + isNodeConnection: function(node) { + return this.model.isLink() && (!node || node === this.el); + }, + + findNodesAttributes: function(attrs, root, selectorCache, selectors) { + + var i, n, nodeAttrs, nodeId; + var nodesAttrs = {}; + var mergeIds = []; + for (var selector in attrs) { + if (!attrs.hasOwnProperty(selector)) { continue; } + nodeAttrs = attrs[selector]; + if (!isPlainObject(nodeAttrs)) { continue; } // Not a valid selector-attributes pair + var selected = selectorCache[selector] = this.findBySelector(selector, root, selectors); + for (i = 0, n = selected.length; i < n; i++) { + var node = selected[i]; + nodeId = V.ensureId(node); + // "unique" selectors are selectors that referencing a single node (defined by `selector`) + // groupSelector referencing a single node is not "unique" + var unique = (selectors && selectors[selector] === node); + var prevNodeAttrs = nodesAttrs[nodeId]; + if (prevNodeAttrs) { + // Note, that nodes referenced by deprecated `CSS selectors` are not taken into account. + // e.g. css:`.circle` and selector:`circle` can be applied in a random order + if (!prevNodeAttrs.array) { + mergeIds.push(nodeId); + prevNodeAttrs.array = true; + prevNodeAttrs.attributes = [prevNodeAttrs.attributes]; + prevNodeAttrs.selectedLength = [prevNodeAttrs.selectedLength]; + } + var attributes = prevNodeAttrs.attributes; + var selectedLength = prevNodeAttrs.selectedLength; + if (unique) { + // node referenced by `selector` + attributes.unshift(nodeAttrs); + selectedLength.unshift(-1); + } else { + // node referenced by `groupSelector` + var sortIndex = sortedIndex(selectedLength, n); + attributes.splice(sortIndex, 0, nodeAttrs); + selectedLength.splice(sortIndex, 0, n); + } + } else { + nodesAttrs[nodeId] = { + attributes: nodeAttrs, + selectedLength: unique ? -1 : n, + node: node, + array: false + }; + } + } + } + + for (i = 0, n = mergeIds.length; i < n; i++) { + nodeId = mergeIds[i]; + nodeAttrs = nodesAttrs[nodeId]; + nodeAttrs.attributes = merge.apply(void 0, [ {} ].concat( nodeAttrs.attributes.reverse() )); + } + + return nodesAttrs; + }, + + getEventTarget: function(evt, opt) { + if ( opt === void 0 ) opt = {}; + + // Touchmove/Touchend event's target is not reflecting the element under the coordinates as mousemove does. + // It holds the element when a touchstart triggered. + var target = evt.target; + var type = evt.type; + var clientX = evt.clientX; if ( clientX === void 0 ) clientX = 0; + var clientY = evt.clientY; if ( clientY === void 0 ) clientY = 0; + if (opt.fromPoint || type === 'touchmove' || type === 'touchend') { + return document.elementFromPoint(clientX, clientY); + } + + return target; + }, + + // Default is to process the `model.attributes.attrs` object and set attributes on subelements based on the selectors, + // unless `attrs` parameter was passed. + updateDOMSubtreeAttributes: function(rootNode, attrs, opt) { + + opt || (opt = {}); + opt.rootBBox || (opt.rootBBox = Rect()); + opt.selectors || (opt.selectors = this.selectors); // selector collection to use + + // Cache table for query results and bounding box calculation. + // Note that `selectorCache` needs to be invalidated for all + // `updateAttributes` calls, as the selectors might pointing + // to nodes designated by an attribute or elements dynamically + // created. + var selectorCache = {}; + var bboxCache = {}; + var relativeItems = []; + var relativeRefItems = []; + var item, node, nodeAttrs, nodeData, processedAttrs; + + var roAttrs = opt.roAttributes; + var nodesAttrs = this.findNodesAttributes(roAttrs || attrs, rootNode, selectorCache, opt.selectors); + // `nodesAttrs` are different from all attributes, when + // rendering only attributes sent to this method. + var nodesAllAttrs = (roAttrs) + ? this.findNodesAttributes(attrs, rootNode, selectorCache, opt.selectors) + : nodesAttrs; + + for (var nodeId in nodesAttrs) { + nodeData = nodesAttrs[nodeId]; + nodeAttrs = nodeData.attributes; + node = nodeData.node; + processedAttrs = this.processNodeAttributes(node, nodeAttrs); + + if (!processedAttrs.set && !processedAttrs.position && !processedAttrs.offset) { + // Set all the normal attributes right on the SVG/HTML element. + this.setNodeAttributes(node, processedAttrs.normal); + + } else { + + var nodeAllAttrs = nodesAllAttrs[nodeId] && nodesAllAttrs[nodeId].attributes; + var refSelector = (nodeAllAttrs && (nodeAttrs.ref === undefined)) + ? nodeAllAttrs.ref + : nodeAttrs.ref; + + var refNode; + if (refSelector) { + refNode = (selectorCache[refSelector] || this.findBySelector(refSelector, rootNode, opt.selectors))[0]; + if (!refNode) { + throw new Error('dia.CellView: "' + refSelector + '" reference does not exist.'); + } + } else { + refNode = null; + } + + item = { + node: node, + refNode: refNode, + processedAttributes: processedAttrs, + allAttributes: nodeAllAttrs + }; + + if (refNode) { + // If an element in the list is positioned relative to this one, then + // we want to insert this one before it in the list. + var itemIndex = relativeRefItems.findIndex(function(item) { + return item.refNode === node; + }); + + if (itemIndex > -1) { + relativeRefItems.splice(itemIndex, 0, item); + } else { + relativeRefItems.push(item); + } + } else { + // A node with no ref attribute. To be updated before the nodes referencing other nodes. + // The order of no-ref-items is not specified/important. + relativeItems.push(item); + } + } + } + + relativeItems.push.apply(relativeItems, relativeRefItems); + + var rotatableMatrix; + for (var i = 0, n = relativeItems.length; i < n; i++) { + item = relativeItems[i]; + node = item.node; + refNode = item.refNode; + + // Find the reference element bounding box. If no reference was provided, we + // use the optional bounding box. + var vRotatable = V(opt.rotatableNode); + var refNodeId = refNode ? V.ensureId(refNode) : ''; + var isRefNodeRotatable = !!vRotatable && !!refNode && vRotatable.contains(refNode); + var unrotatedRefBBox = bboxCache[refNodeId]; + if (!unrotatedRefBBox) { + // Get the bounding box of the reference element relative to the `rotatable` `` (without rotation) + // or to the root `` element if no rotatable group present if reference node present. + // Uses the bounding box provided. + var transformationTarget = (isRefNodeRotatable) ? vRotatable : rootNode; + unrotatedRefBBox = bboxCache[refNodeId] = (refNode) + ? V(refNode).getBBox({ target: transformationTarget }) + : opt.rootBBox; + } + + if (roAttrs) { + // if there was a special attribute affecting the position amongst passed-in attributes + // we have to merge it with the rest of the element's attributes as they are necessary + // to update the position relatively (i.e `ref-x` && 'ref-dx') + processedAttrs = this.processNodeAttributes(node, item.allAttributes); + this.mergeProcessedAttributes(processedAttrs, item.processedAttributes); + + } else { + processedAttrs = item.processedAttributes; + } + + var refBBox = unrotatedRefBBox; + if (isRefNodeRotatable && !vRotatable.contains(node)) { + // if the referenced node is inside the rotatable group while the updated node is outside, + // we need to take the rotatable node transformation into account + if (!rotatableMatrix) { rotatableMatrix = V.transformStringToMatrix(vRotatable.attr('transform')); } + refBBox = V.transformRect(unrotatedRefBBox, rotatableMatrix); + } + + this.updateRelativeAttributes(node, processedAttrs, refBBox, opt); + } + }, + + mergeProcessedAttributes: function(processedAttrs, roProcessedAttrs) { + + processedAttrs.set || (processedAttrs.set = {}); + processedAttrs.position || (processedAttrs.position = {}); + processedAttrs.offset || (processedAttrs.offset = {}); + + assign(processedAttrs.set, roProcessedAttrs.set); + assign(processedAttrs.position, roProcessedAttrs.position); + assign(processedAttrs.offset, roProcessedAttrs.offset); + + // Handle also the special transform property. + var transform = processedAttrs.normal && processedAttrs.normal.transform; + if (transform !== undefined && roProcessedAttrs.normal) { + roProcessedAttrs.normal.transform = transform; + } + processedAttrs.normal = roProcessedAttrs.normal; + }, + + onRemove: function() { + this.removeTools(); + this.removeHighlighters(); + }, + + _toolsView: null, + + hasTools: function(name) { + var toolsView = this._toolsView; + if (!toolsView) { return false; } + if (!name) { return true; } + return (toolsView.getName() === name); + }, + + addTools: function(toolsView) { + + this.removeTools(); + + if (toolsView) { + this._toolsView = toolsView; + toolsView.configure({ relatedView: this }); + toolsView.listenTo(this.paper, 'tools:event', this.onToolEvent.bind(this)); + } + return this; + }, + + updateTools: function(opt) { + + var toolsView = this._toolsView; + if (toolsView) { toolsView.update(opt); } + return this; + }, + + removeTools: function() { + + var toolsView = this._toolsView; + if (toolsView) { + toolsView.remove(); + this._toolsView = null; + } + return this; + }, + + hideTools: function() { + + var toolsView = this._toolsView; + if (toolsView) { toolsView.hide(); } + return this; + }, + + showTools: function() { + + var toolsView = this._toolsView; + if (toolsView) { toolsView.show(); } + return this; + }, + + onToolEvent: function(event) { + switch (event) { + case 'remove': + this.removeTools(); + break; + case 'hide': + this.hideTools(); + break; + case 'show': + this.showTools(); + break; + } + }, + + removeHighlighters: function() { + HighlighterView.remove(this); + }, + + updateHighlighters: function(dirty) { + if ( dirty === void 0 ) dirty = false; + + HighlighterView.update(this, null, dirty); + }, + + transformHighlighters: function() { + HighlighterView.transform(this); + }, + + // Interaction. The controller part. + // --------------------------------- + + // Interaction is handled by the paper and delegated to the view in interest. + // `x` & `y` parameters passed to these functions represent the coordinates already snapped to the paper grid. + // If necessary, real coordinates can be obtained from the `evt` event object. + + // These functions are supposed to be overriden by the views that inherit from `joint.dia.Cell`, + // i.e. `joint.dia.Element` and `joint.dia.Link`. + + pointerdblclick: function(evt, x, y) { + + this.notify('cell:pointerdblclick', evt, x, y); + }, + + pointerclick: function(evt, x, y) { + + this.notify('cell:pointerclick', evt, x, y); + }, + + contextmenu: function(evt, x, y) { + + this.notify('cell:contextmenu', evt, x, y); + }, + + pointerdown: function(evt, x, y) { + + var ref = this; + var model = ref.model; + var graph = model.graph; + if (graph) { + model.startBatch('pointer'); + this.eventData(evt, { graph: graph }); + } + + this.notify('cell:pointerdown', evt, x, y); + }, + + pointermove: function(evt, x, y) { + + this.notify('cell:pointermove', evt, x, y); + }, + + pointerup: function(evt, x, y) { + + var ref = this.eventData(evt); + var graph = ref.graph; + + this.notify('cell:pointerup', evt, x, y); + + if (graph) { + // we don't want to trigger event on model as model doesn't + // need to be member of collection anymore (remove) + graph.stopBatch('pointer', { cell: this.model }); + } + }, + + mouseover: function(evt) { + + this.notify('cell:mouseover', evt); + }, + + mouseout: function(evt) { + + this.notify('cell:mouseout', evt); + }, + + mouseenter: function(evt) { + + this.notify('cell:mouseenter', evt); + }, + + mouseleave: function(evt) { + + this.notify('cell:mouseleave', evt); + }, + + mousewheel: function(evt, x, y, delta) { + + this.notify('cell:mousewheel', evt, x, y, delta); + }, + + onevent: function(evt, eventName, x, y) { + + this.notify(eventName, evt, x, y); + }, + + onmagnet: function() { + + // noop + }, + + magnetpointerdblclick: function() { + + // noop + }, + + magnetcontextmenu: function() { + + // noop + }, + + checkMouseleave: function checkMouseleave(evt) { + var ref = this; + var paper = ref.paper; + if (paper.isAsync()) { + // Do the updates of the current view synchronously now + paper.dumpView(this); + } + var target = this.getEventTarget(evt, { fromPoint: true }); + var view = paper.findView(target); + if (view === this) { return; } + // Leaving the current view + this.mouseleave(evt); + if (!view) { return; } + // Entering another view + view.mouseenter(evt); + }, + + setInteractivity: function(value) { + + this.options.interactive = value; + } + }, { + + Highlighting: HighlightingTypes, + + addPresentationAttributes: function(presentationAttributes) { + return merge({}, result(this.prototype, 'presentationAttributes'), presentationAttributes, function(a, b) { + if (!a || !b) { return; } + if (typeof a === 'string') { a = [a]; } + if (typeof b === 'string') { b = [b]; } + if (Array.isArray(a) && Array.isArray(b)) { return uniq(a.concat(b)); } + }); + } + }); + + var Flags = { + UPDATE: 'UPDATE', + TRANSLATE: 'TRANSLATE', + TOOLS: 'TOOLS', + RESIZE: 'RESIZE', + PORTS: 'PORTS', + ROTATE: 'ROTATE', + RENDER: 'RENDER' + }; + + // Element base view and controller. + // ------------------------------------------- + + var ElementView = CellView.extend({ + + /** + * @abstract + */ + _removePorts: function() { + // implemented in ports.js + }, + + /** + * + * @abstract + */ + _renderPorts: function() { + // implemented in ports.js + }, + + className: function() { + + var classNames = CellView.prototype.className.apply(this).split(' '); + + classNames.push('element'); + + return classNames.join(' '); + }, + + initialize: function() { + + CellView.prototype.initialize.apply(this, arguments); + + this._initializePorts(); + }, + + presentationAttributes: { + 'attrs': [Flags.UPDATE], + 'position': [Flags.TRANSLATE, Flags.TOOLS], + 'size': [Flags.RESIZE, Flags.PORTS, Flags.TOOLS], + 'angle': [Flags.ROTATE, Flags.TOOLS], + 'markup': [Flags.RENDER], + 'ports': [Flags.PORTS], + }, + + initFlag: [Flags.RENDER], + + UPDATE_PRIORITY: 0, + + confirmUpdate: function(flag, opt) { + + var useCSSSelectors = config.useCSSSelectors; + if (this.hasFlag(flag, Flags.PORTS)) { + this._removePorts(); + this._cleanPortsCache(); + } + var transformHighlighters = false; + if (this.hasFlag(flag, Flags.RENDER)) { + this.render(); + this.updateTools(opt); + this.updateHighlighters(true); + transformHighlighters = true; + flag = this.removeFlag(flag, [Flags.RENDER, Flags.UPDATE, Flags.RESIZE, Flags.TRANSLATE, Flags.ROTATE, Flags.PORTS, Flags.TOOLS]); + } else { + var updateHighlighters = false; + + // Skip this branch if render is required + if (this.hasFlag(flag, Flags.RESIZE)) { + this.resize(opt); + updateHighlighters = true; + // Resize method is calling `update()` internally + flag = this.removeFlag(flag, [Flags.RESIZE, Flags.UPDATE]); + } + if (this.hasFlag(flag, Flags.UPDATE)) { + this.update(this.model, null, opt); + flag = this.removeFlag(flag, Flags.UPDATE); + updateHighlighters = true; + if (useCSSSelectors) { + // `update()` will render ports when useCSSSelectors are enabled + flag = this.removeFlag(flag, Flags.PORTS); + } + } + if (this.hasFlag(flag, Flags.TRANSLATE)) { + this.translate(); + flag = this.removeFlag(flag, Flags.TRANSLATE); + transformHighlighters = true; + } + if (this.hasFlag(flag, Flags.ROTATE)) { + this.rotate(); + flag = this.removeFlag(flag, Flags.ROTATE); + transformHighlighters = true; + } + if (this.hasFlag(flag, Flags.PORTS)) { + this._renderPorts(); + updateHighlighters = true; + flag = this.removeFlag(flag, Flags.PORTS); + } + + if (updateHighlighters) { + this.updateHighlighters(false); + } + } + + if (transformHighlighters) { + this.transformHighlighters(); + } + + if (this.hasFlag(flag, Flags.TOOLS)) { + this.updateTools(opt); + flag = this.removeFlag(flag, Flags.TOOLS); + } + + return flag; + }, + + /** + * @abstract + */ + _initializePorts: function() { + + }, + + update: function(_, renderingOnlyAttrs) { + + this.cleanNodesCache(); + + // When CSS selector strings are used, make sure no rule matches port nodes. + var useCSSSelectors = config.useCSSSelectors; + if (useCSSSelectors) { this._removePorts(); } + + var model = this.model; + var modelAttrs = model.attr(); + this.updateDOMSubtreeAttributes(this.el, modelAttrs, { + rootBBox: new Rect(model.size()), + selectors: this.selectors, + scalableNode: this.scalableNode, + rotatableNode: this.rotatableNode, + // Use rendering only attributes if they differs from the model attributes + roAttributes: (renderingOnlyAttrs === modelAttrs) ? null : renderingOnlyAttrs + }); + + if (useCSSSelectors) { + this._renderPorts(); + } + }, + + rotatableSelector: 'rotatable', + scalableSelector: 'scalable', + scalableNode: null, + rotatableNode: null, + + // `prototype.markup` is rendered by default. Set the `markup` attribute on the model if the + // default markup is not desirable. + renderMarkup: function() { + + var element = this.model; + var markup = element.get('markup') || element.markup; + if (!markup) { throw new Error('dia.ElementView: markup required'); } + if (Array.isArray(markup)) { return this.renderJSONMarkup(markup); } + if (typeof markup === 'string') { return this.renderStringMarkup(markup); } + throw new Error('dia.ElementView: invalid markup'); + }, + + renderJSONMarkup: function(markup) { + + var doc = this.parseDOMJSON(markup, this.el); + var selectors = this.selectors = doc.selectors; + this.rotatableNode = V(selectors[this.rotatableSelector]) || null; + this.scalableNode = V(selectors[this.scalableSelector]) || null; + // Fragment + this.vel.append(doc.fragment); + }, + + renderStringMarkup: function(markup) { + + var vel = this.vel; + vel.append(V(markup)); + // Cache transformation groups + this.rotatableNode = vel.findOne('.rotatable'); + this.scalableNode = vel.findOne('.scalable'); + + var selectors = this.selectors = {}; + selectors[this.selector] = this.el; + }, + + render: function() { + + this.vel.empty(); + this.renderMarkup(); + if (this.scalableNode) { + // Double update is necessary for elements with the scalable group only + // Note the resize() triggers the other `update`. + this.update(); + } + this.resize(); + if (this.rotatableNode) { + // Translate transformation is applied on `this.el` while the rotation transformation + // on `this.rotatableNode` + this.rotate(); + this.translate(); + } else { + this.updateTransformation(); + } + if (!config.useCSSSelectors) { this._renderPorts(); } + return this; + }, + + resize: function(opt) { + + if (this.scalableNode) { return this.sgResize(opt); } + if (this.model.attributes.angle) { this.rotate(); } + this.update(); + }, + + translate: function() { + + if (this.rotatableNode) { return this.rgTranslate(); } + this.updateTransformation(); + }, + + rotate: function() { + + if (this.rotatableNode) { + this.rgRotate(); + // It's necessary to call the update for the nodes outside + // the rotatable group referencing nodes inside the group + this.update(); + return; + } + this.updateTransformation(); + }, + + updateTransformation: function() { + + var transformation = this.getTranslateString(); + var rotateString = this.getRotateString(); + if (rotateString) { transformation += ' ' + rotateString; } + this.vel.attr('transform', transformation); + }, + + getTranslateString: function() { + + var position = this.model.attributes.position; + return 'translate(' + position.x + ',' + position.y + ')'; + }, + + getRotateString: function() { + var attributes = this.model.attributes; + var angle = attributes.angle; + if (!angle) { return null; } + var size = attributes.size; + return 'rotate(' + angle + ',' + (size.width / 2) + ',' + (size.height / 2) + ')'; + }, + + // Rotatable & Scalable Group + // always slower, kept mainly for backwards compatibility + + rgRotate: function() { + + this.rotatableNode.attr('transform', this.getRotateString()); + }, + + rgTranslate: function() { + + this.vel.attr('transform', this.getTranslateString()); + }, + + sgResize: function(opt) { + + var model = this.model; + var angle = model.angle(); + var size = model.size(); + var scalable = this.scalableNode; + + // Getting scalable group's bbox. + // Due to a bug in webkit's native SVG .getBBox implementation, the bbox of groups with path children includes the paths' control points. + // To work around the issue, we need to check whether there are any path elements inside the scalable group. + var recursive = false; + if (scalable.node.getElementsByTagName('path').length > 0) { + // If scalable has at least one descendant that is a path, we need to switch to recursive bbox calculation. + // If there are no path descendants, group bbox calculation works and so we can use the (faster) native function directly. + recursive = true; + } + var scalableBBox = scalable.getBBox({ recursive: recursive }); + + // Make sure `scalableBbox.width` and `scalableBbox.height` are not zero which can happen if the element does not have any content. By making + // the width/height 1, we prevent HTML errors of the type `scale(Infinity, Infinity)`. + var sx = (size.width / (scalableBBox.width || 1)); + var sy = (size.height / (scalableBBox.height || 1)); + scalable.attr('transform', 'scale(' + sx + ',' + sy + ')'); + + // Now the interesting part. The goal is to be able to store the object geometry via just `x`, `y`, `angle`, `width` and `height` + // Order of transformations is significant but we want to reconstruct the object always in the order: + // resize(), rotate(), translate() no matter of how the object was transformed. For that to work, + // we must adjust the `x` and `y` coordinates of the object whenever we resize it (because the origin of the + // rotation changes). The new `x` and `y` coordinates are computed by canceling the previous rotation + // around the center of the resized object (which is a different origin then the origin of the previous rotation) + // and getting the top-left corner of the resulting object. Then we clean up the rotation back to what it originally was. + + // Cancel the rotation but now around a different origin, which is the center of the scaled object. + var rotatable = this.rotatableNode; + var rotation = rotatable && rotatable.attr('transform'); + if (rotation) { + + rotatable.attr('transform', rotation + ' rotate(' + (-angle) + ',' + (size.width / 2) + ',' + (size.height / 2) + ')'); + var rotatableBBox = scalable.getBBox({ target: this.paper.cells }); + + // Store new x, y and perform rotate() again against the new rotation origin. + model.set('position', { x: rotatableBBox.x, y: rotatableBBox.y }, assign({ updateHandled: true }, opt)); + this.translate(); + this.rotate(); + } + + // Update must always be called on non-rotated element. Otherwise, relative positioning + // would work with wrong (rotated) bounding boxes. + this.update(); + }, + + // Embedding mode methods. + // ----------------------- + + prepareEmbedding: function(data) { + if ( data === void 0 ) data = {}; + + + var element = data.model || this.model; + var paper = data.paper || this.paper; + var graph = paper.model; + + var initialZIndices = data.initialZIndices = {}; + var embeddedCells = element.getEmbeddedCells({ deep: true }); + var connectedLinks = graph.getConnectedLinks(element, { deep: true, includeEnclosed: true }); + + // Note: an embedded cell can be a connect link, but it's fine + // to iterate over the cell twice. + [ + element ].concat( embeddedCells, + connectedLinks + ).forEach(function (cell) { return initialZIndices[cell.id] = cell.attributes.z; }); + + element.startBatch('to-front'); + + // Bring the model to the front with all his embeds. + element.toFront({ deep: true, ui: true }); + + // Note that at this point cells in the collection are not sorted by z index (it's running in the batch, see + // the dia.Graph._sortOnChangeZ), so we can't assume that the last cell in the collection has the highest z. + var maxZ = graph.getElements().reduce(function (max, cell) { return Math.max(max, cell.attributes.z || 0); }, 0); + + // Move to front also all the inbound and outbound links that are connected + // to any of the element descendant. If we bring to front only embedded elements, + // links connected to them would stay in the background. + connectedLinks.forEach(function (link) { + if (link.attributes.z <= maxZ) { + link.set('z', maxZ + 1, { ui: true }); + } + }); + + element.stopBatch('to-front'); + + // Before we start looking for suitable parent we remove the current one. + var parentId = element.parent(); + if (parentId) { + var parent = graph.getCell(parentId); + parent.unembed(element, { ui: true }); + data.initialParentId = parentId; + } else { + data.initialParentId = null; + } + }, + + processEmbedding: function(data, evt, x, y) { + if ( data === void 0 ) data = {}; + + + var model = data.model || this.model; + var paper = data.paper || this.paper; + var graph = paper.model; + var ref = paper.options; + var findParentBy = ref.findParentBy; + var frontParentOnly = ref.frontParentOnly; + var validateEmbedding = ref.validateEmbedding; + + var candidates; + if (isFunction(findParentBy)) { + candidates = toArray(findParentBy.call(graph, this, evt, x, y)); + } else if (findParentBy === 'pointer') { + candidates = toArray(graph.findModelsFromPoint({ x: x, y: y })); + } else { + candidates = graph.findModelsUnderElement(model, { searchBy: findParentBy }); + } + + candidates = candidates.filter(function (el) { + return (el instanceof Cell) && (model.id !== el.id) && !el.isEmbeddedIn(model); + }); + + if (frontParentOnly) { + // pick the element with the highest `z` index + candidates = candidates.slice(-1); + } + + var newCandidateView = null; + var prevCandidateView = data.candidateEmbedView; + + // iterate over all candidates starting from the last one (has the highest z-index). + for (var i = candidates.length - 1; i >= 0; i--) { + var candidate = candidates[i]; + if (prevCandidateView && prevCandidateView.model.id == candidate.id) { + // candidate remains the same + newCandidateView = prevCandidateView; + break; + } else { + var view = candidate.findView(paper); + if (!isFunction(validateEmbedding) || validateEmbedding.call(paper, this, view)) { + // flip to the new candidate + newCandidateView = view; + break; + } + } + } + + if (newCandidateView && newCandidateView != prevCandidateView) { + // A new candidate view found. Highlight the new one. + this.clearEmbedding(data); + data.candidateEmbedView = newCandidateView.highlight( + newCandidateView.findProxyNode(null, 'container'), + { embedding: true } + ); + } + + if (!newCandidateView && prevCandidateView) { + // No candidate view found. Unhighlight the previous candidate. + this.clearEmbedding(data); + } + }, + + clearEmbedding: function(data) { + + data || (data = {}); + + var candidateView = data.candidateEmbedView; + if (candidateView) { + // No candidate view found. Unhighlight the previous candidate. + candidateView.unhighlight( + candidateView.findProxyNode(null, 'container'), + { embedding: true } + ); + data.candidateEmbedView = null; + } + }, + + finalizeEmbedding: function(data) { + if ( data === void 0 ) data = {}; + + + var candidateView = data.candidateEmbedView; + var element = data.model || this.model; + var paper = data.paper || this.paper; + + if (candidateView) { + + // We finished embedding. Candidate view is chosen to become the parent of the model. + candidateView.model.embed(element, { ui: true }); + candidateView.unhighlight(candidateView.findProxyNode(null, 'container'), { embedding: true }); + + data.candidateEmbedView = null; + + } else { + + var ref = paper.options; + var validateUnembedding = ref.validateUnembedding; + var initialParentId = data.initialParentId; + // The element was originally embedded into another element. + // The interaction would unembed the element. Let's validate + // if the element can be unembedded. + if ( + initialParentId && + typeof validateUnembedding === 'function' && + !validateUnembedding.call(paper, this) + ) { + this._disallowUnembed(data); + return; + } + } + + paper.model.getConnectedLinks(element, { deep: true }).forEach(function (link) { + link.reparent({ ui: true }); + }); + }, + + _disallowUnembed: function(data) { + var model = data.model; + var whenNotAllowed = data.whenNotAllowed; if ( whenNotAllowed === void 0 ) whenNotAllowed = 'revert'; + var element = model || this.model; + var paper = data.paper || this.paper; + var graph = paper.model; + switch (whenNotAllowed) { + case 'remove': { + element.remove({ ui: true }); + break; + } + case 'revert': { + var initialParentId = data.initialParentId; + var initialPosition = data.initialPosition; + var initialZIndices = data.initialZIndices; + // Revert the element's position (and the position of its embedded cells if any) + if (initialPosition) { + var x = initialPosition.x; + var y = initialPosition.y; + element.position(x, y, { deep: true, ui: true }); + } + // Revert all the z-indices changed during the embedding + if (initialZIndices) { + Object.keys(initialZIndices).forEach(function (id) { + var cell = graph.getCell(id); + if (cell) { + cell.set('z', initialZIndices[id], { ui: true }); + } + }); + } + // Revert the original parent + var parent = graph.getCell(initialParentId); + if (parent) { + parent.embed(element, { ui: true }); + } + break; + } + } + }, + + getDelegatedView: function() { + + var view = this; + var model = view.model; + var paper = view.paper; + + while (view) { + if (model.isLink()) { break; } + if (!model.isEmbedded() || view.can('stopDelegation')) { return view; } + model = model.getParentCell(); + view = paper.findViewByModel(model); + } + + return null; + }, + + findProxyNode: function(el, type) { + el || (el = this.el); + var nodeSelector = el.getAttribute((type + "-selector")); + if (nodeSelector) { + var port = this.findAttribute('port', el); + if (port) { + var proxyPortNode = this.findPortNode(port, nodeSelector); + if (proxyPortNode) { return proxyPortNode; } + } else { + var ref = this.findBySelector(nodeSelector); + var proxyNode = ref[0]; + if (proxyNode) { return proxyNode; } + } + } + return el; + }, + + // Interaction. The controller part. + // --------------------------------- + + notifyPointerdown: function notifyPointerdown(evt, x, y) { + CellView.prototype.pointerdown.call(this, evt, x, y); + this.notify('element:pointerdown', evt, x, y); + }, + + notifyPointermove: function notifyPointermove(evt, x, y) { + CellView.prototype.pointermove.call(this, evt, x, y); + this.notify('element:pointermove', evt, x, y); + }, + + notifyPointerup: function notifyPointerup(evt, x, y) { + this.notify('element:pointerup', evt, x, y); + CellView.prototype.pointerup.call(this, evt, x, y); + }, + + pointerdblclick: function(evt, x, y) { + + CellView.prototype.pointerdblclick.apply(this, arguments); + this.notify('element:pointerdblclick', evt, x, y); + }, + + pointerclick: function(evt, x, y) { + + CellView.prototype.pointerclick.apply(this, arguments); + this.notify('element:pointerclick', evt, x, y); + }, + + contextmenu: function(evt, x, y) { + + CellView.prototype.contextmenu.apply(this, arguments); + this.notify('element:contextmenu', evt, x, y); + }, + + pointerdown: function(evt, x, y) { + + if (this.isPropagationStopped(evt)) { return; } + + this.notifyPointerdown(evt, x, y); + this.dragStart(evt, x, y); + }, + + pointermove: function(evt, x, y) { + + var data = this.eventData(evt); + + switch (data.action) { + case 'magnet': + this.dragMagnet(evt, x, y); + break; + case 'move': + (data.delegatedView || this).drag(evt, x, y); + // eslint: no-fallthrough=false + default: + this.notifyPointermove(evt, x, y); + break; + } + + // Make sure the element view data is passed along. + // It could have been wiped out in the handlers above. + this.eventData(evt, data); + }, + + pointerup: function(evt, x, y) { + + var data = this.eventData(evt); + switch (data.action) { + case 'magnet': + this.dragMagnetEnd(evt, x, y); + break; + case 'move': + (data.delegatedView || this).dragEnd(evt, x, y); + // eslint: no-fallthrough=false + default: + this.notifyPointerup(evt, x, y); + } + + var magnet = data.targetMagnet; + if (magnet) { this.magnetpointerclick(evt, magnet, x, y); } + + this.checkMouseleave(evt); + }, + + mouseover: function(evt) { + + CellView.prototype.mouseover.apply(this, arguments); + this.notify('element:mouseover', evt); + }, + + mouseout: function(evt) { + + CellView.prototype.mouseout.apply(this, arguments); + this.notify('element:mouseout', evt); + }, + + mouseenter: function(evt) { + + CellView.prototype.mouseenter.apply(this, arguments); + this.notify('element:mouseenter', evt); + }, + + mouseleave: function(evt) { + + CellView.prototype.mouseleave.apply(this, arguments); + this.notify('element:mouseleave', evt); + }, + + mousewheel: function(evt, x, y, delta) { + + CellView.prototype.mousewheel.apply(this, arguments); + this.notify('element:mousewheel', evt, x, y, delta); + }, + + onmagnet: function(evt, x, y) { + + this.dragMagnetStart(evt, x, y); + }, + + magnetpointerdblclick: function(evt, magnet, x, y) { + + this.notify('element:magnet:pointerdblclick', evt, magnet, x, y); + }, + + magnetcontextmenu: function(evt, magnet, x, y) { + + this.notify('element:magnet:contextmenu', evt, magnet, x, y); + }, + + // Drag Start Handlers + + dragStart: function(evt, x, y) { + + var view = this.getDelegatedView(); + if (!view || !view.can('elementMove')) { return; } + + this.eventData(evt, { + action: 'move', + delegatedView: view + }); + + var position = view.model.position(); + view.eventData(evt, { + initialPosition: position, + pointerOffset: position.difference(x, y), + restrictedArea: this.paper.getRestrictedArea(view, x, y) + }); + }, + + dragMagnetStart: function(evt, x, y) { + + if (!this.can('addLinkFromMagnet')) { return; } + + var magnet = evt.currentTarget; + var paper = this.paper; + this.eventData(evt, { targetMagnet: magnet }); + evt.stopPropagation(); + + if (paper.options.validateMagnet(this, magnet, evt)) { + + if (paper.options.magnetThreshold <= 0) { + this.dragLinkStart(evt, magnet, x, y); + } + + this.eventData(evt, { action: 'magnet' }); + this.stopPropagation(evt); + + } else { + + this.pointerdown(evt, x, y); + } + + paper.delegateDragEvents(this, evt.data); + }, + + // Drag Handlers + + drag: function(evt, x, y) { + + var paper = this.paper; + var grid = paper.options.gridSize; + var element = this.model; + var data = this.eventData(evt); + var pointerOffset = data.pointerOffset; + var restrictedArea = data.restrictedArea; + var embedding = data.embedding; + + // Make sure the new element's position always snaps to the current grid + var elX = snapToGrid(x + pointerOffset.x, grid); + var elY = snapToGrid(y + pointerOffset.y, grid); + + element.position(elX, elY, { restrictedArea: restrictedArea, deep: true, ui: true }); + + if (paper.options.embeddingMode) { + if (!embedding) { + // Prepare the element for embedding only if the pointer moves. + // We don't want to do unnecessary action with the element + // if an user only clicks/dblclicks on it. + this.prepareEmbedding(data); + embedding = true; + } + this.processEmbedding(data, evt, x, y); + } + + this.eventData(evt, { + embedding: embedding + }); + }, + + dragMagnet: function(evt, x, y) { + this.dragLink(evt, x, y); + }, + + // Drag End Handlers + + dragEnd: function(evt, x, y) { + + var data = this.eventData(evt); + if (data.embedding) { this.finalizeEmbedding(data); } + }, + + dragMagnetEnd: function(evt, x, y) { + this.dragLinkEnd(evt, x, y); + }, + + magnetpointerclick: function(evt, magnet, x, y) { + var paper = this.paper; + if (paper.eventData(evt).mousemoved > paper.options.clickThreshold) { return; } + this.notify('element:magnet:pointerclick', evt, magnet, x, y); + } + + }, { + + Flags: Flags, + }); + + assign(ElementView.prototype, elementViewPortPrototype); + + // Does not make any changes to vertices. + // Returns the arguments that are passed to it, unchanged. + var normal = function(vertices, opt, linkView) { + + return vertices; + }; + + // Routes the link always to/from a certain side + // + // Arguments: + // padding ... gap between the element and the first vertex. :: Default 40. + // side ... 'left' | 'right' | 'top' | 'bottom' :: Default 'bottom'. + // + var oneSide = function(vertices, opt, linkView) { + + var side = opt.side || 'bottom'; + var padding = normalizeSides(opt.padding || 40); + + // LinkView contains cached source an target bboxes. + // Note that those are Geometry rectangle objects. + var sourceBBox = linkView.sourceBBox; + var targetBBox = linkView.targetBBox; + var sourcePoint = sourceBBox.center(); + var targetPoint = targetBBox.center(); + + var coordinate, dimension, direction; + + switch (side) { + case 'bottom': + direction = 1; + coordinate = 'y'; + dimension = 'height'; + break; + case 'top': + direction = -1; + coordinate = 'y'; + dimension = 'height'; + break; + case 'left': + direction = -1; + coordinate = 'x'; + dimension = 'width'; + break; + case 'right': + direction = 1; + coordinate = 'x'; + dimension = 'width'; + break; + default: + throw new Error('Router: invalid side'); + } + + // move the points from the center of the element to outside of it. + sourcePoint[coordinate] += direction * (sourceBBox[dimension] / 2 + padding[side]); + targetPoint[coordinate] += direction * (targetBBox[dimension] / 2 + padding[side]); + + // make link orthogonal (at least the first and last vertex). + if ((direction * (sourcePoint[coordinate] - targetPoint[coordinate])) > 0) { + targetPoint[coordinate] = sourcePoint[coordinate]; + } else { + sourcePoint[coordinate] = targetPoint[coordinate]; + } + + return [sourcePoint].concat(vertices, targetPoint); + }; + + // bearing -> opposite bearing + var opposites = { + N: 'S', + S: 'N', + E: 'W', + W: 'E' + }; + + // bearing -> radians + var radians = { + N: -Math.PI / 2 * 3, + S: -Math.PI / 2, + E: 0, + W: Math.PI + }; + + // HELPERS // + + // returns a point `p` where lines p,p1 and p,p2 are perpendicular and p is not contained + // in the given box + function freeJoin(p1, p2, bbox) { + + var p = new Point(p1.x, p2.y); + if (bbox.containsPoint(p)) { p = new Point(p2.x, p1.y); } + // kept for reference + // if (bbox.containsPoint(p)) p = null; + + return p; + } + + // returns either width or height of a bbox based on the given bearing + function getBBoxSize(bbox, bearing) { + + return bbox[(bearing === 'W' || bearing === 'E') ? 'width' : 'height']; + } + + // simple bearing method (calculates only orthogonal cardinals) + function getBearing(from, to) { + + if (from.x === to.x) { return (from.y > to.y) ? 'N' : 'S'; } + if (from.y === to.y) { return (from.x > to.x) ? 'W' : 'E'; } + return null; + } + + // transform point to a rect + function getPointBox(p) { + + return new Rect(p.x, p.y, 0, 0); + } + + function getPaddingBox(opt) { + + // if both provided, opt.padding wins over opt.elementPadding + var sides = normalizeSides(opt.padding || opt.elementPadding || 20); + + return { + x: -sides.left, + y: -sides.top, + width: sides.left + sides.right, + height: sides.top + sides.bottom + }; + } + + // return source bbox + function getSourceBBox(linkView, opt) { + + return linkView.sourceBBox.clone().moveAndExpand(getPaddingBox(opt)); + } + + // return target bbox + function getTargetBBox(linkView, opt) { + + return linkView.targetBBox.clone().moveAndExpand(getPaddingBox(opt)); + } + + // return source anchor + function getSourceAnchor(linkView, opt) { + + if (linkView.sourceAnchor) { return linkView.sourceAnchor; } + + // fallback: center of bbox + var sourceBBox = getSourceBBox(linkView, opt); + return sourceBBox.center(); + } + + // return target anchor + function getTargetAnchor(linkView, opt) { + + if (linkView.targetAnchor) { return linkView.targetAnchor; } + + // fallback: center of bbox + var targetBBox = getTargetBBox(linkView, opt); + return targetBBox.center(); // default + } + + // PARTIAL ROUTERS // + + function vertexVertex(from, to, bearing) { + + var p1 = new Point(from.x, to.y); + var p2 = new Point(to.x, from.y); + var d1 = getBearing(from, p1); + var d2 = getBearing(from, p2); + var opposite = opposites[bearing]; + + var p = (d1 === bearing || (d1 !== opposite && (d2 === opposite || d2 !== bearing))) ? p1 : p2; + + return { points: [p], direction: getBearing(p, to) }; + } + + function elementVertex(from, to, fromBBox) { + + var p = freeJoin(from, to, fromBBox); + + return { points: [p], direction: getBearing(p, to) }; + } + + function vertexElement(from, to, toBBox, bearing) { + + var route = {}; + + var points = [new Point(from.x, to.y), new Point(to.x, from.y)]; + var freePoints = points.filter(function(pt) { + return !toBBox.containsPoint(pt); + }); + var freeBearingPoints = freePoints.filter(function(pt) { + return getBearing(pt, from) !== bearing; + }); + + var p; + + if (freeBearingPoints.length > 0) { + // Try to pick a point which bears the same direction as the previous segment. + + p = freeBearingPoints.filter(function(pt) { + return getBearing(from, pt) === bearing; + }).pop(); + p = p || freeBearingPoints[0]; + + route.points = [p]; + route.direction = getBearing(p, to); + + } else { + // Here we found only points which are either contained in the element or they would create + // a link segment going in opposite direction from the previous one. + // We take the point inside element and move it outside the element in the direction the + // route is going. Now we can join this point with the current end (using freeJoin). + + p = difference(points, freePoints)[0]; + + var p2 = (new Point(to)).move(p, -getBBoxSize(toBBox, bearing) / 2); + var p1 = freeJoin(p2, from, toBBox); + + route.points = [p1, p2]; + route.direction = getBearing(p2, to); + } + + return route; + } + + function elementElement(from, to, fromBBox, toBBox) { + + var route = elementVertex(to, from, toBBox); + var p1 = route.points[0]; + + if (fromBBox.containsPoint(p1)) { + + route = elementVertex(from, to, fromBBox); + var p2 = route.points[0]; + + if (toBBox.containsPoint(p2)) { + + var fromBorder = (new Point(from)).move(p2, -getBBoxSize(fromBBox, getBearing(from, p2)) / 2); + var toBorder = (new Point(to)).move(p1, -getBBoxSize(toBBox, getBearing(to, p1)) / 2); + var mid = (new Line(fromBorder, toBorder)).midpoint(); + + var startRoute = elementVertex(from, mid, fromBBox); + var endRoute = vertexVertex(mid, to, startRoute.direction); + + route.points = [startRoute.points[0], endRoute.points[0]]; + route.direction = endRoute.direction; + } + } + + return route; + } + + // Finds route for situations where one element is inside the other. + // Typically the route is directed outside the outer element first and + // then back towards the inner element. + function insideElement(from, to, fromBBox, toBBox, bearing) { + + var route = {}; + var boundary = fromBBox.union(toBBox).inflate(1); + + // start from the point which is closer to the boundary + var reversed = boundary.center().distance(to) > boundary.center().distance(from); + var start = reversed ? to : from; + var end = reversed ? from : to; + + var p1, p2, p3; + + if (bearing) { + // Points on circle with radius equals 'W + H` are always outside the rectangle + // with width W and height H if the center of that circle is the center of that rectangle. + p1 = Point.fromPolar(boundary.width + boundary.height, radians[bearing], start); + p1 = boundary.pointNearestToPoint(p1).move(p1, -1); + + } else { + p1 = boundary.pointNearestToPoint(start).move(start, 1); + } + + p2 = freeJoin(p1, end, boundary); + + if (p1.round().equals(p2.round())) { + p2 = Point.fromPolar(boundary.width + boundary.height, toRad(p1.theta(start)) + Math.PI / 2, end); + p2 = boundary.pointNearestToPoint(p2).move(end, 1).round(); + p3 = freeJoin(p1, p2, boundary); + route.points = reversed ? [p2, p3, p1] : [p1, p3, p2]; + + } else { + route.points = reversed ? [p2, p1] : [p1, p2]; + } + + route.direction = reversed ? getBearing(p1, to) : getBearing(p2, to); + + return route; + } + + // MAIN ROUTER // + + // Return points through which a connection needs to be drawn in order to obtain an orthogonal link + // routing from source to target going through `vertices`. + function orthogonal(vertices, opt, linkView) { + + var sourceBBox = getSourceBBox(linkView, opt); + var targetBBox = getTargetBBox(linkView, opt); + + var sourceAnchor = getSourceAnchor(linkView, opt); + var targetAnchor = getTargetAnchor(linkView, opt); + + // if anchor lies outside of bbox, the bbox expands to include it + sourceBBox = sourceBBox.union(getPointBox(sourceAnchor)); + targetBBox = targetBBox.union(getPointBox(targetAnchor)); + + vertices = toArray(vertices).map(Point); + vertices.unshift(sourceAnchor); + vertices.push(targetAnchor); + + var bearing; // bearing of previous route segment + + var orthogonalVertices = []; // the array of found orthogonal vertices to be returned + for (var i = 0, max = vertices.length - 1; i < max; i++) { + + var route = null; + + var from = vertices[i]; + var to = vertices[i + 1]; + + var isOrthogonal = !!getBearing(from, to); + + if (i === 0) { // source + + if (i + 1 === max) { // route source -> target + + // Expand one of the elements by 1px to detect situations when the two + // elements are positioned next to each other with no gap in between. + if (sourceBBox.intersect(targetBBox.clone().inflate(1))) { + route = insideElement(from, to, sourceBBox, targetBBox); + + } else if (!isOrthogonal) { + route = elementElement(from, to, sourceBBox, targetBBox); + } + + } else { // route source -> vertex + + if (sourceBBox.containsPoint(to)) { + route = insideElement(from, to, sourceBBox, getPointBox(to).moveAndExpand(getPaddingBox(opt))); + + } else if (!isOrthogonal) { + route = elementVertex(from, to, sourceBBox); + } + } + + } else if (i + 1 === max) { // route vertex -> target + + // prevent overlaps with previous line segment + var isOrthogonalLoop = isOrthogonal && getBearing(to, from) === bearing; + + if (targetBBox.containsPoint(from) || isOrthogonalLoop) { + route = insideElement(from, to, getPointBox(from).moveAndExpand(getPaddingBox(opt)), targetBBox, bearing); + + } else if (!isOrthogonal) { + route = vertexElement(from, to, targetBBox, bearing); + } + + } else if (!isOrthogonal) { // route vertex -> vertex + route = vertexVertex(from, to, bearing); + } + + // applicable to all routes: + + // set bearing for next iteration + if (route) { + Array.prototype.push.apply(orthogonalVertices, route.points); + bearing = route.direction; + + } else { + // orthogonal route and not looped + bearing = getBearing(from, to); + } + + // push `to` point to identified orthogonal vertices array + if (i + 1 < max) { + orthogonalVertices.push(to); + } + } + + return orthogonalVertices; + } + + var config$1 = { + + // size of the step to find a route (the grid of the manhattan pathfinder) + step: 10, + + // the number of route finding loops that cause the router to abort + // returns fallback route instead + maximumLoops: 2000, + + // the number of decimal places to round floating point coordinates + precision: 1, + + // maximum change of direction + maxAllowedDirectionChange: 90, + + // should the router use perpendicular linkView option? + // does not connect anchor of element but rather a point close-by that is orthogonal + // this looks much better + perpendicular: true, + + // should the source and/or target not be considered as obstacles? + excludeEnds: [], // 'source', 'target' + + // should certain types of elements not be considered as obstacles? + excludeTypes: ['basic.Text'], + + // possible starting directions from an element + startDirections: ['top', 'right', 'bottom', 'left'], + + // possible ending directions to an element + endDirections: ['top', 'right', 'bottom', 'left'], + + // specify the directions used above and what they mean + directionMap: { + top: { x: 0, y: -1 }, + right: { x: 1, y: 0 }, + bottom: { x: 0, y: 1 }, + left: { x: -1, y: 0 } + }, + + // cost of an orthogonal step + cost: function() { + + return this.step; + }, + + // an array of directions to find next points on the route + // different from start/end directions + directions: function() { + + var step = this.step; + var cost = this.cost(); + + return [ + { offsetX: step, offsetY: 0, cost: cost }, + { offsetX: -step, offsetY: 0, cost: cost }, + { offsetX: 0, offsetY: step, cost: cost }, + { offsetX: 0, offsetY: -step, cost: cost } + ]; + }, + + // a penalty received for direction change + penalties: function() { + + return { + 0: 0, + 45: this.step / 2, + 90: this.step / 2 + }; + }, + + // padding applied on the element bounding boxes + paddingBox: function() { + + var step = this.step; + + return { + x: -step, + y: -step, + width: 2 * step, + height: 2 * step + }; + }, + + // A function that determines whether a given point is an obstacle or not. + // If used, the `padding`, `excludeEnds`and `excludeTypes` options are ignored. + // (point: dia.Point) => boolean; + isPointObstacle: null, + + // a router to use when the manhattan router fails + // (one of the partial routes returns null) + fallbackRouter: function(vertices, opt, linkView) { + + if (!isFunction(orthogonal)) { + throw new Error('Manhattan requires the orthogonal router as default fallback.'); + } + + return orthogonal(vertices, assign({}, config$1, opt), linkView); + }, + + /* Deprecated */ + // a simple route used in situations when main routing method fails + // (exceed max number of loop iterations, inaccessible) + fallbackRoute: function(from, to, opt) { + + return null; // null result will trigger the fallbackRouter + + // left for reference: + /*// Find an orthogonal route ignoring obstacles. + + var point = ((opt.previousDirAngle || 0) % 180 === 0) + ? new g.Point(from.x, to.y) + : new g.Point(to.x, from.y); + + return [point];*/ + }, + + // if a function is provided, it's used to route the link while dragging an end + // i.e. function(from, to, opt) { return []; } + draggingRoute: null + }; + + // HELPER CLASSES // + + // Map of obstacles + // Helper structure to identify whether a point lies inside an obstacle. + function ObstacleMap(opt) { + + this.map = {}; + this.options = opt; + // tells how to divide the paper when creating the elements map + this.mapGridSize = 100; + } + + ObstacleMap.prototype.build = function(graph, link) { + + var opt = this.options; + + // source or target element could be excluded from set of obstacles + var excludedEnds = toArray(opt.excludeEnds).reduce(function(res, item) { + + var end = link.get(item); + if (end) { + var cell = graph.getCell(end.id); + if (cell) { + res.push(cell); + } + } + + return res; + }, []); + + // Exclude any embedded elements from the source and the target element. + var excludedAncestors = []; + + var source = graph.getCell(link.get('source').id); + if (source) { + excludedAncestors = union(excludedAncestors, source.getAncestors().map(function(cell) { + return cell.id; + })); + } + + var target = graph.getCell(link.get('target').id); + if (target) { + excludedAncestors = union(excludedAncestors, target.getAncestors().map(function(cell) { + return cell.id; + })); + } + + // Builds a map of all elements for quicker obstacle queries (i.e. is a point contained + // in any obstacle?) (a simplified grid search). + // The paper is divided into smaller cells, where each holds information about which + // elements belong to it. When we query whether a point lies inside an obstacle we + // don't need to go through all obstacles, we check only those in a particular cell. + var mapGridSize = this.mapGridSize; + + graph.getElements().reduce(function(map, element) { + + var isExcludedType = toArray(opt.excludeTypes).includes(element.get('type')); + var isExcludedEnd = excludedEnds.find(function(excluded) { + return excluded.id === element.id; + }); + var isExcludedAncestor = excludedAncestors.includes(element.id); + + var isExcluded = isExcludedType || isExcludedEnd || isExcludedAncestor; + if (!isExcluded) { + var bbox = element.getBBox().moveAndExpand(opt.paddingBox); + + var origin = bbox.origin().snapToGrid(mapGridSize); + var corner = bbox.corner().snapToGrid(mapGridSize); + + for (var x = origin.x; x <= corner.x; x += mapGridSize) { + for (var y = origin.y; y <= corner.y; y += mapGridSize) { + var gridKey = x + '@' + y; + map[gridKey] = map[gridKey] || []; + map[gridKey].push(bbox); + } + } + } + + return map; + }, this.map); + + return this; + }; + + ObstacleMap.prototype.isPointAccessible = function(point) { + + var mapKey = point.clone().snapToGrid(this.mapGridSize).toString(); + + return toArray(this.map[mapKey]).every(function(obstacle) { + return !obstacle.containsPoint(point); + }); + }; + + // Sorted Set + // Set of items sorted by given value. + function SortedSet() { + this.items = []; + this.hash = {}; + this.values = {}; + this.OPEN = 1; + this.CLOSE = 2; + } + + SortedSet.prototype.add = function(item, value) { + + if (this.hash[item]) { + // item removal + this.items.splice(this.items.indexOf(item), 1); + } else { + this.hash[item] = this.OPEN; + } + + this.values[item] = value; + + var index$1 = sortedIndex(this.items, item, function(i) { + return this.values[i]; + }.bind(this)); + + this.items.splice(index$1, 0, item); + }; + + SortedSet.prototype.remove = function(item) { + + this.hash[item] = this.CLOSE; + }; + + SortedSet.prototype.isOpen = function(item) { + + return this.hash[item] === this.OPEN; + }; + + SortedSet.prototype.isClose = function(item) { + + return this.hash[item] === this.CLOSE; + }; + + SortedSet.prototype.isEmpty = function() { + + return this.items.length === 0; + }; + + SortedSet.prototype.pop = function() { + + var item = this.items.shift(); + this.remove(item); + return item; + }; + + // HELPERS // + + // return source bbox + function getSourceBBox$1(linkView, opt) { + + // expand by padding box + if (opt && opt.paddingBox) { return linkView.sourceBBox.clone().moveAndExpand(opt.paddingBox); } + + return linkView.sourceBBox.clone(); + } + + // return target bbox + function getTargetBBox$1(linkView, opt) { + + // expand by padding box + if (opt && opt.paddingBox) { return linkView.targetBBox.clone().moveAndExpand(opt.paddingBox); } + + return linkView.targetBBox.clone(); + } + + // return source anchor + function getSourceAnchor$1(linkView, opt) { + + if (linkView.sourceAnchor) { return linkView.sourceAnchor; } + + // fallback: center of bbox + var sourceBBox = getSourceBBox$1(linkView, opt); + return sourceBBox.center(); + } + + // return target anchor + function getTargetAnchor$1(linkView, opt) { + + if (linkView.targetAnchor) { return linkView.targetAnchor; } + + // fallback: center of bbox + var targetBBox = getTargetBBox$1(linkView, opt); + return targetBBox.center(); // default + } + + // returns a direction index from start point to end point + // corrects for grid deformation between start and end + function getDirectionAngle(start, end, numDirections, grid, opt) { + + var quadrant = 360 / numDirections; + var angleTheta = start.theta(fixAngleEnd(start, end, grid, opt)); + var normalizedAngle = normalizeAngle(angleTheta + (quadrant / 2)); + return quadrant * Math.floor(normalizedAngle / quadrant); + } + + // helper function for getDirectionAngle() + // corrects for grid deformation + // (if a point is one grid steps away from another in both dimensions, + // it is considered to be 45 degrees away, even if the real angle is different) + // this causes visible angle discrepancies if `opt.step` is much larger than `paper.gridSize` + function fixAngleEnd(start, end, grid, opt) { + + var step = opt.step; + + var diffX = end.x - start.x; + var diffY = end.y - start.y; + + var gridStepsX = diffX / grid.x; + var gridStepsY = diffY / grid.y; + + var distanceX = gridStepsX * step; + var distanceY = gridStepsY * step; + + return new Point(start.x + distanceX, start.y + distanceY); + } + + // return the change in direction between two direction angles + function getDirectionChange(angle1, angle2) { + + var directionChange = Math.abs(angle1 - angle2); + return (directionChange > 180) ? (360 - directionChange) : directionChange; + } + + // fix direction offsets according to current grid + function getGridOffsets(directions, grid, opt) { + + var step = opt.step; + + toArray(opt.directions).forEach(function(direction) { + + direction.gridOffsetX = (direction.offsetX / step) * grid.x; + direction.gridOffsetY = (direction.offsetY / step) * grid.y; + }); + } + + // get grid size in x and y dimensions, adapted to source and target positions + function getGrid(step, source, target) { + + return { + source: source.clone(), + x: getGridDimension(target.x - source.x, step), + y: getGridDimension(target.y - source.y, step) + }; + } + + // helper function for getGrid() + function getGridDimension(diff, step) { + + // return step if diff = 0 + if (!diff) { return step; } + + var absDiff = Math.abs(diff); + var numSteps = Math.round(absDiff / step); + + // return absDiff if less than one step apart + if (!numSteps) { return absDiff; } + + // otherwise, return corrected step + var roundedDiff = numSteps * step; + var remainder = absDiff - roundedDiff; + var stepCorrection = remainder / numSteps; + + return step + stepCorrection; + } + + // return a clone of point snapped to grid + function snapToGrid$1(point, grid) { + + var source = grid.source; + + var snappedX = snapToGrid(point.x - source.x, grid.x) + source.x; + var snappedY = snapToGrid(point.y - source.y, grid.y) + source.y; + + return new Point(snappedX, snappedY); + } + + // round the point to opt.precision + function round$4(point, precision) { + + return point.round(precision); + } + + // snap to grid and then round the point + function align(point, grid, precision) { + + return round$4(snapToGrid$1(point.clone(), grid), precision); + } + + // return a string representing the point + // string is rounded in both dimensions + function getKey(point) { + + return point.clone().toString(); + } + + // return a normalized vector from given point + // used to determine the direction of a difference of two points + function normalizePoint(point) { + + return new Point( + point.x === 0 ? 0 : Math.abs(point.x) / point.x, + point.y === 0 ? 0 : Math.abs(point.y) / point.y + ); + } + + // PATHFINDING // + + // reconstructs a route by concatenating points with their parents + function reconstructRoute(parents, points, tailPoint, from, to, grid, opt) { + + var route = []; + + var prevDiff = normalizePoint(to.difference(tailPoint)); + + // tailPoint is assumed to be aligned already + var currentKey = getKey(tailPoint); + var parent = parents[currentKey]; + + var point; + while (parent) { + + // point is assumed to be aligned already + point = points[currentKey]; + + var diff = normalizePoint(point.difference(parent)); + if (!diff.equals(prevDiff)) { + route.unshift(point); + prevDiff = diff; + } + + // parent is assumed to be aligned already + currentKey = getKey(parent); + parent = parents[currentKey]; + } + + // leadPoint is assumed to be aligned already + var leadPoint = points[currentKey]; + + var fromDiff = normalizePoint(leadPoint.difference(from)); + if (!fromDiff.equals(prevDiff)) { + route.unshift(leadPoint); + } + + return route; + } + + // heuristic method to determine the distance between two points + function estimateCost(from, endPoints) { + + var min = Infinity; + + for (var i = 0, len = endPoints.length; i < len; i++) { + var cost = from.manhattanDistance(endPoints[i]); + if (cost < min) { min = cost; } + } + + return min; + } + + // find points around the bbox taking given directions into account + // lines are drawn from anchor in given directions, intersections recorded + // if anchor is outside bbox, only those directions that intersect get a rect point + // the anchor itself is returned as rect point (representing some directions) + // (since those directions are unobstructed by the bbox) + function getRectPoints(anchor, bbox, directionList, grid, opt) { + + var precision = opt.precision; + var directionMap = opt.directionMap; + + var anchorCenterVector = anchor.difference(bbox.center()); + + var keys = isObject$1(directionMap) ? Object.keys(directionMap) : []; + var dirList = toArray(directionList); + var rectPoints = keys.reduce(function(res, key) { + + if (dirList.includes(key)) { + var direction = directionMap[key]; + + // create a line that is guaranteed to intersect the bbox if bbox is in the direction + // even if anchor lies outside of bbox + var endpoint = new Point( + anchor.x + direction.x * (Math.abs(anchorCenterVector.x) + bbox.width), + anchor.y + direction.y * (Math.abs(anchorCenterVector.y) + bbox.height) + ); + var intersectionLine = new Line(anchor, endpoint); + + // get the farther intersection, in case there are two + // (that happens if anchor lies next to bbox) + var intersections = intersectionLine.intersect(bbox) || []; + var numIntersections = intersections.length; + var farthestIntersectionDistance; + var farthestIntersection = null; + for (var i = 0; i < numIntersections; i++) { + var currentIntersection = intersections[i]; + var distance = anchor.squaredDistance(currentIntersection); + if ((farthestIntersectionDistance === undefined) || (distance > farthestIntersectionDistance)) { + farthestIntersectionDistance = distance; + farthestIntersection = currentIntersection; + } + } + + // if an intersection was found in this direction, it is our rectPoint + if (farthestIntersection) { + var point = align(farthestIntersection, grid, precision); + + // if the rectPoint lies inside the bbox, offset it by one more step + if (bbox.containsPoint(point)) { + point = align(point.offset(direction.x * grid.x, direction.y * grid.y), grid, precision); + } + + // then add the point to the result array + // aligned + res.push(point); + } + } + + return res; + }, []); + + // if anchor lies outside of bbox, add it to the array of points + if (!bbox.containsPoint(anchor)) { + // aligned + rectPoints.push(align(anchor, grid, precision)); + } + + return rectPoints; + } + + // finds the route between two points/rectangles (`from`, `to`) implementing A* algorithm + // rectangles get rect points assigned by getRectPoints() + function findRoute(from, to, isPointObstacle, opt) { + + var precision = opt.precision; + + // Get grid for this route. + + var sourceAnchor, targetAnchor; + + if (from instanceof Rect) { // `from` is sourceBBox + sourceAnchor = round$4(getSourceAnchor$1(this, opt).clone(), precision); + } else { + sourceAnchor = round$4(from.clone(), precision); + } + + if (to instanceof Rect) { // `to` is targetBBox + targetAnchor = round$4(getTargetAnchor$1(this, opt).clone(), precision); + } else { + targetAnchor = round$4(to.clone(), precision); + } + + var grid = getGrid(opt.step, sourceAnchor, targetAnchor); + + // Get pathfinding points. + + var start, end; // aligned with grid by definition + var startPoints, endPoints; // assumed to be aligned with grid already + + // set of points we start pathfinding from + if (from instanceof Rect) { // `from` is sourceBBox + start = sourceAnchor; + startPoints = getRectPoints(start, from, opt.startDirections, grid, opt); + + } else { + start = sourceAnchor; + startPoints = [start]; + } + + // set of points we want the pathfinding to finish at + if (to instanceof Rect) { // `to` is targetBBox + end = targetAnchor; + endPoints = getRectPoints(targetAnchor, to, opt.endDirections, grid, opt); + + } else { + end = targetAnchor; + endPoints = [end]; + } + + // take into account only accessible rect points (those not under obstacles) + startPoints = startPoints.filter(function (p) { return !isPointObstacle(p); }); + endPoints = endPoints.filter(function (p) { return !isPointObstacle(p); }); + + // Check that there is an accessible route point on both sides. + // Otherwise, use fallbackRoute(). + if (startPoints.length > 0 && endPoints.length > 0) { + + // The set of tentative points to be evaluated, initially containing the start points. + // Rounded to nearest integer for simplicity. + var openSet = new SortedSet(); + // Keeps reference to actual points for given elements of the open set. + var points = {}; + // Keeps reference to a point that is immediate predecessor of given element. + var parents = {}; + // Cost from start to a point along best known path. + var costs = {}; + + for (var i = 0, n = startPoints.length; i < n; i++) { + // startPoint is assumed to be aligned already + var startPoint = startPoints[i]; + + var key = getKey(startPoint); + + openSet.add(key, estimateCost(startPoint, endPoints)); + points[key] = startPoint; + costs[key] = 0; + } + + var previousRouteDirectionAngle = opt.previousDirectionAngle; // undefined for first route + var isPathBeginning = (previousRouteDirectionAngle === undefined); + + // directions + var direction, directionChange; + var directions = opt.directions; + getGridOffsets(directions, grid, opt); + + var numDirections = directions.length; + + var endPointsKeys = toArray(endPoints).reduce(function(res, endPoint) { + // endPoint is assumed to be aligned already + + var key = getKey(endPoint); + res.push(key); + return res; + }, []); + + // main route finding loop + var loopsRemaining = opt.maximumLoops; + while (!openSet.isEmpty() && loopsRemaining > 0) { + + // remove current from the open list + var currentKey = openSet.pop(); + var currentPoint = points[currentKey]; + var currentParent = parents[currentKey]; + var currentCost = costs[currentKey]; + + var isRouteBeginning = (currentParent === undefined); // undefined for route starts + var isStart = currentPoint.equals(start); // (is source anchor or `from` point) = can leave in any direction + + var previousDirectionAngle; + if (!isRouteBeginning) { previousDirectionAngle = getDirectionAngle(currentParent, currentPoint, numDirections, grid, opt); } // a vertex on the route + else if (!isPathBeginning) { previousDirectionAngle = previousRouteDirectionAngle; } // beginning of route on the path + else if (!isStart) { previousDirectionAngle = getDirectionAngle(start, currentPoint, numDirections, grid, opt); } // beginning of path, start rect point + else { previousDirectionAngle = null; } // beginning of path, source anchor or `from` point + + // check if we reached any endpoint + var samePoints = startPoints.length === endPoints.length; + if (samePoints) { + for (var j = 0; j < startPoints.length; j++) { + if (!startPoints[j].equals(endPoints[j])) { + samePoints = false; + break; + } + } + } + var skipEndCheck = (isRouteBeginning && samePoints); + if (!skipEndCheck && (endPointsKeys.indexOf(currentKey) >= 0)) { + opt.previousDirectionAngle = previousDirectionAngle; + return reconstructRoute(parents, points, currentPoint, start, end, grid, opt); + } + + // go over all possible directions and find neighbors + for (i = 0; i < numDirections; i++) { + direction = directions[i]; + + var directionAngle = direction.angle; + directionChange = getDirectionChange(previousDirectionAngle, directionAngle); + + // if the direction changed rapidly, don't use this point + // any direction is allowed for starting points + if (!(isPathBeginning && isStart) && directionChange > opt.maxAllowedDirectionChange) { continue; } + + var neighborPoint = align(currentPoint.clone().offset(direction.gridOffsetX, direction.gridOffsetY), grid, precision); + var neighborKey = getKey(neighborPoint); + + // Closed points from the openSet were already evaluated. + if (openSet.isClose(neighborKey) || isPointObstacle(neighborPoint)) { continue; } + + // We can only enter end points at an acceptable angle. + if (endPointsKeys.indexOf(neighborKey) >= 0) { // neighbor is an end point + + var isNeighborEnd = neighborPoint.equals(end); // (is target anchor or `to` point) = can be entered in any direction + + if (!isNeighborEnd) { + var endDirectionAngle = getDirectionAngle(neighborPoint, end, numDirections, grid, opt); + var endDirectionChange = getDirectionChange(directionAngle, endDirectionAngle); + + if (endDirectionChange > opt.maxAllowedDirectionChange) { continue; } + } + } + + // The current direction is ok. + + var neighborCost = direction.cost; + var neighborPenalty = isStart ? 0 : opt.penalties[directionChange]; // no penalties for start point + var costFromStart = currentCost + neighborCost + neighborPenalty; + + if (!openSet.isOpen(neighborKey) || (costFromStart < costs[neighborKey])) { + // neighbor point has not been processed yet + // or the cost of the path from start is lower than previously calculated + + points[neighborKey] = neighborPoint; + parents[neighborKey] = currentPoint; + costs[neighborKey] = costFromStart; + openSet.add(neighborKey, costFromStart + estimateCost(neighborPoint, endPoints)); + } + } + + loopsRemaining--; + } + } + + // no route found (`to` point either wasn't accessible or finding route took + // way too much calculation) + return opt.fallbackRoute.call(this, start, end, opt); + } + + // resolve some of the options + function resolveOptions(opt) { + + opt.directions = result(opt, 'directions'); + opt.penalties = result(opt, 'penalties'); + opt.paddingBox = result(opt, 'paddingBox'); + opt.padding = result(opt, 'padding'); + + if (opt.padding) { + // if both provided, opt.padding wins over opt.paddingBox + var sides = normalizeSides(opt.padding); + opt.paddingBox = { + x: -sides.left, + y: -sides.top, + width: sides.left + sides.right, + height: sides.top + sides.bottom + }; + } + + toArray(opt.directions).forEach(function(direction) { + + var point1 = new Point(0, 0); + var point2 = new Point(direction.offsetX, direction.offsetY); + + direction.angle = normalizeAngle(point1.theta(point2)); + }); + } + + // initialization of the route finding + function router(vertices, opt, linkView) { + + resolveOptions(opt); + + // enable/disable linkView perpendicular option + linkView.options.perpendicular = !!opt.perpendicular; + + var sourceBBox = getSourceBBox$1(linkView, opt); + var targetBBox = getTargetBBox$1(linkView, opt); + + var sourceAnchor = getSourceAnchor$1(linkView, opt); + //var targetAnchor = getTargetAnchor(linkView, opt); + + // pathfinding + var isPointObstacle; + if (typeof opt.isPointObstacle === 'function') { + isPointObstacle = opt.isPointObstacle; + } else { + var map = new ObstacleMap(opt); + map.build(linkView.paper.model, linkView.model); + isPointObstacle = function (point) { return !map.isPointAccessible(point); }; + } + + var oldVertices = toArray(vertices).map(Point); + var newVertices = []; + var tailPoint = sourceAnchor; // the origin of first route's grid, does not need snapping + + // find a route by concatenating all partial routes (routes need to pass through vertices) + // source -> vertex[1] -> ... -> vertex[n] -> target + var to, from; + + for (var i = 0, len = oldVertices.length; i <= len; i++) { + + var partialRoute = null; + + from = to || sourceBBox; + to = oldVertices[i]; + + if (!to) { + // this is the last iteration + // we ran through all vertices in oldVertices + // 'to' is not a vertex. + + to = targetBBox; + + // If the target is a point (i.e. it's not an element), we + // should use dragging route instead of main routing method if it has been provided. + var isEndingAtPoint = !linkView.model.get('source').id || !linkView.model.get('target').id; + + if (isEndingAtPoint && isFunction(opt.draggingRoute)) { + // Make sure we are passing points only (not rects). + var dragFrom = (from === sourceBBox) ? sourceAnchor : from; + var dragTo = to.origin(); + + partialRoute = opt.draggingRoute.call(linkView, dragFrom, dragTo, opt); + } + } + + // if partial route has not been calculated yet use the main routing method to find one + partialRoute = partialRoute || findRoute.call(linkView, from, to, isPointObstacle, opt); + + if (partialRoute === null) { // the partial route cannot be found + return opt.fallbackRouter(vertices, opt, linkView); + } + + var leadPoint = partialRoute[0]; + + // remove the first point if the previous partial route had the same point as last + if (leadPoint && leadPoint.equals(tailPoint)) { partialRoute.shift(); } + + // save tailPoint for next iteration + tailPoint = partialRoute[partialRoute.length - 1] || tailPoint; + + Array.prototype.push.apply(newVertices, partialRoute); + } + + return newVertices; + } + + // public function + var manhattan = function(vertices, opt, linkView) { + return router(vertices, assign({}, config$1, opt), linkView); + }; + + var config$2 = { + + maxAllowedDirectionChange: 45, + + // cost of a diagonal step + diagonalCost: function() { + + var step = this.step; + return Math.ceil(Math.sqrt(step * step << 1)); + }, + + // an array of directions to find next points on the route + // different from start/end directions + directions: function() { + + var step = this.step; + var cost = this.cost(); + var diagonalCost = this.diagonalCost(); + + return [ + { offsetX: step, offsetY: 0, cost: cost }, + { offsetX: step, offsetY: step, cost: diagonalCost }, + { offsetX: 0, offsetY: step, cost: cost }, + { offsetX: -step, offsetY: step, cost: diagonalCost }, + { offsetX: -step, offsetY: 0, cost: cost }, + { offsetX: -step, offsetY: -step, cost: diagonalCost }, + { offsetX: 0, offsetY: -step, cost: cost }, + { offsetX: step, offsetY: -step, cost: diagonalCost } + ]; + }, + + // a simple route used in situations when main routing method fails + // (exceed max number of loop iterations, inaccessible) + fallbackRoute: function(from, to, opt) { + + // Find a route which breaks by 45 degrees ignoring all obstacles. + + var theta = from.theta(to); + + var route = []; + + var a = { x: to.x, y: from.y }; + var b = { x: from.x, y: to.y }; + + if (theta % 180 > 90) { + var t = a; + a = b; + b = t; + } + + var p1 = (theta % 90) < 45 ? a : b; + var l1 = new Line(from, p1); + + var alpha = 90 * Math.ceil(theta / 90); + + var p2 = Point.fromPolar(l1.squaredLength(), toRad(alpha + 135), p1); + var l2 = new Line(to, p2); + + var intersectionPoint = l1.intersection(l2); + var point = intersectionPoint ? intersectionPoint : to; + + var directionFrom = intersectionPoint ? point : from; + + var quadrant = 360 / opt.directions.length; + var angleTheta = directionFrom.theta(to); + var normalizedAngle = normalizeAngle(angleTheta + (quadrant / 2)); + var directionAngle = quadrant * Math.floor(normalizedAngle / quadrant); + + opt.previousDirectionAngle = directionAngle; + + if (point) { route.push(point.round()); } + route.push(to); + + return route; + } + }; + + // public function + var metro = function(vertices, opt, linkView) { + + if (!isFunction(manhattan)) { + throw new Error('Metro requires the manhattan router.'); + } + + return manhattan(vertices, assign({}, config$2, opt), linkView); + }; + + + + var routers = ({ + normal: normal, + oneSide: oneSide, + orthogonal: orthogonal, + manhattan: manhattan, + metro: metro + }); + + // default size of jump if not specified in options + var JUMP_SIZE = 5; + + // available jump types + // first one taken as default + var JUMP_TYPES = ['arc', 'gap', 'cubic']; + + // default radius + var RADIUS = 0; + + // takes care of math. error for case when jump is too close to end of line + var CLOSE_PROXIMITY_PADDING = 1; + + // list of connector types not to jump over. + var IGNORED_CONNECTORS = ['smooth']; + + // internal constants for round segment + var _13 = 1 / 3; + var _23 = 2 / 3; + + /** + * Transform start/end and route into series of lines + * @param {g.point} sourcePoint start point + * @param {g.point} targetPoint end point + * @param {g.point[]} route optional list of route + * @return {g.line[]} [description] + */ + function createLines(sourcePoint, targetPoint, route) { + // make a flattened array of all points + var points = [].concat(sourcePoint, route, targetPoint); + return points.reduce(function(resultLines, point, idx) { + // if there is a next point, make a line with it + var nextPoint = points[idx + 1]; + if (nextPoint != null) { + resultLines[idx] = line(point, nextPoint); + } + return resultLines; + }, []); + } + + function setupUpdating(jumpOverLinkView) { + var paper = jumpOverLinkView.paper; + var updateList = paper._jumpOverUpdateList; + + // first time setup for this paper + if (updateList == null) { + updateList = paper._jumpOverUpdateList = []; + var graph = paper.model; + graph.on('batch:stop', function() { + if (this.hasActiveBatch()) { return; } + updateJumpOver(paper); + }); + graph.on('reset', function() { + updateList = paper._jumpOverUpdateList = []; + }); + } + + // add this link to a list so it can be updated when some other link is updated + if (updateList.indexOf(jumpOverLinkView) < 0) { + updateList.push(jumpOverLinkView); + + // watch for change of connector type or removal of link itself + // to remove the link from a list of jump over connectors + jumpOverLinkView.listenToOnce(jumpOverLinkView.model, 'change:connector remove', function() { + updateList.splice(updateList.indexOf(jumpOverLinkView), 1); + }); + } + } + + /** + * Handler for a batch:stop event to force + * update of all registered links with jump over connector + * @param {object} batchEvent optional object with info about batch + */ + function updateJumpOver(paper) { + var updateList = paper._jumpOverUpdateList; + for (var i = 0; i < updateList.length; i++) { + var linkView = updateList[i]; + var updateFlag = linkView.getFlag(linkView.constructor.Flags.CONNECTOR); + linkView.requestUpdate(updateFlag); + } + } + + /** + * Utility function to collect all intersection points of a single + * line against group of other lines. + * @param {g.line} line where to find points + * @param {g.line[]} crossCheckLines lines to cross + * @return {g.point[]} list of intersection points + */ + function findLineIntersections(line, crossCheckLines) { + return toArray(crossCheckLines).reduce(function(res, crossCheckLine) { + var intersection = line.intersection(crossCheckLine); + if (intersection) { + res.push(intersection); + } + return res; + }, []); + } + + /** + * Sorting function for list of points by their distance. + * @param {g.point} p1 first point + * @param {g.point} p2 second point + * @return {number} squared distance between points + */ + function sortPoints(p1, p2) { + return line(p1, p2).squaredLength(); + } + + /** + * Split input line into multiple based on intersection points. + * @param {g.line} line input line to split + * @param {g.point[]} intersections points where to split the line + * @param {number} jumpSize the size of jump arc (length empty spot on a line) + * @return {g.line[]} list of lines being split + */ + function createJumps(line$1, intersections, jumpSize) { + return intersections.reduce(function(resultLines, point$1, idx) { + // skipping points that were merged with the previous line + // to make bigger arc over multiple lines that are close to each other + if (point$1.skip === true) { + return resultLines; + } + + // always grab the last line from buffer and modify it + var lastLine = resultLines.pop() || line$1; + + // calculate start and end of jump by moving by a given size of jump + var jumpStart = point(point$1).move(lastLine.start, -(jumpSize)); + var jumpEnd = point(point$1).move(lastLine.start, +(jumpSize)); + + // now try to look at the next intersection point + var nextPoint = intersections[idx + 1]; + if (nextPoint != null) { + var distance = jumpEnd.distance(nextPoint); + if (distance <= jumpSize) { + // next point is close enough, move the jump end by this + // difference and mark the next point to be skipped + jumpEnd = nextPoint.move(lastLine.start, distance); + nextPoint.skip = true; + } + } else { + // this block is inside of `else` as an optimization so the distance is + // not calculated when we know there are no other intersection points + var endDistance = jumpStart.distance(lastLine.end); + // if the end is too close to possible jump, draw remaining line instead of a jump + if (endDistance < jumpSize * 2 + CLOSE_PROXIMITY_PADDING) { + resultLines.push(lastLine); + return resultLines; + } + } + + var startDistance = jumpEnd.distance(lastLine.start); + if (startDistance < jumpSize * 2 + CLOSE_PROXIMITY_PADDING) { + // if the start of line is too close to jump, draw that line instead of a jump + resultLines.push(lastLine); + return resultLines; + } + + // finally create a jump line + var jumpLine = line(jumpStart, jumpEnd); + // it's just simple line but with a `isJump` property + jumpLine.isJump = true; + + resultLines.push( + line(lastLine.start, jumpStart), + jumpLine, + line(jumpEnd, lastLine.end) + ); + return resultLines; + }, []); + } + + /** + * Assemble `D` attribute of a SVG path by iterating given lines. + * @param {g.line[]} lines source lines to use + * @param {number} jumpSize the size of jump arc (length empty spot on a line) + * @param {number} radius the radius + * @return {string} + */ + function buildPath(lines, jumpSize, jumpType, radius) { + + var path = new Path(); + var segment; + + // first move to the start of a first line + segment = Path.createSegment('M', lines[0].start); + path.appendSegment(segment); + + // make a paths from lines + toArray(lines).forEach(function(line, index) { + + if (line.isJump) { + var angle, diff; + + var control1, control2; + + if (jumpType === 'arc') { // approximates semicircle with 2 curves + angle = -90; + // determine rotation of arc based on difference between points + diff = line.start.difference(line.end); + // make sure the arc always points up (or right) + var xAxisRotate = Number((diff.x < 0) || (diff.x === 0 && diff.y < 0)); + if (xAxisRotate) { angle += 180; } + + var midpoint = line.midpoint(); + var centerLine = new Line(midpoint, line.end).rotate(midpoint, angle); + + var halfLine; + + // first half + halfLine = new Line(line.start, midpoint); + + control1 = halfLine.pointAt(2 / 3).rotate(line.start, angle); + control2 = centerLine.pointAt(1 / 3).rotate(centerLine.end, -angle); + + segment = Path.createSegment('C', control1, control2, centerLine.end); + path.appendSegment(segment); + + // second half + halfLine = new Line(midpoint, line.end); + + control1 = centerLine.pointAt(1 / 3).rotate(centerLine.end, angle); + control2 = halfLine.pointAt(1 / 3).rotate(line.end, -angle); + + segment = Path.createSegment('C', control1, control2, line.end); + path.appendSegment(segment); + + } else if (jumpType === 'gap') { + segment = Path.createSegment('M', line.end); + path.appendSegment(segment); + + } else if (jumpType === 'cubic') { // approximates semicircle with 1 curve + angle = line.start.theta(line.end); + + var xOffset = jumpSize * 0.6; + var yOffset = jumpSize * 1.35; + + // determine rotation of arc based on difference between points + diff = line.start.difference(line.end); + // make sure the arc always points up (or right) + xAxisRotate = Number((diff.x < 0) || (diff.x === 0 && diff.y < 0)); + if (xAxisRotate) { yOffset *= -1; } + + control1 = Point(line.start.x + xOffset, line.start.y + yOffset).rotate(line.start, angle); + control2 = Point(line.end.x - xOffset, line.end.y + yOffset).rotate(line.end, angle); + + segment = Path.createSegment('C', control1, control2, line.end); + path.appendSegment(segment); + } + + } else { + var nextLine = lines[index + 1]; + if (radius == 0 || !nextLine || nextLine.isJump) { + segment = Path.createSegment('L', line.end); + path.appendSegment(segment); + } else { + buildRoundedSegment(radius, path, line.end, line.start, nextLine.end); + } + } + }); + + return path; + } + + function buildRoundedSegment(offset, path, curr, prev, next) { + var prevDistance = curr.distance(prev) / 2; + var nextDistance = curr.distance(next) / 2; + + var startMove = -Math.min(offset, prevDistance); + var endMove = -Math.min(offset, nextDistance); + + var roundedStart = curr.clone().move(prev, startMove).round(); + var roundedEnd = curr.clone().move(next, endMove).round(); + + var control1 = new Point((_13 * roundedStart.x) + (_23 * curr.x), (_23 * curr.y) + (_13 * roundedStart.y)); + var control2 = new Point((_13 * roundedEnd.x) + (_23 * curr.x), (_23 * curr.y) + (_13 * roundedEnd.y)); + + var segment; + segment = Path.createSegment('L', roundedStart); + path.appendSegment(segment); + + segment = Path.createSegment('C', control1, control2, roundedEnd); + path.appendSegment(segment); + } + + /** + * Actual connector function that will be run on every update. + * @param {g.point} sourcePoint start point of this link + * @param {g.point} targetPoint end point of this link + * @param {g.point[]} route of this link + * @param {object} opt options + * @property {number} size optional size of a jump arc + * @return {string} created `D` attribute of SVG path + */ + var jumpover = function(sourcePoint, targetPoint, route, opt) { // eslint-disable-line max-params + + setupUpdating(this); + + var raw = opt.raw; + var jumpSize = opt.size || JUMP_SIZE; + var jumpType = opt.jump && ('' + opt.jump).toLowerCase(); + var radius = opt.radius || RADIUS; + var ignoreConnectors = opt.ignoreConnectors || IGNORED_CONNECTORS; + + // grab the first jump type as a default if specified one is invalid + if (JUMP_TYPES.indexOf(jumpType) === -1) { + jumpType = JUMP_TYPES[0]; + } + + var paper = this.paper; + var graph = paper.model; + var allLinks = graph.getLinks(); + + // there is just one link, draw it directly + if (allLinks.length === 1) { + return buildPath( + createLines(sourcePoint, targetPoint, route), + jumpSize, jumpType, radius + ); + } + + var thisModel = this.model; + var thisIndex = allLinks.indexOf(thisModel); + var defaultConnector = paper.options.defaultConnector || {}; + + // not all links are meant to be jumped over. + var links = allLinks.filter(function(link, idx) { + + var connector = link.get('connector') || defaultConnector; + + // avoid jumping over links with connector type listed in `ignored connectors`. + if (toArray(ignoreConnectors).includes(connector.name)) { + return false; + } + // filter out links that are above this one and have the same connector type + // otherwise there would double hoops for each intersection + if (idx > thisIndex) { + return connector.name !== 'jumpover'; + } + return true; + }); + + // find views for all links + var linkViews = links.map(function(link) { + return paper.findViewByModel(link); + }); + + // create lines for this link + var thisLines = createLines( + sourcePoint, + targetPoint, + route + ); + + // create lines for all other links + var linkLines = linkViews.map(function(linkView) { + if (linkView == null) { + return []; + } + if (linkView === this) { + return thisLines; + } + return createLines( + linkView.sourcePoint, + linkView.targetPoint, + linkView.route + ); + }, this); + + // transform lines for this link by splitting with jump lines at + // points of intersection with other links + var jumpingLines = thisLines.reduce(function(resultLines, thisLine) { + // iterate all links and grab the intersections with this line + // these are then sorted by distance so the line can be split more easily + + var intersections = links.reduce(function(res, link, i) { + // don't intersection with itself + if (link !== thisModel) { + + var lineIntersections = findLineIntersections(thisLine, linkLines[i]); + res.push.apply(res, lineIntersections); + } + return res; + }, []).sort(function(a, b) { + return sortPoints(thisLine.start, a) - sortPoints(thisLine.start, b); + }); + + if (intersections.length > 0) { + // split the line based on found intersection points + resultLines.push.apply(resultLines, createJumps(thisLine, intersections, jumpSize)); + } else { + // without any intersection the line goes uninterrupted + resultLines.push(thisLine); + } + return resultLines; + }, []); + + var path = buildPath(jumpingLines, jumpSize, jumpType, radius); + return (raw) ? path : path.serialize(); + }; + + var normal$1 = function(sourcePoint, targetPoint, route, opt) { + + var raw = opt && opt.raw; + var points = [sourcePoint].concat(route).concat([targetPoint]); + + var polyline = new Polyline(points); + var path = new Path(polyline); + + return (raw) ? path : path.serialize(); + }; + + var rounded = function(sourcePoint, targetPoint, route, opt) { + + opt || (opt = {}); + + var offset = opt.radius || 10; + var raw = opt.raw; + var path = new Path(); + var segment; + + segment = Path.createSegment('M', sourcePoint); + path.appendSegment(segment); + + var _13 = 1 / 3; + var _23 = 2 / 3; + + var curr; + var prev, next; + var prevDistance, nextDistance; + var startMove, endMove; + var roundedStart, roundedEnd; + var control1, control2; + + for (var index = 0, n = route.length; index < n; index++) { + + curr = new Point(route[index]); + + prev = route[index - 1] || sourcePoint; + next = route[index + 1] || targetPoint; + + prevDistance = nextDistance || (curr.distance(prev) / 2); + nextDistance = curr.distance(next) / 2; + + startMove = -Math.min(offset, prevDistance); + endMove = -Math.min(offset, nextDistance); + + roundedStart = curr.clone().move(prev, startMove).round(); + roundedEnd = curr.clone().move(next, endMove).round(); + + control1 = new Point((_13 * roundedStart.x) + (_23 * curr.x), (_23 * curr.y) + (_13 * roundedStart.y)); + control2 = new Point((_13 * roundedEnd.x) + (_23 * curr.x), (_23 * curr.y) + (_13 * roundedEnd.y)); + + segment = Path.createSegment('L', roundedStart); + path.appendSegment(segment); + + segment = Path.createSegment('C', control1, control2, roundedEnd); + path.appendSegment(segment); + } + + segment = Path.createSegment('L', targetPoint); + path.appendSegment(segment); + + return (raw) ? path : path.serialize(); + }; + + var smooth = function(sourcePoint, targetPoint, route, opt) { + + var raw = opt && opt.raw; + var path; + + if (route && route.length !== 0) { + + var points = [sourcePoint].concat(route).concat([targetPoint]); + var curves = Curve.throughPoints(points); + + path = new Path(curves); + + } else { + // if we have no route, use a default cubic bezier curve + // cubic bezier requires two control points + // the control points have `x` midway between source and target + // this produces an S-like curve + + path = new Path(); + + var segment; + + segment = Path.createSegment('M', sourcePoint); + path.appendSegment(segment); + + if ((Math.abs(sourcePoint.x - targetPoint.x)) >= (Math.abs(sourcePoint.y - targetPoint.y))) { + var controlPointX = (sourcePoint.x + targetPoint.x) / 2; + + segment = Path.createSegment('C', controlPointX, sourcePoint.y, controlPointX, targetPoint.y, targetPoint.x, targetPoint.y); + path.appendSegment(segment); + + } else { + var controlPointY = (sourcePoint.y + targetPoint.y) / 2; + + segment = Path.createSegment('C', sourcePoint.x, controlPointY, targetPoint.x, controlPointY, targetPoint.x, targetPoint.y); + path.appendSegment(segment); + + } + } + + return (raw) ? path : path.serialize(); + }; + + var Directions = { + AUTO: 'auto', + HORIZONTAL: 'horizontal', + VERTICAL: 'vertical', + CLOSEST_POINT: 'closest-point', + OUTWARDS: 'outwards' + }; + + var TangentDirections = { + UP: 'up', + DOWN: 'down', + LEFT: 'left', + RIGHT: 'right', + AUTO: 'auto', + CLOSEST_POINT: 'closest-point', + OUTWARDS: 'outwards' + }; + + var curve = function(sourcePoint, targetPoint, route, opt, linkView) { + if ( route === void 0 ) route = []; + if ( opt === void 0 ) opt = {}; + + var raw = Boolean(opt.raw); + // distanceCoefficient - a coefficient of the tangent vector length relative to the distance between points. + // angleTangentCoefficient - a coefficient of the end tangents length in the case of angles larger than 45 degrees. + // tension - a Catmull-Rom curve tension parameter. + // sourceTangent - a tangent vector along the curve at the sourcePoint. + // sourceDirection - a unit direction vector along the curve at the sourcePoint. + // targetTangent - a tangent vector along the curve at the targetPoint. + // targetDirection - a unit direction vector along the curve at the targetPoint. + // precision - a rounding precision for path values. + var direction = opt.direction; if ( direction === void 0 ) direction = Directions.AUTO; + var precision = opt.precision; if ( precision === void 0 ) precision = 3; + var options = { + coeff: opt.distanceCoefficient || 0.6, + angleTangentCoefficient: opt.angleTangentCoefficient || 80, + tau: opt.tension || 0.5, + sourceTangent: opt.sourceTangent ? new Point(opt.sourceTangent) : null, + targetTangent: opt.targetTangent ? new Point(opt.targetTangent) : null, + rotate: Boolean(opt.rotate) + }; + if (typeof opt.sourceDirection === 'string') + { options.sourceDirection = opt.sourceDirection; } + else if (typeof opt.sourceDirection === 'number') + { options.sourceDirection = new Point(1, 0).rotate(null, opt.sourceDirection); } + else + { options.sourceDirection = opt.sourceDirection ? new Point(opt.sourceDirection).normalize() : null; } + + if (typeof opt.targetDirection === 'string') + { options.targetDirection = opt.targetDirection; } + else if (typeof opt.targetDirection === 'number') + { options.targetDirection = new Point(1, 0).rotate(null, opt.targetDirection); } + else + { options.targetDirection = opt.targetDirection ? new Point(opt.targetDirection).normalize() : null; } + + var completeRoute = [sourcePoint ].concat( route.map(function (p) { return new Point(p); }), [targetPoint]); + + // The calculation of a sourceTangent + var sourceTangent; + if (options.sourceTangent) { + sourceTangent = options.sourceTangent; + } else { + var sourceDirection = getSourceTangentDirection(linkView, completeRoute, direction, options); + var tangentLength = completeRoute[0].distance(completeRoute[1]) * options.coeff; + var pointsVector = completeRoute[1].difference(completeRoute[0]).normalize(); + var angle = angleBetweenVectors(sourceDirection, pointsVector); + if (angle > Math.PI / 4) { + var updatedLength = tangentLength + (angle - Math.PI / 4) * options.angleTangentCoefficient; + sourceTangent = sourceDirection.clone().scale(updatedLength, updatedLength); + } else { + sourceTangent = sourceDirection.clone().scale(tangentLength, tangentLength); + } + } + + // The calculation of a targetTangent + var targetTangent; + if (options.targetTangent) { + targetTangent = options.targetTangent; + } else { + var targetDirection = getTargetTangentDirection(linkView, completeRoute, direction, options); + var last = completeRoute.length - 1; + var tangentLength$1 = completeRoute[last - 1].distance(completeRoute[last]) * options.coeff; + var pointsVector$1 = completeRoute[last - 1].difference(completeRoute[last]).normalize(); + var angle$1 = angleBetweenVectors(targetDirection, pointsVector$1); + if (angle$1 > Math.PI / 4) { + var updatedLength$1 = tangentLength$1 + (angle$1 - Math.PI / 4) * options.angleTangentCoefficient; + targetTangent = targetDirection.clone().scale(updatedLength$1, updatedLength$1); + } else { + targetTangent = targetDirection.clone().scale(tangentLength$1, tangentLength$1); + } + } + + var catmullRomCurves = createCatmullRomCurves(completeRoute, sourceTangent, targetTangent, options); + var bezierCurves = catmullRomCurves.map(function (curve) { return catmullRomToBezier(curve, options); }); + var path = new Path(bezierCurves).round(precision); + + return (raw) ? path : path.serialize(); + }; + curve.Directions = Directions; + curve.TangentDirections = TangentDirections; + + function getHorizontalSourceDirection(linkView, route, options) { + var sourceBBox = linkView.sourceBBox; + + var sourceSide; + var rotation; + if (!linkView.sourceView) { + if (sourceBBox.x > route[1].x) + { sourceSide = 'right'; } + else + { sourceSide = 'left'; } + } else { + rotation = linkView.sourceView.model.angle(); + if (options.rotate && rotation) { + var unrotatedBBox = linkView.sourceView.getNodeUnrotatedBBox(linkView.sourceView.el); + var sourcePoint = route[0].clone(); + sourcePoint.rotate(sourceBBox.center(), rotation); + sourceSide = unrotatedBBox.sideNearestToPoint(sourcePoint); + } else { + sourceSide = sourceBBox.sideNearestToPoint(route[0]); + } + } + + var direction; + switch (sourceSide) { + case 'left': + direction = new Point(-1, 0); + break; + case 'right': + default: + direction = new Point(1, 0); + break; + } + + if (options.rotate && rotation) { + direction.rotate(null, -rotation); + } + + return direction; + } + + function getHorizontalTargetDirection(linkView, route, options) { + var targetBBox = linkView.targetBBox; + + var targetSide; + var rotation; + if (!linkView.targetView) { + if (targetBBox.x > route[route.length - 2].x) + { targetSide = 'left'; } + else + { targetSide = 'right'; } + } else { + rotation = linkView.targetView.model.angle(); + if (options.rotate && rotation) { + var unrotatedBBox = linkView.targetView.getNodeUnrotatedBBox(linkView.targetView.el); + var targetPoint = route[route.length - 1].clone(); + targetPoint.rotate(targetBBox.center(), rotation); + targetSide = unrotatedBBox.sideNearestToPoint(targetPoint); + } else { + targetSide = targetBBox.sideNearestToPoint(route[route.length - 1]); + } + } + + var direction; + switch (targetSide) { + case 'left': + direction = new Point(-1, 0); + break; + case 'right': + default: + direction = new Point(1, 0); + break; + } + + if (options.rotate && rotation) { + direction.rotate(null, -rotation); + } + + return direction; + } + + function getVerticalSourceDirection(linkView, route, options) { + var sourceBBox = linkView.sourceBBox; + + var sourceSide; + var rotation; + if (!linkView.sourceView) { + if (sourceBBox.y > route[1].y) + { sourceSide = 'bottom'; } + else + { sourceSide = 'top'; } + } else { + rotation = linkView.sourceView.model.angle(); + if (options.rotate && rotation) { + var unrotatedBBox = linkView.sourceView.getNodeUnrotatedBBox(linkView.sourceView.el); + var sourcePoint = route[0].clone(); + sourcePoint.rotate(sourceBBox.center(), rotation); + sourceSide = unrotatedBBox.sideNearestToPoint(sourcePoint); + } else { + sourceSide = sourceBBox.sideNearestToPoint(route[0]); + } + } + + var direction; + switch (sourceSide) { + case 'top': + direction = new Point(0, -1); + break; + case 'bottom': + default: + direction = new Point(0, 1); + break; + } + + if (options.rotate && rotation) { + direction.rotate(null, -rotation); + } + + return direction; + } + + function getVerticalTargetDirection(linkView, route, options) { + var targetBBox = linkView.targetBBox; + + var targetSide; + var rotation; + if (!linkView.targetView) { + if (targetBBox.y > route[route.length - 2].y) + { targetSide = 'top'; } + else + { targetSide = 'bottom'; } + } else { + rotation = linkView.targetView.model.angle(); + if (options.rotate && rotation) { + var unrotatedBBox = linkView.targetView.getNodeUnrotatedBBox(linkView.targetView.el); + var targetPoint = route[route.length - 1].clone(); + targetPoint.rotate(targetBBox.center(), rotation); + targetSide = unrotatedBBox.sideNearestToPoint(targetPoint); + } else { + targetSide = targetBBox.sideNearestToPoint(route[route.length - 1]); + } + } + + + var direction; + switch (targetSide) { + case 'top': + direction = new Point(0, -1); + break; + case 'bottom': + default: + direction = new Point(0, 1); + break; + } + + if (options.rotate && rotation) { + direction.rotate(null, -rotation); + } + + return direction; + } + + function getAutoSourceDirection(linkView, route, options) { + var sourceBBox = linkView.sourceBBox; + + var sourceSide; + var rotation; + if (!linkView.sourceView) { + sourceSide = sourceBBox.sideNearestToPoint(route[1]); + } else { + rotation = linkView.sourceView.model.angle(); + if (options.rotate && rotation) { + var unrotatedBBox = linkView.sourceView.getNodeUnrotatedBBox(linkView.sourceView.el); + var sourcePoint = route[0].clone(); + sourcePoint.rotate(sourceBBox.center(), rotation); + sourceSide = unrotatedBBox.sideNearestToPoint(sourcePoint); + } else { + sourceSide = sourceBBox.sideNearestToPoint(route[0]); + } + } + + var direction; + switch (sourceSide) { + case 'top': + direction = new Point(0, -1); + break; + case 'bottom': + direction = new Point(0, 1); + break; + case 'right': + direction = new Point(1, 0); + break; + case 'left': + direction = new Point(-1, 0); + break; + } + + if (options.rotate && rotation) { + direction.rotate(null, -rotation); + } + + return direction; + } + + function getAutoTargetDirection(linkView, route, options) { + var targetBBox = linkView.targetBBox; + + var targetSide; + var rotation; + if (!linkView.targetView) { + targetSide = targetBBox.sideNearestToPoint(route[route.length - 2]); + } else { + rotation = linkView.targetView.model.angle(); + if (options.rotate && rotation) { + var unrotatedBBox = linkView.targetView.getNodeUnrotatedBBox(linkView.targetView.el); + var targetPoint = route[route.length - 1].clone(); + targetPoint.rotate(targetBBox.center(), rotation); + targetSide = unrotatedBBox.sideNearestToPoint(targetPoint); + } else { + targetSide = targetBBox.sideNearestToPoint(route[route.length - 1]); + } + } + + var direction; + switch (targetSide) { + case 'top': + direction = new Point(0, -1); + break; + case 'bottom': + direction = new Point(0, 1); + break; + case 'right': + direction = new Point(1, 0); + break; + case 'left': + direction = new Point(-1, 0); + break; + } + + if (options.rotate && rotation) { + direction.rotate(null, -rotation); + } + + return direction; + } + + function getClosestPointSourceDirection(linkView, route, options) { + return route[1].difference(route[0]).normalize(); + } + + function getClosestPointTargetDirection(linkView, route, options) { + var last = route.length - 1; + return route[last - 1].difference(route[last]).normalize(); + } + + function getOutwardsSourceDirection(linkView, route, options) { + var sourceBBox = linkView.sourceBBox; + var sourceCenter = sourceBBox.center(); + return route[0].difference(sourceCenter).normalize(); + } + + function getOutwardsTargetDirection(linkView, route, options) { + var targetBBox = linkView.targetBBox; + var targetCenter = targetBBox.center(); + return route[route.length - 1].difference(targetCenter).normalize(); + } + + function getSourceTangentDirection(linkView, route, direction, options) { + if (options.sourceDirection) { + switch (options.sourceDirection) { + case TangentDirections.UP: + return new Point(0, -1); + case TangentDirections.DOWN: + return new Point(0, 1); + case TangentDirections.LEFT: + return new Point(-1, 0); + case TangentDirections.RIGHT: + return new Point(1, 0); + case TangentDirections.AUTO: + return getAutoSourceDirection(linkView, route, options); + case TangentDirections.CLOSEST_POINT: + return getClosestPointSourceDirection(linkView, route, options); + case TangentDirections.OUTWARDS: + return getOutwardsSourceDirection(linkView, route, options); + default: + return options.sourceDirection; + } + } + + switch (direction) { + case Directions.HORIZONTAL: + return getHorizontalSourceDirection(linkView, route, options); + case Directions.VERTICAL: + return getVerticalSourceDirection(linkView, route, options); + case Directions.CLOSEST_POINT: + return getClosestPointSourceDirection(linkView, route, options); + case Directions.OUTWARDS: + return getOutwardsSourceDirection(linkView, route, options); + case Directions.AUTO: + default: + return getAutoSourceDirection(linkView, route, options); + } + } + + function getTargetTangentDirection(linkView, route, direction, options) { + if (options.targetDirection) { + switch (options.targetDirection) { + case TangentDirections.UP: + return new Point(0, -1); + case TangentDirections.DOWN: + return new Point(0, 1); + case TangentDirections.LEFT: + return new Point(-1, 0); + case TangentDirections.RIGHT: + return new Point(0, 1); + case TangentDirections.AUTO: + return getAutoTargetDirection(linkView, route, options); + case TangentDirections.CLOSEST_POINT: + return getClosestPointTargetDirection(linkView, route, options); + case TangentDirections.OUTWARDS: + return getOutwardsTargetDirection(linkView, route, options); + default: + return options.targetDirection; + } + } + + switch (direction) { + case Directions.HORIZONTAL: + return getHorizontalTargetDirection(linkView, route, options); + case Directions.VERTICAL: + return getVerticalTargetDirection(linkView, route, options); + case Directions.CLOSEST_POINT: + return getClosestPointTargetDirection(linkView, route, options); + case Directions.OUTWARDS: + return getOutwardsTargetDirection(linkView, route, options); + case Directions.AUTO: + default: + return getAutoTargetDirection(linkView, route, options); + } + } + + function rotateVector(vector, angle) { + var cos = Math.cos(angle); + var sin = Math.sin(angle); + var x = cos * vector.x - sin * vector.y; + var y = sin * vector.x + cos * vector.y; + vector.x = x; + vector.y = y; + } + + function angleBetweenVectors(v1, v2) { + var cos = v1.dot(v2) / (v1.magnitude() * v2.magnitude()); + if (cos < -1) { cos = -1; } + if (cos > 1) { cos = 1; } + return Math.acos(cos); + } + + function determinant(v1, v2) { + return v1.x * v2.y - v1.y * v2.x; + } + + function createCatmullRomCurves(points, sourceTangent, targetTangent, options) { + var tau = options.tau; + var coeff = options.coeff; + var distances = []; + var tangents = []; + var catmullRomCurves = []; + var n = points.length - 1; + + for (var i = 0; i < n; i++) { + distances[i] = points[i].distance(points[i + 1]); + } + + tangents[0] = sourceTangent; + tangents[n] = targetTangent; + + // The calculation of tangents of vertices + for (var i$1 = 1; i$1 < n; i$1++) { + var tpPrev = (void 0); + var tpNext = (void 0); + if (i$1 === 1) { + tpPrev = points[i$1 - 1].clone().offset(tangents[i$1 - 1].x, tangents[i$1 - 1].y); + } else { + tpPrev = points[i$1 - 1].clone(); + } + if (i$1 === n - 1) { + tpNext = points[i$1 + 1].clone().offset(tangents[i$1 + 1].x, tangents[i$1 + 1].y); + } else { + tpNext = points[i$1 + 1].clone(); + } + var v1 = tpPrev.difference(points[i$1]).normalize(); + var v2 = tpNext.difference(points[i$1]).normalize(); + var vAngle = angleBetweenVectors(v1, v2); + + var rot = (Math.PI - vAngle) / 2; + var t = (void 0); + var vectorDeterminant = determinant(v1, v2); + var pointsDeterminant = (void 0); + pointsDeterminant = determinant(points[i$1].difference(points[i$1 + 1]), points[i$1].difference(points[i$1 - 1])); + if (vectorDeterminant < 0) { + rot = -rot; + } + if ((vAngle < Math.PI / 2) && ((rot < 0 && pointsDeterminant < 0) || (rot > 0 && pointsDeterminant > 0))) { + rot = rot - Math.PI; + } + t = v2.clone(); + rotateVector(t, rot); + + var t1 = t.clone(); + var t2 = t.clone(); + var scaleFactor1 = distances[i$1 - 1] * coeff; + var scaleFactor2 = distances[i$1] * coeff; + t1.scale(scaleFactor1, scaleFactor1); + t2.scale(scaleFactor2, scaleFactor2); + + tangents[i$1] = [t1, t2]; + } + + // The building of a Catmull-Rom curve based of tangents of points + for (var i$2 = 0; i$2 < n; i$2++) { + var p0 = (void 0); + var p3 = (void 0); + if (i$2 === 0) { + p0 = points[i$2 + 1].difference(tangents[i$2].x / tau, tangents[i$2].y / tau); + } else { + p0 = points[i$2 + 1].difference(tangents[i$2][1].x / tau, tangents[i$2][1].y / tau); + } + if (i$2 === n - 1) { + p3 = points[i$2].clone().offset(tangents[i$2 + 1].x / tau, tangents[i$2 + 1].y / tau); + } else { + p3 = points[i$2].difference(tangents[i$2 + 1][0].x / tau, tangents[i$2 + 1][0].y / tau); + } + + catmullRomCurves[i$2] = [p0, points[i$2], points[i$2 + 1], p3]; + } + return catmullRomCurves; + } + + // The function to convert Catmull-Rom curve to Bezier curve using the tension (tau) + function catmullRomToBezier(points, options) { + var tau = options.tau; + + var bcp1 = new Point(); + bcp1.x = points[1].x + (points[2].x - points[0].x) / (6 * tau); + bcp1.y = points[1].y + (points[2].y - points[0].y) / (6 * tau); + + var bcp2 = new Point(); + bcp2.x = points[2].x + (points[3].x - points[1].x) / (6 * tau); + bcp2.y = points[2].y + (points[3].y - points[1].y) / (6 * tau); + return new Curve( + points[1], + bcp1, + bcp2, + points[2] + ); + } + + + + var connectors = ({ + jumpover: jumpover, + normal: normal$1, + rounded: rounded, + smooth: smooth, + curve: curve + }); + + var Flags$1 = { + RENDER: 'RENDER', + UPDATE: 'UPDATE', + TOOLS: 'TOOLS', + LEGACY_TOOLS: 'LEGACY_TOOLS', + LABELS: 'LABELS', + VERTICES: 'VERTICES', + SOURCE: 'SOURCE', + TARGET: 'TARGET', + CONNECTOR: 'CONNECTOR' + }; + + // Link base view and controller. + // ---------------------------------------- + + var LinkView = CellView.extend({ + + className: function() { + + var classNames = CellView.prototype.className.apply(this).split(' '); + + classNames.push('link'); + + return classNames.join(' '); + }, + + options: { + + shortLinkLength: 105, + doubleLinkTools: false, + longLinkLength: 155, + linkToolsOffset: 40, + doubleLinkToolsOffset: 65, + sampleInterval: 50 + }, + + _labelCache: null, + _labelSelectors: null, + _markerCache: null, + _V: null, + _dragData: null, // deprecated + + metrics: null, + decimalsRounding: 2, + + initialize: function() { + + CellView.prototype.initialize.apply(this, arguments); + + // `_.labelCache` is a mapping of indexes of labels in the `this.get('labels')` array to + // `` nodes wrapped by Vectorizer. This allows for quick access to the + // nodes in `updateLabelPosition()` in order to update the label positions. + this._labelCache = {}; + + // a cache of label selectors + this._labelSelectors = {}; + + // keeps markers bboxes and positions again for quicker access + this._markerCache = {}; + + // cache of default markup nodes + this._V = {}; + + // connection path metrics + this.cleanNodesCache(); + }, + + presentationAttributes: { + markup: [Flags$1.RENDER], + attrs: [Flags$1.UPDATE], + router: [Flags$1.UPDATE], + connector: [Flags$1.CONNECTOR], + smooth: [Flags$1.UPDATE], + manhattan: [Flags$1.UPDATE], + toolMarkup: [Flags$1.LEGACY_TOOLS], + labels: [Flags$1.LABELS], + labelMarkup: [Flags$1.LABELS], + vertices: [Flags$1.VERTICES, Flags$1.UPDATE], + vertexMarkup: [Flags$1.VERTICES], + source: [Flags$1.SOURCE, Flags$1.UPDATE], + target: [Flags$1.TARGET, Flags$1.UPDATE] + }, + + initFlag: [Flags$1.RENDER, Flags$1.SOURCE, Flags$1.TARGET, Flags$1.TOOLS], + + UPDATE_PRIORITY: 1, + + confirmUpdate: function(flags, opt) { + + opt || (opt = {}); + + if (this.hasFlag(flags, Flags$1.SOURCE)) { + if (!this.updateEndProperties('source')) { return flags; } + flags = this.removeFlag(flags, Flags$1.SOURCE); + } + + if (this.hasFlag(flags, Flags$1.TARGET)) { + if (!this.updateEndProperties('target')) { return flags; } + flags = this.removeFlag(flags, Flags$1.TARGET); + } + + var ref = this; + var paper = ref.paper; + var sourceView = ref.sourceView; + var targetView = ref.targetView; + if (paper && ((sourceView && !paper.isViewMounted(sourceView)) || (targetView && !paper.isViewMounted(targetView)))) { + // Wait for the sourceView and targetView to be rendered + return flags; + } + + if (this.hasFlag(flags, Flags$1.RENDER)) { + this.render(); + this.updateHighlighters(true); + this.updateTools(opt); + flags = this.removeFlag(flags, [Flags$1.RENDER, Flags$1.UPDATE, Flags$1.VERTICES, Flags$1.LABELS, Flags$1.TOOLS, Flags$1.LEGACY_TOOLS, Flags$1.CONNECTOR]); + return flags; + } + + var updateHighlighters = false; + + if (this.hasFlag(flags, Flags$1.VERTICES)) { + this.renderVertexMarkers(); + flags = this.removeFlag(flags, Flags$1.VERTICES); + } + + var ref$1 = this; + var model = ref$1.model; + var attributes = model.attributes; + var updateLabels = this.hasFlag(flags, Flags$1.LABELS); + var updateLegacyTools = this.hasFlag(flags, Flags$1.LEGACY_TOOLS); + + if (updateLabels) { + this.onLabelsChange(model, attributes.labels, opt); + flags = this.removeFlag(flags, Flags$1.LABELS); + updateHighlighters = true; + } + + if (updateLegacyTools) { + this.renderTools(); + flags = this.removeFlag(flags, Flags$1.LEGACY_TOOLS); + } + + var updateAll = this.hasFlag(flags, Flags$1.UPDATE); + var updateConnector = this.hasFlag(flags, Flags$1.CONNECTOR); + if (updateAll || updateConnector) { + if (!updateAll) { + // Keep the current route and update the geometry + this.updatePath(); + this.updateDOM(); + } else if (opt.translateBy && model.isRelationshipEmbeddedIn(opt.translateBy)) { + // The link is being translated by an ancestor that will + // shift source point, target point and all vertices + // by an equal distance. + this.translate(opt.tx, opt.ty); + } else { + this.update(); + } + this.updateTools(opt); + flags = this.removeFlag(flags, [Flags$1.UPDATE, Flags$1.TOOLS, Flags$1.CONNECTOR]); + updateLabels = false; + updateLegacyTools = false; + updateHighlighters = true; + } + + if (updateLabels) { + this.updateLabelPositions(); + } + + if (updateLegacyTools) { + this.updateToolsPosition(); + } + + if (updateHighlighters) { + this.updateHighlighters(); + } + + if (this.hasFlag(flags, Flags$1.TOOLS)) { + this.updateTools(opt); + flags = this.removeFlag(flags, Flags$1.TOOLS); + } + + return flags; + }, + + requestConnectionUpdate: function(opt) { + this.requestUpdate(this.getFlag(Flags$1.UPDATE), opt); + }, + + isLabelsRenderRequired: function(opt) { + if ( opt === void 0 ) opt = {}; + + + var previousLabels = this.model.previous('labels'); + if (!previousLabels) { return true; } + + // Here is an optimization for cases when we know, that change does + // not require re-rendering of all labels. + if (('propertyPathArray' in opt) && ('propertyValue' in opt)) { + // The label is setting by `prop()` method + var pathArray = opt.propertyPathArray || []; + var pathLength = pathArray.length; + if (pathLength > 1) { + // We are changing a single label here e.g. 'labels/0/position' + var labelExists = !!previousLabels[pathArray[1]]; + if (labelExists) { + if (pathLength === 2) { + // We are changing the entire label. Need to check if the + // markup is also being changed. + return ('markup' in Object(opt.propertyValue)); + } else if (pathArray[2] !== 'markup') { + // We are changing a label property but not the markup + return false; + } + } + } + } + + return true; + }, + + onLabelsChange: function(_link, _labels, opt) { + + // Note: this optimization works in async=false mode only + if (this.isLabelsRenderRequired(opt)) { + this.renderLabels(); + } else { + this.updateLabels(); + } + }, + + // Rendering. + // ---------- + + render: function() { + + this.vel.empty(); + this.unmountLabels(); + this._V = {}; + this.renderMarkup(); + // rendering labels has to be run after the link is appended to DOM tree. (otherwise bbox + // returns zero values) + this.renderLabels(); + this.update(); + + return this; + }, + + renderMarkup: function() { + + var link = this.model; + var markup = link.get('markup') || link.markup; + if (!markup) { throw new Error('dia.LinkView: markup required'); } + if (Array.isArray(markup)) { return this.renderJSONMarkup(markup); } + if (typeof markup === 'string') { return this.renderStringMarkup(markup); } + throw new Error('dia.LinkView: invalid markup'); + }, + + renderJSONMarkup: function(markup) { + + var doc = this.parseDOMJSON(markup, this.el); + // Selectors + this.selectors = doc.selectors; + // Fragment + this.vel.append(doc.fragment); + }, + + renderStringMarkup: function(markup) { + + // A special markup can be given in the `properties.markup` property. This might be handy + // if e.g. arrowhead markers should be `` elements or any other element than ``s. + // `.connection`, `.connection-wrap`, `.marker-source` and `.marker-target` selectors + // of elements with special meaning though. Therefore, those classes should be preserved in any + // special markup passed in `properties.markup`. + var children = V(markup); + // custom markup may contain only one children + if (!Array.isArray(children)) { children = [children]; } + // Cache all children elements for quicker access. + var cache = this._V; // vectorized markup; + for (var i = 0, n = children.length; i < n; i++) { + var child = children[i]; + var className = child.attr('class'); + if (className) { + // Strip the joint class name prefix, if there is one. + className = removeClassNamePrefix(className); + cache[$.camelCase(className)] = child; + } + } + // partial rendering + this.renderTools(); + this.renderVertexMarkers(); + this.renderArrowheadMarkers(); + this.vel.append(children); + }, + + _getLabelMarkup: function(labelMarkup) { + + if (!labelMarkup) { return undefined; } + + if (Array.isArray(labelMarkup)) { return this.parseDOMJSON(labelMarkup, null); } + if (typeof labelMarkup === 'string') { return this._getLabelStringMarkup(labelMarkup); } + throw new Error('dia.linkView: invalid label markup'); + }, + + _getLabelStringMarkup: function(labelMarkup) { + + var children = V(labelMarkup); + var fragment = document.createDocumentFragment(); + + if (!Array.isArray(children)) { + fragment.appendChild(children.node); + + } else { + for (var i = 0, n = children.length; i < n; i++) { + var currentChild = children[i].node; + fragment.appendChild(currentChild); + } + } + + return { fragment: fragment, selectors: {}}; // no selectors + }, + + // Label markup fragment may come wrapped in , or not. + // If it doesn't, add the container here. + _normalizeLabelMarkup: function(markup) { + + if (!markup) { return undefined; } + + var fragment = markup.fragment; + if (!(markup.fragment instanceof DocumentFragment) || !markup.fragment.hasChildNodes()) { throw new Error('dia.LinkView: invalid label markup.'); } + + var vNode; + var childNodes = fragment.childNodes; + + if ((childNodes.length > 1) || childNodes[0].nodeName.toUpperCase() !== 'G') { + // default markup fragment is not wrapped in + // add a container + vNode = V('g').append(fragment); + } else { + vNode = V(childNodes[0]); + } + + vNode.addClass('label'); + + return { node: vNode.node, selectors: markup.selectors }; + }, + + renderLabels: function() { + + var cache = this._V; + var vLabels = cache.labels; + var labelCache = this._labelCache = {}; + var labelSelectors = this._labelSelectors = {}; + var model = this.model; + var labels = model.attributes.labels || []; + var labelsCount = labels.length; + + if (labelsCount === 0) { + if (vLabels) { vLabels.remove(); } + return this; + } + + if (vLabels) { + vLabels.empty(); + } else { + // there is no label container in the markup but some labels are defined + // add a container + vLabels = cache.labels = V('g').addClass('labels'); + if (this.options.labelsLayer) { + vLabels.addClass(addClassNamePrefix(result(this, 'className'))); + vLabels.attr('model-id', model.id); + } + } + + for (var i = 0; i < labelsCount; i++) { + + var label = labels[i]; + var labelMarkup = this._normalizeLabelMarkup(this._getLabelMarkup(label.markup)); + var labelNode; + var selectors; + if (labelMarkup) { + + labelNode = labelMarkup.node; + selectors = labelMarkup.selectors; + + } else { + + var builtinDefaultLabel = model._builtins.defaultLabel; + var builtinDefaultLabelMarkup = this._normalizeLabelMarkup(this._getLabelMarkup(builtinDefaultLabel.markup)); + var defaultLabel = model._getDefaultLabel(); + var defaultLabelMarkup = this._normalizeLabelMarkup(this._getLabelMarkup(defaultLabel.markup)); + var defaultMarkup = defaultLabelMarkup || builtinDefaultLabelMarkup; + + labelNode = defaultMarkup.node; + selectors = defaultMarkup.selectors; + } + + labelNode.setAttribute('label-idx', i); // assign label-idx + vLabels.append(labelNode); + labelCache[i] = labelNode; // cache node for `updateLabels()` so it can just update label node positions + + var rootSelector = this.selector; + if (selectors[rootSelector]) { throw new Error('dia.LinkView: ambiguous label root selector.'); } + selectors[rootSelector] = labelNode; + + labelSelectors[i] = selectors; // cache label selectors for `updateLabels()` + } + if (!vLabels.parent()) { + this.mountLabels(); + } + + this.updateLabels(); + + return this; + }, + + mountLabels: function() { + var ref = this; + var el = ref.el; + var paper = ref.paper; + var model = ref.model; + var _V = ref._V; + var options = ref.options; + var vLabels = _V.labels; + if (!vLabels || !model.hasLabels()) { return; } + var node = vLabels.node; + if (options.labelsLayer) { + paper.getLayerView(options.labelsLayer).insertSortedNode(node, model.get('z')); + } else { + if (node.parentNode !== el) { + el.appendChild(node); + } + } + }, + + unmountLabels: function() { + var ref = this; + var options = ref.options; + var _V = ref._V; + if (!_V) { return; } + var vLabels = _V.labels; + if (vLabels && options.labelsLayer) { + vLabels.remove(); + } + }, + + onMount: function() { + this.mountLabels(); + }, + + unmount: function() { + CellView.prototype.unmount.apply(this, arguments); + this.unmountLabels(); + }, + + findLabelNode: function(labelIndex, selector) { + var labelRoot = this._labelCache[labelIndex]; + if (!labelRoot) { return null; } + var labelSelectors = this._labelSelectors[labelIndex]; + var ref = this.findBySelector(selector, labelRoot, labelSelectors); + var node = ref[0]; if ( node === void 0 ) node = null; + return node; + }, + + + // merge default label attrs into label attrs + // keep `undefined` or `null` because `{}` means something else + _mergeLabelAttrs: function(hasCustomMarkup, labelAttrs, defaultLabelAttrs, builtinDefaultLabelAttrs) { + + if (labelAttrs === null) { return null; } + if (labelAttrs === undefined) { + + if (defaultLabelAttrs === null) { return null; } + if (defaultLabelAttrs === undefined) { + + if (hasCustomMarkup) { return undefined; } + return builtinDefaultLabelAttrs; + } + + if (hasCustomMarkup) { return defaultLabelAttrs; } + return merge({}, builtinDefaultLabelAttrs, defaultLabelAttrs); + } + + if (hasCustomMarkup) { return merge({}, defaultLabelAttrs, labelAttrs); } + return merge({}, builtinDefaultLabelAttrs, defaultLabelAttrs, labelAttrs); + }, + + updateLabels: function() { + + if (!this._V.labels) { return this; } + + var model = this.model; + var labels = model.get('labels') || []; + var canLabelMove = this.can('labelMove'); + + var builtinDefaultLabel = model._builtins.defaultLabel; + var builtinDefaultLabelAttrs = builtinDefaultLabel.attrs; + + var defaultLabel = model._getDefaultLabel(); + var defaultLabelMarkup = defaultLabel.markup; + var defaultLabelAttrs = defaultLabel.attrs; + + for (var i = 0, n = labels.length; i < n; i++) { + + var labelNode = this._labelCache[i]; + labelNode.setAttribute('cursor', (canLabelMove ? 'move' : 'default')); + + var selectors = this._labelSelectors[i]; + + var label = labels[i]; + var labelMarkup = label.markup; + var labelAttrs = label.attrs; + + var attrs = this._mergeLabelAttrs( + (labelMarkup || defaultLabelMarkup), + labelAttrs, + defaultLabelAttrs, + builtinDefaultLabelAttrs + ); + + this.updateDOMSubtreeAttributes(labelNode, attrs, { + rootBBox: new Rect(label.size), + selectors: selectors + }); + } + + return this; + }, + + renderTools: function() { + + if (!this._V.linkTools) { return this; } + + // Tools are a group of clickable elements that manipulate the whole link. + // A good example of this is the remove tool that removes the whole link. + // Tools appear after hovering the link close to the `source` element/point of the link + // but are offset a bit so that they don't cover the `marker-arrowhead`. + + var $tools = $(this._V.linkTools.node).empty(); + var toolTemplate = template(this.model.get('toolMarkup') || this.model.toolMarkup); + var tool = V(toolTemplate()); + + $tools.append(tool.node); + + // Cache the tool node so that the `updateToolsPosition()` can update the tool position quickly. + this._toolCache = tool; + + // If `doubleLinkTools` is enabled, we render copy of the tools on the other side of the + // link as well but only if the link is longer than `longLinkLength`. + if (this.options.doubleLinkTools) { + + var tool2; + if (this.model.get('doubleToolMarkup') || this.model.doubleToolMarkup) { + toolTemplate = template(this.model.get('doubleToolMarkup') || this.model.doubleToolMarkup); + tool2 = V(toolTemplate()); + } else { + tool2 = tool.clone(); + } + + $tools.append(tool2.node); + this._tool2Cache = tool2; + } + + return this; + }, + + renderVertexMarkers: function() { + + if (!this._V.markerVertices) { return this; } + + var $markerVertices = $(this._V.markerVertices.node).empty(); + + // A special markup can be given in the `properties.vertexMarkup` property. This might be handy + // if default styling (elements) are not desired. This makes it possible to use any + // SVG elements for .marker-vertex and .marker-vertex-remove tools. + var markupTemplate = template(this.model.get('vertexMarkup') || this.model.vertexMarkup); + + this.model.vertices().forEach(function(vertex, idx) { + $markerVertices.append(V(markupTemplate(assign({ idx: idx }, vertex))).node); + }); + + return this; + }, + + renderArrowheadMarkers: function() { + + // Custom markups might not have arrowhead markers. Therefore, jump of this function immediately if that's the case. + if (!this._V.markerArrowheads) { return this; } + + var $markerArrowheads = $(this._V.markerArrowheads.node); + + $markerArrowheads.empty(); + + // A special markup can be given in the `properties.vertexMarkup` property. This might be handy + // if default styling (elements) are not desired. This makes it possible to use any + // SVG elements for .marker-vertex and .marker-vertex-remove tools. + var markupTemplate = template(this.model.get('arrowheadMarkup') || this.model.arrowheadMarkup); + + this._V.sourceArrowhead = V(markupTemplate({ end: 'source' })); + this._V.targetArrowhead = V(markupTemplate({ end: 'target' })); + + $markerArrowheads.append(this._V.sourceArrowhead.node, this._V.targetArrowhead.node); + + return this; + }, + + // remove vertices that lie on (or nearly on) straight lines within the link + // return the number of removed points + removeRedundantLinearVertices: function(opt) { + + var SIMPLIFY_THRESHOLD = 0.001; + + var link = this.model; + var vertices = link.vertices(); + var routePoints = [this.sourceAnchor ].concat( vertices, [this.targetAnchor]); + var numRoutePoints = routePoints.length; + + // put routePoints into a polyline and try to simplify + var polyline = new Polyline(routePoints); + polyline.simplify({ threshold: SIMPLIFY_THRESHOLD }); + var polylinePoints = polyline.points.map(function (point) { return (point.toJSON()); }); // JSON of points after simplification + var numPolylinePoints = polylinePoints.length; // number of points after simplification + + // shortcut if simplification did not remove any redundant vertices: + if (numRoutePoints === numPolylinePoints) { return 0; } + + // else: set simplified polyline points as link vertices + // remove first and last polyline points again (= source/target anchors) + link.vertices(polylinePoints.slice(1, numPolylinePoints - 1), opt); + return (numRoutePoints - numPolylinePoints); + }, + + updateDefaultConnectionPath: function() { + + var cache = this._V; + + if (cache.connection) { + cache.connection.attr('d', this.getSerializedConnection()); + } + + if (cache.connectionWrap) { + cache.connectionWrap.attr('d', this.getSerializedConnection()); + } + + if (cache.markerSource && cache.markerTarget) { + this._translateAndAutoOrientArrows(cache.markerSource, cache.markerTarget); + } + }, + + getEndView: function(type) { + switch (type) { + case 'source': + return this.sourceView || null; + case 'target': + return this.targetView || null; + default: + throw new Error('dia.LinkView: type parameter required.'); + } + }, + + getEndAnchor: function(type) { + switch (type) { + case 'source': + return new Point(this.sourceAnchor); + case 'target': + return new Point(this.targetAnchor); + default: + throw new Error('dia.LinkView: type parameter required.'); + } + }, + + getEndConnectionPoint: function(type) { + switch (type) { + case 'source': + return new Point(this.sourcePoint); + case 'target': + return new Point(this.targetPoint); + default: + throw new Error('dia.LinkView: type parameter required.'); + } + }, + + getEndMagnet: function(type) { + switch (type) { + case 'source': + var sourceView = this.sourceView; + if (!sourceView) { break; } + return this.sourceMagnet || sourceView.el; + case 'target': + var targetView = this.targetView; + if (!targetView) { break; } + return this.targetMagnet || targetView.el; + default: + throw new Error('dia.LinkView: type parameter required.'); + } + return null; + }, + + + // Updating. + // --------- + + update: function() { + this.updateRoute(); + this.updatePath(); + this.updateDOM(); + return this; + }, + + translate: function(tx, ty) { + if ( tx === void 0 ) tx = 0; + if ( ty === void 0 ) ty = 0; + + var ref = this; + var route = ref.route; + var path = ref.path; + if (!route || !path) { return; } + // translate the route + var polyline = new Polyline(route); + polyline.translate(tx, ty); + this.route = polyline.points; + // translate source and target connection and marker points. + this._translateConnectionPoints(tx, ty); + // translate the geometry path + path.translate(tx, ty); + this.updateDOM(); + }, + + updateDOM: function updateDOM() { + var ref = this; + var el = ref.el; + var model = ref.model; + var selectors = ref.selectors; + this.cleanNodesCache(); + // update SVG attributes defined by 'attrs/'. + this.updateDOMSubtreeAttributes(el, model.attr(), { selectors: selectors }); + // legacy link path update + this.updateDefaultConnectionPath(); + // update the label position etc. + this.updateLabelPositions(); + this.updateToolsPosition(); + this.updateArrowheadMarkers(); + // *Deprecated* + // Local perpendicular flag (as opposed to one defined on paper). + // Could be enabled inside a connector/router. It's valid only + // during the update execution. + this.options.perpendicular = null; + }, + + updateRoute: function() { + var ref = this; + var model = ref.model; + var vertices = model.vertices(); + // 1. Find Anchors + var anchors = this.findAnchors(vertices); + var sourceAnchor = this.sourceAnchor = anchors.source; + var targetAnchor = this.targetAnchor = anchors.target; + // 2. Find Route + var route = this.findRoute(vertices); + this.route = route; + // 3. Find Connection Points + var connectionPoints = this.findConnectionPoints(route, sourceAnchor, targetAnchor); + this.sourcePoint = connectionPoints.source; + this.targetPoint = connectionPoints.target; + }, + + updatePath: function() { + var ref = this; + var route = ref.route; + var sourcePoint = ref.sourcePoint; + var targetPoint = ref.targetPoint; + // 3b. Find Marker Connection Point - Backwards Compatibility + var markerPoints = this.findMarkerPoints(route, sourcePoint, targetPoint); + // 4. Find Connection + var path = this.findPath(route, markerPoints.source || sourcePoint, markerPoints.target || targetPoint); + this.path = path; + }, + + findMarkerPoints: function(route, sourcePoint, targetPoint) { + + var firstWaypoint = route[0]; + var lastWaypoint = route[route.length - 1]; + + // Move the source point by the width of the marker taking into account + // its scale around x-axis. Note that scale is the only transform that + // makes sense to be set in `.marker-source` attributes object + // as all other transforms (translate/rotate) will be replaced + // by the `translateAndAutoOrient()` function. + var cache = this._markerCache; + // cache source and target points + var sourceMarkerPoint, targetMarkerPoint; + + if (this._V.markerSource) { + + cache.sourceBBox = cache.sourceBBox || this._V.markerSource.getBBox(); + sourceMarkerPoint = Point(sourcePoint).move( + firstWaypoint || targetPoint, + cache.sourceBBox.width * this._V.markerSource.scale().sx * -1 + ).round(); + } + + if (this._V.markerTarget) { + + cache.targetBBox = cache.targetBBox || this._V.markerTarget.getBBox(); + targetMarkerPoint = Point(targetPoint).move( + lastWaypoint || sourcePoint, + cache.targetBBox.width * this._V.markerTarget.scale().sx * -1 + ).round(); + } + + // if there was no markup for the marker, use the connection point. + cache.sourcePoint = sourceMarkerPoint || sourcePoint.clone(); + cache.targetPoint = targetMarkerPoint || targetPoint.clone(); + + return { + source: sourceMarkerPoint, + target: targetMarkerPoint + }; + }, + + findAnchorsOrdered: function(firstEndType, firstRef, secondEndType, secondRef) { + + var firstAnchor, secondAnchor; + var firstAnchorRef, secondAnchorRef; + var model = this.model; + var firstDef = model.get(firstEndType); + var secondDef = model.get(secondEndType); + var firstView = this.getEndView(firstEndType); + var secondView = this.getEndView(secondEndType); + var firstMagnet = this.getEndMagnet(firstEndType); + var secondMagnet = this.getEndMagnet(secondEndType); + + // Anchor first + if (firstView) { + if (firstRef) { + firstAnchorRef = new Point(firstRef); + } else if (secondView) { + firstAnchorRef = secondMagnet; + } else { + firstAnchorRef = new Point(secondDef); + } + firstAnchor = this.getAnchor(firstDef.anchor, firstView, firstMagnet, firstAnchorRef, firstEndType); + } else { + firstAnchor = new Point(firstDef); + } + + // Anchor second + if (secondView) { + secondAnchorRef = new Point(secondRef || firstAnchor); + secondAnchor = this.getAnchor(secondDef.anchor, secondView, secondMagnet, secondAnchorRef, secondEndType); + } else { + secondAnchor = new Point(secondDef); + } + + var res = {}; + res[firstEndType] = firstAnchor; + res[secondEndType] = secondAnchor; + return res; + }, + + findAnchors: function(vertices) { + + var model = this.model; + var firstVertex = vertices[0]; + var lastVertex = vertices[vertices.length - 1]; + + if (model.target().priority && !model.source().priority) { + // Reversed order + return this.findAnchorsOrdered('target', lastVertex, 'source', firstVertex); + } + + // Usual order + return this.findAnchorsOrdered('source', firstVertex, 'target', lastVertex); + }, + + findConnectionPoints: function(route, sourceAnchor, targetAnchor) { + + var firstWaypoint = route[0]; + var lastWaypoint = route[route.length - 1]; + var model = this.model; + var sourceDef = model.get('source'); + var targetDef = model.get('target'); + var sourceView = this.sourceView; + var targetView = this.targetView; + var paperOptions = this.paper.options; + var sourceMagnet, targetMagnet; + + // Connection Point Source + var sourcePoint; + if (sourceView && !sourceView.isNodeConnection(this.sourceMagnet)) { + sourceMagnet = (this.sourceMagnet || sourceView.el); + var sourceConnectionPointDef = sourceDef.connectionPoint || paperOptions.defaultConnectionPoint; + var sourcePointRef = firstWaypoint || targetAnchor; + var sourceLine = new Line(sourcePointRef, sourceAnchor); + sourcePoint = this.getConnectionPoint( + sourceConnectionPointDef, + sourceView, + sourceMagnet, + sourceLine, + 'source' + ); + } else { + sourcePoint = sourceAnchor; + } + // Connection Point Target + var targetPoint; + if (targetView && !targetView.isNodeConnection(this.targetMagnet)) { + targetMagnet = (this.targetMagnet || targetView.el); + var targetConnectionPointDef = targetDef.connectionPoint || paperOptions.defaultConnectionPoint; + var targetPointRef = lastWaypoint || sourceAnchor; + var targetLine = new Line(targetPointRef, targetAnchor); + targetPoint = this.getConnectionPoint( + targetConnectionPointDef, + targetView, + targetMagnet, + targetLine, + 'target' + ); + } else { + targetPoint = targetAnchor; + } + + return { + source: sourcePoint, + target: targetPoint + }; + }, + + getAnchor: function(anchorDef, cellView, magnet, ref, endType) { + + var isConnection = cellView.isNodeConnection(magnet); + var paperOptions = this.paper.options; + if (!anchorDef) { + if (isConnection) { + anchorDef = paperOptions.defaultLinkAnchor; + } else { + if (paperOptions.perpendicularLinks || this.options.perpendicular) { + // Backwards compatibility + // If `perpendicularLinks` flag is set on the paper and there are vertices + // on the link, then try to find a connection point that makes the link perpendicular + // even though the link won't point to the center of the targeted object. + anchorDef = { name: 'perpendicular' }; + } else { + anchorDef = paperOptions.defaultAnchor; + } + } + } + + if (!anchorDef) { throw new Error('Anchor required.'); } + var anchorFn; + if (typeof anchorDef === 'function') { + anchorFn = anchorDef; + } else { + var anchorName = anchorDef.name; + var anchorNamespace = isConnection ? 'linkAnchorNamespace' : 'anchorNamespace'; + anchorFn = paperOptions[anchorNamespace][anchorName]; + if (typeof anchorFn !== 'function') { throw new Error('Unknown anchor: ' + anchorName); } + } + var anchor = anchorFn.call( + this, + cellView, + magnet, + ref, + anchorDef.args || {}, + endType, + this + ); + if (!anchor) { return new Point(); } + return anchor.round(this.decimalsRounding); + }, + + + getConnectionPoint: function(connectionPointDef, view, magnet, line, endType) { + + var connectionPoint; + var anchor = line.end; + var paperOptions = this.paper.options; + + // Backwards compatibility + if (typeof paperOptions.linkConnectionPoint === 'function') { + var linkConnectionMagnet = (magnet === view.el) ? undefined : magnet; + connectionPoint = paperOptions.linkConnectionPoint(this, view, linkConnectionMagnet, line.start, endType); + if (connectionPoint) { return connectionPoint; } + } + + if (!connectionPointDef) { return anchor; } + var connectionPointFn; + if (typeof connectionPointDef === 'function') { + connectionPointFn = connectionPointDef; + } else { + var connectionPointName = connectionPointDef.name; + connectionPointFn = paperOptions.connectionPointNamespace[connectionPointName]; + if (typeof connectionPointFn !== 'function') { throw new Error('Unknown connection point: ' + connectionPointName); } + } + connectionPoint = connectionPointFn.call(this, line, view, magnet, connectionPointDef.args || {}, endType, this); + if (!connectionPoint) { return anchor; } + return connectionPoint.round(this.decimalsRounding); + }, + + _translateConnectionPoints: function(tx, ty) { + + var cache = this._markerCache; + + cache.sourcePoint.offset(tx, ty); + cache.targetPoint.offset(tx, ty); + this.sourcePoint.offset(tx, ty); + this.targetPoint.offset(tx, ty); + this.sourceAnchor.offset(tx, ty); + this.targetAnchor.offset(tx, ty); + }, + + // if label position is a number, normalize it to a position object + // this makes sure that label positions can be merged properly + _normalizeLabelPosition: function(labelPosition) { + + if (typeof labelPosition === 'number') { return { distance: labelPosition, offset: null, angle: 0, args: null }; } + return labelPosition; + }, + + updateLabelPositions: function() { + + if (!this._V.labels) { return this; } + + var path = this.path; + if (!path) { return this; } + + // This method assumes all the label nodes are stored in the `this._labelCache` hash table + // by their indices in the `this.get('labels')` array. This is done in the `renderLabels()` method. + + var model = this.model; + var labels = model.get('labels') || []; + if (!labels.length) { return this; } + + var builtinDefaultLabel = model._builtins.defaultLabel; + var builtinDefaultLabelPosition = builtinDefaultLabel.position; + + var defaultLabel = model._getDefaultLabel(); + var defaultLabelPosition = this._normalizeLabelPosition(defaultLabel.position); + + var defaultPosition = merge({}, builtinDefaultLabelPosition, defaultLabelPosition); + + for (var idx = 0, n = labels.length; idx < n; idx++) { + var labelNode = this._labelCache[idx]; + if (!labelNode) { continue; } + var label = labels[idx]; + var labelPosition = this._normalizeLabelPosition(label.position); + var position = merge({}, defaultPosition, labelPosition); + var transformationMatrix = this._getLabelTransformationMatrix(position); + labelNode.setAttribute('transform', V.matrixToTransformString(transformationMatrix)); + this._cleanLabelMatrices(idx); + } + + return this; + }, + + _cleanLabelMatrices: function(index) { + // Clean magnetMatrix for all nodes of the label. + // Cached BoundingRect does not need to updated when the position changes + // TODO: this doesn't work for labels with XML String markups. + var ref = this; + var metrics = ref.metrics; + var _labelSelectors = ref._labelSelectors; + var selectors = _labelSelectors[index]; + if (!selectors) { return; } + for (var selector in selectors) { + var ref$1 = selectors[selector]; + var id = ref$1.id; + if (id && (id in metrics)) { delete metrics[id].magnetMatrix; } + } + }, + + updateToolsPosition: function() { + + if (!this._V.linkTools) { return this; } + + // Move the tools a bit to the target position but don't cover the `sourceArrowhead` marker. + // Note that the offset is hardcoded here. The offset should be always + // more than the `this.$('.marker-arrowhead[end="source"]')[0].bbox().width` but looking + // this up all the time would be slow. + + var scale = ''; + var offset = this.options.linkToolsOffset; + var connectionLength = this.getConnectionLength(); + + // Firefox returns connectionLength=NaN in odd cases (for bezier curves). + // In that case we won't update tools position at all. + if (!Number.isNaN(connectionLength)) { + + // If the link is too short, make the tools half the size and the offset twice as low. + if (connectionLength < this.options.shortLinkLength) { + scale = 'scale(.5)'; + offset /= 2; + } + + var toolPosition = this.getPointAtLength(offset); + + this._toolCache.attr('transform', 'translate(' + toolPosition.x + ', ' + toolPosition.y + ') ' + scale); + + if (this.options.doubleLinkTools && connectionLength >= this.options.longLinkLength) { + + var doubleLinkToolsOffset = this.options.doubleLinkToolsOffset || offset; + + toolPosition = this.getPointAtLength(connectionLength - doubleLinkToolsOffset); + this._tool2Cache.attr('transform', 'translate(' + toolPosition.x + ', ' + toolPosition.y + ') ' + scale); + this._tool2Cache.attr('visibility', 'visible'); + + } else if (this.options.doubleLinkTools) { + + this._tool2Cache.attr('visibility', 'hidden'); + } + } + + return this; + }, + + updateArrowheadMarkers: function() { + + if (!this._V.markerArrowheads) { return this; } + + // getting bbox of an element with `display="none"` in IE9 ends up with access violation + if ($.css(this._V.markerArrowheads.node, 'display') === 'none') { return this; } + + var sx = this.getConnectionLength() < this.options.shortLinkLength ? .5 : 1; + this._V.sourceArrowhead.scale(sx); + this._V.targetArrowhead.scale(sx); + + this._translateAndAutoOrientArrows(this._V.sourceArrowhead, this._V.targetArrowhead); + + return this; + }, + + updateEndProperties: function(endType) { + + var ref = this; + var model = ref.model; + var paper = ref.paper; + var endViewProperty = endType + "View"; + var endDef = model.get(endType); + var endId = endDef && endDef.id; + + if (!endId) { + // the link end is a point ~ rect 0x0 + this[endViewProperty] = null; + this.updateEndMagnet(endType); + return true; + } + + var endModel = paper.getModelById(endId); + if (!endModel) { throw new Error('LinkView: invalid ' + endType + ' cell.'); } + + var endView = endModel.findView(paper); + if (!endView) { + // A view for a model should always exist + return false; + } + + this[endViewProperty] = endView; + this.updateEndMagnet(endType); + return true; + }, + + updateEndMagnet: function(endType) { + + var endMagnetProperty = endType + "Magnet"; + var endView = this.getEndView(endType); + if (endView) { + var connectedMagnet = endView.getMagnetFromLinkEnd(this.model.get(endType)); + if (connectedMagnet === endView.el) { connectedMagnet = null; } + this[endMagnetProperty] = connectedMagnet; + } else { + this[endMagnetProperty] = null; + } + }, + + _translateAndAutoOrientArrows: function(sourceArrow, targetArrow) { + + // Make the markers "point" to their sticky points being auto-oriented towards + // `targetPosition`/`sourcePosition`. And do so only if there is a markup for them. + var route = toArray(this.route); + if (sourceArrow) { + sourceArrow.translateAndAutoOrient( + this.sourcePoint, + route[0] || this.targetPoint, + this.paper.cells + ); + } + + if (targetArrow) { + targetArrow.translateAndAutoOrient( + this.targetPoint, + route[route.length - 1] || this.sourcePoint, + this.paper.cells + ); + } + }, + + _getLabelPositionAngle: function(idx) { + + var labelPosition = this.model.label(idx).position || {}; + return (labelPosition.angle || 0); + }, + + _getLabelPositionArgs: function(idx) { + + var labelPosition = this.model.label(idx).position || {}; + return labelPosition.args; + }, + + _getDefaultLabelPositionArgs: function() { + + var defaultLabel = this.model._getDefaultLabel(); + var defaultLabelPosition = defaultLabel.position || {}; + return defaultLabelPosition.args; + }, + + // merge default label position args into label position args + // keep `undefined` or `null` because `{}` means something else + _mergeLabelPositionArgs: function(labelPositionArgs, defaultLabelPositionArgs) { + + if (labelPositionArgs === null) { return null; } + if (labelPositionArgs === undefined) { + + if (defaultLabelPositionArgs === null) { return null; } + return defaultLabelPositionArgs; + } + + return merge({}, defaultLabelPositionArgs, labelPositionArgs); + }, + + // Add default label at given position at end of `labels` array. + // Four signatures: + // - obj, obj = point, opt + // - obj, num, obj = point, angle, opt + // - num, num, obj = x, y, opt + // - num, num, num, obj = x, y, angle, opt + // Assigns relative coordinates by default: + // `opt.absoluteDistance` forces absolute coordinates. + // `opt.reverseDistance` forces reverse absolute coordinates (if absoluteDistance = true). + // `opt.absoluteOffset` forces absolute coordinates for offset. + // Additional args: + // `opt.keepGradient` auto-adjusts the angle of the label to match path gradient at position. + // `opt.ensureLegibility` rotates labels so they are never upside-down. + addLabel: function(p1, p2, p3, p4) { + + // normalize data from the four possible signatures + var localX; + var localY; + var localAngle = 0; + var localOpt; + if (typeof p1 !== 'number') { + // {x, y} object provided as first parameter + localX = p1.x; + localY = p1.y; + if (typeof p2 === 'number') { + // angle and opt provided as second and third parameters + localAngle = p2; + localOpt = p3; + } else { + // opt provided as second parameter + localOpt = p2; + } + } else { + // x and y provided as first and second parameters + localX = p1; + localY = p2; + if (typeof p3 === 'number') { + // angle and opt provided as third and fourth parameters + localAngle = p3; + localOpt = p4; + } else { + // opt provided as third parameter + localOpt = p3; + } + } + + // merge label position arguments + var defaultLabelPositionArgs = this._getDefaultLabelPositionArgs(); + var labelPositionArgs = localOpt; + var positionArgs = this._mergeLabelPositionArgs(labelPositionArgs, defaultLabelPositionArgs); + + // append label to labels array + var label = { position: this.getLabelPosition(localX, localY, localAngle, positionArgs) }; + var idx = -1; + this.model.insertLabel(idx, label, localOpt); + return idx; + }, + + // Add a new vertex at calculated index to the `vertices` array. + addVertex: function(x, y, opt) { + + // accept input in form `{ x, y }, opt` or `x, y, opt` + var isPointProvided = (typeof x !== 'number'); + var localX = isPointProvided ? x.x : x; + var localY = isPointProvided ? x.y : y; + var localOpt = isPointProvided ? y : opt; + + var vertex = { x: localX, y: localY }; + var idx = this.getVertexIndex(localX, localY); + this.model.insertVertex(idx, vertex, localOpt); + return idx; + }, + + // Send a token (an SVG element, usually a circle) along the connection path. + // Example: `link.findView(paper).sendToken(V('circle', { r: 7, fill: 'green' }).node)` + // `opt.duration` is optional and is a time in milliseconds that the token travels from the source to the target of the link. Default is `1000`. + // `opt.directon` is optional and it determines whether the token goes from source to target or other way round (`reverse`) + // `opt.connection` is an optional selector to the connection path. + // `callback` is optional and is a function to be called once the token reaches the target. + sendToken: function(token, opt, callback) { + + function onAnimationEnd(vToken, callback) { + return function() { + vToken.remove(); + if (typeof callback === 'function') { + callback(); + } + }; + } + + var duration, isReversed, selector; + if (isObject$1(opt)) { + duration = opt.duration; + isReversed = (opt.direction === 'reverse'); + selector = opt.connection; + } else { + // Backwards compatibility + duration = opt; + isReversed = false; + selector = null; + } + + duration = duration || 1000; + + var animationAttributes = { + dur: duration + 'ms', + repeatCount: 1, + calcMode: 'linear', + fill: 'freeze' + }; + + if (isReversed) { + animationAttributes.keyPoints = '1;0'; + animationAttributes.keyTimes = '0;1'; + } + + var vToken = V(token); + var connection; + if (typeof selector === 'string') { + // Use custom connection path. + connection = this.findBySelector(selector, this.el, this.selectors)[0]; + } else { + // Select connection path automatically. + var cache = this._V; + connection = (cache.connection) ? cache.connection.node : this.el.querySelector('path'); + } + + if (!(connection instanceof SVGPathElement)) { + throw new Error('dia.LinkView: token animation requires a valid connection path.'); + } + + vToken + .appendTo(this.paper.cells) + .animateAlongPath(animationAttributes, connection); + + setTimeout(onAnimationEnd(vToken, callback), duration); + }, + + findRoute: function(vertices) { + + vertices || (vertices = []); + + var namespace = this.paper.options.routerNamespace || routers; + var router = this.model.router(); + var defaultRouter = this.paper.options.defaultRouter; + + if (!router) { + if (defaultRouter) { router = defaultRouter; } + else { return vertices.map(Point); } // no router specified + } + + var routerFn = isFunction(router) ? router : namespace[router.name]; + if (!isFunction(routerFn)) { + throw new Error('dia.LinkView: unknown router: "' + router.name + '".'); + } + + var args = router.args || {}; + + var route = routerFn.call( + this, // context + vertices, // vertices + args, // options + this // linkView + ); + + if (!route) { return vertices.map(Point); } + return route; + }, + + // Return the `d` attribute value of the `` element representing the link + // between `source` and `target`. + findPath: function(route, sourcePoint, targetPoint) { + + var namespace = this.paper.options.connectorNamespace || connectors; + var connector = this.model.connector(); + var defaultConnector = this.paper.options.defaultConnector; + + if (!connector) { + connector = defaultConnector || {}; + } + + var connectorFn = isFunction(connector) ? connector : namespace[connector.name]; + if (!isFunction(connectorFn)) { + throw new Error('dia.LinkView: unknown connector: "' + connector.name + '".'); + } + + var args = clone(connector.args || {}); + args.raw = true; // Request raw g.Path as the result. + + var path = connectorFn.call( + this, // context + sourcePoint, // start point + targetPoint, // end point + route, // vertices + args, // options + this // linkView + ); + + if (typeof path === 'string') { + // Backwards compatibility for connectors not supporting `raw` option. + path = new Path(V.normalizePathData(path)); + } + + return path; + }, + + // Public API. + // ----------- + + getConnection: function() { + + var path = this.path; + if (!path) { return null; } + + return path.clone(); + }, + + getSerializedConnection: function() { + + var path = this.path; + if (!path) { return null; } + + var metrics = this.metrics; + if (metrics.hasOwnProperty('data')) { return metrics.data; } + var data = path.serialize(); + metrics.data = data; + return data; + }, + + getConnectionSubdivisions: function() { + + var path = this.path; + if (!path) { return null; } + + var metrics = this.metrics; + if (metrics.hasOwnProperty('segmentSubdivisions')) { return metrics.segmentSubdivisions; } + var subdivisions = path.getSegmentSubdivisions(); + metrics.segmentSubdivisions = subdivisions; + return subdivisions; + }, + + getConnectionLength: function() { + + var path = this.path; + if (!path) { return 0; } + + var metrics = this.metrics; + if (metrics.hasOwnProperty('length')) { return metrics.length; } + var length = path.length({ segmentSubdivisions: this.getConnectionSubdivisions() }); + metrics.length = length; + return length; + }, + + getPointAtLength: function(length) { + + var path = this.path; + if (!path) { return null; } + + return path.pointAtLength(length, { segmentSubdivisions: this.getConnectionSubdivisions() }); + }, + + getPointAtRatio: function(ratio) { + + var path = this.path; + if (!path) { return null; } + if (isPercentage(ratio)) { ratio = parseFloat(ratio) / 100; } + return path.pointAt(ratio, { segmentSubdivisions: this.getConnectionSubdivisions() }); + }, + + getTangentAtLength: function(length) { + + var path = this.path; + if (!path) { return null; } + + return path.tangentAtLength(length, { segmentSubdivisions: this.getConnectionSubdivisions() }); + }, + + getTangentAtRatio: function(ratio) { + + var path = this.path; + if (!path) { return null; } + + return path.tangentAt(ratio, { segmentSubdivisions: this.getConnectionSubdivisions() }); + }, + + getClosestPoint: function(point) { + + var path = this.path; + if (!path) { return null; } + + return path.closestPoint(point, { segmentSubdivisions: this.getConnectionSubdivisions() }); + }, + + getClosestPointLength: function(point) { + + var path = this.path; + if (!path) { return null; } + + return path.closestPointLength(point, { segmentSubdivisions: this.getConnectionSubdivisions() }); + }, + + getClosestPointRatio: function(point) { + + var path = this.path; + if (!path) { return null; } + + return path.closestPointNormalizedLength(point, { segmentSubdivisions: this.getConnectionSubdivisions() }); + }, + + // Get label position object based on two provided coordinates, x and y. + // (Used behind the scenes when user moves labels around.) + // Two signatures: + // - num, num, obj = x, y, options + // - num, num, num, obj = x, y, angle, options + // Accepts distance/offset options = `absoluteDistance: boolean`, `reverseDistance: boolean`, `absoluteOffset: boolean` + // - `absoluteOffset` is necessary in order to move beyond connection endpoints + // Additional options = `keepGradient: boolean`, `ensureLegibility: boolean` + getLabelPosition: function(x, y, p3, p4) { + + var position = {}; + + // normalize data from the two possible signatures + var localAngle = 0; + var localOpt; + if (typeof p3 === 'number') { + // angle and opt provided as third and fourth argument + localAngle = p3; + localOpt = p4; + } else { + // opt provided as third argument + localOpt = p3; + } + + // save localOpt as `args` of the position object that is passed along + if (localOpt) { position.args = localOpt; } + + // identify distance/offset settings + var isDistanceRelative = !(localOpt && localOpt.absoluteDistance); // relative by default + var isDistanceAbsoluteReverse = (localOpt && localOpt.absoluteDistance && localOpt.reverseDistance); // non-reverse by default + var isOffsetAbsolute = localOpt && localOpt.absoluteOffset; // offset is non-absolute by default + + // find closest point t + var path = this.path; + var pathOpt = { segmentSubdivisions: this.getConnectionSubdivisions() }; + var labelPoint = new Point(x, y); + var t = path.closestPointT(labelPoint, pathOpt); + + // DISTANCE: + var labelDistance = path.lengthAtT(t, pathOpt); + if (isDistanceRelative) { labelDistance = (labelDistance / this.getConnectionLength()) || 0; } // fix to prevent NaN for 0 length + if (isDistanceAbsoluteReverse) { labelDistance = (-1 * (this.getConnectionLength() - labelDistance)) || 1; } // fix for end point (-0 => 1) + position.distance = labelDistance; + + // OFFSET: + // use absolute offset if: + // - opt.absoluteOffset is true, + // - opt.absoluteOffset is not true but there is no tangent + var tangent; + if (!isOffsetAbsolute) { tangent = path.tangentAtT(t); } + var labelOffset; + if (tangent) { + labelOffset = tangent.pointOffset(labelPoint); + } else { + var closestPoint = path.pointAtT(t); + var labelOffsetDiff = labelPoint.difference(closestPoint); + labelOffset = { x: labelOffsetDiff.x, y: labelOffsetDiff.y }; + } + position.offset = labelOffset; + + // ANGLE: + position.angle = localAngle; + + return position; + }, + + _getLabelTransformationMatrix: function(labelPosition) { + + var labelDistance; + var labelAngle = 0; + var args = {}; + if (typeof labelPosition === 'number') { + labelDistance = labelPosition; + } else if (typeof labelPosition.distance === 'number') { + args = labelPosition.args || {}; + labelDistance = labelPosition.distance; + labelAngle = labelPosition.angle || 0; + } else { + throw new Error('dia.LinkView: invalid label position distance.'); + } + + var isDistanceRelative = ((labelDistance > 0) && (labelDistance <= 1)); + + var labelOffset = 0; + var labelOffsetCoordinates = { x: 0, y: 0 }; + if (labelPosition.offset) { + var positionOffset = labelPosition.offset; + if (typeof positionOffset === 'number') { labelOffset = positionOffset; } + if (positionOffset.x) { labelOffsetCoordinates.x = positionOffset.x; } + if (positionOffset.y) { labelOffsetCoordinates.y = positionOffset.y; } + } + + var isOffsetAbsolute = ((labelOffsetCoordinates.x !== 0) || (labelOffsetCoordinates.y !== 0) || labelOffset === 0); + + var isKeepGradient = args.keepGradient; + var isEnsureLegibility = args.ensureLegibility; + + var path = this.path; + var pathOpt = { segmentSubdivisions: this.getConnectionSubdivisions() }; + + var distance = isDistanceRelative ? (labelDistance * this.getConnectionLength()) : labelDistance; + var tangent = path.tangentAtLength(distance, pathOpt); + + var translation; + var angle = labelAngle; + if (tangent) { + if (isOffsetAbsolute) { + translation = tangent.start; + translation.offset(labelOffsetCoordinates); + } else { + var normal = tangent.clone(); + normal.rotate(tangent.start, -90); + normal.setLength(labelOffset); + translation = normal.end; + } + if (isKeepGradient) { + angle = (tangent.angle() + labelAngle); + if (isEnsureLegibility) { + angle = normalizeAngle(((angle + 90) % 180) - 90); + } + } + } else { + // fallback - the connection has zero length + translation = path.start; + if (isOffsetAbsolute) { translation.offset(labelOffsetCoordinates); } + } + + return V.createSVGMatrix() + .translate(translation.x, translation.y) + .rotate(angle); + }, + + getLabelCoordinates: function(labelPosition) { + + var transformationMatrix = this._getLabelTransformationMatrix(labelPosition); + return new Point(transformationMatrix.e, transformationMatrix.f); + }, + + getVertexIndex: function(x, y) { + + var model = this.model; + var vertices = model.vertices(); + + var vertexLength = this.getClosestPointLength(new Point(x, y)); + + var idx = 0; + for (var n = vertices.length; idx < n; idx++) { + var currentVertex = vertices[idx]; + var currentVertexLength = this.getClosestPointLength(currentVertex); + if (vertexLength < currentVertexLength) { break; } + } + + return idx; + }, + + // Interaction. The controller part. + // --------------------------------- + + notifyPointerdown: function notifyPointerdown(evt, x, y) { + CellView.prototype.pointerdown.call(this, evt, x, y); + this.notify('link:pointerdown', evt, x, y); + }, + + notifyPointermove: function notifyPointermove(evt, x, y) { + CellView.prototype.pointermove.call(this, evt, x, y); + this.notify('link:pointermove', evt, x, y); + }, + + notifyPointerup: function notifyPointerup(evt, x, y) { + this.notify('link:pointerup', evt, x, y); + CellView.prototype.pointerup.call(this, evt, x, y); + }, + + pointerdblclick: function(evt, x, y) { + + CellView.prototype.pointerdblclick.apply(this, arguments); + this.notify('link:pointerdblclick', evt, x, y); + }, + + pointerclick: function(evt, x, y) { + + CellView.prototype.pointerclick.apply(this, arguments); + this.notify('link:pointerclick', evt, x, y); + }, + + contextmenu: function(evt, x, y) { + + CellView.prototype.contextmenu.apply(this, arguments); + this.notify('link:contextmenu', evt, x, y); + }, + + pointerdown: function(evt, x, y) { + + this.notifyPointerdown(evt, x, y); + + // Backwards compatibility for the default markup + var className = evt.target.getAttribute('class'); + switch (className) { + + case 'marker-vertex': + this.dragVertexStart(evt, x, y); + return; + + case 'marker-vertex-remove': + case 'marker-vertex-remove-area': + this.dragVertexRemoveStart(evt, x, y); + return; + + case 'marker-arrowhead': + this.dragArrowheadStart(evt, x, y); + return; + + case 'connection': + case 'connection-wrap': + this.dragConnectionStart(evt, x, y); + return; + + case 'marker-source': + case 'marker-target': + return; + } + + this.dragStart(evt, x, y); + }, + + pointermove: function(evt, x, y) { + + // Backwards compatibility + var dragData = this._dragData; + if (dragData) { this.eventData(evt, dragData); } + + var data = this.eventData(evt); + switch (data.action) { + + case 'vertex-move': + this.dragVertex(evt, x, y); + break; + + case 'label-move': + this.dragLabel(evt, x, y); + break; + + case 'arrowhead-move': + this.dragArrowhead(evt, x, y); + break; + + case 'move': + this.drag(evt, x, y); + break; + } + + // Backwards compatibility + if (dragData) { assign(dragData, this.eventData(evt)); } + + this.notifyPointermove(evt, x, y); + }, + + pointerup: function(evt, x, y) { + + // Backwards compatibility + var dragData = this._dragData; + if (dragData) { + this.eventData(evt, dragData); + this._dragData = null; + } + + var data = this.eventData(evt); + switch (data.action) { + + case 'vertex-move': + this.dragVertexEnd(evt, x, y); + break; + + case 'label-move': + this.dragLabelEnd(evt, x, y); + break; + + case 'arrowhead-move': + this.dragArrowheadEnd(evt, x, y); + break; + + case 'move': + this.dragEnd(evt, x, y); + } + + this.notifyPointerup(evt, x, y); + this.checkMouseleave(evt); + }, + + mouseover: function(evt) { + + CellView.prototype.mouseover.apply(this, arguments); + this.notify('link:mouseover', evt); + }, + + mouseout: function(evt) { + + CellView.prototype.mouseout.apply(this, arguments); + this.notify('link:mouseout', evt); + }, + + mouseenter: function(evt) { + + CellView.prototype.mouseenter.apply(this, arguments); + this.notify('link:mouseenter', evt); + }, + + mouseleave: function(evt) { + + CellView.prototype.mouseleave.apply(this, arguments); + this.notify('link:mouseleave', evt); + }, + + mousewheel: function(evt, x, y, delta) { + + CellView.prototype.mousewheel.apply(this, arguments); + this.notify('link:mousewheel', evt, x, y, delta); + }, + + onevent: function(evt, eventName, x, y) { + + // Backwards compatibility + var linkTool = V(evt.target).findParentByClass('link-tool', this.el); + if (linkTool) { + // No further action to be executed + evt.stopPropagation(); + + // Allow `interactive.useLinkTools=false` + if (this.can('useLinkTools')) { + if (eventName === 'remove') { + // Built-in remove event + this.model.remove({ ui: true }); + // Do not trigger link pointerdown + return; + + } else { + // link:options and other custom events inside the link tools + this.notify(eventName, evt, x, y); + } + } + + this.notifyPointerdown(evt, x, y); + this.paper.delegateDragEvents(this, evt.data); + + } else { + CellView.prototype.onevent.apply(this, arguments); + } + }, + + onlabel: function(evt, x, y) { + + this.notifyPointerdown(evt, x, y); + + this.dragLabelStart(evt, x, y); + + var stopPropagation = this.eventData(evt).stopPropagation; + if (stopPropagation) { evt.stopPropagation(); } + }, + + // Drag Start Handlers + + dragConnectionStart: function(evt, x, y) { + + if (!this.can('vertexAdd')) { return; } + + // Store the index at which the new vertex has just been placed. + // We'll be update the very same vertex position in `pointermove()`. + var vertexIdx = this.addVertex({ x: x, y: y }, { ui: true }); + this.eventData(evt, { + action: 'vertex-move', + vertexIdx: vertexIdx + }); + }, + + dragLabelStart: function(evt, _x, _y) { + + if (this.can('labelMove')) { + + var labelNode = evt.currentTarget; + var labelIdx = parseInt(labelNode.getAttribute('label-idx'), 10); + + var positionAngle = this._getLabelPositionAngle(labelIdx); + var labelPositionArgs = this._getLabelPositionArgs(labelIdx); + var defaultLabelPositionArgs = this._getDefaultLabelPositionArgs(); + var positionArgs = this._mergeLabelPositionArgs(labelPositionArgs, defaultLabelPositionArgs); + + this.eventData(evt, { + action: 'label-move', + labelIdx: labelIdx, + positionAngle: positionAngle, + positionArgs: positionArgs, + stopPropagation: true + }); + + } else { + + // Backwards compatibility: + // If labels can't be dragged no default action is triggered. + this.eventData(evt, { stopPropagation: true }); + } + + this.paper.delegateDragEvents(this, evt.data); + }, + + dragVertexStart: function(evt, x, y) { + + if (!this.can('vertexMove')) { return; } + + var vertexNode = evt.target; + var vertexIdx = parseInt(vertexNode.getAttribute('idx'), 10); + this.eventData(evt, { + action: 'vertex-move', + vertexIdx: vertexIdx + }); + }, + + dragVertexRemoveStart: function(evt, x, y) { + + if (!this.can('vertexRemove')) { return; } + + var removeNode = evt.target; + var vertexIdx = parseInt(removeNode.getAttribute('idx'), 10); + this.model.removeVertex(vertexIdx); + }, + + dragArrowheadStart: function(evt, x, y) { + + if (!this.can('arrowheadMove')) { return; } + + var arrowheadNode = evt.target; + var arrowheadType = arrowheadNode.getAttribute('end'); + var data = this.startArrowheadMove(arrowheadType, { ignoreBackwardsCompatibility: true }); + + this.eventData(evt, data); + }, + + dragStart: function(evt, x, y) { + + if (!this.can('linkMove')) { return; } + + this.eventData(evt, { + action: 'move', + dx: x, + dy: y + }); + }, + + // Drag Handlers + dragLabel: function(evt, x, y) { + + var data = this.eventData(evt); + var label = { position: this.getLabelPosition(x, y, data.positionAngle, data.positionArgs) }; + if (this.paper.options.snapLabels) { delete label.position.offset; } + this.model.label(data.labelIdx, label); + }, + + dragVertex: function(evt, x, y) { + + var data = this.eventData(evt); + this.model.vertex(data.vertexIdx, { x: x, y: y }, { ui: true }); + }, + + dragArrowhead: function(evt, x, y) { + if (this.paper.options.snapLinks) { + var isSnapped = this._snapArrowhead(evt, x, y); + if (!isSnapped && this.paper.options.snapLinksSelf) { + this._snapArrowheadSelf(evt, x, y); + } + } else { + if (this.paper.options.snapLinksSelf) { + this._snapArrowheadSelf(evt, x, y); + } else { + this._connectArrowhead(this.getEventTarget(evt), x, y, this.eventData(evt)); + } + } + }, + + drag: function(evt, x, y) { + + var data = this.eventData(evt); + this.model.translate(x - data.dx, y - data.dy, { ui: true }); + this.eventData(evt, { + dx: x, + dy: y + }); + }, + + // Drag End Handlers + + dragLabelEnd: function() { + // noop + }, + + dragVertexEnd: function() { + // noop + }, + + dragArrowheadEnd: function(evt, x, y) { + + var data = this.eventData(evt); + var paper = this.paper; + + if (paper.options.snapLinks) { + this._snapArrowheadEnd(data); + } else { + this._connectArrowheadEnd(data, x, y); + } + + if (!paper.linkAllowed(this)) { + // If the changed link is not allowed, revert to its previous state. + this._disallow(data); + } else { + this._finishEmbedding(data); + this._notifyConnectEvent(data, evt); + } + + this._afterArrowheadMove(data); + }, + + dragEnd: function() { + // noop + }, + + _disallow: function(data) { + + switch (data.whenNotAllowed) { + + case 'remove': + this.model.remove({ ui: true }); + break; + + case 'revert': + default: + this.model.set(data.arrowhead, data.initialEnd, { ui: true }); + break; + } + }, + + _finishEmbedding: function(data) { + + // Reparent the link if embedding is enabled + if (this.paper.options.embeddingMode && this.model.reparent()) { + // Make sure we don't reverse to the original 'z' index (see afterArrowheadMove()). + data.z = null; + } + }, + + _notifyConnectEvent: function(data, evt) { + + var arrowhead = data.arrowhead; + var initialEnd = data.initialEnd; + var currentEnd = this.model.prop(arrowhead); + var endChanged = currentEnd && !Link.endsEqual(initialEnd, currentEnd); + if (endChanged) { + var paper = this.paper; + if (initialEnd.id) { + this.notify('link:disconnect', evt, paper.findViewByModel(initialEnd.id), data.initialMagnet, arrowhead); + } + if (currentEnd.id) { + this.notify('link:connect', evt, paper.findViewByModel(currentEnd.id), data.magnetUnderPointer, arrowhead); + } + } + }, + + _snapToPoints: function(snapPoint, points, radius) { + var closestPointX = null; + var closestDistanceX = Infinity; + + var closestPointY = null; + var closestDistanceY = Infinity; + + var x = snapPoint.x; + var y = snapPoint.y; + + for (var i = 0; i < points.length; i++) { + var distX = Math.abs(points[i].x - snapPoint.x); + if (distX < closestDistanceX) { + closestDistanceX = distX; + closestPointX = points[i]; + } + + var distY = Math.abs(points[i].y - snapPoint.y); + if (distY < closestDistanceY) { + closestDistanceY = distY; + closestPointY = points[i]; + } + } + + if (closestDistanceX < radius) { + x = closestPointX.x; + } + if (closestDistanceY < radius) { + y = closestPointY.y; + } + + return { x: x, y: y }; + }, + + _snapArrowheadSelf: function(evt, x, y) { + + var ref = this; + var paper = ref.paper; + var model = ref.model; + var ref$1 = paper.options; + var snapLinksSelf = ref$1.snapLinksSelf; + var data = this.eventData(evt); + var radius = snapLinksSelf.radius || 20; + + var anchor = this.getEndAnchor(data.arrowhead === 'source' ? 'target' : 'source'); + var vertices = model.vertices(); + var points = [anchor ].concat( vertices); + + var snapPoint = this._snapToPoints({ x: x, y: y }, points, radius); + + this._connectArrowhead(document.elementFromPoint(snapPoint.x, snapPoint.y), snapPoint.x, snapPoint.y, this.eventData(evt)); + }, + + _snapArrowhead: function(evt, x, y) { + + var ref = this; + var paper = ref.paper; + var ref$1 = paper.options; + var snapLinks = ref$1.snapLinks; + var connectionStrategy = ref$1.connectionStrategy; + var data = this.eventData(evt); + var isSnapped = false; + // checking view in close area of the pointer + + var r = snapLinks.radius || 50; + var viewsInArea = paper.findViewsInArea({ x: x - r, y: y - r, width: 2 * r, height: 2 * r }); + + var prevClosestView = data.closestView || null; + var prevClosestMagnet = data.closestMagnet || null; + var prevMagnetProxy = data.magnetProxy || null; + + data.closestView = data.closestMagnet = data.magnetProxy = null; + + var minDistance = Number.MAX_VALUE; + var pointer = new Point(x, y); + + viewsInArea.forEach(function(view) { + var candidates = []; + // skip connecting to the element in case '.': { magnet: false } attribute present + if (view.el.getAttribute('magnet') !== 'false') { + candidates.push({ + bbox: view.model.getBBox(), + magnet: view.el + }); + } + + view.$('[magnet]').toArray().forEach(function (magnet) { + candidates.push({ + bbox: view.getNodeBBox(magnet), + magnet: magnet + }); + }); + + candidates.forEach(function (candidate) { + var magnet = candidate.magnet; + var bbox = candidate.bbox; + // find distance from the center of the model to pointer coordinates + var distance = bbox.center().squaredDistance(pointer); + // the connection is looked up in a circle area by `distance < r` + if (distance < minDistance) { + var isAlreadyValidated = prevClosestMagnet === magnet; + if (isAlreadyValidated || paper.options.validateConnection.apply( + paper, data.validateConnectionArgs(view, (view.el === magnet) ? null : magnet) + )) { + minDistance = distance; + data.closestView = view; + data.closestMagnet = magnet; + } + } + }); + + }, this); + + var end; + var magnetProxy = null; + var closestView = data.closestView; + var closestMagnet = data.closestMagnet; + if (closestMagnet) { + magnetProxy = data.magnetProxy = closestView.findProxyNode(closestMagnet, 'highlighter'); + } + var endType = data.arrowhead; + var newClosestMagnet = (prevClosestMagnet !== closestMagnet); + if (prevClosestView && newClosestMagnet) { + prevClosestView.unhighlight(prevMagnetProxy, { + connecting: true, + snapping: true + }); + } + + if (closestView) { + var prevEnd = data.prevEnd; + var prevX = data.prevX; + var prevY = data.prevY; + data.prevX = x; + data.prevY = y; + isSnapped = true; + + if (!newClosestMagnet) { + if (typeof connectionStrategy !== 'function' || (prevX === x && prevY === y)) { + // the magnet has not changed and the link's end does not depend on the x and y + return isSnapped; + } + } + + end = closestView.getLinkEnd(closestMagnet, x, y, this.model, endType); + if (!newClosestMagnet && isEqual(prevEnd, end)) { + // the source/target json has not changed + return isSnapped; + } + + data.prevEnd = end; + + if (newClosestMagnet) { + closestView.highlight(magnetProxy, { + connecting: true, + snapping: true + }); + } + + } else { + + end = { x: x, y: y }; + } + + this.model.set(endType, end || { x: x, y: y }, { ui: true }); + + if (prevClosestView) { + this.notify('link:snap:disconnect', evt, prevClosestView, prevClosestMagnet, endType); + } + if (closestView) { + this.notify('link:snap:connect', evt, closestView, closestMagnet, endType); + } + + return isSnapped; + }, + + _snapArrowheadEnd: function(data) { + + // Finish off link snapping. + // Everything except view unhighlighting was already done on pointermove. + var closestView = data.closestView; + var closestMagnet = data.closestMagnet; + if (closestView && closestMagnet) { + + closestView.unhighlight(data.magnetProxy, { connecting: true, snapping: true }); + data.magnetUnderPointer = closestView.findMagnet(closestMagnet); + } + + data.closestView = data.closestMagnet = null; + }, + + _connectArrowhead: function(target, x, y, data) { + + // checking views right under the pointer + var ref = this; + var paper = ref.paper; + var model = ref.model; + + if (data.eventTarget !== target) { + // Unhighlight the previous view under pointer if there was one. + if (data.magnetProxy) { + data.viewUnderPointer.unhighlight(data.magnetProxy, { + connecting: true + }); + } + + var viewUnderPointer = data.viewUnderPointer = paper.findView(target); + if (viewUnderPointer) { + // If we found a view that is under the pointer, we need to find the closest + // magnet based on the real target element of the event. + var magnetUnderPointer = data.magnetUnderPointer = viewUnderPointer.findMagnet(target); + var magnetProxy = data.magnetProxy = viewUnderPointer.findProxyNode(magnetUnderPointer, 'highlighter'); + + if (magnetUnderPointer && this.paper.options.validateConnection.apply( + paper, + data.validateConnectionArgs(viewUnderPointer, magnetUnderPointer) + )) { + // If there was no magnet found, do not highlight anything and assume there + // is no view under pointer we're interested in reconnecting to. + // This can only happen if the overall element has the attribute `'.': { magnet: false }`. + if (magnetProxy) { + viewUnderPointer.highlight(magnetProxy, { + connecting: true + }); + } + } else { + // This type of connection is not valid. Disregard this magnet. + data.magnetUnderPointer = null; + data.magnetProxy = null; + } + } else { + // Make sure we'll unset previous magnet. + data.magnetUnderPointer = null; + data.magnetProxy = null; + } + } + + data.eventTarget = target; + + model.set(data.arrowhead, { x: x, y: y }, { ui: true }); + }, + + _connectArrowheadEnd: function(data, x, y) { + if ( data === void 0 ) data = {}; + + + var ref = this; + var model = ref.model; + var viewUnderPointer = data.viewUnderPointer; + var magnetUnderPointer = data.magnetUnderPointer; + var magnetProxy = data.magnetProxy; + var arrowhead = data.arrowhead; + + if (!magnetUnderPointer || !magnetProxy || !viewUnderPointer) { return; } + + viewUnderPointer.unhighlight(magnetProxy, { connecting: true }); + + // The link end is taken from the magnet under the pointer, not the proxy. + var end = viewUnderPointer.getLinkEnd(magnetUnderPointer, x, y, model, arrowhead); + model.set(arrowhead, end, { ui: true }); + }, + + _beforeArrowheadMove: function(data) { + + data.z = this.model.get('z'); + this.model.toFront(); + + // Let the pointer propagate through the link view elements so that + // the `evt.target` is another element under the pointer, not the link itself. + var style = this.el.style; + data.pointerEvents = style.pointerEvents; + style.pointerEvents = 'none'; + + if (this.paper.options.markAvailable) { + this._markAvailableMagnets(data); + } + }, + + _afterArrowheadMove: function(data) { + + if (data.z !== null) { + this.model.set('z', data.z, { ui: true }); + data.z = null; + } + + // Put `pointer-events` back to its original value. See `_beforeArrowheadMove()` for explanation. + this.el.style.pointerEvents = data.pointerEvents; + + if (this.paper.options.markAvailable) { + this._unmarkAvailableMagnets(data); + } + }, + + _createValidateConnectionArgs: function(arrowhead) { + // It makes sure the arguments for validateConnection have the following form: + // (source view, source magnet, target view, target magnet and link view) + var args = []; + + args[4] = arrowhead; + args[5] = this; + + var oppositeArrowhead; + var i = 0; + var j = 0; + + if (arrowhead === 'source') { + i = 2; + oppositeArrowhead = 'target'; + } else { + j = 2; + oppositeArrowhead = 'source'; + } + + var end = this.model.get(oppositeArrowhead); + + if (end.id) { + var view = args[i] = this.paper.findViewByModel(end.id); + var magnet = view.getMagnetFromLinkEnd(end); + if (magnet === view.el) { magnet = undefined; } + args[i + 1] = magnet; + } + + function validateConnectionArgs(cellView, magnet) { + args[j] = cellView; + args[j + 1] = cellView.el === magnet ? undefined : magnet; + return args; + } + + return validateConnectionArgs; + }, + + _markAvailableMagnets: function(data) { + + function isMagnetAvailable(view, magnet) { + var paper = view.paper; + var validate = paper.options.validateConnection; + return validate.apply(paper, this.validateConnectionArgs(view, magnet)); + } + + var paper = this.paper; + var elements = paper.model.getCells(); + data.marked = {}; + + for (var i = 0, n = elements.length; i < n; i++) { + var view = elements[i].findView(paper); + + if (!view) { + continue; + } + + var magnets = Array.prototype.slice.call(view.el.querySelectorAll('[magnet]')); + if (view.el.getAttribute('magnet') !== 'false') { + // Element wrapping group is also a magnet + magnets.push(view.el); + } + + var availableMagnets = magnets.filter(isMagnetAvailable.bind(data, view)); + + if (availableMagnets.length > 0) { + // highlight all available magnets + for (var j = 0, m = availableMagnets.length; j < m; j++) { + view.highlight(availableMagnets[j], { magnetAvailability: true }); + } + // highlight the entire view + view.highlight(null, { elementAvailability: true }); + + data.marked[view.model.id] = availableMagnets; + } + } + }, + + _unmarkAvailableMagnets: function(data) { + + var markedKeys = Object.keys(data.marked); + var id; + var markedMagnets; + + for (var i = 0, n = markedKeys.length; i < n; i++) { + id = markedKeys[i]; + markedMagnets = data.marked[id]; + + var view = this.paper.findViewByModel(id); + if (view) { + for (var j = 0, m = markedMagnets.length; j < m; j++) { + view.unhighlight(markedMagnets[j], { magnetAvailability: true }); + } + view.unhighlight(null, { elementAvailability: true }); + } + } + + data.marked = null; + }, + + startArrowheadMove: function(end, opt) { + + opt || (opt = {}); + + // Allow to delegate events from an another view to this linkView in order to trigger arrowhead + // move without need to click on the actual arrowhead dom element. + var data = { + action: 'arrowhead-move', + arrowhead: end, + whenNotAllowed: opt.whenNotAllowed || 'revert', + initialMagnet: this[end + 'Magnet'] || (this[end + 'View'] ? this[end + 'View'].el : null), + initialEnd: clone(this.model.get(end)), + validateConnectionArgs: this._createValidateConnectionArgs(end) + }; + + this._beforeArrowheadMove(data); + + if (opt.ignoreBackwardsCompatibility !== true) { + this._dragData = data; + } + + return data; + }, + + onRemove: function() { + CellView.prototype.onRemove.apply(this, arguments); + this.unmountLabels(); + } + + }, { + + Flags: Flags$1, + }); + + Object.defineProperty(LinkView.prototype, 'sourceBBox', { + + enumerable: true, + + get: function() { + var sourceView = this.sourceView; + if (!sourceView) { + var sourceDef = this.model.source(); + return new Rect(sourceDef.x, sourceDef.y); + } + var sourceMagnet = this.sourceMagnet; + if (sourceView.isNodeConnection(sourceMagnet)) { + return new Rect(this.sourceAnchor); + } + return sourceView.getNodeBBox(sourceMagnet || sourceView.el); + } + + }); + + Object.defineProperty(LinkView.prototype, 'targetBBox', { + + enumerable: true, + + get: function() { + var targetView = this.targetView; + if (!targetView) { + var targetDef = this.model.target(); + return new Rect(targetDef.x, targetDef.y); + } + var targetMagnet = this.targetMagnet; + if (targetView.isNodeConnection(targetMagnet)) { + return new Rect(this.targetAnchor); + } + return targetView.getNodeBBox(targetMagnet || targetView.el); + } + }); + + var stroke = HighlighterView.extend({ + + tagName: 'path', + className: 'highlight-stroke', + attributes: { + 'pointer-events': 'none', + 'vector-effect': 'non-scaling-stroke', + 'fill': 'none' + }, + + options: { + padding: 3, + rx: 0, + ry: 0, + useFirstSubpath: false, + attrs: { + 'stroke-width': 3, + 'stroke': '#FEB663' + } + }, + + getPathData: function getPathData(cellView, node) { + var ref = this; + var options = ref.options; + var useFirstSubpath = options.useFirstSubpath; + var d; + try { + var vNode = V(node); + d = vNode.convertToPathData().trim(); + if (vNode.tagName() === 'PATH' && useFirstSubpath) { + var secondSubpathIndex = d.search(/.M/i) + 1; + if (secondSubpathIndex > 0) { + d = d.substr(0, secondSubpathIndex); + } + } + } catch (error) { + // Failed to get path data from magnet element. + // Draw a rectangle around the node instead. + var nodeBBox = cellView.getNodeBoundingRect(node); + d = V.rectToPath(assign({}, options, nodeBBox.toJSON())); + } + return d; + }, + + highlightConnection: function highlightConnection(cellView) { + this.vel.attr('d', cellView.getSerializedConnection()); + }, + + highlightNode: function highlightNode(cellView, node) { + var ref = this; + var vel = ref.vel; + var options = ref.options; + var padding = options.padding; + var layer = options.layer; + var highlightMatrix = this.getNodeMatrix(cellView, node); + // Add padding to the highlight element. + if (padding) { + if (!layer && node === cellView.el) { + // If the highlighter is appended to the cellView + // and we measure the size of the cellView wrapping group + // it's necessary to remove the highlighter first + vel.remove(); + } + var nodeBBox = cellView.getNodeBoundingRect(node); + var cx = nodeBBox.x + (nodeBBox.width / 2); + var cy = nodeBBox.y + (nodeBBox.height / 2); + nodeBBox = V.transformRect(nodeBBox, highlightMatrix); + var width = Math.max(nodeBBox.width, 1); + var height = Math.max(nodeBBox.height, 1); + var sx = (width + padding) / width; + var sy = (height + padding) / height; + var paddingMatrix = V.createSVGMatrix({ + a: sx, + b: 0, + c: 0, + d: sy, + e: cx - sx * cx, + f: cy - sy * cy + }); + highlightMatrix = highlightMatrix.multiply(paddingMatrix); + } + vel.attr({ + 'd': this.getPathData(cellView, node), + 'transform': V.matrixToTransformString(highlightMatrix) + }); + }, + + highlight: function highlight(cellView, node) { + var ref = this; + var vel = ref.vel; + var options = ref.options; + vel.attr(options.attrs); + if (cellView.isNodeConnection(node)) { + this.highlightConnection(cellView); + } else { + this.highlightNode(cellView, node); + } + } + + }); + + var MASK_CLIP = 20; + + function forEachDescendant(vel, fn) { + var descendants = vel.children(); + while (descendants.length > 0) { + var descendant = descendants.shift(); + if (fn(descendant)) { + descendants.push.apply(descendants, descendant.children()); + } + } + } + + var mask = HighlighterView.extend({ + + tagName: 'rect', + className: 'highlight-mask', + attributes: { + 'pointer-events': 'none' + }, + + options: { + padding: 3, + maskClip: MASK_CLIP, + deep: false, + attrs: { + 'stroke': '#FEB663', + 'stroke-width': 3, + 'stroke-linecap': 'butt', + 'stroke-linejoin': 'miter', + } + }, + + VISIBLE: 'white', + INVISIBLE: 'black', + + MASK_ROOT_ATTRIBUTE_BLACKLIST: [ + 'marker-start', + 'marker-end', + 'marker-mid', + 'transform', + 'stroke-dasharray' + ], + + MASK_CHILD_ATTRIBUTE_BLACKLIST: [ + 'stroke', + 'fill', + 'stroke-width', + 'stroke-opacity', + 'stroke-dasharray', + 'fill-opacity', + 'marker-start', + 'marker-end', + 'marker-mid' + ], + + // TODO: change the list to a function callback + MASK_REPLACE_TAGS: [ + 'FOREIGNOBJECT', + 'IMAGE', + 'USE', + 'TEXT', + 'TSPAN', + 'TEXTPATH' + ], + + // TODO: change the list to a function callback + MASK_REMOVE_TAGS: [ + 'TEXT', + 'TSPAN', + 'TEXTPATH' + ], + + transformMaskChild: function transformMaskChild(cellView, childEl) { + var ref = this; + var MASK_CHILD_ATTRIBUTE_BLACKLIST = ref.MASK_CHILD_ATTRIBUTE_BLACKLIST; + var MASK_REPLACE_TAGS = ref.MASK_REPLACE_TAGS; + var MASK_REMOVE_TAGS = ref.MASK_REMOVE_TAGS; + var childTagName = childEl.tagName(); + // Do not include the element in the mask's image + if (!V.isSVGGraphicsElement(childEl) || MASK_REMOVE_TAGS.includes(childTagName)) { + childEl.remove(); + return false; + } + // Replace the element with a rectangle + if (MASK_REPLACE_TAGS.includes(childTagName)) { + // Note: clone() method does not change the children ids + var originalChild = cellView.vel.findOne(("#" + (childEl.id))); + if (originalChild) { + var originalNode = originalChild.node; + var childBBox = cellView.getNodeBoundingRect(originalNode); + if (cellView.model.isElement()) { + childBBox = V.transformRect(childBBox, cellView.getNodeMatrix(originalNode)); + } + var replacement = V('rect', childBBox.toJSON()); + var ref$1 = childBBox.center(); + var ox = ref$1.x; + var oy = ref$1.y; + var ref$2 = originalChild.rotate(); + var angle = ref$2.angle; + var cx = ref$2.cx; if ( cx === void 0 ) cx = ox; + var cy = ref$2.cy; if ( cy === void 0 ) cy = oy; + if (angle) { replacement.rotate(angle, cx, cy); } + // Note: it's not important to keep the same sibling index since all subnodes are filled + childEl.parent().append(replacement); + } + childEl.remove(); + return false; + } + // Keep the element, but clean it from certain attributes + MASK_CHILD_ATTRIBUTE_BLACKLIST.forEach(function (attrName) { + if (attrName === 'fill' && childEl.attr('fill') === 'none') { return; } + childEl.removeAttr(attrName); + }); + return true; + }, + + transformMaskRoot: function transformMaskRoot(_cellView, rootEl) { + var ref = this; + var MASK_ROOT_ATTRIBUTE_BLACKLIST = ref.MASK_ROOT_ATTRIBUTE_BLACKLIST; + MASK_ROOT_ATTRIBUTE_BLACKLIST.forEach(function (attrName) { + rootEl.removeAttr(attrName); + }); + }, + + getMaskShape: function getMaskShape(cellView, vel) { + var this$1 = this; + + var ref = this; + var options = ref.options; + var MASK_REPLACE_TAGS = ref.MASK_REPLACE_TAGS; + var deep = options.deep; + var tagName = vel.tagName(); + var maskRoot; + if (tagName === 'G') { + if (!deep) { return null; } + maskRoot = vel.clone(); + forEachDescendant(maskRoot, function (maskChild) { return this$1.transformMaskChild(cellView, maskChild); }); + } else { + if (MASK_REPLACE_TAGS.includes(tagName)) { return null; } + maskRoot = vel.clone(); + } + this.transformMaskRoot(cellView, maskRoot); + return maskRoot; + }, + + getMaskId: function getMaskId() { + return ("highlight-mask-" + (this.cid)); + }, + + getMask: function getMask(cellView, vNode) { + + var ref = this; + var VISIBLE = ref.VISIBLE; + var INVISIBLE = ref.INVISIBLE; + var options = ref.options; + var padding = options.padding; + var attrs = options.attrs; + + var strokeWidth = ('stroke-width' in attrs) ? attrs['stroke-width'] : 1; + var hasNodeFill = vNode.attr('fill') !== 'none'; + var magnetStrokeWidth = parseFloat(vNode.attr('stroke-width')); + if (isNaN(magnetStrokeWidth)) { magnetStrokeWidth = 1; } + // stroke of the invisible shape + var minStrokeWidth = magnetStrokeWidth + padding * 2; + // stroke of the visible shape + var maxStrokeWidth = minStrokeWidth + strokeWidth * 2; + var maskEl = this.getMaskShape(cellView, vNode); + if (!maskEl) { + var nodeBBox = cellView.getNodeBoundingRect(vNode.node); + // Make sure the rect is visible + nodeBBox.inflate(nodeBBox.width ? 0 : 0.5, nodeBBox.height ? 0 : 0.5); + maskEl = V('rect', nodeBBox.toJSON()); + } + maskEl.attr(attrs); + return V('mask', { + 'id': this.getMaskId() + }).append([ + maskEl.clone().attr({ + 'fill': hasNodeFill ? VISIBLE : 'none', + 'stroke': VISIBLE, + 'stroke-width': maxStrokeWidth + }), + maskEl.clone().attr({ + 'fill': hasNodeFill ? INVISIBLE : 'none', + 'stroke': INVISIBLE, + 'stroke-width': minStrokeWidth + }) + ]); + }, + + removeMask: function removeMask(paper) { + var maskNode = paper.svg.getElementById(this.getMaskId()); + if (maskNode) { + paper.defs.removeChild(maskNode); + } + }, + + addMask: function addMask(paper, maskEl) { + paper.defs.appendChild(maskEl.node); + }, + + highlight: function highlight(cellView, node) { + var ref = this; + var options = ref.options; + var vel = ref.vel; + var padding = options.padding; + var attrs = options.attrs; + var maskClip = options.maskClip; if ( maskClip === void 0 ) maskClip = MASK_CLIP; + var layer = options.layer; + var color = ('stroke' in attrs) ? attrs['stroke'] : '#000000'; + if (!layer && node === cellView.el) { + // If the highlighter is appended to the cellView + // and we measure the size of the cellView wrapping group + // it's necessary to remove the highlighter first + vel.remove(); + } + var highlighterBBox = cellView.getNodeBoundingRect(node).inflate(padding + maskClip); + var highlightMatrix = this.getNodeMatrix(cellView, node); + var maskEl = this.getMask(cellView, V(node)); + this.addMask(cellView.paper, maskEl); + vel.attr(highlighterBBox.toJSON()); + vel.attr({ + 'transform': V.matrixToTransformString(highlightMatrix), + 'mask': ("url(#" + (maskEl.id) + ")"), + 'fill': color + }); + }, + + unhighlight: function unhighlight(cellView) { + this.removeMask(cellView.paper); + } + + }); + + var opacity = HighlighterView.extend({ + + UPDATABLE: false, + MOUNTABLE: false, + + opacityClassName: addClassNamePrefix('highlight-opacity'), + + highlight: function(_cellView, node) { + V(node).addClass(this.opacityClassName); + }, + + unhighlight: function(_cellView, node) { + V(node).removeClass(this.opacityClassName); + } + + }); + + var className = addClassNamePrefix('highlighted'); + + var addClass = HighlighterView.extend({ + + UPDATABLE: false, + MOUNTABLE: false, + + options: { + className: className + }, + + highlight: function(_cellView, node) { + V(node).addClass(this.options.className); + }, + + unhighlight: function(_cellView, node) { + V(node).removeClass(this.options.className); + } + + }, { + // Backwards Compatibility + className: className + }); + + var Directions$1 = { + ROW: 'row', + COLUMN: 'column' + }; + + var list = HighlighterView.extend({ + + tagName: 'g', + MOUNTABLE: true, + UPDATE_ATTRIBUTES: function() { + return [this.options.attribute]; + }, + + _prevItems: null, + + highlight: function highlight(elementView, node) { + var this$1 = this; + + var element = elementView.model; + var ref = this.options; + var attribute = ref.attribute; + var size = ref.size; if ( size === void 0 ) size = 20; + var gap = ref.gap; if ( gap === void 0 ) gap = 5; + var direction = ref.direction; if ( direction === void 0 ) direction = Directions$1.ROW; + if (!attribute) { throw new Error('List: attribute is required'); } + var normalizedSize = (typeof size === 'number') ? { width: size, height: size } : size; + var isRowDirection = (direction === Directions$1.ROW); + var itemWidth = isRowDirection ? normalizedSize.width : normalizedSize.height; + var items = element.get(attribute); + if (!Array.isArray(items)) { items = []; } + var prevItems = this._prevItems || []; + var comparison = items.map(function (item, index) { return isEqual(prevItems[index], items[index]); }); + if (prevItems.length !== items.length || comparison.some(function (unchanged) { return !unchanged; })) { + var prevEls = this.vel.children(); + var itemsEls = items.map(function (item, index) { + var prevEl = (index in prevEls) ? prevEls[index].node : null; + if (comparison[index]) { return prevEl; } + var itemEl = this$1.createListItem(item, normalizedSize, prevEl); + if (!itemEl) { return null; } + if (!(itemEl instanceof SVGElement)) { throw new Error('List: item must be an SVGElement'); } + itemEl.dataset.index = index; + itemEl.dataset.attribute = attribute; + var offset = index * (itemWidth + gap); + itemEl.setAttribute('transform', (isRowDirection) + ? ("translate(" + offset + ", 0)") + : ("translate(0, " + offset + ")") + ); + return itemEl; + }); + this.vel.empty().append(itemsEls); + this._prevItems = items; + } + var itemsCount = items.length; + var length = (itemsCount === 0) + ? 0 + : (itemsCount * itemWidth + (itemsCount - 1) * gap); + var listSize = (isRowDirection) + ? { width: length, height: normalizedSize.height } + : { width: normalizedSize.width, height: length }; + + this.position(element, listSize); + }, + + position: function position(element, listSize) { + var ref = this; + var vel = ref.vel; + var options = ref.options; + var margin = options.margin; if ( margin === void 0 ) margin = 5; + var position = options.position; if ( position === void 0 ) position = 'top-left'; + var ref$1 = element.size(); + var width = ref$1.width; + var height = ref$1.height; + var ref$2 = normalizeSides(margin); + var left = ref$2.left; + var right = ref$2.right; + var top = ref$2.top; + var bottom = ref$2.bottom; + var bbox = new Rect(left, top, width - (left + right), height - (top + bottom)); + var ref$3 = getRectPoint(bbox, position); + var x = ref$3.x; + var y = ref$3.y; + // x + switch (position) { + case Positions.CENTER: + case Positions.TOP: + case Positions.BOTTOM: { + x -= listSize.width / 2; + break; + } + case Positions.RIGHT: + case Positions.BOTTOM_RIGHT: + case Positions.TOP_RIGHT: { + x -= listSize.width; + break; + } + } + // y + switch (position) { + case Positions.CENTER: + case Positions.RIGHT: + case Positions.LEFT: { + y -= listSize.height / 2; + break; + } + case Positions.BOTTOM: + case Positions.BOTTOM_RIGHT: + case Positions.BOTTOM_LEFT: { + y -= listSize.height; + break; + } + } + vel.attr('transform', ("translate(" + x + ", " + y + ")")); + } + }, { + Directions: Directions$1, + Positions: Positions + }); + + + + var highlighters = ({ + stroke: stroke, + mask: mask, + opacity: opacity, + addClass: addClass, + list: list + }); + + function connectionRatio(view, _magnet, _refPoint, opt) { + + var ratio = ('ratio' in opt) ? opt.ratio : 0.5; + return view.getPointAtRatio(ratio); + } + + function connectionLength(view, _magnet, _refPoint, opt) { + + var length = ('length' in opt) ? opt.length : 20; + return view.getPointAtLength(length); + } + + function _connectionPerpendicular(view, _magnet, refPoint, opt) { + + var OFFSET = 1e6; + var path = view.getConnection(); + var segmentSubdivisions = view.getConnectionSubdivisions(); + var verticalLine = new Line(refPoint.clone().offset(0, OFFSET), refPoint.clone().offset(0, -OFFSET)); + var horizontalLine = new Line(refPoint.clone().offset(OFFSET, 0), refPoint.clone().offset(-OFFSET, 0)); + var verticalIntersections = verticalLine.intersect(path, { segmentSubdivisions: segmentSubdivisions }); + var horizontalIntersections = horizontalLine.intersect(path, { segmentSubdivisions: segmentSubdivisions }); + var intersections = []; + if (verticalIntersections) { Array.prototype.push.apply(intersections, verticalIntersections); } + if (horizontalIntersections) { Array.prototype.push.apply(intersections, horizontalIntersections); } + if (intersections.length > 0) { return refPoint.chooseClosest(intersections); } + if ('fallbackAt' in opt) { + return getPointAtLink(view, opt.fallbackAt); + } + return connectionClosest(view, _magnet, refPoint, opt); + } + + function _connectionClosest(view, _magnet, refPoint, _opt) { + + var closestPoint = view.getClosestPoint(refPoint); + if (!closestPoint) { return new Point(); } + return closestPoint; + } + + function resolveRef(fn) { + return function(view, magnet, ref, opt) { + if (ref instanceof Element) { + var refView = this.paper.findView(ref); + var refPoint; + if (refView) { + if (refView.isNodeConnection(ref)) { + var distance = ('fixedAt' in opt) ? opt.fixedAt : '50%'; + refPoint = getPointAtLink(refView, distance); + } else { + refPoint = refView.getNodeBBox(ref).center(); + } + } else { + // Something went wrong + refPoint = new Point(); + } + return fn.call(this, view, magnet, refPoint, opt); + } + return fn.apply(this, arguments); + }; + } + + function getPointAtLink(view, value) { + var parsedValue = parseFloat(value); + if (isPercentage(value)) { + return view.getPointAtRatio(parsedValue / 100); + } else { + return view.getPointAtLength(parsedValue); + } + } + var connectionPerpendicular = resolveRef(_connectionPerpendicular); + var connectionClosest = resolveRef(_connectionClosest); + + var linkAnchors = ({ + resolveRef: resolveRef, + connectionRatio: connectionRatio, + connectionLength: connectionLength, + connectionPerpendicular: connectionPerpendicular, + connectionClosest: connectionClosest + }); + + function offsetPoint(p1, p2, offset) { + if (isPlainObject(offset)) { + var x = offset.x; + var y = offset.y; + if (isFinite(y)) { + var line = new Line(p2, p1); + var ref = line.parallel(y); + var start = ref.start; + var end = ref.end; + p2 = start; + p1 = end; + } + offset = x; + } + if (!isFinite(offset)) { return p1; } + var length = p1.distance(p2); + if (offset === 0 && length > 0) { return p1; } + return p1.move(p2, -Math.min(offset, length - 1)); + } + + function stroke$1(magnet) { + + var stroke = magnet.getAttribute('stroke-width'); + if (stroke === null) { return 0; } + return parseFloat(stroke) || 0; + } + + function alignLine(line, type, offset) { + if ( offset === void 0 ) offset = 0; + + var coordinate, a, b, direction; + var start = line.start; + var end = line.end; + switch (type) { + case 'left': + coordinate = 'x'; + a = end; + b = start; + direction = -1; + break; + case 'right': + coordinate = 'x'; + a = start; + b = end; + direction = 1; + break; + case 'top': + coordinate = 'y'; + a = end; + b = start; + direction = -1; + break; + case 'bottom': + coordinate = 'y'; + a = start; + b = end; + direction = 1; + break; + default: + return; + } + if (start[coordinate] < end[coordinate]) { + a[coordinate] = b[coordinate]; + } else { + b[coordinate] = a[coordinate]; + } + if (isFinite(offset)) { + a[coordinate] += direction * offset; + b[coordinate] += direction * offset; + } + } + + // Connection Points + + function anchorConnectionPoint(line, _view, _magnet, opt) { + var offset = opt.offset; + var alignOffset = opt.alignOffset; + var align = opt.align; + if (align) { alignLine(line, align, alignOffset); } + return offsetPoint(line.end, line.start, offset); + } + + function bboxIntersection(line, view, magnet, opt) { + + var bbox = view.getNodeBBox(magnet); + if (opt.stroke) { bbox.inflate(stroke$1(magnet) / 2); } + var intersections = line.intersect(bbox); + var cp = (intersections) + ? line.start.chooseClosest(intersections) + : line.end; + return offsetPoint(cp, line.start, opt.offset); + } + + function rectangleIntersection(line, view, magnet, opt) { + + var angle = view.model.angle(); + if (angle === 0) { + return bboxIntersection(line, view, magnet, opt); + } + + var bboxWORotation = view.getNodeUnrotatedBBox(magnet); + if (opt.stroke) { bboxWORotation.inflate(stroke$1(magnet) / 2); } + var center = bboxWORotation.center(); + var lineWORotation = line.clone().rotate(center, angle); + var intersections = lineWORotation.setLength(1e6).intersect(bboxWORotation); + var cp = (intersections) + ? lineWORotation.start.chooseClosest(intersections).rotate(center, -angle) + : line.end; + return offsetPoint(cp, line.start, opt.offset); + } + + function findShapeNode(magnet) { + if (!magnet) { return null; } + var node = magnet; + do { + var tagName = node.tagName; + if (typeof tagName !== 'string') { return null; } + tagName = tagName.toUpperCase(); + if (tagName === 'G') { + node = node.firstElementChild; + } else if (tagName === 'TITLE') { + node = node.nextElementSibling; + } else { break; } + } while (node); + return node; + } + + var BNDR_SUBDIVISIONS = 'segmentSubdivisons'; + var BNDR_SHAPE_BBOX = 'shapeBBox'; + + function boundaryIntersection(line, view, magnet, opt) { + + var node, intersection; + var selector = opt.selector; + var anchor = line.end; + + if (typeof selector === 'string') { + node = view.findBySelector(selector)[0]; + } else if (Array.isArray(selector)) { + node = getByPath(magnet, selector); + } else { + node = findShapeNode(magnet); + } + + if (!V.isSVGGraphicsElement(node)) { + if (node === magnet || !V.isSVGGraphicsElement(magnet)) { return anchor; } + node = magnet; + } + + var localShape = view.getNodeShape(node); + var magnetMatrix = view.getNodeMatrix(node); + var translateMatrix = view.getRootTranslateMatrix(); + var rotateMatrix = view.getRootRotateMatrix(); + var targetMatrix = translateMatrix.multiply(rotateMatrix).multiply(magnetMatrix); + var localMatrix = targetMatrix.inverse(); + var localLine = V.transformLine(line, localMatrix); + var localRef = localLine.start.clone(); + var data = view.getNodeData(node); + + if (opt.insideout === false) { + if (!data[BNDR_SHAPE_BBOX]) { data[BNDR_SHAPE_BBOX] = localShape.bbox(); } + var localBBox = data[BNDR_SHAPE_BBOX]; + if (localBBox.containsPoint(localRef)) { return anchor; } + } + + // Caching segment subdivisions for paths + var pathOpt; + if (localShape instanceof Path) { + var precision = opt.precision || 2; + if (!data[BNDR_SUBDIVISIONS]) { data[BNDR_SUBDIVISIONS] = localShape.getSegmentSubdivisions({ precision: precision }); } + pathOpt = { + precision: precision, + segmentSubdivisions: data[BNDR_SUBDIVISIONS] + }; + } + + if (opt.extrapolate === true) { localLine.setLength(1e6); } + + intersection = localLine.intersect(localShape, pathOpt); + if (intersection) { + // More than one intersection + if (V.isArray(intersection)) { intersection = localRef.chooseClosest(intersection); } + } else if (opt.sticky === true) { + // No intersection, find the closest point instead + if (localShape instanceof Rect) { + intersection = localShape.pointNearestToPoint(localRef); + } else if (localShape instanceof Ellipse) { + intersection = localShape.intersectionWithLineFromCenterToPoint(localRef); + } else { + intersection = localShape.closestPoint(localRef, pathOpt); + } + } + + var cp = (intersection) ? V.transformPoint(intersection, targetMatrix) : anchor; + var cpOffset = opt.offset || 0; + if (opt.stroke) { cpOffset += stroke$1(node) / 2; } + + return offsetPoint(cp, line.start, cpOffset); + } + + var anchor = anchorConnectionPoint; + var bbox = bboxIntersection; + var rectangle = rectangleIntersection; + var boundary = boundaryIntersection; + + var connectionPoints = ({ + anchor: anchor, + bbox: bbox, + rectangle: rectangle, + boundary: boundary + }); + + function bboxWrapper(method) { + + return function(view, magnet, ref, opt) { + + var rotate = !!opt.rotate; + var bbox = (rotate) ? view.getNodeUnrotatedBBox(magnet) : view.getNodeBBox(magnet); + var anchor = bbox[method](); + + var dx = opt.dx; + if (dx) { + var dxPercentage = isPercentage(dx); + dx = parseFloat(dx); + if (isFinite(dx)) { + if (dxPercentage) { + dx /= 100; + dx *= bbox.width; + } + anchor.x += dx; + } + } + + var dy = opt.dy; + if (dy) { + var dyPercentage = isPercentage(dy); + dy = parseFloat(dy); + if (isFinite(dy)) { + if (dyPercentage) { + dy /= 100; + dy *= bbox.height; + } + anchor.y += dy; + } + } + + return (rotate) ? anchor.rotate(view.model.getBBox().center(), -view.model.angle()) : anchor; + }; + } + + function _perpendicular(view, magnet, refPoint, opt) { + + var angle = view.model.angle(); + var bbox = view.getNodeBBox(magnet); + var anchor = bbox.center(); + var topLeft = bbox.origin(); + var bottomRight = bbox.corner(); + + var padding = opt.padding; + if (!isFinite(padding)) { padding = 0; } + + if ((topLeft.y + padding) <= refPoint.y && refPoint.y <= (bottomRight.y - padding)) { + var dy = (refPoint.y - anchor.y); + anchor.x += (angle === 0 || angle === 180) ? 0 : dy * 1 / Math.tan(toRad(angle)); + anchor.y += dy; + } else if ((topLeft.x + padding) <= refPoint.x && refPoint.x <= (bottomRight.x - padding)) { + var dx = (refPoint.x - anchor.x); + anchor.y += (angle === 90 || angle === 270) ? 0 : dx * Math.tan(toRad(angle)); + anchor.x += dx; + } + + return anchor; + } + + function _midSide(view, magnet, refPoint, opt) { + + var rotate = !!opt.rotate; + var bbox, angle, center; + if (rotate) { + bbox = view.getNodeUnrotatedBBox(magnet); + center = view.model.getBBox().center(); + angle = view.model.angle(); + } else { + bbox = view.getNodeBBox(magnet); + } + + var padding = opt.padding; + if (isFinite(padding)) { bbox.inflate(padding); } + + if (rotate) { refPoint.rotate(center, angle); } + + var side = bbox.sideNearestToPoint(refPoint); + var anchor; + switch (side) { + case 'left': + anchor = bbox.leftMiddle(); + break; + case 'right': + anchor = bbox.rightMiddle(); + break; + case 'top': + anchor = bbox.topMiddle(); + break; + case 'bottom': + anchor = bbox.bottomMiddle(); + break; + } + + return (rotate) ? anchor.rotate(center, -angle) : anchor; + } + + // Can find anchor from model, when there is no selector or the link end + // is connected to a port + function _modelCenter(view, _magnet, _refPoint, opt, endType) { + return view.model.getPointFromConnectedLink(this.model, endType).offset(opt.dx, opt.dy); + } + + //joint.anchors + var center = bboxWrapper('center'); + var top$2 = bboxWrapper('topMiddle'); + var bottom$2 = bboxWrapper('bottomMiddle'); + var left$2 = bboxWrapper('leftMiddle'); + var right$2 = bboxWrapper('rightMiddle'); + var topLeft = bboxWrapper('origin'); + var topRight = bboxWrapper('topRight'); + var bottomLeft = bboxWrapper('bottomLeft'); + var bottomRight = bboxWrapper('corner'); + var perpendicular = resolveRef(_perpendicular); + var midSide = resolveRef(_midSide); + var modelCenter = _modelCenter; + + var anchors = ({ + center: center, + top: top$2, + bottom: bottom$2, + left: left$2, + right: right$2, + topLeft: topLeft, + topRight: topRight, + bottomLeft: bottomLeft, + bottomRight: bottomRight, + perpendicular: perpendicular, + midSide: midSide, + modelCenter: modelCenter + }); + + var sortingTypes = { + NONE: 'sorting-none', + APPROX: 'sorting-approximate', + EXACT: 'sorting-exact' + }; + + var WHEEL_CAP = 50; + var WHEEL_WAIT_MS = 20; + var MOUNT_BATCH_SIZE = 1000; + var UPDATE_BATCH_SIZE = Infinity; + var MIN_PRIORITY = 9007199254740991; // Number.MAX_SAFE_INTEGER + + var HighlightingTypes$1 = CellView.Highlighting; + + var defaultHighlighting = {}; + defaultHighlighting[HighlightingTypes$1.DEFAULT] = { + name: 'stroke', + options: { + padding: 3 + } + }; + defaultHighlighting[HighlightingTypes$1.MAGNET_AVAILABILITY] = { + name: 'addClass', + options: { + className: 'available-magnet' + } + }; + defaultHighlighting[HighlightingTypes$1.ELEMENT_AVAILABILITY] = { + name: 'addClass', + options: { + className: 'available-cell' + } + }; + + var defaultLayers = [{ + name: LayersNames.BACK, + }, { + name: LayersNames.CELLS, + }, { + name: LayersNames.LABELS, + }, { + name: LayersNames.FRONT + }, { + name: LayersNames.TOOLS + }]; + + var Paper = View.extend({ + + className: 'paper', + + options: { + + width: 800, + height: 600, + origin: { x: 0, y: 0 }, // x,y coordinates in top-left corner + gridSize: 1, + + // Whether or not to draw the grid lines on the paper's DOM element. + // e.g drawGrid: true, drawGrid: { color: 'red', thickness: 2 } + drawGrid: false, + + // Whether or not to draw the background on the paper's DOM element. + // e.g. background: { color: 'lightblue', image: '/paper-background.png', repeat: 'flip-xy' } + background: false, + + perpendicularLinks: false, + elementView: ElementView, + linkView: LinkView, + snapLabels: false, // false, true + snapLinks: false, // false, true, { radius: value } + snapLinksSelf: false, // false, true, { radius: value } + + // Should the link labels be rendered into its own layer? + // `false` - the labels are part of the links + // `true` - the labels are appended to LayersName.LABELS + // [LayersName] - the labels are appended to the layer specified + labelsLayer: false, + + // When set to FALSE, an element may not have more than 1 link with the same source and target element. + multiLinks: true, + + // For adding custom guard logic. + guard: function(evt, view) { + + // FALSE means the event isn't guarded. + return false; + }, + + highlighting: defaultHighlighting, + + // Prevent the default context menu from being displayed. + preventContextMenu: true, + + // Prevent the default action for blank:pointer. + preventDefaultBlankAction: true, + + // Restrict the translation of elements by given bounding box. + // Option accepts a boolean: + // true - the translation is restricted to the paper area + // false - no restrictions + // A method: + // restrictTranslate: function(elementView) { + // var parentId = elementView.model.get('parent'); + // return parentId && this.model.getCell(parentId).getBBox(); + // }, + // Or a bounding box: + // restrictTranslate: { x: 10, y: 10, width: 790, height: 590 } + restrictTranslate: false, + + // Marks all available magnets with 'available-magnet' class name and all available cells with + // 'available-cell' class name. Marks them when dragging a link is started and unmark + // when the dragging is stopped. + markAvailable: false, + + // Defines what link model is added to the graph after an user clicks on an active magnet. + // Value could be the Backbone.model or a function returning the Backbone.model + // defaultLink: function(elementView, magnet) { return condition ? new customLink1() : new customLink2() } + defaultLink: new Link, + + // A connector that is used by links with no connector defined on the model. + // e.g. { name: 'rounded', args: { radius: 5 }} or a function + defaultConnector: { name: 'normal' }, + + // A router that is used by links with no router defined on the model. + // e.g. { name: 'oneSide', args: { padding: 10 }} or a function + defaultRouter: { name: 'normal' }, + + defaultAnchor: { name: 'center' }, + + defaultLinkAnchor: { name: 'connectionRatio' }, + + defaultConnectionPoint: { name: 'bbox' }, + + /* CONNECTING */ + + connectionStrategy: null, + + // Check whether to add a new link to the graph when user clicks on an a magnet. + validateMagnet: function(_cellView, magnet, _evt) { + return magnet.getAttribute('magnet') !== 'passive'; + }, + + // Check whether to allow or disallow the link connection while an arrowhead end (source/target) + // being changed. + validateConnection: function(cellViewS, _magnetS, cellViewT, _magnetT, end, _linkView) { + return (end === 'target' ? cellViewT : cellViewS) instanceof ElementView; + }, + + /* EMBEDDING */ + + // Enables embedding. Re-parent the dragged element with elements under it and makes sure that + // all links and elements are visible taken the level of embedding into account. + embeddingMode: false, + + // Check whether to allow or disallow the element embedding while an element being translated. + validateEmbedding: function(childView, parentView) { + // by default all elements can be in relation child-parent + return true; + }, + + // Check whether to allow or disallow an embedded element to be unembedded / to become a root. + validateUnembedding: function(childView) { + // by default all elements can become roots + return true; + }, + + // Determines the way how a cell finds a suitable parent when it's dragged over the paper. + // The cell with the highest z-index (visually on the top) will be chosen. + findParentBy: 'bbox', // 'bbox'|'center'|'origin'|'corner'|'topRight'|'bottomLeft' + + // If enabled only the element on the very front is taken into account for the embedding. + // If disabled the elements under the dragged view are tested one by one + // (from front to back) until a valid parent found. + frontParentOnly: true, + + // Interactive flags. See online docs for the complete list of interactive flags. + interactive: { + labelMove: false + }, + + // When set to true the links can be pinned to the paper. + // i.e. link source/target can be a point e.g. link.get('source') ==> { x: 100, y: 100 }; + linkPinning: true, + + // Custom validation after an interaction with a link ends. + // Recognizes a function. If `false` is returned, the link is disallowed (removed or reverted) + // (linkView, paper) => boolean + allowLink: null, + + // Allowed number of mousemove events after which the pointerclick event will be still triggered. + clickThreshold: 0, + + // Number of required mousemove events before the first pointermove event will be triggered. + moveThreshold: 0, + + // Number of required mousemove events before the a link is created out of the magnet. + // Or string `onleave` so the link is created when the pointer leaves the magnet + magnetThreshold: 0, + + // Rendering Options + + sorting: sortingTypes.EXACT, + + frozen: false, + + // no docs yet + onViewUpdate: function(view, flag, priority, opt, paper) { + // Do not update connected links when: + // 1. the view was just inserted (added to the graph and rendered) + // 2. the view was just mounted (added back to the paper by viewport function) + // 3. the change was marked as `isolate`. + // 4. the view model was just removed from the graph + if ((flag & (view.FLAG_INSERT | view.FLAG_REMOVE)) || opt.mounting || opt.isolate) { return; } + paper.requestConnectedLinksUpdate(view, priority, opt); + }, + + // no docs yet + onViewPostponed: function(view, flag, paper) { + return paper.forcePostponedViewUpdate(view, flag); + }, + + beforeRender: null, // function(opt, paper) { }, + + afterRender: null, // function(stats, opt, paper) { + + viewport: null, + + // Default namespaces + + cellViewNamespace: null, + + routerNamespace: null, + + connectorNamespace: null, + + highlighterNamespace: highlighters, + + anchorNamespace: anchors, + + linkAnchorNamespace: linkAnchors, + + connectionPointNamespace: connectionPoints + }, + + events: { + 'dblclick': 'pointerdblclick', + 'dbltap': 'pointerdblclick', + 'contextmenu': 'contextmenu', + 'mousedown': 'pointerdown', + 'touchstart': 'pointerdown', + 'mouseover': 'mouseover', + 'mouseout': 'mouseout', + 'mouseenter': 'mouseenter', + 'mouseleave': 'mouseleave', + 'wheel': 'mousewheel', + 'mouseenter .joint-cell': 'mouseenter', + 'mouseleave .joint-cell': 'mouseleave', + 'mouseenter .joint-tools': 'mouseenter', + 'mouseleave .joint-tools': 'mouseleave', + 'mousedown .joint-cell [event]': 'onevent', // interaction with cell with `event` attribute set + 'touchstart .joint-cell [event]': 'onevent', + 'mousedown .joint-cell [magnet]': 'onmagnet', // interaction with cell with `magnet` attribute set + 'touchstart .joint-cell [magnet]': 'onmagnet', + 'dblclick .joint-cell [magnet]': 'magnetpointerdblclick', + 'contextmenu .joint-cell [magnet]': 'magnetcontextmenu', + 'mousedown .joint-link .label': 'onlabel', // interaction with link label + 'touchstart .joint-link .label': 'onlabel', + 'dragstart .joint-cell image': 'onImageDragStart' // firefox fix + }, + + documentEvents: { + 'mousemove': 'pointermove', + 'touchmove': 'pointermove', + 'mouseup': 'pointerup', + 'touchend': 'pointerup', + 'touchcancel': 'pointerup' + }, + + svg: null, + viewport: null, + defs: null, + tools: null, + $background: null, + layers: null, + $grid: null, + $document: null, + + // For storing the current transformation matrix (CTM) of the paper's viewport. + _viewportMatrix: null, + // For verifying whether the CTM is up-to-date. The viewport transform attribute + // could have been manipulated directly. + _viewportTransformString: null, + // Updates data (priorities, unmounted views etc.) + _updates: null, + // Paper Layers + _layers: null, + + SORT_DELAYING_BATCHES: ['add', 'to-front', 'to-back'], + UPDATE_DELAYING_BATCHES: ['translate'], + MIN_SCALE: 1e-6, + + init: function() { + + var ref = this; + var options = ref.options; + var el = ref.el; + if (!options.cellViewNamespace) { + /* eslint-disable no-undef */ + options.cellViewNamespace = typeof joint !== 'undefined' && has$2(joint, 'shapes') ? joint.shapes : null; + /* eslint-enable no-undef */ + } + + var model = this.model = options.model || new Graph; + + // Layers (SVGGroups) + this._layers = {}; + + this.setGrid(options.drawGrid); + this.cloneOptions(); + this.render(); + this._setDimensions(); + this.startListening(); + + // Hash of all cell views. + this._views = {}; + + // Mouse wheel events buffer + this._mw_evt_buffer = { + event: null, + deltas: [], + }; + + // Reference to the paper owner document + this.$document = $(el.ownerDocument); + // Render existing cells in the graph + this.resetViews(model.attributes.cells.models); + // Start the Rendering Loop + if (!this.isFrozen() && this.isAsync()) { this.updateViewsAsync(); } + }, + + _resetUpdates: function() { + return this._updates = { + id: null, + priorities: [{}, {}, {}], + unmountedCids: [], + mountedCids: [], + unmounted: {}, + mounted: {}, + count: 0, + keyFrozen: false, + freezeKey: null, + sort: false + }; + }, + + startListening: function() { + var model = this.model; + this.listenTo(model, 'add', this.onCellAdded) + .listenTo(model, 'remove', this.onCellRemoved) + .listenTo(model, 'change', this.onCellChange) + .listenTo(model, 'reset', this.onGraphReset) + .listenTo(model, 'sort', this.onGraphSort) + .listenTo(model, 'batch:stop', this.onGraphBatchStop); + this.on('cell:highlight', this.onCellHighlight) + .on('cell:unhighlight', this.onCellUnhighlight) + .on('scale translate', this.update); + }, + + onCellAdded: function(cell, _, opt) { + var position = opt.position; + if (this.isAsync() || !isNumber(position)) { + this.renderView(cell, opt); + } else { + if (opt.maxPosition === position) { this.freeze({ key: 'addCells' }); } + this.renderView(cell, opt); + if (position === 0) { this.unfreeze({ key: 'addCells' }); } + } + }, + + onCellRemoved: function(cell, _, opt) { + var view = this.findViewByModel(cell); + if (view) { this.requestViewUpdate(view, view.FLAG_REMOVE, view.UPDATE_PRIORITY, opt); } + }, + + onCellChange: function(cell, opt) { + if (cell === this.model.attributes.cells) { return; } + if (cell.hasChanged('z') && this.options.sorting === sortingTypes.APPROX) { + var view = this.findViewByModel(cell); + if (view) { this.requestViewUpdate(view, view.FLAG_INSERT, view.UPDATE_PRIORITY, opt); } + } + }, + + onGraphReset: function(collection, opt) { + this.resetLayers(); + this.resetViews(collection.models, opt); + }, + + onGraphSort: function() { + if (this.model.hasActiveBatch(this.SORT_DELAYING_BATCHES)) { return; } + this.sortViews(); + }, + + onGraphBatchStop: function(data) { + if (this.isFrozen()) { return; } + var name = data && data.batchName; + var graph = this.model; + if (!this.isAsync()) { + var updateDelayingBatches = this.UPDATE_DELAYING_BATCHES; + if (updateDelayingBatches.includes(name) && !graph.hasActiveBatch(updateDelayingBatches)) { + this.updateViews(data); + } + } + var sortDelayingBatches = this.SORT_DELAYING_BATCHES; + if (sortDelayingBatches.includes(name) && !graph.hasActiveBatch(sortDelayingBatches)) { + this.sortViews(); + } + }, + + cloneOptions: function() { + + var ref = this; + var options = ref.options; + var defaultConnector = options.defaultConnector; + var defaultRouter = options.defaultRouter; + var defaultConnectionPoint = options.defaultConnectionPoint; + var defaultAnchor = options.defaultAnchor; + var defaultLinkAnchor = options.defaultLinkAnchor; + var origin = options.origin; + var highlighting = options.highlighting; + var cellViewNamespace = options.cellViewNamespace; + var interactive = options.interactive; + + // Default cellView namespace for ES5 + /* eslint-disable no-undef */ + if (!cellViewNamespace && typeof joint !== 'undefined' && has$2(joint, 'shapes')) { + options.cellViewNamespace = joint.shapes; + } + /* eslint-enable no-undef */ + + // Here if a function was provided, we can not clone it, as this would result in loosing the function. + // If the default is used, the cloning is necessary in order to prevent modifying the options on prototype. + if (!isFunction(defaultConnector)) { + options.defaultConnector = cloneDeep(defaultConnector); + } + if (!isFunction(defaultRouter)) { + options.defaultRouter = cloneDeep(defaultRouter); + } + if (!isFunction(defaultConnectionPoint)) { + options.defaultConnectionPoint = cloneDeep(defaultConnectionPoint); + } + if (!isFunction(defaultAnchor)) { + options.defaultAnchor = cloneDeep(defaultAnchor); + } + if (!isFunction(defaultLinkAnchor)) { + options.defaultLinkAnchor = cloneDeep(defaultLinkAnchor); + } + if (isPlainObject(interactive)) { + options.interactive = assign({}, interactive); + } + if (isPlainObject(highlighting)) { + // Return the default highlighting options into the user specified options. + options.highlighting = defaultsDeep({}, highlighting, defaultHighlighting); + } + options.origin = assign({}, origin); + }, + + children: function() { + var ns = V.namespace; + return [{ + namespaceURI: ns.xhtml, + tagName: 'div', + className: addClassNamePrefix('paper-background'), + selector: 'background' + }, { + namespaceURI: ns.xhtml, + tagName: 'div', + className: addClassNamePrefix('paper-grid'), + selector: 'grid' + }, { + namespaceURI: ns.svg, + tagName: 'svg', + attributes: { + 'width': '100%', + 'height': '100%', + 'xmlns:xlink': ns.xlink + }, + selector: 'svg', + children: [{ + // Append `` element to the SVG document. This is useful for filters and gradients. + // It's desired to have the defs defined before the viewport (e.g. to make a PDF document pick up defs properly). + tagName: 'defs', + selector: 'defs' + }, { + tagName: 'g', + className: addClassNamePrefix('layers'), + selector: 'layers' + }] + }]; + }, + + hasLayerView: function hasLayerView(layerName) { + return (layerName in this._layers); + }, + + getLayerView: function getLayerView(layerName) { + var ref = this; + var _layers = ref._layers; + if (layerName in _layers) { return _layers[layerName]; } + throw new Error(("dia.Paper: Unknown layer \"" + layerName + "\"")); + }, + + getLayerNode: function getLayerNode(layerName) { + return this.getLayerView(layerName).el; + }, + + render: function() { + + this.renderChildren(); + var ref = this; + var childNodes = ref.childNodes; + var options = ref.options; + var svg = childNodes.svg; + var defs = childNodes.defs; + var layers = childNodes.layers; + var background = childNodes.background; + var grid = childNodes.grid; + + this.svg = svg; + this.defs = defs; + this.layers = layers; + this.$background = $(background); + this.$grid = $(grid); + + this.renderLayers(); + + V.ensureId(svg); + + if (options.background) { + this.drawBackground(options.background); + } + + if (options.drawGrid) { + this.drawGrid(); + } + + return this; + }, + + renderLayers: function(layers) { + var this$1 = this; + if ( layers === void 0 ) layers = defaultLayers; + + this.removeLayers(); + // TODO: Layers to be read from the graph `layers` attribute + layers.forEach(function (ref) { + var name = ref.name; + var sorted = ref.sorted; + + var layerView = new PaperLayer({ name: name }); + this$1.layers.appendChild(layerView.el); + this$1._layers[name] = layerView; + }); + // Throws an exception if doesn't exist + var cellsLayerView = this.getLayerView(LayersNames.CELLS); + var toolsLayerView = this.getLayerView(LayersNames.TOOLS); + var labelsLayerView = this.getLayerView(LayersNames.LABELS); + // backwards compatibility + this.tools = toolsLayerView.el; + this.cells = this.viewport = cellsLayerView.el; + // user-select: none; + cellsLayerView.vel.addClass(addClassNamePrefix('viewport')); + labelsLayerView.vel.addClass(addClassNamePrefix('viewport')); + }, + + removeLayers: function() { + var ref = this; + var _layers = ref._layers; + Object.keys(_layers).forEach(function (name) { + _layers[name].remove(); + delete _layers[name]; + }); + }, + + resetLayers: function() { + var ref = this; + var _layers = ref._layers; + Object.keys(_layers).forEach(function (name) { + _layers[name].removePivots(); + }); + }, + + update: function() { + + if (this.options.drawGrid) { + this.drawGrid(); + } + + if (this._background) { + this.updateBackgroundImage(this._background); + } + + return this; + }, + + matrix: function(ctm) { + + var viewport = this.layers; + + // Getter: + if (ctm === undefined) { + + var transformString = viewport.getAttribute('transform'); + + if ((this._viewportTransformString || null) === transformString) { + // It's ok to return the cached matrix. The transform attribute has not changed since + // the matrix was stored. + ctm = this._viewportMatrix; + } else { + // The viewport transform attribute has changed. Measure the matrix and cache again. + ctm = viewport.getCTM(); + this._viewportMatrix = ctm; + this._viewportTransformString = transformString; + } + + // Clone the cached current transformation matrix. + // If no matrix previously stored the identity matrix is returned. + return V.createSVGMatrix(ctm); + } + + // Setter: + ctm = V.createSVGMatrix(ctm); + var ctmString = V.matrixToTransformString(ctm); + viewport.setAttribute('transform', ctmString); + + this._viewportMatrix = ctm; + this._viewportTransformString = viewport.getAttribute('transform'); + + return this; + }, + + clientMatrix: function() { + + return V.createSVGMatrix(this.cells.getScreenCTM()); + }, + + requestConnectedLinksUpdate: function(view, priority, opt) { + if (view instanceof CellView) { + var model = view.model; + var links = this.model.getConnectedLinks(model); + for (var j = 0, n = links.length; j < n; j++) { + var link = links[j]; + var linkView = this.findViewByModel(link); + if (!linkView) { continue; } + var flagLabels = ['UPDATE']; + if (link.getTargetCell() === model) { flagLabels.push('TARGET'); } + if (link.getSourceCell() === model) { flagLabels.push('SOURCE'); } + var nextPriority = Math.max(priority + 1, linkView.UPDATE_PRIORITY); + this.scheduleViewUpdate(linkView, linkView.getFlag(flagLabels), nextPriority, opt); + } + } + }, + + forcePostponedViewUpdate: function(view, flag) { + if (!view || !(view instanceof CellView)) { return false; } + var model = view.model; + if (model.isElement()) { return false; } + if ((flag & view.getFlag(['SOURCE', 'TARGET'])) === 0) { + // LinkView is waiting for the target or the source cellView to be rendered + // This can happen when the cells are not in the viewport. + var sourceFlag = 0; + var sourceView = this.findViewByModel(model.getSourceCell()); + if (sourceView && !this.isViewMounted(sourceView)) { + sourceFlag = this.dumpView(sourceView); + view.updateEndMagnet('source'); + } + var targetFlag = 0; + var targetView = this.findViewByModel(model.getTargetCell()); + if (targetView && !this.isViewMounted(targetView)) { + targetFlag = this.dumpView(targetView); + view.updateEndMagnet('target'); + } + if (sourceFlag === 0 && targetFlag === 0) { + // If leftover flag is 0, all view updates were done. + return !this.dumpView(view); + } + } + return false; + }, + + requestViewUpdate: function(view, flag, priority, opt) { + opt || (opt = {}); + this.scheduleViewUpdate(view, flag, priority, opt); + var isAsync = this.isAsync(); + if (this.isFrozen() || (isAsync && opt.async !== false)) { return; } + if (this.model.hasActiveBatch(this.UPDATE_DELAYING_BATCHES)) { return; } + var stats = this.updateViews(opt); + if (isAsync) { this.notifyAfterRender(stats, opt); } + }, + + scheduleViewUpdate: function(view, type, priority, opt) { + var ref = this; + var updates = ref._updates; + var options = ref.options; + var FLAG_REMOVE = view.FLAG_REMOVE; + var FLAG_INSERT = view.FLAG_INSERT; + var UPDATE_PRIORITY = view.UPDATE_PRIORITY; + var cid = view.cid; + var priorityUpdates = updates.priorities[priority]; + if (!priorityUpdates) { priorityUpdates = updates.priorities[priority] = {}; } + // Move higher priority updates to this priority + if (priority > UPDATE_PRIORITY) { + // Not the default priority for this view. It's most likely a link view + // connected to another link view, which triggered the update. + // TODO: If there is an update scheduled with a lower priority already, we should + // change the requested priority to the lowest one. Does not seem to be critical + // right now, as it "only" results in multiple updates on the same view. + for (var i = priority - 1; i >= UPDATE_PRIORITY; i--) { + var prevPriorityUpdates = updates.priorities[i]; + if (!prevPriorityUpdates || !(cid in prevPriorityUpdates)) { continue; } + priorityUpdates[cid] |= prevPriorityUpdates[cid]; + delete prevPriorityUpdates[cid]; + } + } + var currentType = priorityUpdates[cid] || 0; + // Prevent cycling + if ((currentType & type) === type) { return; } + if (!currentType) { updates.count++; } + if (type & FLAG_REMOVE && currentType & FLAG_INSERT) { + // When a view is removed we need to remove the insert flag as this is a reinsert + priorityUpdates[cid] ^= FLAG_INSERT; + } else if (type & FLAG_INSERT && currentType & FLAG_REMOVE) { + // When a view is added we need to remove the remove flag as this is view was previously removed + priorityUpdates[cid] ^= FLAG_REMOVE; + } + priorityUpdates[cid] |= type; + var viewUpdateFn = options.onViewUpdate; + if (typeof viewUpdateFn === 'function') { viewUpdateFn.call(this, view, type, priority, opt || {}, this); } + }, + + dumpViewUpdate: function(view) { + if (!view) { return 0; } + var updates = this._updates; + var cid = view.cid; + var priorityUpdates = updates.priorities[view.UPDATE_PRIORITY]; + var flag = this.registerMountedView(view) | priorityUpdates[cid]; + delete priorityUpdates[cid]; + return flag; + }, + + dumpView: function(view, opt) { + var flag = this.dumpViewUpdate(view); + if (!flag) { return 0; } + return this.updateView(view, flag, opt); + }, + + updateView: function(view, flag, opt) { + if (!view) { return 0; } + var FLAG_REMOVE = view.FLAG_REMOVE; + var FLAG_INSERT = view.FLAG_INSERT; + var model = view.model; + if (view instanceof CellView) { + if (flag & FLAG_REMOVE) { + this.removeView(model); + return 0; + } + if (flag & FLAG_INSERT) { + this.insertView(view); + flag ^= FLAG_INSERT; + } + } + if (!flag) { return 0; } + return view.confirmUpdate(flag, opt || {}); + }, + + requireView: function(model, opt) { + var view = this.findViewByModel(model); + if (!view) { return null; } + this.dumpView(view, opt); + return view; + }, + + registerUnmountedView: function(view) { + var cid = view.cid; + var updates = this._updates; + if (cid in updates.unmounted) { return 0; } + var flag = updates.unmounted[cid] |= view.FLAG_INSERT; + updates.unmountedCids.push(cid); + delete updates.mounted[cid]; + return flag; + }, + + registerMountedView: function(view) { + var cid = view.cid; + var updates = this._updates; + if (cid in updates.mounted) { return 0; } + updates.mounted[cid] = true; + updates.mountedCids.push(cid); + var flag = updates.unmounted[cid] || 0; + delete updates.unmounted[cid]; + return flag; + }, + + isViewMounted: function(view) { + if (!view) { return false; } + var cid = view.cid; + var updates = this._updates; + return (cid in updates.mounted); + }, + + dumpViews: function(opt) { + var passingOpt = defaults({}, opt, { viewport: null }); + this.checkViewport(passingOpt); + this.updateViews(passingOpt); + }, + + // Synchronous views update + updateViews: function(opt) { + this.notifyBeforeRender(opt); + var batchStats; + var updateCount = 0; + var batchCount = 0; + var priority = MIN_PRIORITY; + do { + batchCount++; + batchStats = this.updateViewsBatch(opt); + updateCount += batchStats.updated; + priority = Math.min(batchStats.priority, priority); + } while (!batchStats.empty); + var stats = { updated: updateCount, batches: batchCount, priority: priority }; + this.notifyAfterRender(stats, opt); + return stats; + }, + + hasScheduledUpdates: function() { + var priorities = this._updates.priorities; + var priorityIndexes = Object.keys(priorities); // convert priorities to a dense array + var i = priorityIndexes.length; + while (i > 0 && i--) { + // a faster way how to check if an object is empty + for (var _key in priorities[priorityIndexes[i]]) { return true; } + } + return false; + }, + + updateViewsAsync: function(opt, data) { + opt || (opt = {}); + data || (data = { processed: 0, priority: MIN_PRIORITY }); + var updates = this._updates; + var id = updates.id; + if (id) { + cancelFrame(id); + if (data.processed === 0 && this.hasScheduledUpdates()) { + this.notifyBeforeRender(opt); + } + var stats = this.updateViewsBatch(opt); + var passingOpt = defaults({}, opt, { + mountBatchSize: MOUNT_BATCH_SIZE - stats.mounted, + unmountBatchSize: MOUNT_BATCH_SIZE - stats.unmounted + }); + var checkStats = this.checkViewport(passingOpt); + var unmountCount = checkStats.unmounted; + var mountCount = checkStats.mounted; + var processed = data.processed; + var total = updates.count; + if (stats.updated > 0) { + // Some updates have been just processed + processed += stats.updated + stats.unmounted; + stats.processed = processed; + data.priority = Math.min(stats.priority, data.priority); + if (stats.empty && mountCount === 0) { + stats.unmounted += unmountCount; + stats.mounted += mountCount; + stats.priority = data.priority; + this.notifyAfterRender(stats, opt); + data.processed = 0; + data.priority = MIN_PRIORITY; + updates.count = 0; + } else { + data.processed = processed; + } + } + // Progress callback + var progressFn = opt.progress; + if (total && typeof progressFn === 'function') { + progressFn.call(this, stats.empty, processed, total, stats, this); + } + // The current frame could have been canceled in a callback + if (updates.id !== id) { return; } + } + updates.id = nextFrame(this.updateViewsAsync, this, opt, data); + }, + + notifyBeforeRender: function(opt) { + if ( opt === void 0 ) opt = {}; + + var beforeFn = opt.beforeRender; + if (typeof beforeFn !== 'function') { + beforeFn = this.options.beforeRender; + if (typeof beforeFn !== 'function') { return; } + } + beforeFn.call(this, opt, this); + }, + + notifyAfterRender: function(stats, opt) { + if ( opt === void 0 ) opt = {}; + + var afterFn = opt.afterRender; + if (typeof afterFn !== 'function') { + afterFn = this.options.afterRender; + } + if (typeof afterFn === 'function') { + afterFn.call(this, stats, opt, this); + } + this.trigger('render:done', stats, opt); + }, + + updateViewsBatch: function(opt) { + opt || (opt = {}); + var batchSize = opt.batchSize || UPDATE_BATCH_SIZE; + var updates = this._updates; + var updateCount = 0; + var postponeCount = 0; + var unmountCount = 0; + var mountCount = 0; + var maxPriority = MIN_PRIORITY; + var empty = true; + var options = this.options; + var priorities = updates.priorities; + var viewportFn = 'viewport' in opt ? opt.viewport : options.viewport; + if (typeof viewportFn !== 'function') { viewportFn = null; } + var postponeViewFn = options.onViewPostponed; + if (typeof postponeViewFn !== 'function') { postponeViewFn = null; } + var priorityIndexes = Object.keys(priorities); // convert priorities to a dense array + main: for (var i = 0, n = priorityIndexes.length; i < n; i++) { + var priority = +priorityIndexes[i]; + var priorityUpdates = priorities[priority]; + for (var cid in priorityUpdates) { + if (updateCount >= batchSize) { + empty = false; + break main; + } + var view = views[cid]; + if (!view) { + // This should not occur + delete priorityUpdates[cid]; + continue; + } + var currentFlag = priorityUpdates[cid]; + if ((currentFlag & view.FLAG_REMOVE) === 0) { + // We should never check a view for viewport if we are about to remove the view + var isDetached = cid in updates.unmounted; + if (view.DETACHABLE && viewportFn && !viewportFn.call(this, view, !isDetached, this)) { + // Unmount View + if (!isDetached) { + this.registerUnmountedView(view); + view.unmount(); + } + updates.unmounted[cid] |= currentFlag; + delete priorityUpdates[cid]; + unmountCount++; + continue; + } + // Mount View + if (isDetached) { + currentFlag |= view.FLAG_INSERT; + mountCount++; + } + currentFlag |= this.registerMountedView(view); + } + var leftoverFlag = this.updateView(view, currentFlag, opt); + if (leftoverFlag > 0) { + // View update has not finished completely + priorityUpdates[cid] = leftoverFlag; + if (!postponeViewFn || !postponeViewFn.call(this, view, leftoverFlag, this) || priorityUpdates[cid]) { + postponeCount++; + empty = false; + continue; + } + } + if (maxPriority > priority) { maxPriority = priority; } + updateCount++; + delete priorityUpdates[cid]; + } + } + return { + priority: maxPriority, + updated: updateCount, + postponed: postponeCount, + unmounted: unmountCount, + mounted: mountCount, + empty: empty + }; + }, + + getUnmountedViews: function() { + var updates = this._updates; + var unmountedCids = Object.keys(updates.unmounted); + var n = unmountedCids.length; + var unmountedViews = new Array(n); + for (var i = 0; i < n; i++) { + unmountedViews[i] = views[unmountedCids[i]]; + } + return unmountedViews; + }, + + getMountedViews: function() { + var updates = this._updates; + var mountedCids = Object.keys(updates.mounted); + var n = mountedCids.length; + var mountedViews = new Array(n); + for (var i = 0; i < n; i++) { + mountedViews[i] = views[mountedCids[i]]; + } + return mountedViews; + }, + + checkUnmountedViews: function(viewportFn, opt) { + opt || (opt = {}); + var mountCount = 0; + if (typeof viewportFn !== 'function') { viewportFn = null; } + var batchSize = 'mountBatchSize' in opt ? opt.mountBatchSize : Infinity; + var updates = this._updates; + var unmountedCids = updates.unmountedCids; + var unmounted = updates.unmounted; + for (var i = 0, n = Math.min(unmountedCids.length, batchSize); i < n; i++) { + var cid = unmountedCids[i]; + if (!(cid in unmounted)) { continue; } + var view = views[cid]; + if (!view) { continue; } + if (view.DETACHABLE && viewportFn && !viewportFn.call(this, view, false, this)) { + // Push at the end of all unmounted ids, so this can be check later again + unmountedCids.push(cid); + continue; + } + mountCount++; + var flag = this.registerMountedView(view); + if (flag) { this.scheduleViewUpdate(view, flag, view.UPDATE_PRIORITY, { mounting: true }); } + } + // Get rid of views, that have been mounted + unmountedCids.splice(0, i); + return mountCount; + }, + + checkMountedViews: function(viewportFn, opt) { + opt || (opt = {}); + var unmountCount = 0; + if (typeof viewportFn !== 'function') { return unmountCount; } + var batchSize = 'unmountBatchSize' in opt ? opt.unmountBatchSize : Infinity; + var updates = this._updates; + var mountedCids = updates.mountedCids; + var mounted = updates.mounted; + for (var i = 0, n = Math.min(mountedCids.length, batchSize); i < n; i++) { + var cid = mountedCids[i]; + if (!(cid in mounted)) { continue; } + var view = views[cid]; + if (!view) { continue; } + if (!view.DETACHABLE || viewportFn.call(this, view, true, this)) { + // Push at the end of all mounted ids, so this can be check later again + mountedCids.push(cid); + continue; + } + unmountCount++; + var flag = this.registerUnmountedView(view); + if (flag) { view.unmount(); } + } + // Get rid of views, that have been unmounted + mountedCids.splice(0, i); + return unmountCount; + }, + + checkViewport: function(opt) { + var passingOpt = defaults({}, opt, { + mountBatchSize: Infinity, + unmountBatchSize: Infinity + }); + var viewportFn = 'viewport' in passingOpt ? passingOpt.viewport : this.options.viewport; + var unmountedCount = this.checkMountedViews(viewportFn, passingOpt); + if (unmountedCount > 0) { + // Do not check views, that have been just unmounted and pushed at the end of the cids array + var unmountedCids = this._updates.unmountedCids; + passingOpt.mountBatchSize = Math.min(unmountedCids.length - unmountedCount, passingOpt.mountBatchSize); + } + var mountedCount = this.checkUnmountedViews(viewportFn, passingOpt); + return { + mounted: mountedCount, + unmounted: unmountedCount + }; + }, + + freeze: function(opt) { + opt || (opt = {}); + var updates = this._updates; + var key = opt.key; + var isFrozen = this.options.frozen; + var freezeKey = updates.freezeKey; + if (key && key !== freezeKey) { + // key passed, but the paper is already freezed with another key + if (isFrozen && freezeKey) { return; } + updates.freezeKey = key; + updates.keyFrozen = isFrozen; + } + this.options.frozen = true; + var id = updates.id; + updates.id = null; + if (this.isAsync() && id) { cancelFrame(id); } + }, + + unfreeze: function(opt) { + opt || (opt = {}); + var updates = this._updates; + var key = opt.key; + var freezeKey = updates.freezeKey; + // key passed, but the paper is already freezed with another key + if (key && freezeKey && key !== freezeKey) { return; } + updates.freezeKey = null; + // key passed, but the paper is already freezed + if (key && key === freezeKey && updates.keyFrozen) { return; } + if (this.isAsync()) { + this.freeze(); + this.updateViewsAsync(opt); + } else { + this.updateViews(opt); + } + this.options.frozen = updates.keyFrozen = false; + if (updates.sort) { + this.sortViews(); + updates.sort = false; + } + }, + + isAsync: function() { + return !!this.options.async; + }, + + isFrozen: function() { + return !!this.options.frozen; + }, + + isExactSorting: function() { + return this.options.sorting === sortingTypes.EXACT; + }, + + onRemove: function() { + + this.freeze(); + //clean up all DOM elements/views to prevent memory leaks + this.removeLayers(); + this.removeViews(); + }, + + getComputedSize: function() { + + var options = this.options; + var w = options.width; + var h = options.height; + if (!isNumber(w)) { w = this.el.clientWidth; } + if (!isNumber(h)) { h = this.el.clientHeight; } + return { width: w, height: h }; + }, + + setDimensions: function(width, height) { + var ref = this; + var options = ref.options; + var currentWidth = options.width; + var currentHeight = options.height; + var w = (width === undefined) ? currentWidth : width; + var h = (height === undefined) ? currentHeight : height; + if (currentWidth === w && currentHeight === h) { return; } + options.width = w; + options.height = h; + this._setDimensions(); + var computedSize = this.getComputedSize(); + this.trigger('resize', computedSize.width, computedSize.height); + }, + + _setDimensions: function() { + var ref = this; + var options = ref.options; + var w = options.width; + var h = options.height; + if (isNumber(w)) { w = Math.round(w); } + if (isNumber(h)) { h = Math.round(h); } + this.$el.css({ + width: (w === null) ? '' : w, + height: (h === null) ? '' : h + }); + }, + + setOrigin: function(ox, oy) { + return this.translate(ox || 0, oy || 0); + }, + + // Expand/shrink the paper to fit the content. + // Alternatively signature function(opt) + fitToContent: function(gridWidth, gridHeight, padding, opt) { + + if (isObject$1(gridWidth)) { + // first parameter is an option object + opt = gridWidth; + } else { + // Support for a deprecated signature + opt = assign({ gridWidth: gridWidth, gridHeight: gridHeight, padding: padding }, opt); + } + + var ref = this.getFitToContentArea(opt); + var x = ref.x; + var y = ref.y; + var width = ref.width; + var height = ref.height; + var ref$1 = this.scale(); + var sx = ref$1.sx; + var sy = ref$1.sy; + + this.setOrigin(-x * sx, -y * sy); + this.setDimensions(width * sx, height * sy); + + return new Rect(x, y, width, height); + }, + + getFitToContentArea: function(opt) { + if ( opt === void 0 ) opt = {}; + + + // Calculate the paper size to accommodate all the graph's elements. + + var gridWidth = opt.gridWidth || 1; + var gridHeight = opt.gridHeight || 1; + var padding = normalizeSides(opt.padding || 0); + + var minWidth = Math.max(opt.minWidth || 0, gridWidth); + var minHeight = Math.max(opt.minHeight || 0, gridHeight); + var maxWidth = opt.maxWidth || Number.MAX_VALUE; + var maxHeight = opt.maxHeight || Number.MAX_VALUE; + var newOrigin = opt.allowNewOrigin; + + var area = ('contentArea' in opt) ? new Rect(opt.contentArea) : this.getContentArea(opt); + var ref = this.scale(); + var sx = ref.sx; + var sy = ref.sy; + area.x *= sx; + area.y *= sy; + area.width *= sx; + area.height *= sy; + + var calcWidth = Math.ceil((area.width + area.x) / gridWidth); + var calcHeight = Math.ceil((area.height + area.y) / gridHeight); + if (!opt.allowNegativeBottomRight) { + calcWidth = Math.max(calcWidth, 1); + calcHeight = Math.max(calcHeight, 1); + } + calcWidth *= gridWidth; + calcHeight *= gridHeight; + + var tx = 0; + if ((newOrigin === 'negative' && area.x < 0) || (newOrigin === 'positive' && area.x >= 0) || newOrigin === 'any') { + tx = Math.ceil(-area.x / gridWidth) * gridWidth; + tx += padding.left; + calcWidth += tx; + } + + var ty = 0; + if ((newOrigin === 'negative' && area.y < 0) || (newOrigin === 'positive' && area.y >= 0) || newOrigin === 'any') { + ty = Math.ceil(-area.y / gridHeight) * gridHeight; + ty += padding.top; + calcHeight += ty; + } + + calcWidth += padding.right; + calcHeight += padding.bottom; + + // Make sure the resulting width and height are greater than minimum. + calcWidth = Math.max(calcWidth, minWidth); + calcHeight = Math.max(calcHeight, minHeight); + + // Make sure the resulting width and height are lesser than maximum. + calcWidth = Math.min(calcWidth, maxWidth); + calcHeight = Math.min(calcHeight, maxHeight); + + return new Rect(-tx / sx, -ty / sy, calcWidth / sx, calcHeight / sy); + }, + + scaleContentToFit: function(opt) { + + opt || (opt = {}); + + var contentBBox, contentLocalOrigin; + if ('contentArea' in opt) { + var contentArea = opt.contentArea; + contentBBox = this.localToPaperRect(contentArea); + contentLocalOrigin = new Point(contentArea); + } else { + contentBBox = this.getContentBBox(opt); + contentLocalOrigin = this.paperToLocalPoint(contentBBox); + } + + if (!contentBBox.width || !contentBBox.height) { return; } + + defaults(opt, { + padding: 0, + preserveAspectRatio: true, + scaleGrid: null, + minScale: 0, + maxScale: Number.MAX_VALUE + //minScaleX + //minScaleY + //maxScaleX + //maxScaleY + //fittingBBox + }); + + var padding = normalizeSides(opt.padding); + + var minScaleX = opt.minScaleX || opt.minScale; + var maxScaleX = opt.maxScaleX || opt.maxScale; + var minScaleY = opt.minScaleY || opt.minScale; + var maxScaleY = opt.maxScaleY || opt.maxScale; + + var fittingBBox; + if (opt.fittingBBox) { + fittingBBox = opt.fittingBBox; + } else { + var currentTranslate = this.translate(); + var computedSize = this.getComputedSize(); + fittingBBox = { + x: currentTranslate.tx, + y: currentTranslate.ty, + width: computedSize.width, + height: computedSize.height + }; + } + + fittingBBox = new Rect(fittingBBox).moveAndExpand({ + x: padding.left, + y: padding.top, + width: -padding.left - padding.right, + height: -padding.top - padding.bottom + }); + + var currentScale = this.scale(); + + var newSx = fittingBBox.width / contentBBox.width * currentScale.sx; + var newSy = fittingBBox.height / contentBBox.height * currentScale.sy; + + if (opt.preserveAspectRatio) { + newSx = newSy = Math.min(newSx, newSy); + } + + // snap scale to a grid + if (opt.scaleGrid) { + + var gridSize = opt.scaleGrid; + + newSx = gridSize * Math.floor(newSx / gridSize); + newSy = gridSize * Math.floor(newSy / gridSize); + } + + // scale min/max boundaries + newSx = Math.min(maxScaleX, Math.max(minScaleX, newSx)); + newSy = Math.min(maxScaleY, Math.max(minScaleY, newSy)); + + var origin = this.options.origin; + var newOx = fittingBBox.x - contentLocalOrigin.x * newSx - origin.x; + var newOy = fittingBBox.y - contentLocalOrigin.y * newSy - origin.y; + + this.scale(newSx, newSy); + this.translate(newOx, newOy); + }, + + // Return the dimensions of the content area in local units (without transformations). + getContentArea: function(opt) { + + if (opt && opt.useModelGeometry) { + return this.model.getBBox() || new Rect(); + } + + return V(this.cells).getBBox(); + }, + + // Return the dimensions of the content bbox in the paper units (as it appears on screen). + getContentBBox: function(opt) { + + return this.localToPaperRect(this.getContentArea(opt)); + }, + + // Returns a geometry rectangle representing the entire + // paper area (coordinates from the left paper border to the right one + // and the top border to the bottom one). + getArea: function() { + + return this.paperToLocalRect(this.getComputedSize()); + }, + + getRestrictedArea: function() { + var args = [], len = arguments.length; + while ( len-- ) args[ len ] = arguments[ len ]; + + + var ref = this.options; + var restrictTranslate = ref.restrictTranslate; + + var restrictedArea; + if (isFunction(restrictTranslate)) { + // A method returning a bounding box + restrictedArea = restrictTranslate.apply(this, args); + } else if (restrictTranslate === true) { + // The paper area + restrictedArea = this.getArea(); + } else if (!restrictTranslate) { + // falsy value + restrictedArea = null; + } else { + // any other value + restrictedArea = new Rect(restrictTranslate); + } + + return restrictedArea; + }, + + createViewForModel: function(cell) { + + var ref = this; + var options = ref.options; + // A class taken from the paper options. + var optionalViewClass; + + // A default basic class (either dia.ElementView or dia.LinkView) + var defaultViewClass; + + // A special class defined for this model in the corresponding namespace. + // e.g. joint.shapes.basic.Rect searches for joint.shapes.basic.RectView + var namespace = options.cellViewNamespace; + var type = cell.get('type') + 'View'; + var namespaceViewClass = getByPath(namespace, type, '.'); + + if (cell.isLink()) { + optionalViewClass = options.linkView; + defaultViewClass = LinkView; + } else { + optionalViewClass = options.elementView; + defaultViewClass = ElementView; + } + + // a) the paper options view is a class (deprecated) + // 1. search the namespace for a view + // 2. if no view was found, use view from the paper options + // b) the paper options view is a function + // 1. call the function from the paper options + // 2. if no view was return, search the namespace for a view + // 3. if no view was found, use the default + var ViewClass = (optionalViewClass.prototype instanceof Backbone.View) + ? namespaceViewClass || optionalViewClass + : optionalViewClass.call(this, cell) || namespaceViewClass || defaultViewClass; + + return new ViewClass({ + model: cell, + interactive: options.interactive, + labelsLayer: options.labelsLayer === true ? LayersNames.LABELS : options.labelsLayer + }); + }, + + removeView: function(cell) { + + var id = cell.id; + var ref = this; + var _views = ref._views; + var _updates = ref._updates; + var view = _views[id]; + if (view) { + var cid = view.cid; + var mounted = _updates.mounted; + var unmounted = _updates.unmounted; + view.remove(); + delete _views[id]; + delete mounted[cid]; + delete unmounted[cid]; + } + return view; + }, + + renderView: function(cell, opt) { + + var id = cell.id; + var views = this._views; + var view, flag; + var create = true; + if (id in views) { + view = views[id]; + if (view.model === cell) { + flag = view.FLAG_INSERT; + create = false; + } else { + // The view for this `id` already exist. + // The cell is a new instance of the model with identical id + // We simply remove the existing view and create a new one + this.removeView(cell); + } + } + if (create) { + view = views[id] = this.createViewForModel(cell); + view.paper = this; + flag = this.registerUnmountedView(view) | view.getFlag(result(view, 'initFlag')); + } + this.requestViewUpdate(view, flag, view.UPDATE_PRIORITY, opt); + return view; + }, + + onImageDragStart: function() { + // This is the only way to prevent image dragging in Firefox that works. + // Setting -moz-user-select: none, draggable="false" attribute or user-drag: none didn't help. + + return false; + }, + + resetViews: function(cells, opt) { + opt || (opt = {}); + cells || (cells = []); + this._resetUpdates(); + // clearing views removes any event listeners + this.removeViews(); + this.freeze({ key: 'reset' }); + for (var i = 0, n = cells.length; i < n; i++) { + this.renderView(cells[i], opt); + } + this.unfreeze({ key: 'reset' }); + this.sortViews(); + }, + + removeViews: function() { + + invoke(this._views, 'remove'); + + this._views = {}; + }, + + sortViews: function() { + + if (!this.isExactSorting()) { + // noop + return; + } + if (this.isFrozen()) { + // sort views once unfrozen + this._updates.sort = true; + return; + } + this.sortViewsExact(); + }, + + sortViewsExact: function() { + + // Run insertion sort algorithm in order to efficiently sort DOM elements according to their + // associated model `z` attribute. + + var $cells = $(this.cells).children('[model-id]'); + var cells = this.model.get('cells'); + + sortElements($cells, function(a, b) { + var cellA = cells.get(a.getAttribute('model-id')); + var cellB = cells.get(b.getAttribute('model-id')); + var zA = cellA.attributes.z || 0; + var zB = cellB.attributes.z || 0; + return (zA === zB) ? 0 : (zA < zB) ? -1 : 1; + }); + }, + + insertView: function(view) { + var layerView = this.getLayerView(LayersNames.CELLS); + var el = view.el; + var model = view.model; + switch (this.options.sorting) { + case sortingTypes.APPROX: + layerView.insertSortedNode(el, model.get('z')); + break; + case sortingTypes.EXACT: + default: + layerView.insertNode(el); + break; + } + view.onMount(); + }, + + scale: function(sx, sy, ox, oy) { + + // getter + if (sx === undefined) { + return V.matrixToScale(this.matrix()); + } + + // setter + if (sy === undefined) { + sy = sx; + } + if (ox === undefined) { + ox = 0; + oy = 0; + } + + var translate = this.translate(); + + if (ox || oy || translate.tx || translate.ty) { + var newTx = translate.tx - ox * (sx - 1); + var newTy = translate.ty - oy * (sy - 1); + this.translate(newTx, newTy); + } + + sx = Math.max(sx || 0, this.MIN_SCALE); + sy = Math.max(sy || 0, this.MIN_SCALE); + + var ctm = this.matrix(); + ctm.a = sx; + ctm.d = sy; + + this.matrix(ctm); + + this.trigger('scale', sx, sy, ox, oy); + + return this; + }, + + // Experimental - do not use in production. + rotate: function(angle, cx, cy) { + + // getter + if (angle === undefined) { + return V.matrixToRotate(this.matrix()); + } + + // setter + + // If the origin is not set explicitely, rotate around the center. Note that + // we must use the plain bounding box (`this.el.getBBox()` instead of the one that gives us + // the real bounding box (`bbox()`) including transformations). + if (cx === undefined) { + var bbox = this.cells.getBBox(); + cx = bbox.width / 2; + cy = bbox.height / 2; + } + + var ctm = this.matrix().translate(cx, cy).rotate(angle).translate(-cx, -cy); + this.matrix(ctm); + + return this; + }, + + translate: function(tx, ty) { + + // getter + if (tx === undefined) { + return V.matrixToTranslate(this.matrix()); + } + + var ref = this; + var options = ref.options; + var origin = options.origin; + var drawGrid = options.drawGrid; + + // setter + tx || (tx = 0); + ty || (ty = 0); + + var ctm = this.matrix(); + if (ctm.e === tx && ctm.f === ty) { return this; } + ctm.e = tx; + ctm.f = ty; + + this.matrix(ctm); + + var ref$1 = this.translate(); + var ox = ref$1.tx; + var oy = ref$1.ty; + origin.x = ox; + origin.y = oy; + + this.trigger('translate', ox, oy); + + if (drawGrid) { + this.drawGrid(); + } + + return this; + }, + + // Find the first view climbing up the DOM tree starting at element `el`. Note that `el` can also + // be a selector or a jQuery object. + findView: function($el) { + + var el = isString($el) + ? this.cells.querySelector($el) + : $el instanceof $ ? $el[0] : $el; + + var id = this.findAttribute('model-id', el); + if (id) { return this._views[id]; } + + return undefined; + }, + + // Find a view for a model `cell`. `cell` can also be a string or number representing a model `id`. + findViewByModel: function(cell) { + + var id = (isString(cell) || isNumber(cell)) ? cell : (cell && cell.id); + + return this._views[id]; + }, + + // Find all views at given point + findViewsFromPoint: function(p) { + + p = new Point(p); + + var views = this.model.getElements().map(this.findViewByModel, this); + + return views.filter(function(view) { + return view && view.vel.getBBox({ target: this.cells }).containsPoint(p); + }, this); + }, + + // Find all views in given area + findViewsInArea: function(rect, opt) { + + opt = defaults(opt || {}, { strict: false }); + rect = new Rect(rect); + + var views = this.model.getElements().map(this.findViewByModel, this); + var method = opt.strict ? 'containsRect' : 'intersect'; + + return views.filter(function(view) { + return view && rect[method](view.vel.getBBox({ target: this.cells })); + }, this); + }, + + removeTools: function() { + this.dispatchToolsEvent('remove'); + return this; + }, + + hideTools: function() { + this.dispatchToolsEvent('hide'); + return this; + }, + + showTools: function() { + this.dispatchToolsEvent('show'); + return this; + }, + + dispatchToolsEvent: function(event) { + var ref; + + var args = [], len = arguments.length - 1; + while ( len-- > 0 ) args[ len ] = arguments[ len + 1 ]; + if (typeof event !== 'string') { return; } + (ref = this).trigger.apply(ref, [ 'tools:event', event ].concat( args )); + }, + + + getModelById: function(id) { + + return this.model.getCell(id); + }, + + snapToGrid: function(x, y) { + + // Convert global coordinates to the local ones of the `viewport`. Otherwise, + // improper transformation would be applied when the viewport gets transformed (scaled/rotated). + return this.clientToLocalPoint(x, y).snapToGrid(this.options.gridSize); + }, + + localToPaperPoint: function(x, y) { + // allow `x` to be a point and `y` undefined + var localPoint = new Point(x, y); + var paperPoint = V.transformPoint(localPoint, this.matrix()); + return paperPoint; + }, + + localToPaperRect: function(x, y, width, height) { + // allow `x` to be a rectangle and rest arguments undefined + var localRect = new Rect(x, y, width, height); + var paperRect = V.transformRect(localRect, this.matrix()); + return paperRect; + }, + + paperToLocalPoint: function(x, y) { + // allow `x` to be a point and `y` undefined + var paperPoint = new Point(x, y); + var localPoint = V.transformPoint(paperPoint, this.matrix().inverse()); + return localPoint; + }, + + paperToLocalRect: function(x, y, width, height) { + // allow `x` to be a rectangle and rest arguments undefined + var paperRect = new Rect(x, y, width, height); + var localRect = V.transformRect(paperRect, this.matrix().inverse()); + return localRect; + }, + + localToClientPoint: function(x, y) { + // allow `x` to be a point and `y` undefined + var localPoint = new Point(x, y); + var clientPoint = V.transformPoint(localPoint, this.clientMatrix()); + return clientPoint; + }, + + localToClientRect: function(x, y, width, height) { + // allow `x` to be a point and `y` undefined + var localRect = new Rect(x, y, width, height); + var clientRect = V.transformRect(localRect, this.clientMatrix()); + return clientRect; + }, + + // Transform client coordinates to the paper local coordinates. + // Useful when you have a mouse event object and you'd like to get coordinates + // inside the paper that correspond to `evt.clientX` and `evt.clientY` point. + // Example: var localPoint = paper.clientToLocalPoint({ x: evt.clientX, y: evt.clientY }); + clientToLocalPoint: function(x, y) { + // allow `x` to be a point and `y` undefined + var clientPoint = new Point(x, y); + var localPoint = V.transformPoint(clientPoint, this.clientMatrix().inverse()); + return localPoint; + }, + + clientToLocalRect: function(x, y, width, height) { + // allow `x` to be a point and `y` undefined + var clientRect = new Rect(x, y, width, height); + var localRect = V.transformRect(clientRect, this.clientMatrix().inverse()); + return localRect; + }, + + localToPagePoint: function(x, y) { + + return this.localToPaperPoint(x, y).offset(this.pageOffset()); + }, + + localToPageRect: function(x, y, width, height) { + + return this.localToPaperRect(x, y, width, height).offset(this.pageOffset()); + }, + + pageToLocalPoint: function(x, y) { + + var pagePoint = new Point(x, y); + var paperPoint = pagePoint.difference(this.pageOffset()); + return this.paperToLocalPoint(paperPoint); + }, + + pageToLocalRect: function(x, y, width, height) { + + var pageOffset = this.pageOffset(); + var paperRect = new Rect(x, y, width, height); + paperRect.x -= pageOffset.x; + paperRect.y -= pageOffset.y; + return this.paperToLocalRect(paperRect); + }, + + clientOffset: function() { + + var clientRect = this.svg.getBoundingClientRect(); + return new Point(clientRect.left, clientRect.top); + }, + + pageOffset: function() { + + return this.clientOffset().offset(window.scrollX, window.scrollY); + }, + + linkAllowed: function(linkView) { + + if (!(linkView instanceof LinkView)) { + throw new Error('Must provide a linkView.'); + } + + var link = linkView.model; + var paperOptions = this.options; + var graph = this.model; + var ns = graph.constructor.validations; + + if (!paperOptions.multiLinks) { + if (!ns.multiLinks.call(this, graph, link)) { return false; } + } + + if (!paperOptions.linkPinning) { + // Link pinning is not allowed and the link is not connected to the target. + if (!ns.linkPinning.call(this, graph, link)) { return false; } + } + + if (typeof paperOptions.allowLink === 'function') { + if (!paperOptions.allowLink.call(this, linkView, this)) { return false; } + } + + return true; + }, + + getDefaultLink: function(cellView, magnet) { + + return isFunction(this.options.defaultLink) + // default link is a function producing link model + ? this.options.defaultLink.call(this, cellView, magnet) + // default link is the Backbone model + : this.options.defaultLink.clone(); + }, + + // Cell highlighting. + // ------------------ + + resolveHighlighter: function(opt) { + if ( opt === void 0 ) opt = {}; + + + var highlighterDef = opt.highlighter; + var type = opt.type; + var ref = this.options; + var highlighting = ref.highlighting; + var highlighterNamespace = ref.highlighterNamespace; + + /* + Expecting opt.highlighter to have the following structure: + { + name: 'highlighter-name', + options: { + some: 'value' + } + } + */ + if (highlighterDef === undefined) { + + // Is highlighting disabled? + if (!highlighting) { return false; } + // check for built-in types + if (type) { + highlighterDef = highlighting[type]; + // Is a specific type highlight disabled? + if (highlighterDef === false) { return false; } + } + if (!highlighterDef) { + // Type not defined use default highlight + highlighterDef = highlighting['default']; + } + } + + // Do nothing if opt.highlighter is falsy. + // This allows the case to not highlight cell(s) in certain cases. + // For example, if you want to NOT highlight when embedding elements + // or use a custom highlighter. + if (!highlighterDef) { return false; } + + // Allow specifying a highlighter by name. + if (isString(highlighterDef)) { + highlighterDef = { + name: highlighterDef + }; + } + + var name = highlighterDef.name; + var highlighter = highlighterNamespace[name]; + + // Highlighter validation + if (!highlighter) { + throw new Error('Unknown highlighter ("' + name + '")'); + } + if (typeof highlighter.highlight !== 'function') { + throw new Error('Highlighter ("' + name + '") is missing required highlight() method'); + } + if (typeof highlighter.unhighlight !== 'function') { + throw new Error('Highlighter ("' + name + '") is missing required unhighlight() method'); + } + + return { + highlighter: highlighter, + options: highlighterDef.options || {}, + name: name + }; + }, + + onCellHighlight: function(cellView, magnetEl, opt) { + var highlighterDescriptor = this.resolveHighlighter(opt); + if (!highlighterDescriptor) { return; } + var highlighter = highlighterDescriptor.highlighter; + var options = highlighterDescriptor.options; + highlighter.highlight(cellView, magnetEl, options); + }, + + onCellUnhighlight: function(cellView, magnetEl, opt) { + var highlighterDescriptor = this.resolveHighlighter(opt); + if (!highlighterDescriptor) { return; } + var highlighter = highlighterDescriptor.highlighter; + var options = highlighterDescriptor.options; + highlighter.unhighlight(cellView, magnetEl, options); + }, + + // Interaction. + // ------------ + + pointerdblclick: function(evt) { + + evt.preventDefault(); + + // magnetpointerdblclick can stop propagation + + evt = normalizeEvent(evt); + + var view = this.findView(evt.target); + if (this.guard(evt, view)) { return; } + + var localPoint = this.snapToGrid(evt.clientX, evt.clientY); + + if (view) { + view.pointerdblclick(evt, localPoint.x, localPoint.y); + + } else { + this.trigger('blank:pointerdblclick', evt, localPoint.x, localPoint.y); + } + }, + + pointerclick: function(evt) { + + // magnetpointerclick can stop propagation + + var data = this.eventData(evt); + // Trigger event only if mouse has not moved. + if (data.mousemoved <= this.options.clickThreshold) { + + evt = normalizeEvent(evt); + + var view = this.findView(evt.target); + if (this.guard(evt, view)) { return; } + + var localPoint = this.snapToGrid(evt.clientX, evt.clientY); + + if (view) { + view.pointerclick(evt, localPoint.x, localPoint.y); + + } else { + this.trigger('blank:pointerclick', evt, localPoint.x, localPoint.y); + } + } + }, + + contextmenu: function(evt) { + + if (this.options.preventContextMenu) { evt.preventDefault(); } + + if (this.contextMenuFired) { + this.contextMenuFired = false; + return; + } + + evt = normalizeEvent(evt); + + this.contextMenuTrigger(evt); + }, + + contextMenuTrigger: function(evt) { + var view = this.findView(evt.target); + if (this.guard(evt, view)) { return; } + + var localPoint = this.snapToGrid(evt.clientX, evt.clientY); + + if (view) { + view.contextmenu(evt, localPoint.x, localPoint.y); + + } else { + this.trigger('blank:contextmenu', evt, localPoint.x, localPoint.y); + } + }, + + pointerdown: function(evt) { + + // onmagnet stops propagation when `addLinkFromMagnet` is allowed + // onevent can stop propagation + + evt = normalizeEvent(evt); + + if (evt.button === 2) { + this.contextMenuFired = true; + var contextmenuEvt = $.Event(evt, { type: 'contextmenu', data: evt.data }); + this.contextMenuTrigger(contextmenuEvt); + } else { + var view = this.findView(evt.target); + + if (this.guard(evt, view)) { return; } + var localPoint = this.snapToGrid(evt.clientX, evt.clientY); + + if (view) { + evt.preventDefault(); + view.pointerdown(evt, localPoint.x, localPoint.y); + } else { + if (this.options.preventDefaultBlankAction) { evt.preventDefault(); } + + this.trigger('blank:pointerdown', evt, localPoint.x, localPoint.y); + } + + this.delegateDragEvents(view, evt.data); + } + + }, + + pointermove: function(evt) { + + // mouse moved counter + var data = this.eventData(evt); + if (!data.mousemoved) { + data.mousemoved = 0; + // Make sure that events like `mouseenter` and `mouseleave` are + // not triggered while the user is dragging a cellView. + this.undelegateEvents(); + // Note: the events are undelegated after the first `pointermove` event. + // Not on `pointerdown` to make sure that `dbltap` is recognized. + } + + var mousemoved = ++data.mousemoved; + + if (mousemoved <= this.options.moveThreshold) { return; } + + evt = normalizeEvent(evt); + + var localPoint = this.snapToGrid(evt.clientX, evt.clientY); + + var view = data.sourceView; + if (view) { + view.pointermove(evt, localPoint.x, localPoint.y); + } else { + this.trigger('blank:pointermove', evt, localPoint.x, localPoint.y); + } + + this.eventData(evt, data); + }, + + pointerup: function(evt) { + + this.undelegateDocumentEvents(); + + var normalizedEvt = normalizeEvent(evt); + + var localPoint = this.snapToGrid(normalizedEvt.clientX, normalizedEvt.clientY); + + var view = this.eventData(evt).sourceView; + if (view) { + view.pointerup(normalizedEvt, localPoint.x, localPoint.y); + } else { + this.trigger('blank:pointerup', normalizedEvt, localPoint.x, localPoint.y); + } + + if (!normalizedEvt.isPropagationStopped()) { + this.pointerclick($.Event(evt, { type: 'click', data: evt.data })); + } + + evt.stopImmediatePropagation(); + this.delegateEvents(); + }, + + mouseover: function(evt) { + + evt = normalizeEvent(evt); + + var view = this.findView(evt.target); + if (this.guard(evt, view)) { return; } + + if (view) { + view.mouseover(evt); + + } else { + if (this.el === evt.target) { return; } // prevent border of paper from triggering this + this.trigger('blank:mouseover', evt); + } + }, + + mouseout: function(evt) { + + evt = normalizeEvent(evt); + + var view = this.findView(evt.target); + if (this.guard(evt, view)) { return; } + + if (view) { + view.mouseout(evt); + + } else { + if (this.el === evt.target) { return; } // prevent border of paper from triggering this + this.trigger('blank:mouseout', evt); + } + }, + + mouseenter: function(evt) { + + evt = normalizeEvent(evt); + + var target = evt.target; + var relatedTarget = evt.relatedTarget; + var currentTarget = evt.currentTarget; + var view = this.findView(target); + if (this.guard(evt, view)) { return; } + var relatedView = this.findView(relatedTarget); + if (view) { + if (relatedView === view) { + // Mouse left a cell tool + return; + } + view.mouseenter(evt); + if (this.el.contains(relatedTarget)) { + // The pointer remains inside the paper. + return; + } + } + if (relatedView) { + return; + } + // prevent double `mouseenter` event if the `relatedTarget` is outside the paper + // (mouseenter method would be fired twice) + if (currentTarget === this.el) { + // `paper` (more descriptive), not `blank` + this.trigger('paper:mouseenter', evt); + } + }, + + mouseleave: function(evt) { + + evt = normalizeEvent(evt); + + var target = evt.target; + var relatedTarget = evt.relatedTarget; + var currentTarget = evt.currentTarget; + var view = this.findView(target); + if (this.guard(evt, view)) { return; } + var relatedView = this.findView(relatedTarget); + if (view) { + if (relatedView === view) { + // Mouse entered a cell tool + return; + } + view.mouseleave(evt); + if (this.el.contains(relatedTarget)) { + // The pointer has exited a cellView. The pointer is still inside of the paper. + return; + } + } + if (relatedView) { + // The pointer has entered a new cellView + return; + } + // prevent double `mouseleave` event if the `relatedTarget` is outside the paper + // (mouseleave method would be fired twice) + if (currentTarget === this.el) { + // There is no cellView under the pointer, nor the blank area of the paper + this.trigger('paper:mouseleave', evt); + } + }, + + _processMouseWheelEvtBuf: debounce(function() { + var ref = this._mw_evt_buffer; + var event = ref.event; + var deltas = ref.deltas; + var deltaY = deltas.reduce(function (acc, deltaY) { return acc + cap(deltaY, WHEEL_CAP); }, 0); + + var scale = Math.pow(0.995, deltaY); // 1.005 for inverted pinch/zoom + var ref$1 = this.clientToLocalPoint(event.clientX, event.clientY); + var x = ref$1.x; + var y = ref$1.y; + this.trigger('paper:pinch', event, x, y, scale); + + this._mw_evt_buffer = { + event: null, + deltas: [], + }; + }, WHEEL_WAIT_MS, { maxWait: WHEEL_WAIT_MS }), + + mousewheel: function(evt) { + + evt = normalizeEvent(evt); + + var view = this.findView(evt.target); + if (this.guard(evt, view)) { return; } + + var originalEvent = evt.originalEvent; + var localPoint = this.snapToGrid(originalEvent.clientX, originalEvent.clientY); + var ref = normalizeWheel(originalEvent); + var deltaX = ref.deltaX; + var deltaY = ref.deltaY; + + // Touchpad devices will send a fake CTRL press when a pinch is performed + if(evt.ctrlKey) { + // Check if there are any subscribers to this event. If there are none, + // just skip the entire block of code (we don't want to blindly call + // .preventDefault() if we really don't have to). + var handlers = this._events['paper:pinch']; + if(handlers && handlers.length > 0) { + // This is a pinch gesture, it's safe to assume that we must call .preventDefault() + originalEvent.preventDefault(); + this._mw_evt_buffer.event = originalEvent; + this._mw_evt_buffer.deltas.push(deltaY); + this._processMouseWheelEvtBuf(); + } + } else { + var delta = Math.max(-1, Math.min(1, originalEvent.wheelDelta)); + if (view) { + view.mousewheel(evt, localPoint.x, localPoint.y, delta); + + } else { + this.trigger('blank:mousewheel', evt, localPoint.x, localPoint.y, delta); + } + + this.trigger('paper:pan', evt, deltaX, deltaY); + } + }, + + onevent: function(evt) { + + var eventNode = evt.currentTarget; + var eventName = eventNode.getAttribute('event'); + if (eventName) { + var view = this.findView(eventNode); + if (view) { + + evt = normalizeEvent(evt); + if (this.guard(evt, view)) { return; } + + var localPoint = this.snapToGrid(evt.clientX, evt.clientY); + view.onevent(evt, eventName, localPoint.x, localPoint.y); + } + } + }, + + magnetEvent: function(evt, handler) { + + var magnetNode = evt.currentTarget; + var magnetValue = magnetNode.getAttribute('magnet'); + if (magnetValue) { + var view = this.findView(magnetNode); + if (view) { + evt = normalizeEvent(evt); + if (this.guard(evt, view)) { return; } + var localPoint = this.snapToGrid(evt.clientX, evt.clientY); + handler.call(this, view, evt, magnetNode, localPoint.x, localPoint.y); + } + } + }, + + onmagnet: function(evt) { + + if (evt.button === 2) { + this.contextMenuFired = true; + this.magnetContextMenuFired = true; + var contextmenuEvt = $.Event(evt, { type: 'contextmenu', data: evt.data }); + this.magnetContextMenuTrigger(contextmenuEvt); + if (contextmenuEvt.isPropagationStopped()) { + evt.stopPropagation(); + } + } else { + this.magnetEvent(evt, function(view, evt, _, x, y) { + view.onmagnet(evt, x, y); + }); + } + }, + + magnetpointerdblclick: function(evt) { + + this.magnetEvent(evt, function(view, evt, magnet, x, y) { + view.magnetpointerdblclick(evt, magnet, x, y); + }); + }, + + magnetcontextmenu: function(evt) { + if (this.options.preventContextMenu) { evt.preventDefault(); } + + if (this.magnetContextMenuFired) { + this.magnetContextMenuFired = false; + return; + } + + this.magnetContextMenuTrigger(evt); + }, + + magnetContextMenuTrigger: function(evt) { + this.magnetEvent(evt, function(view, evt, magnet, x, y) { + view.magnetcontextmenu(evt, magnet, x, y); + }); + }, + + onlabel: function(evt) { + + var labelNode = evt.currentTarget; + var view = this.findView(labelNode); + if (view) { + + evt = normalizeEvent(evt); + if (this.guard(evt, view)) { return; } + + var localPoint = this.snapToGrid(evt.clientX, evt.clientY); + view.onlabel(evt, localPoint.x, localPoint.y); + } + }, + + getPointerArgs: function getPointerArgs(evt) { + var normalizedEvt = normalizeEvent(evt); + var ref = this.snapToGrid(normalizedEvt.clientX, normalizedEvt.clientY); + var x = ref.x; + var y = ref.y; + return [normalizedEvt, x, y]; + }, + + delegateDragEvents: function(view, data) { + + data || (data = {}); + this.eventData({ data: data }, { sourceView: view || null, mousemoved: 0 }); + this.delegateDocumentEvents(null, data); + }, + + // Guard the specified event. If the event is not interesting, guard returns `true`. + // Otherwise, it returns `false`. + guard: function(evt, view) { + + if (evt.type === 'mousedown' && evt.button === 2) { + // handled as `contextmenu` type + return true; + } + + if (this.options.guard && this.options.guard(evt, view)) { + return true; + } + + if (evt.data && evt.data.guarded !== undefined) { + return evt.data.guarded; + } + + if (view && view.model && (view.model instanceof Cell)) { + return false; + } + + if (this.svg === evt.target || this.el === evt.target || $.contains(this.svg, evt.target)) { + return false; + } + + return true; // Event guarded. Paper should not react on it in any way. + }, + + setGridSize: function(gridSize) { + + this.options.gridSize = gridSize; + + if (this.options.drawGrid) { + this.drawGrid(); + } + + return this; + }, + + clearGrid: function() { + + if (this.$grid) { + this.$grid.css('backgroundImage', 'none'); + } + return this; + }, + + _getGridRefs: function() { + + if (!this._gridCache) { + + this._gridCache = { + root: V('svg', { width: '100%', height: '100%' }, V('defs')), + patterns: {}, + add: function(id, vel) { + V(this.root.node.childNodes[0]).append(vel); + this.patterns[id] = vel; + this.root.append(V('rect', { width: '100%', height: '100%', fill: 'url(#' + id + ')' })); + }, + get: function(id) { + return this.patterns[id]; + }, + exist: function(id) { + return this.patterns[id] !== undefined; + } + }; + } + + return this._gridCache; + }, + + setGrid: function(drawGrid) { + + this.clearGrid(); + + this._gridCache = null; + this._gridSettings = []; + + var optionsList = Array.isArray(drawGrid) ? drawGrid : [drawGrid || {}]; + optionsList.forEach(function(item) { + this._gridSettings.push.apply(this._gridSettings, this._resolveDrawGridOption(item)); + }, this); + return this; + }, + + _resolveDrawGridOption: function(opt) { + + var namespace = this.constructor.gridPatterns; + if (isString(opt) && Array.isArray(namespace[opt])) { + return namespace[opt].map(function(item) { + return assign({}, item); + }); + } + + var options = opt || { args: [{}] }; + var isArray = Array.isArray(options); + var name = options.name; + + if (!isArray && !name && !options.markup) { + name = 'dot'; + } + + if (name && Array.isArray(namespace[name])) { + var pattern = namespace[name].map(function(item) { + return assign({}, item); + }); + + var args = Array.isArray(options.args) ? options.args : [options.args || {}]; + + defaults(args[0], omit(opt, 'args')); + for (var i = 0; i < args.length; i++) { + if (pattern[i]) { + assign(pattern[i], args[i]); + } + } + return pattern; + } + + return isArray ? options : [options]; + }, + + drawGrid: function(opt) { + + var gridSize = this.options.gridSize; + if (gridSize <= 1) { + return this.clearGrid(); + } + + var localOptions = Array.isArray(opt) ? opt : [opt]; + + var ctm = this.matrix(); + var refs = this._getGridRefs(); + + this._gridSettings.forEach(function(gridLayerSetting, index) { + + var id = 'pattern_' + index; + var options = merge(gridLayerSetting, localOptions[index], { + sx: ctm.a || 1, + sy: ctm.d || 1, + ox: ctm.e || 0, + oy: ctm.f || 0 + }); + + options.width = gridSize * (ctm.a || 1) * (options.scaleFactor || 1); + options.height = gridSize * (ctm.d || 1) * (options.scaleFactor || 1); + + if (!refs.exist(id)) { + refs.add(id, V('pattern', { id: id, patternUnits: 'userSpaceOnUse' }, V(options.markup))); + } + + var patternDefVel = refs.get(id); + + if (isFunction(options.update)) { + options.update(patternDefVel.node.childNodes[0], options); + } + + var x = options.ox % options.width; + if (x < 0) { x += options.width; } + + var y = options.oy % options.height; + if (y < 0) { y += options.height; } + + patternDefVel.attr({ + x: x, + y: y, + width: options.width, + height: options.height + }); + }); + + var patternUri = new XMLSerializer().serializeToString(refs.root.node); + patternUri = 'url(data:image/svg+xml;base64,' + btoa(patternUri) + ')'; + + this.$grid.css('backgroundImage', patternUri); + + return this; + }, + + updateBackgroundImage: function(opt) { + + opt = opt || {}; + + var backgroundPosition = opt.position || 'center'; + var backgroundSize = opt.size || 'auto auto'; + + var currentScale = this.scale(); + var currentTranslate = this.translate(); + + // backgroundPosition + if (isObject$1(backgroundPosition)) { + var x = currentTranslate.tx + (currentScale.sx * (backgroundPosition.x || 0)); + var y = currentTranslate.ty + (currentScale.sy * (backgroundPosition.y || 0)); + backgroundPosition = x + 'px ' + y + 'px'; + } + + // backgroundSize + if (isObject$1(backgroundSize)) { + backgroundSize = new Rect(backgroundSize).scale(currentScale.sx, currentScale.sy); + backgroundSize = backgroundSize.width + 'px ' + backgroundSize.height + 'px'; + } + + this.$background.css({ + backgroundSize: backgroundSize, + backgroundPosition: backgroundPosition + }); + }, + + drawBackgroundImage: function(img, opt) { + + // Clear the background image if no image provided + if (!(img instanceof HTMLImageElement)) { + this.$background.css('backgroundImage', ''); + return; + } + + if (!this._background || this._background.id !== opt.id) { + // Draw only the last image requested (see drawBackground()) + return; + } + + opt = opt || {}; + + var backgroundImage; + var backgroundSize = opt.size; + var backgroundRepeat = opt.repeat || 'no-repeat'; + var backgroundOpacity = opt.opacity || 1; + var backgroundQuality = Math.abs(opt.quality) || 1; + var backgroundPattern = this.constructor.backgroundPatterns[camelCase(backgroundRepeat)]; + + if (isFunction(backgroundPattern)) { + // 'flip-x', 'flip-y', 'flip-xy', 'watermark' and custom + img.width *= backgroundQuality; + img.height *= backgroundQuality; + var canvas = backgroundPattern(img, opt); + if (!(canvas instanceof HTMLCanvasElement)) { + throw new Error('dia.Paper: background pattern must return an HTML Canvas instance'); + } + + backgroundImage = canvas.toDataURL('image/png'); + backgroundRepeat = 'repeat'; + if (isObject$1(backgroundSize)) { + // recalculate the tile size if an object passed in + backgroundSize.width *= canvas.width / img.width; + backgroundSize.height *= canvas.height / img.height; + } else if (backgroundSize === undefined) { + // calculate the tile size if no provided + opt.size = { + width: canvas.width / backgroundQuality, + height: canvas.height / backgroundQuality + }; + } + } else { + // backgroundRepeat: + // no-repeat', 'round', 'space', 'repeat', 'repeat-x', 'repeat-y' + backgroundImage = img.src; + if (backgroundSize === undefined) { + // pass the image size for the backgroundSize if no size provided + opt.size = { + width: img.width, + height: img.height + }; + } + } + + this.$background.css({ + opacity: backgroundOpacity, + backgroundRepeat: backgroundRepeat, + backgroundImage: 'url(' + backgroundImage + ')' + }); + + this.updateBackgroundImage(opt); + }, + + updateBackgroundColor: function(color) { + + this.$el.css('backgroundColor', color || ''); + }, + + drawBackground: function(opt) { + + opt = opt || {}; + + this.updateBackgroundColor(opt.color); + + if (opt.image) { + opt = this._background = cloneDeep(opt); + guid(opt); + var img = document.createElement('img'); + img.onload = this.drawBackgroundImage.bind(this, img, opt); + img.src = opt.image; + } else { + this.drawBackgroundImage(null); + this._background = null; + } + + return this; + }, + + setInteractivity: function(value) { + + this.options.interactive = value; + + invoke(this._views, 'setInteractivity', value); + }, + + // Paper definitions. + // ------------------ + + isDefined: function(defId) { + + return !!this.svg.getElementById(defId); + }, + + defineFilter: function(filter$1) { + + if (!isObject$1(filter$1)) { + throw new TypeError('dia.Paper: defineFilter() requires 1. argument to be an object.'); + } + + var filterId = filter$1.id; + var name = filter$1.name; + // Generate a hash code from the stringified filter definition. This gives us + // a unique filter ID for different definitions. + if (!filterId) { + filterId = name + this.svg.id + hashCode(JSON.stringify(filter$1)); + } + // If the filter already exists in the document, + // we're done and we can just use it (reference it using `url()`). + // If not, create one. + if (!this.isDefined(filterId)) { + + var namespace = filter; + var filterSVGString = namespace[name] && namespace[name](filter$1.args || {}); + if (!filterSVGString) { + throw new Error('Non-existing filter ' + name); + } + + // Set the filter area to be 3x the bounding box of the cell + // and center the filter around the cell. + var filterAttrs = assign({ + filterUnits: 'objectBoundingBox', + x: -1, + y: -1, + width: 3, + height: 3 + }, filter$1.attrs, { + id: filterId + }); + + V(filterSVGString, filterAttrs).appendTo(this.defs); + } + + return filterId; + }, + + defineGradient: function(gradient) { + if (!isObject$1(gradient)) { + throw new TypeError('dia.Paper: defineGradient() requires 1. argument to be an object.'); + } + var ref = this; + var svg = ref.svg; + var defs = ref.defs; + var type = gradient.type; + var id = gradient.id; if ( id === void 0 ) id = type + svg.id + hashCode(JSON.stringify(gradient)); + var stops = gradient.stops; + var attrs = gradient.attrs; if ( attrs === void 0 ) attrs = {}; + // If the gradient already exists in the document, + // we're done and we can just use it (reference it using `url()`). + if (this.isDefined(id)) { return id; } + // If not, create one. + var stopVEls = toArray(stops).map(function (ref) { + var offset = ref.offset; + var color = ref.color; + var opacity = ref.opacity; + + return V('stop').attr({ + 'offset': offset, + 'stop-color': color, + 'stop-opacity': Number.isFinite(opacity) ? opacity : 1 + }); + }); + var gradientVEl = V(type, attrs, stopVEls); + gradientVEl.id = id; + gradientVEl.appendTo(defs); + return id; + }, + + definePattern: function(pattern) { + if (!isObject$1(pattern)) { + throw new TypeError('dia.Paper: definePattern() requires 1. argument to be an object.'); + } + var ref = this; + var svg = ref.svg; + var defs = ref.defs; + var id = pattern.id; if ( id === void 0 ) id = svg.id + hashCode(JSON.stringify(pattern)); + var markup = pattern.markup; + var attrs = pattern.attrs; if ( attrs === void 0 ) attrs = {}; + if (!markup) { + throw new TypeError('dia.Paper: definePattern() requires markup.'); + } + // If the gradient already exists in the document, + // we're done and we can just use it (reference it using `url()`). + if (this.isDefined(id)) { return id; } + // If not, create one. + var patternVEl = V('pattern', { + patternUnits: 'userSpaceOnUse' + }); + patternVEl.id = id; + patternVEl.attr(attrs); + if (typeof markup === 'string') { + patternVEl.append(V(markup)); + } else { + var ref$1 = parseDOMJSON(markup); + var fragment = ref$1.fragment; + patternVEl.append(fragment); + } + patternVEl.appendTo(defs); + return id; + }, + + defineMarker: function(marker) { + if (!isObject$1(marker)) { + throw new TypeError('dia.Paper: defineMarker() requires 1. argument to be an object.'); + } + var ref = this; + var svg = ref.svg; + var defs = ref.defs; + var id = marker.id; if ( id === void 0 ) id = svg.id + hashCode(JSON.stringify(marker)); + var markup = marker.markup; + var attrs = marker.attrs; if ( attrs === void 0 ) attrs = {}; + var markerUnits = marker.markerUnits; if ( markerUnits === void 0 ) markerUnits = 'userSpaceOnUse'; + // If the marker already exists in the document, + // we're done and we can just use it (reference it using `url()`). + if (this.isDefined(id)) { return id; } + // If not, create one. + var markerVEl = V('marker', { + orient: 'auto', + overflow: 'visible', + markerUnits: markerUnits + }); + markerVEl.id = id; + markerVEl.attr(attrs); + if (markup) { + if (typeof markup === 'string') { + markerVEl.append(V(markup)); + } else { + var ref$1 = parseDOMJSON(markup); + var fragment = ref$1.fragment; + markerVEl.append(fragment); + } + } else { + // marker object is a flat structure + var type = marker.type; if ( type === void 0 ) type = 'path'; + var markerContentVEl = V(type, omit(marker, 'type', 'id', 'markup', 'attrs', 'markerUnits')); + markerVEl.append(markerContentVEl); + } + markerVEl.appendTo(defs); + return id; + } + + }, { + + sorting: sortingTypes, + + Layers: LayersNames, + + backgroundPatterns: { + + flipXy: function(img) { + // d b + // q p + + var canvas = document.createElement('canvas'); + var imgWidth = img.width; + var imgHeight = img.height; + + canvas.width = 2 * imgWidth; + canvas.height = 2 * imgHeight; + + var ctx = canvas.getContext('2d'); + // top-left image + ctx.drawImage(img, 0, 0, imgWidth, imgHeight); + // xy-flipped bottom-right image + ctx.setTransform(-1, 0, 0, -1, canvas.width, canvas.height); + ctx.drawImage(img, 0, 0, imgWidth, imgHeight); + // x-flipped top-right image + ctx.setTransform(-1, 0, 0, 1, canvas.width, 0); + ctx.drawImage(img, 0, 0, imgWidth, imgHeight); + // y-flipped bottom-left image + ctx.setTransform(1, 0, 0, -1, 0, canvas.height); + ctx.drawImage(img, 0, 0, imgWidth, imgHeight); + + return canvas; + }, + + flipX: function(img) { + // d b + // d b + + var canvas = document.createElement('canvas'); + var imgWidth = img.width; + var imgHeight = img.height; + + canvas.width = imgWidth * 2; + canvas.height = imgHeight; + + var ctx = canvas.getContext('2d'); + // left image + ctx.drawImage(img, 0, 0, imgWidth, imgHeight); + // flipped right image + ctx.translate(2 * imgWidth, 0); + ctx.scale(-1, 1); + ctx.drawImage(img, 0, 0, imgWidth, imgHeight); + + return canvas; + }, + + flipY: function(img) { + // d d + // q q + + var canvas = document.createElement('canvas'); + var imgWidth = img.width; + var imgHeight = img.height; + + canvas.width = imgWidth; + canvas.height = imgHeight * 2; + + var ctx = canvas.getContext('2d'); + // top image + ctx.drawImage(img, 0, 0, imgWidth, imgHeight); + // flipped bottom image + ctx.translate(0, 2 * imgHeight); + ctx.scale(1, -1); + ctx.drawImage(img, 0, 0, imgWidth, imgHeight); + + return canvas; + }, + + watermark: function(img, opt) { + // d + // d + + opt = opt || {}; + + var imgWidth = img.width; + var imgHeight = img.height; + + var canvas = document.createElement('canvas'); + canvas.width = imgWidth * 3; + canvas.height = imgHeight * 3; + + var ctx = canvas.getContext('2d'); + var angle = isNumber(opt.watermarkAngle) ? -opt.watermarkAngle : -20; + var radians = toRad(angle); + var stepX = canvas.width / 4; + var stepY = canvas.height / 4; + + for (var i = 0; i < 4; i++) { + for (var j = 0; j < 4; j++) { + if ((i + j) % 2 > 0) { + // reset the current transformations + ctx.setTransform(1, 0, 0, 1, (2 * i - 1) * stepX, (2 * j - 1) * stepY); + ctx.rotate(radians); + ctx.drawImage(img, -imgWidth / 2, -imgHeight / 2, imgWidth, imgHeight); + } + } + } + + return canvas; + } + }, + + gridPatterns: { + dot: [{ + color: '#AAAAAA', + thickness: 1, + markup: 'rect', + update: function(el, opt) { + V(el).attr({ + width: opt.thickness * opt.sx, + height: opt.thickness * opt.sy, + fill: opt.color + }); + } + }], + fixedDot: [{ + color: '#AAAAAA', + thickness: 1, + markup: 'rect', + update: function(el, opt) { + var size = opt.sx <= 1 ? opt.thickness * opt.sx : opt.thickness; + V(el).attr({ width: size, height: size, fill: opt.color }); + } + }], + mesh: [{ + color: '#AAAAAA', + thickness: 1, + markup: 'path', + update: function(el, opt) { + + var d; + var width = opt.width; + var height = opt.height; + var thickness = opt.thickness; + + if (width - thickness >= 0 && height - thickness >= 0) { + d = ['M', width, 0, 'H0 M0 0 V0', height].join(' '); + } else { + d = 'M 0 0 0 0'; + } + + V(el).attr({ 'd': d, stroke: opt.color, 'stroke-width': opt.thickness }); + } + }], + doubleMesh: [{ + color: '#AAAAAA', + thickness: 1, + markup: 'path', + update: function(el, opt) { + + var d; + var width = opt.width; + var height = opt.height; + var thickness = opt.thickness; + + if (width - thickness >= 0 && height - thickness >= 0) { + d = ['M', width, 0, 'H0 M0 0 V0', height].join(' '); + } else { + d = 'M 0 0 0 0'; + } + + V(el).attr({ 'd': d, stroke: opt.color, 'stroke-width': opt.thickness }); + } + }, { + color: '#000000', + thickness: 3, + scaleFactor: 4, + markup: 'path', + update: function(el, opt) { + + var d; + var width = opt.width; + var height = opt.height; + var thickness = opt.thickness; + + if (width - thickness >= 0 && height - thickness >= 0) { + d = ['M', width, 0, 'H0 M0 0 V0', height].join(' '); + } else { + d = 'M 0 0 0 0'; + } + + V(el).attr({ 'd': d, stroke: opt.color, 'stroke-width': opt.thickness }); + } + }] + } + }); + + var ToolView = View.extend({ + name: null, + tagName: 'g', + className: 'tool', + svgElement: true, + _visible: true, + + init: function() { + var name = this.name; + if (name) { this.vel.attr('data-tool-name', name); } + }, + + configure: function(view, toolsView) { + this.relatedView = view; + this.paper = view.paper; + this.parentView = toolsView; + this.simulateRelatedView(this.el); + // Delegate events in case the ToolView was removed from the DOM and reused. + this.delegateEvents(); + return this; + }, + + simulateRelatedView: function(el) { + if (el) { el.setAttribute('model-id', this.relatedView.model.id); } + }, + + getName: function() { + return this.name; + }, + + show: function() { + this.el.style.display = ''; + this._visible = true; + }, + + hide: function() { + this.el.style.display = 'none'; + this._visible = false; + }, + + isVisible: function() { + return !!this._visible; + }, + + focus: function() { + var opacity = this.options.focusOpacity; + if (isFinite(opacity)) { this.el.style.opacity = opacity; } + this.parentView.focusTool(this); + }, + + blur: function() { + this.el.style.opacity = ''; + this.parentView.blurTool(this); + }, + + update: function() { + // to be overridden + }, + + guard: function(evt) { + // Let the context-menu event bubble up to the relatedView + var ref = this; + var paper = ref.paper; + var relatedView = ref.relatedView; + if (!paper || !relatedView) { return true; } + return paper.guard(evt, relatedView); + } + }); + + var ToolsView = View.extend({ + tagName: 'g', + className: 'tools', + svgElement: true, + tools: null, + isRendered: false, + options: { + tools: null, + relatedView: null, + name: null, + // layer?: LayersNames.TOOLS + // z?: number + }, + + configure: function(options) { + options = assign(this.options, options); + var tools = options.tools; + if (!Array.isArray(tools)) { return this; } + var relatedView = options.relatedView; + if (!(relatedView instanceof CellView)) { return this; } + var views = this.tools = []; + for (var i = 0, n = tools.length; i < n; i++) { + var tool = tools[i]; + if (!(tool instanceof ToolView)) { continue; } + tool.configure(relatedView, this); + this.vel.append(tool.el); + views.push(tool); + } + this.isRendered = false; + relatedView.requestUpdate(relatedView.getFlag('TOOLS')); + return this; + }, + + getName: function() { + return this.options.name; + }, + + update: function(opt) { + + opt || (opt = {}); + var tools = this.tools; + if (!tools) { return this; } + var isRendered = this.isRendered; + for (var i = 0, n = tools.length; i < n; i++) { + var tool = tools[i]; + if (!isRendered) { + // First update executes render() + tool.render(); + } else if (opt.tool !== tool.cid && tool.isVisible()) { + tool.update(); + } + } + if (!isRendered) { + this.mount(); + // Make sure tools are visible (if they were hidden and the tool removed) + this.blurTool(); + this.isRendered = true; + } + return this; + }, + + focusTool: function(focusedTool) { + + var tools = this.tools; + if (!tools) { return this; } + for (var i = 0, n = tools.length; i < n; i++) { + var tool = tools[i]; + if (focusedTool === tool) { + tool.show(); + } else { + tool.hide(); + } + } + return this; + }, + + blurTool: function(blurredTool) { + var tools = this.tools; + if (!tools) { return this; } + for (var i = 0, n = tools.length; i < n; i++) { + var tool = tools[i]; + if (tool !== blurredTool && !tool.isVisible()) { + tool.show(); + tool.update(); + } + } + return this; + }, + + hide: function() { + return this.focusTool(null); + }, + + show: function() { + return this.blurTool(null); + }, + + onRemove: function() { + var tools = this.tools; + if (!tools) { return this; } + for (var i = 0, n = tools.length; i < n; i++) { + tools[i].remove(); + } + this.tools = null; + }, + + mount: function() { + var ref = this; + var options = ref.options; + var el = ref.el; + var relatedView = options.relatedView; + var layer = options.layer; if ( layer === void 0 ) layer = LayersNames.TOOLS; + var z = options.z; + if (relatedView) { + if (layer) { + relatedView.paper.getLayerView(layer).insertSortedNode(el, z); + } else { + relatedView.el.appendChild(el); + } + } + return this; + } + + }); + + + + var index$2 = ({ + Graph: Graph, + attributes: attributes, + LayersNames: LayersNames, + PaperLayer: PaperLayer, + Cell: Cell, + CellView: CellView, + Element: Element$1, + ElementView: ElementView, + Link: Link, + LinkView: LinkView, + Paper: Paper, + ToolView: ToolView, + ToolsView: ToolsView, + HighlighterView: HighlighterView + }); + + var DirectedGraph = { + + exportElement: function(element) { + + // The width and height of the element. + return element.size(); + }, + + exportLink: function(link) { + + var labelSize = link.get('labelSize') || {}; + var edge = { + // The number of ranks to keep between the source and target of the edge. + minLen: link.get('minLen') || 1, + // The weight to assign edges. Higher weight edges are generally + // made shorter and straighter than lower weight edges. + weight: link.get('weight') || 1, + // Where to place the label relative to the edge. + // l = left, c = center r = right. + labelpos: link.get('labelPosition') || 'c', + // How many pixels to move the label away from the edge. + // Applies only when labelpos is l or r. + labeloffset: link.get('labelOffset') || 0, + // The width of the edge label in pixels. + width: labelSize.width || 0, + // The height of the edge label in pixels. + height: labelSize.height || 0 + }; + + return edge; + }, + + importElement: function(opt, v, gl) { + + var element = this.getCell(v); + var glNode = gl.node(v); + + if (opt.setPosition) { + opt.setPosition(element, glNode); + } else { + element.set('position', { + x: glNode.x - glNode.width / 2, + y: glNode.y - glNode.height / 2 + }); + } + }, + + importLink: function(opt, edgeObj, gl) { + + var SIMPLIFY_THRESHOLD = 0.001; + + var link = this.getCell(edgeObj.name); + var glEdge = gl.edge(edgeObj); + var points = glEdge.points || []; + var polyline = new Polyline(points); + + // check the `setLinkVertices` here for backwards compatibility + if (opt.setVertices || opt.setLinkVertices) { + if (isFunction(opt.setVertices)) { + opt.setVertices(link, points); + } else { + // simplify the `points` polyline + polyline.simplify({ threshold: SIMPLIFY_THRESHOLD }); + var polylinePoints = polyline.points.map(function (point) { return (point.toJSON()); }); // JSON of points after simplification + var numPolylinePoints = polylinePoints.length; // number of points after simplification + // set simplified polyline points as link vertices + // remove first and last polyline points (= source/target sonnectionPoints) + link.set('vertices', polylinePoints.slice(1, numPolylinePoints - 1)); + } + } + + if (opt.setLabels && ('x' in glEdge) && ('y' in glEdge)) { + var labelPosition = { x: glEdge.x, y: glEdge.y }; + if (isFunction(opt.setLabels)) { + opt.setLabels(link, labelPosition, points); + } else { + // convert the absolute label position to a relative position + // towards the closest point on the edge + var length = polyline.closestPointLength(labelPosition); + var closestPoint = polyline.pointAtLength(length); + var distance = (length / polyline.length()); + var offset = new Point(labelPosition).difference(closestPoint).toJSON(); + link.label(0, { + position: { + distance: distance, + offset: offset + } + }); + } + } + }, + + layout: function(graphOrCells, opt) { + + var graph; + + if (graphOrCells instanceof Graph) { + graph = graphOrCells; + } else { + // Reset cells in dry mode so the graph reference is not stored on the cells. + // `sort: false` to prevent elements to change their order based on the z-index + graph = (new Graph()).resetCells(graphOrCells, { dry: true, sort: false }); + } + + // This is not needed anymore. + graphOrCells = null; + + opt = defaults(opt || {}, { + resizeClusters: true, + clusterPadding: 10, + exportElement: this.exportElement, + exportLink: this.exportLink + }); + + /* eslint-disable no-undef */ + var dagreUtil = opt.dagre || (typeof dagre !== 'undefined' ? dagre : undefined); + /* eslint-enable no-undef */ + + if (dagreUtil === undefined) { throw new Error('The the "dagre" utility is a mandatory dependency.'); } + + // create a graphlib.Graph that represents the joint.dia.Graph + // var glGraph = graph.toGraphLib({ + var glGraph = DirectedGraph.toGraphLib(graph, { + graphlib: opt.graphlib, + directed: true, + // We are about to use edge naming feature. + multigraph: true, + // We are able to layout graphs with embeds. + compound: true, + setNodeLabel: opt.exportElement, + setEdgeLabel: opt.exportLink, + setEdgeName: function(link) { + // Graphlib edges have no ids. We use edge name property + // to store and retrieve ids instead. + return link.id; + } + }); + + var glLabel = {}; + var marginX = opt.marginX || 0; + var marginY = opt.marginY || 0; + + // Dagre layout accepts options as lower case. + // Direction for rank nodes. Can be TB, BT, LR, or RL + if (opt.rankDir) { glLabel.rankdir = opt.rankDir; } + // Alignment for rank nodes. Can be UL, UR, DL, or DR + if (opt.align) { glLabel.align = opt.align; } + // Number of pixels that separate nodes horizontally in the layout. + if (opt.nodeSep) { glLabel.nodesep = opt.nodeSep; } + // Number of pixels that separate edges horizontally in the layout. + if (opt.edgeSep) { glLabel.edgesep = opt.edgeSep; } + // Number of pixels between each rank in the layout. + if (opt.rankSep) { glLabel.ranksep = opt.rankSep; } + // Type of algorithm to assign a rank to each node in the input graph. + // Possible values: network-simplex, tight-tree or longest-path + if (opt.ranker) { glLabel.ranker = opt.ranker; } + // Number of pixels to use as a margin around the left and right of the graph. + if (marginX) { glLabel.marginx = marginX; } + // Number of pixels to use as a margin around the top and bottom of the graph. + if (marginY) { glLabel.marginy = marginY; } + + // Set the option object for the graph label. + glGraph.setGraph(glLabel); + + // Executes the layout. + dagreUtil.layout(glGraph, { debugTiming: !!opt.debugTiming }); + + // Wrap all graph changes into a batch. + graph.startBatch('layout'); + + DirectedGraph.fromGraphLib(glGraph, { + importNode: this.importElement.bind(graph, opt), + importEdge: this.importLink.bind(graph, opt) + }); + + // // Update the graph. + // graph.fromGraphLib(glGraph, { + // importNode: this.importElement.bind(graph, opt), + // importEdge: this.importLink.bind(graph, opt) + // }); + + if (opt.resizeClusters) { + // Resize and reposition cluster elements (parents of other elements) + // to fit their children. + // 1. filter clusters only + // 2. map id on cells + // 3. sort cells by their depth (the deepest first) + // 4. resize cell to fit their direct children only. + var clusters = glGraph.nodes() + .filter(function(v) { return glGraph.children(v).length > 0; }) + .map(graph.getCell.bind(graph)) + .sort(function(aCluster, bCluster) { + return bCluster.getAncestors().length - aCluster.getAncestors().length; + }); + + invoke(clusters, 'fitEmbeds', { padding: opt.clusterPadding }); + } + + graph.stopBatch('layout'); + + // Width and height of the graph extended by margins. + var glSize = glGraph.graph(); + // Return the bounding box of the graph after the layout. + return new Rect( + marginX, + marginY, + Math.abs(glSize.width - 2 * marginX), + Math.abs(glSize.height - 2 * marginY) + ); + }, + + fromGraphLib: function(glGraph, opt) { + + opt = opt || {}; + + var importNode = opt.importNode || noop; + var importEdge = opt.importEdge || noop; + var graph = (this instanceof Graph) ? this : new Graph; + + // Import all nodes. + glGraph.nodes().forEach(function(node) { + importNode.call(graph, node, glGraph, graph, opt); + }); + + // Import all edges. + glGraph.edges().forEach(function(edge) { + importEdge.call(graph, edge, glGraph, graph, opt); + }); + + return graph; + }, + + // Create new graphlib graph from existing JointJS graph. + toGraphLib: function(graph, opt) { + + opt = opt || {}; + + /* eslint-disable no-undef */ + var graphlibUtil = opt.graphlib || (typeof graphlib !== 'undefined' ? graphlib : undefined); + /* eslint-enable no-undef */ + + if (graphlibUtil === undefined) { throw new Error('The the "graphlib" utility is a mandatory dependency.'); } + + var glGraphType = pick(opt, 'directed', 'compound', 'multigraph'); + var glGraph = new graphlibUtil.Graph(glGraphType); + var setNodeLabel = opt.setNodeLabel || noop; + var setEdgeLabel = opt.setEdgeLabel || noop; + var setEdgeName = opt.setEdgeName || noop; + var collection = graph.get('cells'); + + for (var i = 0, n = collection.length; i < n; i++) { + + var cell = collection.at(i); + if (cell.isLink()) { + + var source = cell.get('source'); + var target = cell.get('target'); + + // Links that end at a point are ignored. + if (!source.id || !target.id) { break; } + + // Note that if we are creating a multigraph we can name the edges. If + // we try to name edges on a non-multigraph an exception is thrown. + glGraph.setEdge(source.id, target.id, setEdgeLabel(cell), setEdgeName(cell)); + + } else { + + glGraph.setNode(cell.id, setNodeLabel(cell)); + + // For the compound graphs we have to take embeds into account. + if (glGraph.isCompound() && cell.has('parent')) { + var parentId = cell.get('parent'); + if (collection.has(parentId)) { + // Make sure the parent cell is included in the graph (this can + // happen when the layout is run on part of the graph only). + glGraph.setParent(cell.id, parentId); + } + } + } + } + + return glGraph; + } + }; + + Graph.prototype.toGraphLib = function(opt) { + + return DirectedGraph.toGraphLib(this, opt); + }; + + Graph.prototype.fromGraphLib = function(glGraph, opt) { + + return DirectedGraph.fromGraphLib.call(this, glGraph, opt); + }; + + var env = { + + _results: {}, + + _tests: { + + svgforeignobject: function() { + return !!document.createElementNS && + /SVGForeignObject/.test(({}).toString.call(document.createElementNS('http://www.w3.org/2000/svg', 'foreignObject'))); + } + }, + + addTest: function(name, fn) { + + return this._tests[name] = fn; + }, + + test: function(name) { + + var fn = this._tests[name]; + + if (!fn) { + throw new Error('Test not defined ("' + name + '"). Use `joint.env.addTest(name, fn) to add a new test.`'); + } + + var result = this._results[name]; + + if (typeof result !== 'undefined') { + return result; + } + + try { + result = fn(); + } catch (error) { + result = false; + } + + // Cache the test result. + this._results[name] = result; + + return result; + } + }; + + var Generic = Element$1.define('basic.Generic', { + attrs: { + '.': { fill: '#ffffff', stroke: 'none' } + } + }); + + var Rect$1 = Generic.define('basic.Rect', { + attrs: { + 'rect': { + fill: '#ffffff', + stroke: '#000000', + width: 100, + height: 60 + }, + 'text': { + fill: '#000000', + text: '', + 'font-size': 14, + 'ref-x': .5, + 'ref-y': .5, + 'text-anchor': 'middle', + 'y-alignment': 'middle', + 'font-family': 'Arial, helvetica, sans-serif' + } + } + }, { + markup: '' + }); + + var TextView = ElementView.extend({ + + presentationAttributes: ElementView.addPresentationAttributes({ + // The element view is not automatically re-scaled to fit the model size + // when the attribute 'attrs' is changed. + attrs: ['SCALE'] + }), + + confirmUpdate: function() { + var flags = ElementView.prototype.confirmUpdate.apply(this, arguments); + if (this.hasFlag(flags, 'SCALE')) { + this.resize(); + flags = this.removeFlag(flags, 'SCALE'); + } + return flags; + } + }); + + var Text = Generic.define('basic.Text', { + attrs: { + 'text': { + 'font-size': 18, + fill: '#000000' + } + } + }, { + markup: '', + }); + + var Circle = Generic.define('basic.Circle', { + size: { width: 60, height: 60 }, + attrs: { + 'circle': { + fill: '#ffffff', + stroke: '#000000', + r: 30, + cx: 30, + cy: 30 + }, + 'text': { + 'font-size': 14, + text: '', + 'text-anchor': 'middle', + 'ref-x': .5, + 'ref-y': .5, + 'y-alignment': 'middle', + fill: '#000000', + 'font-family': 'Arial, helvetica, sans-serif' + } + } + }, { + markup: '', + }); + + var Ellipse$1 = Generic.define('basic.Ellipse', { + size: { width: 60, height: 40 }, + attrs: { + 'ellipse': { + fill: '#ffffff', + stroke: '#000000', + rx: 30, + ry: 20, + cx: 30, + cy: 20 + }, + 'text': { + 'font-size': 14, + text: '', + 'text-anchor': 'middle', + 'ref-x': .5, + 'ref-y': .5, + 'y-alignment': 'middle', + fill: '#000000', + 'font-family': 'Arial, helvetica, sans-serif' + } + } + }, { + markup: '', + }); + + var Polygon$1 = Generic.define('basic.Polygon', { + size: { width: 60, height: 40 }, + attrs: { + 'polygon': { + fill: '#ffffff', + stroke: '#000000' + }, + 'text': { + 'font-size': 14, + text: '', + 'text-anchor': 'middle', + 'ref-x': .5, + 'ref-dy': 20, + 'y-alignment': 'middle', + fill: '#000000', + 'font-family': 'Arial, helvetica, sans-serif' + } + } + }, { + markup: '', + }); + + var Polyline$1 = Generic.define('basic.Polyline', { + size: { width: 60, height: 40 }, + attrs: { + 'polyline': { + fill: '#ffffff', + stroke: '#000000' + }, + 'text': { + 'font-size': 14, + text: '', + 'text-anchor': 'middle', + 'ref-x': .5, + 'ref-dy': 20, + 'y-alignment': 'middle', + fill: '#000000', + 'font-family': 'Arial, helvetica, sans-serif' + } + } + }, { + markup: '', + }); + + var Image = Generic.define('basic.Image', { + attrs: { + 'text': { + 'font-size': 14, + text: '', + 'text-anchor': 'middle', + 'ref-x': .5, + 'ref-dy': 20, + 'y-alignment': 'middle', + fill: '#000000', + 'font-family': 'Arial, helvetica, sans-serif' + } + } + }, { + markup: '', + }); + + var Path$1 = Generic.define('basic.Path', { + size: { width: 60, height: 60 }, + attrs: { + 'path': { + fill: '#ffffff', + stroke: '#000000' + }, + 'text': { + 'font-size': 14, + text: '', + 'text-anchor': 'middle', + 'ref': 'path', + 'ref-x': .5, + 'ref-dy': 10, + fill: '#000000', + 'font-family': 'Arial, helvetica, sans-serif' + } + } + + }, { + markup: '', + }); + + var Rhombus = Path$1.define('basic.Rhombus', { + attrs: { + 'path': { + d: 'M 30 0 L 60 30 30 60 0 30 z' + }, + 'text': { + 'ref-y': .5, + 'ref-dy': null, + 'y-alignment': 'middle' + } + } + }); + + var svgForeignObjectSupported = env.test('svgforeignobject'); + + var TextBlock = Generic.define('basic.TextBlock', { + // see joint.css for more element styles + attrs: { + rect: { + fill: '#ffffff', + stroke: '#000000', + width: 80, + height: 100 + }, + text: { + fill: '#000000', + 'font-size': 14, + 'font-family': 'Arial, helvetica, sans-serif' + }, + '.content': { + text: '', + 'ref-x': .5, + 'ref-y': .5, + 'y-alignment': 'middle', + 'x-alignment': 'middle' + } + }, + + content: '' + }, { + markup: [ + '', + '', + svgForeignObjectSupported + ? '
    ' + : '', + '' + ].join(''), + + initialize: function() { + + this.listenTo(this, 'change:size', this.updateSize); + this.listenTo(this, 'change:content', this.updateContent); + this.updateSize(this, this.get('size')); + this.updateContent(this, this.get('content')); + Generic.prototype.initialize.apply(this, arguments); + }, + + updateSize: function(cell, size) { + + // Selector `foreignObject' doesn't work across all browsers, we're using class selector instead. + // We have to clone size as we don't want attributes.div.style to be same object as attributes.size. + this.attr({ + '.fobj': assign({}, size), + div: { + style: assign({}, size) + } + }); + }, + + updateContent: function(cell, content) { + + if (svgForeignObjectSupported) { + + // Content element is a
    element. + this.attr({ + '.content': { + html: sanitizeHTML(content) + } + }); + + } else { + + // Content element is a element. + // SVG elements don't have innerHTML attribute. + this.attr({ + '.content': { + text: content + } + }); + } + }, + + // Here for backwards compatibility: + setForeignObjectSize: function() { + + this.updateSize.apply(this, arguments); + }, + + // Here for backwards compatibility: + setDivContent: function() { + + this.updateContent.apply(this, arguments); + } + }); + + // TextBlockView implements the fallback for IE when no foreignObject exists and + // the text needs to be manually broken. + var TextBlockView = ElementView.extend({ + + presentationAttributes: svgForeignObjectSupported + ? ElementView.prototype.presentationAttributes + : ElementView.addPresentationAttributes({ + content: ['CONTENT'], + size: ['CONTENT'] + }), + + initFlag: ['RENDER', 'CONTENT'], + + confirmUpdate: function() { + var flags = ElementView.prototype.confirmUpdate.apply(this, arguments); + if (this.hasFlag(flags, 'CONTENT')) { + this.updateContent(this.model); + flags = this.removeFlag(flags, 'CONTENT'); + } + return flags; + }, + + update: function(_, renderingOnlyAttrs) { + + var model = this.model; + + if (!svgForeignObjectSupported) { + + // Update everything but the content first. + var noTextAttrs = omit(renderingOnlyAttrs || model.get('attrs'), '.content'); + ElementView.prototype.update.call(this, model, noTextAttrs); + + if (!renderingOnlyAttrs || has$2(renderingOnlyAttrs, '.content')) { + // Update the content itself. + this.updateContent(model, renderingOnlyAttrs); + } + + } else { + + ElementView.prototype.update.call(this, model, renderingOnlyAttrs); + } + }, + + updateContent: function(cell, renderingOnlyAttrs) { + + // Create copy of the text attributes + var textAttrs = merge({}, (renderingOnlyAttrs || cell.get('attrs'))['.content']); + + textAttrs = omit(textAttrs, 'text'); + + // Break the content to fit the element size taking into account the attributes + // set on the model. + var text = breakText(cell.get('content'), cell.get('size'), textAttrs, { + // measuring sandbox svg document + svgDocument: this.paper.svg + }); + + // Create a new attrs with same structure as the model attrs { text: { *textAttributes* }} + var attrs = setByPath({}, '.content', textAttrs, '/'); + + // Replace text attribute with the one we just processed. + attrs['.content'].text = text; + + // Update the view using renderingOnlyAttributes parameter. + ElementView.prototype.update.call(this, cell, attrs); + } + }); + + var basic = ({ + Generic: Generic, + Rect: Rect$1, + TextView: TextView, + Text: Text, + Circle: Circle, + Ellipse: Ellipse$1, + Polygon: Polygon$1, + Polyline: Polyline$1, + Image: Image, + Path: Path$1, + Rhombus: Rhombus, + TextBlock: TextBlock, + TextBlockView: TextBlockView + }); + + // ELEMENTS + + var Rectangle = Element$1.define('standard.Rectangle', { + attrs: { + body: { + refWidth: '100%', + refHeight: '100%', + strokeWidth: 2, + stroke: '#000000', + fill: '#FFFFFF' + }, + label: { + textVerticalAnchor: 'middle', + textAnchor: 'middle', + refX: '50%', + refY: '50%', + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'rect', + selector: 'body', + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var Circle$1 = Element$1.define('standard.Circle', { + attrs: { + body: { + refCx: '50%', + refCy: '50%', + refR: '50%', + strokeWidth: 2, + stroke: '#333333', + fill: '#FFFFFF' + }, + label: { + textVerticalAnchor: 'middle', + textAnchor: 'middle', + refX: '50%', + refY: '50%', + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'circle', + selector: 'body' + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var Ellipse$2 = Element$1.define('standard.Ellipse', { + attrs: { + body: { + refCx: '50%', + refCy: '50%', + refRx: '50%', + refRy: '50%', + strokeWidth: 2, + stroke: '#333333', + fill: '#FFFFFF' + }, + label: { + textVerticalAnchor: 'middle', + textAnchor: 'middle', + refX: '50%', + refY: '50%', + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'ellipse', + selector: 'body' + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var Path$2 = Element$1.define('standard.Path', { + attrs: { + body: { + refD: 'M 0 0 L 10 0 10 10 0 10 Z', + strokeWidth: 2, + stroke: '#333333', + fill: '#FFFFFF' + }, + label: { + textVerticalAnchor: 'middle', + textAnchor: 'middle', + refX: '50%', + refY: '50%', + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'path', + selector: 'body' + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var Polygon$2 = Element$1.define('standard.Polygon', { + attrs: { + body: { + refPoints: '0 0 10 0 10 10 0 10', + strokeWidth: 2, + stroke: '#333333', + fill: '#FFFFFF' + }, + label: { + textVerticalAnchor: 'middle', + textAnchor: 'middle', + refX: '50%', + refY: '50%', + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'polygon', + selector: 'body' + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var Polyline$2 = Element$1.define('standard.Polyline', { + attrs: { + body: { + refPoints: '0 0 10 0 10 10 0 10 0 0', + strokeWidth: 2, + stroke: '#333333', + fill: '#FFFFFF' + }, + label: { + textVerticalAnchor: 'middle', + textAnchor: 'middle', + refX: '50%', + refY: '50%', + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'polyline', + selector: 'body' + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var Image$1 = Element$1.define('standard.Image', { + attrs: { + image: { + refWidth: '100%', + refHeight: '100%', + // xlinkHref: '[URL]' + }, + label: { + textVerticalAnchor: 'top', + textAnchor: 'middle', + refX: '50%', + refY: '100%', + refY2: 10, + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'image', + selector: 'image' + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var BorderedImage = Element$1.define('standard.BorderedImage', { + attrs: { + border: { + refWidth: '100%', + refHeight: '100%', + stroke: '#333333', + strokeWidth: 2 + }, + background: { + refWidth: -1, + refHeight: -1, + x: 0.5, + y: 0.5, + fill: '#FFFFFF' + }, + image: { + // xlinkHref: '[URL]' + refWidth: -1, + refHeight: -1, + x: 0.5, + y: 0.5 + }, + label: { + textVerticalAnchor: 'top', + textAnchor: 'middle', + refX: '50%', + refY: '100%', + refY2: 10, + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'rect', + selector: 'background', + attributes: { + 'stroke': 'none' + } + }, { + tagName: 'image', + selector: 'image' + }, { + tagName: 'rect', + selector: 'border', + attributes: { + 'fill': 'none' + } + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var EmbeddedImage = Element$1.define('standard.EmbeddedImage', { + attrs: { + body: { + refWidth: '100%', + refHeight: '100%', + stroke: '#333333', + fill: '#FFFFFF', + strokeWidth: 2 + }, + image: { + // xlinkHref: '[URL]' + refWidth: '30%', + refHeight: -20, + x: 10, + y: 10, + preserveAspectRatio: 'xMidYMin' + }, + label: { + textVerticalAnchor: 'top', + textAnchor: 'left', + refX: '30%', + refX2: 20, // 10 + 10 + refY: 10, + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'rect', + selector: 'body' + }, { + tagName: 'image', + selector: 'image' + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var InscribedImage = Element$1.define('standard.InscribedImage', { + attrs: { + border: { + refRx: '50%', + refRy: '50%', + refCx: '50%', + refCy: '50%', + stroke: '#333333', + strokeWidth: 2 + }, + background: { + refRx: '50%', + refRy: '50%', + refCx: '50%', + refCy: '50%', + fill: '#FFFFFF' + }, + image: { + // The image corners touch the border when its size is Math.sqrt(2) / 2 = 0.707.. ~= 70% + refWidth: '68%', + refHeight: '68%', + // The image offset is calculated as (100% - 68%) / 2 + refX: '16%', + refY: '16%', + preserveAspectRatio: 'xMidYMid' + // xlinkHref: '[URL]' + }, + label: { + textVerticalAnchor: 'top', + textAnchor: 'middle', + refX: '50%', + refY: '100%', + refY2: 10, + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'ellipse', + selector: 'background' + }, { + tagName: 'image', + selector: 'image' + }, { + tagName: 'ellipse', + selector: 'border', + attributes: { + 'fill': 'none' + } + }, { + tagName: 'text', + selector: 'label' + }] + }); + + var HeaderedRectangle = Element$1.define('standard.HeaderedRectangle', { + attrs: { + body: { + refWidth: '100%', + refHeight: '100%', + strokeWidth: 2, + stroke: '#000000', + fill: '#FFFFFF' + }, + header: { + refWidth: '100%', + height: 30, + strokeWidth: 2, + stroke: '#000000', + fill: '#FFFFFF' + }, + headerText: { + textVerticalAnchor: 'middle', + textAnchor: 'middle', + refX: '50%', + refY: 15, + fontSize: 16, + fill: '#333333' + }, + bodyText: { + textVerticalAnchor: 'middle', + textAnchor: 'middle', + refX: '50%', + refY: '50%', + refY2: 15, + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'rect', + selector: 'body' + }, { + tagName: 'rect', + selector: 'header' + }, { + tagName: 'text', + selector: 'headerText' + }, { + tagName: 'text', + selector: 'bodyText' + }] + }); + + var CYLINDER_TILT = 10; + + var Cylinder = Element$1.define('standard.Cylinder', { + attrs: { + body: { + lateralArea: CYLINDER_TILT, + fill: '#FFFFFF', + stroke: '#333333', + strokeWidth: 2 + }, + top: { + refCx: '50%', + cy: CYLINDER_TILT, + refRx: '50%', + ry: CYLINDER_TILT, + fill: '#FFFFFF', + stroke: '#333333', + strokeWidth: 2 + }, + label: { + textVerticalAnchor: 'middle', + textAnchor: 'middle', + refX: '50%', + refY: '100%', + refY2: 15, + fontSize: 14, + fill: '#333333' + } + } + }, { + markup: [{ + tagName: 'path', + selector: 'body' + }, { + tagName: 'ellipse', + selector: 'top' + }, { + tagName: 'text', + selector: 'label' + }], + + topRy: function(t, opt) { + // getter + if (t === undefined) { return this.attr('body/lateralArea'); } + + // setter + var isPercentageSetter = isPercentage(t); + + var bodyAttrs = { lateralArea: t }; + var topAttrs = isPercentageSetter + ? { refCy: t, refRy: t, cy: null, ry: null } + : { refCy: null, refRy: null, cy: t, ry: t }; + + return this.attr({ body: bodyAttrs, top: topAttrs }, opt); + } + + }, { + attributes: { + lateralArea: { + set: function(t, refBBox) { + var isPercentageSetter = isPercentage(t); + if (isPercentageSetter) { t = parseFloat(t) / 100; } + + var x = refBBox.x; + var y = refBBox.y; + var w = refBBox.width; + var h = refBBox.height; + + // curve control point variables + var rx = w / 2; + var ry = isPercentageSetter ? (h * t) : t; + + var kappa = V.KAPPA; + var cx = kappa * rx; + var cy = kappa * (isPercentageSetter ? (h * t) : t); + + // shape variables + var xLeft = x; + var xCenter = x + (w / 2); + var xRight = x + w; + + var ySideTop = y + ry; + var yCurveTop = ySideTop - ry; + var ySideBottom = y + h - ry; + var yCurveBottom = y + h; + + // return calculated shape + var data = [ + 'M', xLeft, ySideTop, + 'L', xLeft, ySideBottom, + 'C', x, (ySideBottom + cy), (xCenter - cx), yCurveBottom, xCenter, yCurveBottom, + 'C', (xCenter + cx), yCurveBottom, xRight, (ySideBottom + cy), xRight, ySideBottom, + 'L', xRight, ySideTop, + 'C', xRight, (ySideTop - cy), (xCenter + cx), yCurveTop, xCenter, yCurveTop, + 'C', (xCenter - cx), yCurveTop, xLeft, (ySideTop - cy), xLeft, ySideTop, + 'Z' + ]; + return { d: data.join(' ') }; + } + } + } + }); + + var foLabelMarkup = { + tagName: 'foreignObject', + selector: 'foreignObject', + attributes: { + 'overflow': 'hidden' + }, + children: [{ + tagName: 'div', + namespaceURI: 'http://www.w3.org/1999/xhtml', + selector: 'label', + style: { + width: '100%', + height: '100%', + position: 'static', + backgroundColor: 'transparent', + textAlign: 'center', + margin: 0, + padding: '0px 5px', + boxSizing: 'border-box', + display: 'flex', + alignItems: 'center', + justifyContent: 'center' + } + }] + }; + + var svgLabelMarkup = { + tagName: 'text', + selector: 'label', + attributes: { + 'text-anchor': 'middle' + } + }; + + var labelMarkup = (env.test('svgforeignobject')) ? foLabelMarkup : svgLabelMarkup; + + var TextBlock$1 = Element$1.define('standard.TextBlock', { + attrs: { + body: { + refWidth: '100%', + refHeight: '100%', + stroke: '#333333', + fill: '#ffffff', + strokeWidth: 2 + }, + foreignObject: { + refWidth: '100%', + refHeight: '100%' + }, + label: { + style: { + fontSize: 14 + } + } + } + }, { + markup: [{ + tagName: 'rect', + selector: 'body' + }, labelMarkup] + }, { + attributes: { + text: { + set: function(text, refBBox, node, attrs) { + if (node instanceof HTMLElement) { + node.textContent = text; + } else { + // No foreign object + var style = attrs.style || {}; + var wrapValue = { text: text, width: -5, height: '100%' }; + var wrapAttrs = assign({ textVerticalAnchor: 'middle' }, style); + attributes.textWrap.set.call(this, wrapValue, refBBox, node, wrapAttrs); + return { fill: style.color || null }; + } + }, + position: function(text, refBBox, node) { + // No foreign object + if (node instanceof SVGElement) { return refBBox.center(); } + } + } + } + }); + + // LINKS + + var Link$1 = Link.define('standard.Link', { + attrs: { + line: { + connection: true, + stroke: '#333333', + strokeWidth: 2, + strokeLinejoin: 'round', + targetMarker: { + 'type': 'path', + 'd': 'M 10 -5 0 0 10 5 z' + } + }, + wrapper: { + connection: true, + strokeWidth: 10, + strokeLinejoin: 'round' + } + } + }, { + markup: [{ + tagName: 'path', + selector: 'wrapper', + attributes: { + 'fill': 'none', + 'cursor': 'pointer', + 'stroke': 'transparent', + 'stroke-linecap': 'round' + } + }, { + tagName: 'path', + selector: 'line', + attributes: { + 'fill': 'none', + 'pointer-events': 'none' + } + }] + }); + + var DoubleLink = Link.define('standard.DoubleLink', { + attrs: { + line: { + connection: true, + stroke: '#DDDDDD', + strokeWidth: 4, + strokeLinejoin: 'round', + targetMarker: { + type: 'path', + stroke: '#000000', + d: 'M 10 -3 10 -10 -2 0 10 10 10 3' + } + }, + outline: { + connection: true, + stroke: '#000000', + strokeWidth: 6, + strokeLinejoin: 'round' + } + } + }, { + markup: [{ + tagName: 'path', + selector: 'outline', + attributes: { + 'fill': 'none' + } + }, { + tagName: 'path', + selector: 'line', + attributes: { + 'fill': 'none' + } + }] + }); + + var ShadowLink = Link.define('standard.ShadowLink', { + attrs: { + line: { + connection: true, + stroke: '#FF0000', + strokeWidth: 20, + strokeLinejoin: 'round', + targetMarker: { + 'type': 'path', + 'stroke': 'none', + 'd': 'M 0 -10 -10 0 0 10 z' + }, + sourceMarker: { + 'type': 'path', + 'stroke': 'none', + 'd': 'M -10 -10 0 0 -10 10 0 10 0 -10 z' + } + }, + shadow: { + connection: true, + refX: 3, + refY: 6, + stroke: '#000000', + strokeOpacity: 0.2, + strokeWidth: 20, + strokeLinejoin: 'round', + targetMarker: { + 'type': 'path', + 'd': 'M 0 -10 -10 0 0 10 z', + 'stroke': 'none' + }, + sourceMarker: { + 'type': 'path', + 'stroke': 'none', + 'd': 'M -10 -10 0 0 -10 10 0 10 0 -10 z' + } + } + } + }, { + markup: [{ + tagName: 'path', + selector: 'shadow', + attributes: { + 'fill': 'none' + } + }, { + tagName: 'path', + selector: 'line', + attributes: { + 'fill': 'none' + } + }] + }); + + var standard = ({ + Rectangle: Rectangle, + Circle: Circle$1, + Ellipse: Ellipse$2, + Path: Path$2, + Polygon: Polygon$2, + Polyline: Polyline$2, + Image: Image$1, + BorderedImage: BorderedImage, + EmbeddedImage: EmbeddedImage, + InscribedImage: InscribedImage, + HeaderedRectangle: HeaderedRectangle, + Cylinder: Cylinder, + TextBlock: TextBlock$1, + Link: Link$1, + DoubleLink: DoubleLink, + ShadowLink: ShadowLink + }); + + /** + * @deprecated use the port api instead + */ + var Model = Generic.define('devs.Model', { + inPorts: [], + outPorts: [], + size: { + width: 80, + height: 80 + }, + attrs: { + '.': { + magnet: false + }, + '.label': { + text: 'Model', + 'ref-x': .5, + 'ref-y': 10, + 'font-size': 18, + 'text-anchor': 'middle', + fill: '#000' + }, + '.body': { + 'ref-width': '100%', + 'ref-height': '100%', + stroke: '#000' + } + }, + ports: { + groups: { + 'in': { + position: { + name: 'left' + }, + attrs: { + '.port-label': { + fill: '#000' + }, + '.port-body': { + fill: '#fff', + stroke: '#000', + r: 10, + magnet: true + } + }, + label: { + position: { + name: 'left', + args: { + y: 10 + } + } + } + }, + 'out': { + position: { + name: 'right' + }, + attrs: { + '.port-label': { + fill: '#000' + }, + '.port-body': { + fill: '#fff', + stroke: '#000', + r: 10, + magnet: true + } + }, + label: { + position: { + name: 'right', + args: { + y: 10 + } + } + } + } + } + } + }, { + markup: '', + portMarkup: '', + portLabelMarkup: '', + + initialize: function() { + + Generic.prototype.initialize.apply(this, arguments); + + this.on('change:inPorts change:outPorts', this.updatePortItems, this); + this.updatePortItems(); + }, + + updatePortItems: function(model, changed, opt) { + + // Make sure all ports are unique. + var inPorts = uniq(this.get('inPorts')); + var outPorts = difference(uniq(this.get('outPorts')), inPorts); + + var inPortItems = this.createPortItems('in', inPorts); + var outPortItems = this.createPortItems('out', outPorts); + + this.prop('ports/items', inPortItems.concat(outPortItems), assign({ rewrite: true }, opt)); + }, + + createPortItem: function(group, port) { + + return { + id: port, + group: group, + attrs: { + '.port-label': { + text: port + } + } + }; + }, + + createPortItems: function(group, ports) { + + return toArray(ports).map(this.createPortItem.bind(this, group)); + }, + + _addGroupPort: function(port, group, opt) { + + var ports = this.get(group); + return this.set(group, Array.isArray(ports) ? ports.concat(port) : [port], opt); + }, + + addOutPort: function(port, opt) { + + return this._addGroupPort(port, 'outPorts', opt); + }, + + addInPort: function(port, opt) { + + return this._addGroupPort(port, 'inPorts', opt); + }, + + _removeGroupPort: function(port, group, opt) { + + return this.set(group, without(this.get(group), port), opt); + }, + + removeOutPort: function(port, opt) { + + return this._removeGroupPort(port, 'outPorts', opt); + }, + + removeInPort: function(port, opt) { + + return this._removeGroupPort(port, 'inPorts', opt); + }, + + _changeGroup: function(group, properties, opt) { + + return this.prop('ports/groups/' + group, isObject$1(properties) ? properties : {}, opt); + }, + + changeInGroup: function(properties, opt) { + + return this._changeGroup('in', properties, opt); + }, + + changeOutGroup: function(properties, opt) { + + return this._changeGroup('out', properties, opt); + } + }); + + var Atomic = Model.define('devs.Atomic', { + size: { + width: 80, + height: 80 + }, + attrs: { + '.label': { + text: 'Atomic' + } + } + }); + + var Coupled = Model.define('devs.Coupled', { + size: { + width: 200, + height: 300 + }, + attrs: { + '.label': { + text: 'Coupled' + } + } + }); + + var Link$2 = Link.define('devs.Link', { + attrs: { + '.connection': { + 'stroke-width': 2 + } + } + }); + + var devs = ({ + Model: Model, + Atomic: Atomic, + Coupled: Coupled, + Link: Link$2 + }); + + var Gate = Generic.define('logic.Gate', { + size: { width: 80, height: 40 }, + attrs: { + '.': { magnet: false }, + '.body': { width: 100, height: 50 }, + circle: { r: 7, stroke: 'black', fill: 'transparent', 'stroke-width': 2 } + } + }, { + operation: function() { + return true; + } + }); + + var IO = Gate.define('logic.IO', { + size: { width: 60, height: 30 }, + attrs: { + '.body': { fill: 'white', stroke: 'black', 'stroke-width': 2 }, + '.wire': { ref: '.body', 'ref-y': .5, stroke: 'black' }, + text: { + fill: 'black', + ref: '.body', 'ref-x': .5, 'ref-y': .5, 'y-alignment': 'middle', + 'text-anchor': 'middle', + 'font-weight': 'bold', + 'font-variant': 'small-caps', + 'text-transform': 'capitalize', + 'font-size': '14px' + } + } + }, { + markup: '', + }); + + var Input = IO.define('logic.Input', { + attrs: { + '.wire': { 'ref-dx': 0, d: 'M 0 0 L 23 0' }, + circle: { ref: '.body', 'ref-dx': 30, 'ref-y': 0.5, magnet: true, 'class': 'output', port: 'out' }, + text: { text: 'input' } + } + }); + + var Output = IO.define('logic.Output', { + attrs: { + '.wire': { 'ref-x': 0, d: 'M 0 0 L -23 0' }, + circle: { ref: '.body', 'ref-x': -30, 'ref-y': 0.5, magnet: 'passive', 'class': 'input', port: 'in' }, + text: { text: 'output' } + } + }); + + var Gate11 = Gate.define('logic.Gate11', { + attrs: { + '.input': { ref: '.body', 'ref-x': -2, 'ref-y': 0.5, magnet: 'passive', port: 'in' }, + '.output': { ref: '.body', 'ref-dx': 2, 'ref-y': 0.5, magnet: true, port: 'out' } + } + }, { + markup: '', + }); + + var Gate21 = Gate.define('logic.Gate21', { + attrs: { + '.input1': { ref: '.body', 'ref-x': -2, 'ref-y': 0.3, magnet: 'passive', port: 'in1' }, + '.input2': { ref: '.body', 'ref-x': -2, 'ref-y': 0.7, magnet: 'passive', port: 'in2' }, + '.output': { ref: '.body', 'ref-dx': 2, 'ref-y': 0.5, magnet: true, port: 'out' } + } + }, { + markup: '', + }); + + var Repeater = Gate11.define('logic.Repeater', { + attrs: { image: { 'xlink:href': 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjwhLS0gQ3JlYXRlZCB3aXRoIElua3NjYXBlIChodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy8pIC0tPgo8c3ZnCiAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgeG1sbnM6Y2M9Imh0dHA6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL25zIyIKICAgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIgogICB4bWxuczpzdmc9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zOnNvZGlwb2RpPSJodHRwOi8vc29kaXBvZGkuc291cmNlZm9yZ2UubmV0L0RURC9zb2RpcG9kaS0wLmR0ZCIKICAgeG1sbnM6aW5rc2NhcGU9Imh0dHA6Ly93d3cuaW5rc2NhcGUub3JnL25hbWVzcGFjZXMvaW5rc2NhcGUiCiAgIHdpZHRoPSIxMDAiCiAgIGhlaWdodD0iNTAiCiAgIGlkPSJzdmcyIgogICBzb2RpcG9kaTp2ZXJzaW9uPSIwLjMyIgogICBpbmtzY2FwZTp2ZXJzaW9uPSIwLjQ2IgogICB2ZXJzaW9uPSIxLjAiCiAgIHNvZGlwb2RpOmRvY25hbWU9Ik5PVCBBTlNJLnN2ZyIKICAgaW5rc2NhcGU6b3V0cHV0X2V4dGVuc2lvbj0ib3JnLmlua3NjYXBlLm91dHB1dC5zdmcuaW5rc2NhcGUiPgogIDxkZWZzCiAgICAgaWQ9ImRlZnM0Ij4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiAxNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF96PSI1MCA6IDE1IDogMSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIyNSA6IDEwIDogMSIKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI3MTQiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMC41IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEgOiAwLjUgOiAxIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjAuNSA6IDAuMzMzMzMzMzMgOiAxIgogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgwNiIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgxOSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIzNzIuMDQ3MjQgOiAzNTAuNzg3MzkgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNzQ0LjA5NDQ4IDogNTI2LjE4MTA5IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MjYuMTgxMDkgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjc3NyIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSI3NSA6IDQwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjE1MCA6IDYwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA2MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmUzMjc1IgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjUwIDogMzMuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEwMCA6IDUwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmU1NTMzIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjMyIDogMjEuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjY0IDogMzIgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDMyIDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI1NTciCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMjUgOiAxNi42NjY2NjcgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNTAgOiAyNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMjUgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICA8L2RlZnM+CiAgPHNvZGlwb2RpOm5hbWVkdmlldwogICAgIGlkPSJiYXNlIgogICAgIHBhZ2Vjb2xvcj0iI2ZmZmZmZiIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBib3JkZXJvcGFjaXR5PSIxLjAiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAuMCIKICAgICBpbmtzY2FwZTpwYWdlc2hhZG93PSIyIgogICAgIGlua3NjYXBlOnpvb209IjgiCiAgICAgaW5rc2NhcGU6Y3g9Ijg0LjY4NTM1MiIKICAgICBpbmtzY2FwZTpjeT0iMTUuMjg4NjI4IgogICAgIGlua3NjYXBlOmRvY3VtZW50LXVuaXRzPSJweCIKICAgICBpbmtzY2FwZTpjdXJyZW50LWxheWVyPSJsYXllcjEiCiAgICAgc2hvd2dyaWQ9InRydWUiCiAgICAgaW5rc2NhcGU6Z3JpZC1iYm94PSJ0cnVlIgogICAgIGlua3NjYXBlOmdyaWQtcG9pbnRzPSJ0cnVlIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwMDAwIgogICAgIGlua3NjYXBlOndpbmRvdy13aWR0aD0iMTM5OSIKICAgICBpbmtzY2FwZTp3aW5kb3ctaGVpZ2h0PSI4NzQiCiAgICAgaW5rc2NhcGU6d2luZG93LXg9IjMzIgogICAgIGlua3NjYXBlOndpbmRvdy15PSIwIgogICAgIGlua3NjYXBlOnNuYXAtYmJveD0idHJ1ZSI+CiAgICA8aW5rc2NhcGU6Z3JpZAogICAgICAgaWQ9IkdyaWRGcm9tUHJlMDQ2U2V0dGluZ3MiCiAgICAgICB0eXBlPSJ4eWdyaWQiCiAgICAgICBvcmlnaW54PSIwcHgiCiAgICAgICBvcmlnaW55PSIwcHgiCiAgICAgICBzcGFjaW5neD0iMXB4IgogICAgICAgc3BhY2luZ3k9IjFweCIKICAgICAgIGNvbG9yPSIjMDAwMGZmIgogICAgICAgZW1wY29sb3I9IiMwMDAwZmYiCiAgICAgICBvcGFjaXR5PSIwLjIiCiAgICAgICBlbXBvcGFjaXR5PSIwLjQiCiAgICAgICBlbXBzcGFjaW5nPSI1IgogICAgICAgdmlzaWJsZT0idHJ1ZSIKICAgICAgIGVuYWJsZWQ9InRydWUiIC8+CiAgPC9zb2RpcG9kaTpuYW1lZHZpZXc+CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhNyI+CiAgICA8cmRmOlJERj4KICAgICAgPGNjOldvcmsKICAgICAgICAgcmRmOmFib3V0PSIiPgogICAgICAgIDxkYzpmb3JtYXQ+aW1hZ2Uvc3ZnK3htbDwvZGM6Zm9ybWF0PgogICAgICAgIDxkYzp0eXBlCiAgICAgICAgICAgcmRmOnJlc291cmNlPSJodHRwOi8vcHVybC5vcmcvZGMvZGNtaXR5cGUvU3RpbGxJbWFnZSIgLz4KICAgICAgPC9jYzpXb3JrPgogICAgPC9yZGY6UkRGPgogIDwvbWV0YWRhdGE+CiAgPGcKICAgICBpbmtzY2FwZTpsYWJlbD0iTGF5ZXIgMSIKICAgICBpbmtzY2FwZTpncm91cG1vZGU9ImxheWVyIgogICAgIGlkPSJsYXllcjEiPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmaWxsOm5vbmU7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjEuOTk5OTk5ODg7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgIGQ9Ik0gNzIuMTU2OTEsMjUgTCA5NSwyNSIKICAgICAgIGlkPSJwYXRoMzA1OSIKICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2MiIC8+CiAgICA8cGF0aAogICAgICAgc3R5bGU9ImZpbGw6bm9uZTtzdHJva2U6IzAwMDAwMDtzdHJva2Utd2lkdGg6MjtzdHJva2UtbGluZWNhcDpidXR0O3N0cm9rZS1saW5lam9pbjptaXRlcjtzdHJva2Utb3BhY2l0eToxIgogICAgICAgZD0iTSAyOS4wNDM0NzgsMjUgTCA1LjA0MzQ3ODEsMjUiCiAgICAgICBpZD0icGF0aDMwNjEiIC8+CiAgICA8cGF0aAogICAgICAgc3R5bGU9ImZpbGw6IzAwMDAwMDtmaWxsLW9wYWNpdHk6MTtzdHJva2U6bm9uZTtzdHJva2Utd2lkdGg6MztzdHJva2UtbGluZWpvaW46bWl0ZXI7bWFya2VyOm5vbmU7c3Ryb2tlLW9wYWNpdHk6MTt2aXNpYmlsaXR5OnZpc2libGU7ZGlzcGxheTppbmxpbmU7b3ZlcmZsb3c6dmlzaWJsZTtlbmFibGUtYmFja2dyb3VuZDphY2N1bXVsYXRlIgogICAgICAgZD0iTSAyOC45Njg3NSwyLjU5Mzc1IEwgMjguOTY4NzUsNSBMIDI4Ljk2ODc1LDQ1IEwgMjguOTY4NzUsNDcuNDA2MjUgTCAzMS4xMjUsNDYuMzQzNzUgTCA3Mi4xNTYyNSwyNi4zNDM3NSBMIDcyLjE1NjI1LDIzLjY1NjI1IEwgMzEuMTI1LDMuNjU2MjUgTCAyOC45Njg3NSwyLjU5Mzc1IHogTSAzMS45Njg3NSw3LjQwNjI1IEwgNjguMDkzNzUsMjUgTCAzMS45Njg3NSw0Mi41OTM3NSBMIDMxLjk2ODc1LDcuNDA2MjUgeiIKICAgICAgIGlkPSJwYXRoMjYzOCIKICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2NjY2NjY2NjY2NjYyIgLz4KICA8L2c+Cjwvc3ZnPgo=' }} + }, { + operation: function(input) { + return input; + } + }); + + var Not = Gate11.define('logic.Not', { + attrs: { image: { 'xlink:href': 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjwhLS0gQ3JlYXRlZCB3aXRoIElua3NjYXBlIChodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy8pIC0tPgo8c3ZnCiAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgeG1sbnM6Y2M9Imh0dHA6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL25zIyIKICAgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIgogICB4bWxuczpzdmc9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zOnNvZGlwb2RpPSJodHRwOi8vc29kaXBvZGkuc291cmNlZm9yZ2UubmV0L0RURC9zb2RpcG9kaS0wLmR0ZCIKICAgeG1sbnM6aW5rc2NhcGU9Imh0dHA6Ly93d3cuaW5rc2NhcGUub3JnL25hbWVzcGFjZXMvaW5rc2NhcGUiCiAgIHdpZHRoPSIxMDAiCiAgIGhlaWdodD0iNTAiCiAgIGlkPSJzdmcyIgogICBzb2RpcG9kaTp2ZXJzaW9uPSIwLjMyIgogICBpbmtzY2FwZTp2ZXJzaW9uPSIwLjQ2IgogICB2ZXJzaW9uPSIxLjAiCiAgIHNvZGlwb2RpOmRvY25hbWU9Ik5PVCBBTlNJLnN2ZyIKICAgaW5rc2NhcGU6b3V0cHV0X2V4dGVuc2lvbj0ib3JnLmlua3NjYXBlLm91dHB1dC5zdmcuaW5rc2NhcGUiPgogIDxkZWZzCiAgICAgaWQ9ImRlZnM0Ij4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiAxNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF96PSI1MCA6IDE1IDogMSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIyNSA6IDEwIDogMSIKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI3MTQiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMC41IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEgOiAwLjUgOiAxIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjAuNSA6IDAuMzMzMzMzMzMgOiAxIgogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgwNiIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgxOSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIzNzIuMDQ3MjQgOiAzNTAuNzg3MzkgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNzQ0LjA5NDQ4IDogNTI2LjE4MTA5IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MjYuMTgxMDkgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjc3NyIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSI3NSA6IDQwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjE1MCA6IDYwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA2MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmUzMjc1IgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjUwIDogMzMuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEwMCA6IDUwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmU1NTMzIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjMyIDogMjEuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjY0IDogMzIgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDMyIDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI1NTciCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMjUgOiAxNi42NjY2NjcgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNTAgOiAyNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMjUgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICA8L2RlZnM+CiAgPHNvZGlwb2RpOm5hbWVkdmlldwogICAgIGlkPSJiYXNlIgogICAgIHBhZ2Vjb2xvcj0iI2ZmZmZmZiIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBib3JkZXJvcGFjaXR5PSIxLjAiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAuMCIKICAgICBpbmtzY2FwZTpwYWdlc2hhZG93PSIyIgogICAgIGlua3NjYXBlOnpvb209IjgiCiAgICAgaW5rc2NhcGU6Y3g9Ijg0LjY4NTM1MiIKICAgICBpbmtzY2FwZTpjeT0iMTUuMjg4NjI4IgogICAgIGlua3NjYXBlOmRvY3VtZW50LXVuaXRzPSJweCIKICAgICBpbmtzY2FwZTpjdXJyZW50LWxheWVyPSJsYXllcjEiCiAgICAgc2hvd2dyaWQ9InRydWUiCiAgICAgaW5rc2NhcGU6Z3JpZC1iYm94PSJ0cnVlIgogICAgIGlua3NjYXBlOmdyaWQtcG9pbnRzPSJ0cnVlIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwMDAwIgogICAgIGlua3NjYXBlOndpbmRvdy13aWR0aD0iMTM5OSIKICAgICBpbmtzY2FwZTp3aW5kb3ctaGVpZ2h0PSI4NzQiCiAgICAgaW5rc2NhcGU6d2luZG93LXg9IjMzIgogICAgIGlua3NjYXBlOndpbmRvdy15PSIwIgogICAgIGlua3NjYXBlOnNuYXAtYmJveD0idHJ1ZSI+CiAgICA8aW5rc2NhcGU6Z3JpZAogICAgICAgaWQ9IkdyaWRGcm9tUHJlMDQ2U2V0dGluZ3MiCiAgICAgICB0eXBlPSJ4eWdyaWQiCiAgICAgICBvcmlnaW54PSIwcHgiCiAgICAgICBvcmlnaW55PSIwcHgiCiAgICAgICBzcGFjaW5neD0iMXB4IgogICAgICAgc3BhY2luZ3k9IjFweCIKICAgICAgIGNvbG9yPSIjMDAwMGZmIgogICAgICAgZW1wY29sb3I9IiMwMDAwZmYiCiAgICAgICBvcGFjaXR5PSIwLjIiCiAgICAgICBlbXBvcGFjaXR5PSIwLjQiCiAgICAgICBlbXBzcGFjaW5nPSI1IgogICAgICAgdmlzaWJsZT0idHJ1ZSIKICAgICAgIGVuYWJsZWQ9InRydWUiIC8+CiAgPC9zb2RpcG9kaTpuYW1lZHZpZXc+CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhNyI+CiAgICA8cmRmOlJERj4KICAgICAgPGNjOldvcmsKICAgICAgICAgcmRmOmFib3V0PSIiPgogICAgICAgIDxkYzpmb3JtYXQ+aW1hZ2Uvc3ZnK3htbDwvZGM6Zm9ybWF0PgogICAgICAgIDxkYzp0eXBlCiAgICAgICAgICAgcmRmOnJlc291cmNlPSJodHRwOi8vcHVybC5vcmcvZGMvZGNtaXR5cGUvU3RpbGxJbWFnZSIgLz4KICAgICAgPC9jYzpXb3JrPgogICAgPC9yZGY6UkRGPgogIDwvbWV0YWRhdGE+CiAgPGcKICAgICBpbmtzY2FwZTpsYWJlbD0iTGF5ZXIgMSIKICAgICBpbmtzY2FwZTpncm91cG1vZGU9ImxheWVyIgogICAgIGlkPSJsYXllcjEiPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmaWxsOm5vbmU7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjEuOTk5OTk5ODg7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgIGQ9Ik0gNzkuMTU2OTEsMjUgTCA5NSwyNSIKICAgICAgIGlkPSJwYXRoMzA1OSIKICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2MiIC8+CiAgICA8cGF0aAogICAgICAgc3R5bGU9ImZpbGw6bm9uZTtzdHJva2U6IzAwMDAwMDtzdHJva2Utd2lkdGg6MjtzdHJva2UtbGluZWNhcDpidXR0O3N0cm9rZS1saW5lam9pbjptaXRlcjtzdHJva2Utb3BhY2l0eToxIgogICAgICAgZD0iTSAyOS4wNDM0NzgsMjUgTCA1LjA0MzQ3ODEsMjUiCiAgICAgICBpZD0icGF0aDMwNjEiIC8+CiAgICA8cGF0aAogICAgICAgc3R5bGU9ImZpbGw6IzAwMDAwMDtmaWxsLW9wYWNpdHk6MTtzdHJva2U6bm9uZTtzdHJva2Utd2lkdGg6MztzdHJva2UtbGluZWpvaW46bWl0ZXI7bWFya2VyOm5vbmU7c3Ryb2tlLW9wYWNpdHk6MTt2aXNpYmlsaXR5OnZpc2libGU7ZGlzcGxheTppbmxpbmU7b3ZlcmZsb3c6dmlzaWJsZTtlbmFibGUtYmFja2dyb3VuZDphY2N1bXVsYXRlIgogICAgICAgZD0iTSAyOC45Njg3NSwyLjU5Mzc1IEwgMjguOTY4NzUsNSBMIDI4Ljk2ODc1LDQ1IEwgMjguOTY4NzUsNDcuNDA2MjUgTCAzMS4xMjUsNDYuMzQzNzUgTCA3Mi4xNTYyNSwyNi4zNDM3NSBMIDcyLjE1NjI1LDIzLjY1NjI1IEwgMzEuMTI1LDMuNjU2MjUgTCAyOC45Njg3NSwyLjU5Mzc1IHogTSAzMS45Njg3NSw3LjQwNjI1IEwgNjguMDkzNzUsMjUgTCAzMS45Njg3NSw0Mi41OTM3NSBMIDMxLjk2ODc1LDcuNDA2MjUgeiIKICAgICAgIGlkPSJwYXRoMjYzOCIKICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2NjY2NjY2NjY2NjYyIgLz4KICAgIDxwYXRoCiAgICAgICBzb2RpcG9kaTp0eXBlPSJhcmMiCiAgICAgICBzdHlsZT0iZmlsbDpub25lO2ZpbGwtb3BhY2l0eToxO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDozO3N0cm9rZS1saW5lam9pbjptaXRlcjttYXJrZXI6bm9uZTtzdHJva2Utb3BhY2l0eToxO3Zpc2liaWxpdHk6dmlzaWJsZTtkaXNwbGF5OmlubGluZTtvdmVyZmxvdzp2aXNpYmxlO2VuYWJsZS1iYWNrZ3JvdW5kOmFjY3VtdWxhdGUiCiAgICAgICBpZD0icGF0aDI2NzEiCiAgICAgICBzb2RpcG9kaTpjeD0iNzYiCiAgICAgICBzb2RpcG9kaTpjeT0iMjUiCiAgICAgICBzb2RpcG9kaTpyeD0iNCIKICAgICAgIHNvZGlwb2RpOnJ5PSI0IgogICAgICAgZD0iTSA4MCwyNSBBIDQsNCAwIDEgMSA3MiwyNSBBIDQsNCAwIDEgMSA4MCwyNSB6IgogICAgICAgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTEsMCkiIC8+CiAgPC9nPgo8L3N2Zz4K' }} + }, { + operation: function(input) { + return !input; + } + }); + + var Or = Gate21.define('logic.Or', { + attrs: { image: { 'xlink:href': 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjwhLS0gQ3JlYXRlZCB3aXRoIElua3NjYXBlIChodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy8pIC0tPgo8c3ZnCiAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgeG1sbnM6Y2M9Imh0dHA6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL25zIyIKICAgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIgogICB4bWxuczpzdmc9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zOnNvZGlwb2RpPSJodHRwOi8vc29kaXBvZGkuc291cmNlZm9yZ2UubmV0L0RURC9zb2RpcG9kaS0wLmR0ZCIKICAgeG1sbnM6aW5rc2NhcGU9Imh0dHA6Ly93d3cuaW5rc2NhcGUub3JnL25hbWVzcGFjZXMvaW5rc2NhcGUiCiAgIHdpZHRoPSIxMDAiCiAgIGhlaWdodD0iNTAiCiAgIGlkPSJzdmcyIgogICBzb2RpcG9kaTp2ZXJzaW9uPSIwLjMyIgogICBpbmtzY2FwZTp2ZXJzaW9uPSIwLjQ2IgogICB2ZXJzaW9uPSIxLjAiCiAgIHNvZGlwb2RpOmRvY25hbWU9Ik9SIEFOU0kuc3ZnIgogICBpbmtzY2FwZTpvdXRwdXRfZXh0ZW5zaW9uPSJvcmcuaW5rc2NhcGUub3V0cHV0LnN2Zy5pbmtzY2FwZSI+CiAgPGRlZnMKICAgICBpZD0iZGVmczQiPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDE1IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3o9IjUwIDogMTUgOiAxIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjI1IDogMTAgOiAxIgogICAgICAgaWQ9InBlcnNwZWN0aXZlMjcxNCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiAwLjUgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfej0iMSA6IDAuNSA6IDEiCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMC41IDogMC4zMzMzMzMzMyA6IDEiCiAgICAgICBpZD0icGVyc3BlY3RpdmUyODA2IiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmUyODE5IgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjM3Mi4wNDcyNCA6IDM1MC43ODczOSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF96PSI3NDQuMDk0NDggOiA1MjYuMTgxMDkgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDUyNi4xODEwOSA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmUyNzc3IgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49Ijc1IDogNDAgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iMTUwIDogNjAgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDYwIDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTMyNzUiCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iNTAgOiAzMy4zMzMzMzMgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iMTAwIDogNTAgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDUwIDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTU1MzMiCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMzIgOiAyMS4zMzMzMzMgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNjQgOiAzMiA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMzIgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjU1NyIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIyNSA6IDE2LjY2NjY2NyA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF96PSI1MCA6IDI1IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiAyNSA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogIDwvZGVmcz4KICA8c29kaXBvZGk6bmFtZWR2aWV3CiAgICAgaWQ9ImJhc2UiCiAgICAgcGFnZWNvbG9yPSIjZmZmZmZmIgogICAgIGJvcmRlcmNvbG9yPSIjNjY2NjY2IgogICAgIGJvcmRlcm9wYWNpdHk9IjEuMCIKICAgICBpbmtzY2FwZTpwYWdlb3BhY2l0eT0iMC4wIgogICAgIGlua3NjYXBlOnBhZ2VzaGFkb3c9IjIiCiAgICAgaW5rc2NhcGU6em9vbT0iNCIKICAgICBpbmtzY2FwZTpjeD0iMTEzLjAwMDM5IgogICAgIGlua3NjYXBlOmN5PSIxMi44OTM3MzEiCiAgICAgaW5rc2NhcGU6ZG9jdW1lbnQtdW5pdHM9InB4IgogICAgIGlua3NjYXBlOmN1cnJlbnQtbGF5ZXI9ImcyNTYwIgogICAgIHNob3dncmlkPSJmYWxzZSIKICAgICBpbmtzY2FwZTpncmlkLWJib3g9InRydWUiCiAgICAgaW5rc2NhcGU6Z3JpZC1wb2ludHM9InRydWUiCiAgICAgZ3JpZHRvbGVyYW5jZT0iMTAwMDAiCiAgICAgaW5rc2NhcGU6d2luZG93LXdpZHRoPSIxMzk5IgogICAgIGlua3NjYXBlOndpbmRvdy1oZWlnaHQ9Ijg3NCIKICAgICBpbmtzY2FwZTp3aW5kb3cteD0iMzciCiAgICAgaW5rc2NhcGU6d2luZG93LXk9Ii00IgogICAgIGlua3NjYXBlOnNuYXAtYmJveD0idHJ1ZSI+CiAgICA8aW5rc2NhcGU6Z3JpZAogICAgICAgaWQ9IkdyaWRGcm9tUHJlMDQ2U2V0dGluZ3MiCiAgICAgICB0eXBlPSJ4eWdyaWQiCiAgICAgICBvcmlnaW54PSIwcHgiCiAgICAgICBvcmlnaW55PSIwcHgiCiAgICAgICBzcGFjaW5neD0iMXB4IgogICAgICAgc3BhY2luZ3k9IjFweCIKICAgICAgIGNvbG9yPSIjMDAwMGZmIgogICAgICAgZW1wY29sb3I9IiMwMDAwZmYiCiAgICAgICBvcGFjaXR5PSIwLjIiCiAgICAgICBlbXBvcGFjaXR5PSIwLjQiCiAgICAgICBlbXBzcGFjaW5nPSI1IgogICAgICAgdmlzaWJsZT0idHJ1ZSIKICAgICAgIGVuYWJsZWQ9InRydWUiIC8+CiAgPC9zb2RpcG9kaTpuYW1lZHZpZXc+CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhNyI+CiAgICA8cmRmOlJERj4KICAgICAgPGNjOldvcmsKICAgICAgICAgcmRmOmFib3V0PSIiPgogICAgICAgIDxkYzpmb3JtYXQ+aW1hZ2Uvc3ZnK3htbDwvZGM6Zm9ybWF0PgogICAgICAgIDxkYzp0eXBlCiAgICAgICAgICAgcmRmOnJlc291cmNlPSJodHRwOi8vcHVybC5vcmcvZGMvZGNtaXR5cGUvU3RpbGxJbWFnZSIgLz4KICAgICAgPC9jYzpXb3JrPgogICAgPC9yZGY6UkRGPgogIDwvbWV0YWRhdGE+CiAgPGcKICAgICBpbmtzY2FwZTpsYWJlbD0iTGF5ZXIgMSIKICAgICBpbmtzY2FwZTpncm91cG1vZGU9ImxheWVyIgogICAgIGlkPSJsYXllcjEiPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmaWxsOm5vbmU7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjI7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgIGQ9Im0gNzAsMjUgYyAyMCwwIDI1LDAgMjUsMCIKICAgICAgIGlkPSJwYXRoMzA1OSIKICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2MiIC8+CiAgICA8cGF0aAogICAgICAgc3R5bGU9ImZpbGw6bm9uZTtzdHJva2U6IzAwMDAwMDtzdHJva2Utd2lkdGg6MjtzdHJva2UtbGluZWNhcDpidXR0O3N0cm9rZS1saW5lam9pbjptaXRlcjtzdHJva2Utb3BhY2l0eToxIgogICAgICAgZD0iTSAzMSwxNSA1LDE1IgogICAgICAgaWQ9InBhdGgzMDYxIiAvPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmaWxsOm5vbmU7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjEuOTk5OTk5ODg7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgIGQ9Ik0gMzIsMzUgNSwzNSIKICAgICAgIGlkPSJwYXRoMzk0NCIgLz4KICAgIDxnCiAgICAgICBpZD0iZzI1NjAiCiAgICAgICBpbmtzY2FwZTpsYWJlbD0iTGF5ZXIgMSIKICAgICAgIHRyYW5zZm9ybT0idHJhbnNsYXRlKDI2LjUsLTM5LjUpIj4KICAgICAgPHBhdGgKICAgICAgICAgc3R5bGU9ImZpbGw6IzAwMDAwMDtmaWxsLW9wYWNpdHk6MTtmaWxsLXJ1bGU6ZXZlbm9kZDtzdHJva2U6bm9uZTtzdHJva2Utd2lkdGg6MztzdHJva2UtbGluZWNhcDpidXR0O3N0cm9rZS1saW5lam9pbjptaXRlcjtzdHJva2Utb3BhY2l0eToxIgogICAgICAgICBkPSJNIC0yLjQwNjI1LDQ0LjUgTCAtMC40MDYyNSw0Ni45Mzc1IEMgLTAuNDA2MjUsNDYuOTM3NSA1LjI1LDUzLjkzNzU0OSA1LjI1LDY0LjUgQyA1LjI1LDc1LjA2MjQ1MSAtMC40MDYyNSw4Mi4wNjI1IC0wLjQwNjI1LDgyLjA2MjUgTCAtMi40MDYyNSw4NC41IEwgMC43NSw4NC41IEwgMTQuNzUsODQuNSBDIDE3LjE1ODA3Niw4NC41MDAwMDEgMjIuNDM5Njk5LDg0LjUyNDUxNCAyOC4zNzUsODIuMDkzNzUgQyAzNC4zMTAzMDEsNzkuNjYyOTg2IDQwLjkxMTUzNiw3NC43NTA0ODQgNDYuMDYyNSw2NS4yMTg3NSBMIDQ0Ljc1LDY0LjUgTCA0Ni4wNjI1LDYzLjc4MTI1IEMgMzUuNzU5Mzg3LDQ0LjcxNTU5IDE5LjUwNjU3NCw0NC41IDE0Ljc1LDQ0LjUgTCAwLjc1LDQ0LjUgTCAtMi40MDYyNSw0NC41IHogTSAzLjQ2ODc1LDQ3LjUgTCAxNC43NSw0Ny41IEMgMTkuNDM0MTczLDQ3LjUgMzMuMDM2ODUsNDcuMzY5NzkzIDQyLjcxODc1LDY0LjUgQyAzNy45NTE5NjQsNzIuOTI5MDc1IDMyLjE5NzQ2OSw3Ny4xODM5MSAyNyw3OS4zMTI1IEMgMjEuNjM5MzM5LDgxLjUwNzkyNCAxNy4xNTgwNzUsODEuNTAwMDAxIDE0Ljc1LDgxLjUgTCAzLjUsODEuNSBDIDUuMzczNTg4NCw3OC4zOTE1NjYgOC4yNSw3Mi40NTA2NSA4LjI1LDY0LjUgQyA4LjI1LDU2LjUyNjY0NiA1LjM0MTQ2ODYsNTAuNTk5ODE1IDMuNDY4NzUsNDcuNSB6IgogICAgICAgICBpZD0icGF0aDQ5NzMiCiAgICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2NzY2NjY3NjY2NjY2NjY2NzY2NzYyIgLz4KICAgIDwvZz4KICA8L2c+Cjwvc3ZnPgo=' }} + }, { + operation: function(input1, input2) { + return input1 || input2; + } + }); + + var And = Gate21.define('logic.And', { + attrs: { image: { 'xlink:href': 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjwhLS0gQ3JlYXRlZCB3aXRoIElua3NjYXBlIChodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy8pIC0tPgo8c3ZnCiAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgeG1sbnM6Y2M9Imh0dHA6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL25zIyIKICAgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIgogICB4bWxuczpzdmc9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zOnNvZGlwb2RpPSJodHRwOi8vc29kaXBvZGkuc291cmNlZm9yZ2UubmV0L0RURC9zb2RpcG9kaS0wLmR0ZCIKICAgeG1sbnM6aW5rc2NhcGU9Imh0dHA6Ly93d3cuaW5rc2NhcGUub3JnL25hbWVzcGFjZXMvaW5rc2NhcGUiCiAgIHdpZHRoPSIxMDAiCiAgIGhlaWdodD0iNTAiCiAgIGlkPSJzdmcyIgogICBzb2RpcG9kaTp2ZXJzaW9uPSIwLjMyIgogICBpbmtzY2FwZTp2ZXJzaW9uPSIwLjQ2IgogICB2ZXJzaW9uPSIxLjAiCiAgIHNvZGlwb2RpOmRvY25hbWU9IkFORCBBTlNJLnN2ZyIKICAgaW5rc2NhcGU6b3V0cHV0X2V4dGVuc2lvbj0ib3JnLmlua3NjYXBlLm91dHB1dC5zdmcuaW5rc2NhcGUiPgogIDxkZWZzCiAgICAgaWQ9ImRlZnM0Ij4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiAxNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF96PSI1MCA6IDE1IDogMSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIyNSA6IDEwIDogMSIKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI3MTQiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMC41IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEgOiAwLjUgOiAxIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjAuNSA6IDAuMzMzMzMzMzMgOiAxIgogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgwNiIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgxOSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIzNzIuMDQ3MjQgOiAzNTAuNzg3MzkgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNzQ0LjA5NDQ4IDogNTI2LjE4MTA5IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MjYuMTgxMDkgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjc3NyIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSI3NSA6IDQwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjE1MCA6IDYwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA2MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmUzMjc1IgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjUwIDogMzMuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEwMCA6IDUwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmU1NTMzIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjMyIDogMjEuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjY0IDogMzIgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDMyIDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgPC9kZWZzPgogIDxzb2RpcG9kaTpuYW1lZHZpZXcKICAgICBpZD0iYmFzZSIKICAgICBwYWdlY29sb3I9IiNmZmZmZmYiCiAgICAgYm9yZGVyY29sb3I9IiM2NjY2NjYiCiAgICAgYm9yZGVyb3BhY2l0eT0iMS4wIgogICAgIGlua3NjYXBlOnBhZ2VvcGFjaXR5PSIwLjAiCiAgICAgaW5rc2NhcGU6cGFnZXNoYWRvdz0iMiIKICAgICBpbmtzY2FwZTp6b29tPSI4IgogICAgIGlua3NjYXBlOmN4PSI1Ni42OTgzNDgiCiAgICAgaW5rc2NhcGU6Y3k9IjI1LjMyNjg5OSIKICAgICBpbmtzY2FwZTpkb2N1bWVudC11bml0cz0icHgiCiAgICAgaW5rc2NhcGU6Y3VycmVudC1sYXllcj0ibGF5ZXIxIgogICAgIHNob3dncmlkPSJ0cnVlIgogICAgIGlua3NjYXBlOmdyaWQtYmJveD0idHJ1ZSIKICAgICBpbmtzY2FwZTpncmlkLXBvaW50cz0idHJ1ZSIKICAgICBncmlkdG9sZXJhbmNlPSIxMDAwMCIKICAgICBpbmtzY2FwZTp3aW5kb3ctd2lkdGg9IjEzOTkiCiAgICAgaW5rc2NhcGU6d2luZG93LWhlaWdodD0iODc0IgogICAgIGlua3NjYXBlOndpbmRvdy14PSIzMyIKICAgICBpbmtzY2FwZTp3aW5kb3cteT0iMCIKICAgICBpbmtzY2FwZTpzbmFwLWJib3g9InRydWUiPgogICAgPGlua3NjYXBlOmdyaWQKICAgICAgIGlkPSJHcmlkRnJvbVByZTA0NlNldHRpbmdzIgogICAgICAgdHlwZT0ieHlncmlkIgogICAgICAgb3JpZ2lueD0iMHB4IgogICAgICAgb3JpZ2lueT0iMHB4IgogICAgICAgc3BhY2luZ3g9IjFweCIKICAgICAgIHNwYWNpbmd5PSIxcHgiCiAgICAgICBjb2xvcj0iIzAwMDBmZiIKICAgICAgIGVtcGNvbG9yPSIjMDAwMGZmIgogICAgICAgb3BhY2l0eT0iMC4yIgogICAgICAgZW1wb3BhY2l0eT0iMC40IgogICAgICAgZW1wc3BhY2luZz0iNSIKICAgICAgIHZpc2libGU9InRydWUiCiAgICAgICBlbmFibGVkPSJ0cnVlIiAvPgogIDwvc29kaXBvZGk6bmFtZWR2aWV3PgogIDxtZXRhZGF0YQogICAgIGlkPSJtZXRhZGF0YTciPgogICAgPHJkZjpSREY+CiAgICAgIDxjYzpXb3JrCiAgICAgICAgIHJkZjphYm91dD0iIj4KICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3N2Zyt4bWw8L2RjOmZvcm1hdD4KICAgICAgICA8ZGM6dHlwZQogICAgICAgICAgIHJkZjpyZXNvdXJjZT0iaHR0cDovL3B1cmwub3JnL2RjL2RjbWl0eXBlL1N0aWxsSW1hZ2UiIC8+CiAgICAgIDwvY2M6V29yaz4KICAgIDwvcmRmOlJERj4KICA8L21ldGFkYXRhPgogIDxnCiAgICAgaW5rc2NhcGU6bGFiZWw9IkxheWVyIDEiCiAgICAgaW5rc2NhcGU6Z3JvdXBtb2RlPSJsYXllciIKICAgICBpZD0ibGF5ZXIxIj4KICAgIDxwYXRoCiAgICAgICBzdHlsZT0iZmlsbDpub25lO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDoyO3N0cm9rZS1saW5lY2FwOmJ1dHQ7c3Ryb2tlLWxpbmVqb2luOm1pdGVyO3N0cm9rZS1vcGFjaXR5OjEiCiAgICAgICBkPSJtIDcwLDI1IGMgMjAsMCAyNSwwIDI1LDAiCiAgICAgICBpZD0icGF0aDMwNTkiCiAgICAgICBzb2RpcG9kaTpub2RldHlwZXM9ImNjIiAvPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmaWxsOm5vbmU7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjI7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgIGQ9Ik0gMzEsMTUgNSwxNSIKICAgICAgIGlkPSJwYXRoMzA2MSIgLz4KICAgIDxwYXRoCiAgICAgICBzdHlsZT0iZmlsbDpub25lO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDoxLjk5OTk5OTg4O3N0cm9rZS1saW5lY2FwOmJ1dHQ7c3Ryb2tlLWxpbmVqb2luOm1pdGVyO3N0cm9rZS1vcGFjaXR5OjEiCiAgICAgICBkPSJNIDMyLDM1IDUsMzUiCiAgICAgICBpZD0icGF0aDM5NDQiIC8+CiAgICA8cGF0aAogICAgICAgc3R5bGU9ImZvbnQtc2l6ZTptZWRpdW07Zm9udC1zdHlsZTpub3JtYWw7Zm9udC12YXJpYW50Om5vcm1hbDtmb250LXdlaWdodDpub3JtYWw7Zm9udC1zdHJldGNoOm5vcm1hbDt0ZXh0LWluZGVudDowO3RleHQtYWxpZ246c3RhcnQ7dGV4dC1kZWNvcmF0aW9uOm5vbmU7bGluZS1oZWlnaHQ6bm9ybWFsO2xldHRlci1zcGFjaW5nOm5vcm1hbDt3b3JkLXNwYWNpbmc6bm9ybWFsO3RleHQtdHJhbnNmb3JtOm5vbmU7ZGlyZWN0aW9uOmx0cjtibG9jay1wcm9ncmVzc2lvbjp0Yjt3cml0aW5nLW1vZGU6bHItdGI7dGV4dC1hbmNob3I6c3RhcnQ7ZmlsbDojMDAwMDAwO2ZpbGwtb3BhY2l0eToxO3N0cm9rZTpub25lO3N0cm9rZS13aWR0aDozO21hcmtlcjpub25lO3Zpc2liaWxpdHk6dmlzaWJsZTtkaXNwbGF5OmlubGluZTtvdmVyZmxvdzp2aXNpYmxlO2VuYWJsZS1iYWNrZ3JvdW5kOmFjY3VtdWxhdGU7Zm9udC1mYW1pbHk6Qml0c3RyZWFtIFZlcmEgU2FuczstaW5rc2NhcGUtZm9udC1zcGVjaWZpY2F0aW9uOkJpdHN0cmVhbSBWZXJhIFNhbnMiCiAgICAgICBkPSJNIDMwLDUgTCAzMCw2LjQyODU3MTQgTCAzMCw0My41NzE0MjkgTCAzMCw0NSBMIDMxLjQyODU3MSw0NSBMIDUwLjQ3NjE5LDQ1IEMgNjEuNzQ0MDk4LDQ1IDcwLjQ3NjE5LDM1Ljk5OTk1NSA3MC40NzYxOSwyNSBDIDcwLjQ3NjE5LDE0LjAwMDA0NSA2MS43NDQwOTksNS4wMDAwMDAyIDUwLjQ3NjE5LDUgQyA1MC40NzYxOSw1IDUwLjQ3NjE5LDUgMzEuNDI4NTcxLDUgTCAzMCw1IHogTSAzMi44NTcxNDMsNy44NTcxNDI5IEMgNDAuODM0MjY0LDcuODU3MTQyOSA0NS45MTgzNjgsNy44NTcxNDI5IDQ4LjA5NTIzOCw3Ljg1NzE0MjkgQyA0OS4yODU3MTQsNy44NTcxNDI5IDQ5Ljg4MDk1Miw3Ljg1NzE0MjkgNTAuMTc4NTcxLDcuODU3MTQyOSBDIDUwLjMyNzM4MSw3Ljg1NzE0MjkgNTAuNDA5MjI3LDcuODU3MTQyOSA1MC40NDY0MjksNy44NTcxNDI5IEMgNTAuNDY1MDI5LDcuODU3MTQyOSA1MC40NzE1NDMsNy44NTcxNDI5IDUwLjQ3NjE5LDcuODU3MTQyOSBDIDYwLjIzNjg1Myw3Ljg1NzE0MyA2Ny4xNDI4NTcsMTUuNDk3MDk4IDY3LjE0Mjg1NywyNSBDIDY3LjE0Mjg1NywzNC41MDI5MDIgNTkuNzYwNjYyLDQyLjE0Mjg1NyA1MCw0Mi4xNDI4NTcgTCAzMi44NTcxNDMsNDIuMTQyODU3IEwgMzIuODU3MTQzLDcuODU3MTQyOSB6IgogICAgICAgaWQ9InBhdGgyODg0IgogICAgICAgc29kaXBvZGk6bm9kZXR5cGVzPSJjY2NjY2NzY2NjY3Nzc3NzY2NjIiAvPgogIDwvZz4KPC9zdmc+Cg==' }} + + }, { + operation: function(input1, input2) { + return input1 && input2; + } + }); + + var Nor = Gate21.define('logic.Nor', { + attrs: { image: { 'xlink:href': 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjwhLS0gQ3JlYXRlZCB3aXRoIElua3NjYXBlIChodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy8pIC0tPgo8c3ZnCiAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgeG1sbnM6Y2M9Imh0dHA6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL25zIyIKICAgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIgogICB4bWxuczpzdmc9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zOnNvZGlwb2RpPSJodHRwOi8vc29kaXBvZGkuc291cmNlZm9yZ2UubmV0L0RURC9zb2RpcG9kaS0wLmR0ZCIKICAgeG1sbnM6aW5rc2NhcGU9Imh0dHA6Ly93d3cuaW5rc2NhcGUub3JnL25hbWVzcGFjZXMvaW5rc2NhcGUiCiAgIHdpZHRoPSIxMDAiCiAgIGhlaWdodD0iNTAiCiAgIGlkPSJzdmcyIgogICBzb2RpcG9kaTp2ZXJzaW9uPSIwLjMyIgogICBpbmtzY2FwZTp2ZXJzaW9uPSIwLjQ2IgogICB2ZXJzaW9uPSIxLjAiCiAgIHNvZGlwb2RpOmRvY25hbWU9Ik5PUiBBTlNJLnN2ZyIKICAgaW5rc2NhcGU6b3V0cHV0X2V4dGVuc2lvbj0ib3JnLmlua3NjYXBlLm91dHB1dC5zdmcuaW5rc2NhcGUiPgogIDxkZWZzCiAgICAgaWQ9ImRlZnM0Ij4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiAxNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF96PSI1MCA6IDE1IDogMSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIyNSA6IDEwIDogMSIKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI3MTQiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMC41IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEgOiAwLjUgOiAxIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjAuNSA6IDAuMzMzMzMzMzMgOiAxIgogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgwNiIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgxOSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIzNzIuMDQ3MjQgOiAzNTAuNzg3MzkgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNzQ0LjA5NDQ4IDogNTI2LjE4MTA5IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MjYuMTgxMDkgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjc3NyIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSI3NSA6IDQwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjE1MCA6IDYwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA2MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmUzMjc1IgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjUwIDogMzMuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEwMCA6IDUwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmU1NTMzIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjMyIDogMjEuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjY0IDogMzIgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDMyIDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI1NTciCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMjUgOiAxNi42NjY2NjcgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNTAgOiAyNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMjUgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICA8L2RlZnM+CiAgPHNvZGlwb2RpOm5hbWVkdmlldwogICAgIGlkPSJiYXNlIgogICAgIHBhZ2Vjb2xvcj0iI2ZmZmZmZiIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBib3JkZXJvcGFjaXR5PSIxLjAiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAuMCIKICAgICBpbmtzY2FwZTpwYWdlc2hhZG93PSIyIgogICAgIGlua3NjYXBlOnpvb209IjEiCiAgICAgaW5rc2NhcGU6Y3g9Ijc4LjY3NzY0NCIKICAgICBpbmtzY2FwZTpjeT0iMjIuMTAyMzQ0IgogICAgIGlua3NjYXBlOmRvY3VtZW50LXVuaXRzPSJweCIKICAgICBpbmtzY2FwZTpjdXJyZW50LWxheWVyPSJsYXllcjEiCiAgICAgc2hvd2dyaWQ9InRydWUiCiAgICAgaW5rc2NhcGU6Z3JpZC1iYm94PSJ0cnVlIgogICAgIGlua3NjYXBlOmdyaWQtcG9pbnRzPSJ0cnVlIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwMDAwIgogICAgIGlua3NjYXBlOndpbmRvdy13aWR0aD0iMTM5OSIKICAgICBpbmtzY2FwZTp3aW5kb3ctaGVpZ2h0PSI4NzQiCiAgICAgaW5rc2NhcGU6d2luZG93LXg9IjM3IgogICAgIGlua3NjYXBlOndpbmRvdy15PSItNCIKICAgICBpbmtzY2FwZTpzbmFwLWJib3g9InRydWUiPgogICAgPGlua3NjYXBlOmdyaWQKICAgICAgIGlkPSJHcmlkRnJvbVByZTA0NlNldHRpbmdzIgogICAgICAgdHlwZT0ieHlncmlkIgogICAgICAgb3JpZ2lueD0iMHB4IgogICAgICAgb3JpZ2lueT0iMHB4IgogICAgICAgc3BhY2luZ3g9IjFweCIKICAgICAgIHNwYWNpbmd5PSIxcHgiCiAgICAgICBjb2xvcj0iIzAwMDBmZiIKICAgICAgIGVtcGNvbG9yPSIjMDAwMGZmIgogICAgICAgb3BhY2l0eT0iMC4yIgogICAgICAgZW1wb3BhY2l0eT0iMC40IgogICAgICAgZW1wc3BhY2luZz0iNSIKICAgICAgIHZpc2libGU9InRydWUiCiAgICAgICBlbmFibGVkPSJ0cnVlIiAvPgogIDwvc29kaXBvZGk6bmFtZWR2aWV3PgogIDxtZXRhZGF0YQogICAgIGlkPSJtZXRhZGF0YTciPgogICAgPHJkZjpSREY+CiAgICAgIDxjYzpXb3JrCiAgICAgICAgIHJkZjphYm91dD0iIj4KICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3N2Zyt4bWw8L2RjOmZvcm1hdD4KICAgICAgICA8ZGM6dHlwZQogICAgICAgICAgIHJkZjpyZXNvdXJjZT0iaHR0cDovL3B1cmwub3JnL2RjL2RjbWl0eXBlL1N0aWxsSW1hZ2UiIC8+CiAgICAgIDwvY2M6V29yaz4KICAgIDwvcmRmOlJERj4KICA8L21ldGFkYXRhPgogIDxnCiAgICAgaW5rc2NhcGU6bGFiZWw9IkxheWVyIDEiCiAgICAgaW5rc2NhcGU6Z3JvdXBtb2RlPSJsYXllciIKICAgICBpZD0ibGF5ZXIxIj4KICAgIDxwYXRoCiAgICAgICBzdHlsZT0iZmlsbDpub25lO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDoyO3N0cm9rZS1saW5lY2FwOmJ1dHQ7c3Ryb2tlLWxpbmVqb2luOm1pdGVyO3N0cm9rZS1vcGFjaXR5OjEiCiAgICAgICBkPSJNIDc5LDI1IEMgOTksMjUgOTUsMjUgOTUsMjUiCiAgICAgICBpZD0icGF0aDMwNTkiCiAgICAgICBzb2RpcG9kaTpub2RldHlwZXM9ImNjIiAvPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmaWxsOm5vbmU7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjI7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgIGQ9Ik0gMzEsMTUgNSwxNSIKICAgICAgIGlkPSJwYXRoMzA2MSIgLz4KICAgIDxwYXRoCiAgICAgICBzdHlsZT0iZmlsbDpub25lO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDoxLjk5OTk5OTg4O3N0cm9rZS1saW5lY2FwOmJ1dHQ7c3Ryb2tlLWxpbmVqb2luOm1pdGVyO3N0cm9rZS1vcGFjaXR5OjEiCiAgICAgICBkPSJNIDMyLDM1IDUsMzUiCiAgICAgICBpZD0icGF0aDM5NDQiIC8+CiAgICA8ZwogICAgICAgaWQ9ImcyNTYwIgogICAgICAgaW5rc2NhcGU6bGFiZWw9IkxheWVyIDEiCiAgICAgICB0cmFuc2Zvcm09InRyYW5zbGF0ZSgyNi41LC0zOS41KSI+CiAgICAgIDxwYXRoCiAgICAgICAgIHN0eWxlPSJmaWxsOiMwMDAwMDA7ZmlsbC1vcGFjaXR5OjE7ZmlsbC1ydWxlOmV2ZW5vZGQ7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjM7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgICAgZD0iTSAtMi40MDYyNSw0NC41IEwgLTAuNDA2MjUsNDYuOTM3NSBDIC0wLjQwNjI1LDQ2LjkzNzUgNS4yNSw1My45Mzc1NDkgNS4yNSw2NC41IEMgNS4yNSw3NS4wNjI0NTEgLTAuNDA2MjUsODIuMDYyNSAtMC40MDYyNSw4Mi4wNjI1IEwgLTIuNDA2MjUsODQuNSBMIDAuNzUsODQuNSBMIDE0Ljc1LDg0LjUgQyAxNy4xNTgwNzYsODQuNTAwMDAxIDIyLjQzOTY5OSw4NC41MjQ1MTQgMjguMzc1LDgyLjA5Mzc1IEMgMzQuMzEwMzAxLDc5LjY2Mjk4NiA0MC45MTE1MzYsNzQuNzUwNDg0IDQ2LjA2MjUsNjUuMjE4NzUgTCA0NC43NSw2NC41IEwgNDYuMDYyNSw2My43ODEyNSBDIDM1Ljc1OTM4Nyw0NC43MTU1OSAxOS41MDY1NzQsNDQuNSAxNC43NSw0NC41IEwgMC43NSw0NC41IEwgLTIuNDA2MjUsNDQuNSB6IE0gMy40Njg3NSw0Ny41IEwgMTQuNzUsNDcuNSBDIDE5LjQzNDE3Myw0Ny41IDMzLjAzNjg1LDQ3LjM2OTc5MyA0Mi43MTg3NSw2NC41IEMgMzcuOTUxOTY0LDcyLjkyOTA3NSAzMi4xOTc0NjksNzcuMTgzOTEgMjcsNzkuMzEyNSBDIDIxLjYzOTMzOSw4MS41MDc5MjQgMTcuMTU4MDc1LDgxLjUwMDAwMSAxNC43NSw4MS41IEwgMy41LDgxLjUgQyA1LjM3MzU4ODQsNzguMzkxNTY2IDguMjUsNzIuNDUwNjUgOC4yNSw2NC41IEMgOC4yNSw1Ni41MjY2NDYgNS4zNDE0Njg2LDUwLjU5OTgxNSAzLjQ2ODc1LDQ3LjUgeiIKICAgICAgICAgaWQ9InBhdGg0OTczIgogICAgICAgICBzb2RpcG9kaTpub2RldHlwZXM9ImNjc2NjY2NzY2NjY2NjY2Njc2Njc2MiIC8+CiAgICAgIDxwYXRoCiAgICAgICAgIHNvZGlwb2RpOnR5cGU9ImFyYyIKICAgICAgICAgc3R5bGU9ImZpbGw6bm9uZTtmaWxsLW9wYWNpdHk6MTtzdHJva2U6IzAwMDAwMDtzdHJva2Utd2lkdGg6MztzdHJva2UtbGluZWpvaW46bWl0ZXI7bWFya2VyOm5vbmU7c3Ryb2tlLW9wYWNpdHk6MTt2aXNpYmlsaXR5OnZpc2libGU7ZGlzcGxheTppbmxpbmU7b3ZlcmZsb3c6dmlzaWJsZTtlbmFibGUtYmFja2dyb3VuZDphY2N1bXVsYXRlIgogICAgICAgICBpZD0icGF0aDI2MDQiCiAgICAgICAgIHNvZGlwb2RpOmN4PSI3NSIKICAgICAgICAgc29kaXBvZGk6Y3k9IjI1IgogICAgICAgICBzb2RpcG9kaTpyeD0iNCIKICAgICAgICAgc29kaXBvZGk6cnk9IjQiCiAgICAgICAgIGQ9Ik0gNzksMjUgQSA0LDQgMCAxIDEgNzEsMjUgQSA0LDQgMCAxIDEgNzksMjUgeiIKICAgICAgICAgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI2LjUsMzkuNSkiIC8+CiAgICA8L2c+CiAgPC9nPgo8L3N2Zz4K' }} + }, { + operation: function(input1, input2) { + return !(input1 || input2); + } + }); + + var Nand = Gate21.define('logic.Nand', { + attrs: { image: { 'xlink:href': 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjwhLS0gQ3JlYXRlZCB3aXRoIElua3NjYXBlIChodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy8pIC0tPgo8c3ZnCiAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgeG1sbnM6Y2M9Imh0dHA6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL25zIyIKICAgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIgogICB4bWxuczpzdmc9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zOnNvZGlwb2RpPSJodHRwOi8vc29kaXBvZGkuc291cmNlZm9yZ2UubmV0L0RURC9zb2RpcG9kaS0wLmR0ZCIKICAgeG1sbnM6aW5rc2NhcGU9Imh0dHA6Ly93d3cuaW5rc2NhcGUub3JnL25hbWVzcGFjZXMvaW5rc2NhcGUiCiAgIHdpZHRoPSIxMDAiCiAgIGhlaWdodD0iNTAiCiAgIGlkPSJzdmcyIgogICBzb2RpcG9kaTp2ZXJzaW9uPSIwLjMyIgogICBpbmtzY2FwZTp2ZXJzaW9uPSIwLjQ2IgogICB2ZXJzaW9uPSIxLjAiCiAgIHNvZGlwb2RpOmRvY25hbWU9Ik5BTkQgQU5TSS5zdmciCiAgIGlua3NjYXBlOm91dHB1dF9leHRlbnNpb249Im9yZy5pbmtzY2FwZS5vdXRwdXQuc3ZnLmlua3NjYXBlIj4KICA8ZGVmcwogICAgIGlkPSJkZWZzNCI+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMTUgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfej0iNTAgOiAxNSA6IDEiCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMjUgOiAxMCA6IDEiCiAgICAgICBpZD0icGVyc3BlY3RpdmUyNzE0IiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDAuNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF96PSIxIDogMC41IDogMSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIwLjUgOiAwLjMzMzMzMzMzIDogMSIKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI4MDYiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI4MTkiCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMzcyLjA0NzI0IDogMzUwLjc4NzM5IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9Ijc0NC4wOTQ0OCA6IDUyNi4xODEwOSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogNTI2LjE4MTA5IDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI3NzciCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iNzUgOiA0MCA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF96PSIxNTAgOiA2MCA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogNjAgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMzI3NSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSI1MCA6IDMzLjMzMzMzMyA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF96PSIxMDAgOiA1MCA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogNTAgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlNTUzMyIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIzMiA6IDIxLjMzMzMzMyA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF96PSI2NCA6IDMyIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiAzMiA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogIDwvZGVmcz4KICA8c29kaXBvZGk6bmFtZWR2aWV3CiAgICAgaWQ9ImJhc2UiCiAgICAgcGFnZWNvbG9yPSIjZmZmZmZmIgogICAgIGJvcmRlcmNvbG9yPSIjNjY2NjY2IgogICAgIGJvcmRlcm9wYWNpdHk9IjEuMCIKICAgICBpbmtzY2FwZTpwYWdlb3BhY2l0eT0iMC4wIgogICAgIGlua3NjYXBlOnBhZ2VzaGFkb3c9IjIiCiAgICAgaW5rc2NhcGU6em9vbT0iMTYiCiAgICAgaW5rc2NhcGU6Y3g9Ijc4LjI4MzMwNyIKICAgICBpbmtzY2FwZTpjeT0iMTYuNDQyODQzIgogICAgIGlua3NjYXBlOmRvY3VtZW50LXVuaXRzPSJweCIKICAgICBpbmtzY2FwZTpjdXJyZW50LWxheWVyPSJsYXllcjEiCiAgICAgc2hvd2dyaWQ9InRydWUiCiAgICAgaW5rc2NhcGU6Z3JpZC1iYm94PSJ0cnVlIgogICAgIGlua3NjYXBlOmdyaWQtcG9pbnRzPSJ0cnVlIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwMDAwIgogICAgIGlua3NjYXBlOndpbmRvdy13aWR0aD0iMTM5OSIKICAgICBpbmtzY2FwZTp3aW5kb3ctaGVpZ2h0PSI4NzQiCiAgICAgaW5rc2NhcGU6d2luZG93LXg9IjMzIgogICAgIGlua3NjYXBlOndpbmRvdy15PSIwIgogICAgIGlua3NjYXBlOnNuYXAtYmJveD0idHJ1ZSI+CiAgICA8aW5rc2NhcGU6Z3JpZAogICAgICAgaWQ9IkdyaWRGcm9tUHJlMDQ2U2V0dGluZ3MiCiAgICAgICB0eXBlPSJ4eWdyaWQiCiAgICAgICBvcmlnaW54PSIwcHgiCiAgICAgICBvcmlnaW55PSIwcHgiCiAgICAgICBzcGFjaW5neD0iMXB4IgogICAgICAgc3BhY2luZ3k9IjFweCIKICAgICAgIGNvbG9yPSIjMDAwMGZmIgogICAgICAgZW1wY29sb3I9IiMwMDAwZmYiCiAgICAgICBvcGFjaXR5PSIwLjIiCiAgICAgICBlbXBvcGFjaXR5PSIwLjQiCiAgICAgICBlbXBzcGFjaW5nPSI1IgogICAgICAgdmlzaWJsZT0idHJ1ZSIKICAgICAgIGVuYWJsZWQ9InRydWUiIC8+CiAgPC9zb2RpcG9kaTpuYW1lZHZpZXc+CiAgPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhNyI+CiAgICA8cmRmOlJERj4KICAgICAgPGNjOldvcmsKICAgICAgICAgcmRmOmFib3V0PSIiPgogICAgICAgIDxkYzpmb3JtYXQ+aW1hZ2Uvc3ZnK3htbDwvZGM6Zm9ybWF0PgogICAgICAgIDxkYzp0eXBlCiAgICAgICAgICAgcmRmOnJlc291cmNlPSJodHRwOi8vcHVybC5vcmcvZGMvZGNtaXR5cGUvU3RpbGxJbWFnZSIgLz4KICAgICAgPC9jYzpXb3JrPgogICAgPC9yZGY6UkRGPgogIDwvbWV0YWRhdGE+CiAgPGcKICAgICBpbmtzY2FwZTpsYWJlbD0iTGF5ZXIgMSIKICAgICBpbmtzY2FwZTpncm91cG1vZGU9ImxheWVyIgogICAgIGlkPSJsYXllcjEiPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmaWxsOm5vbmU7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjI7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgIGQ9Ik0gNzksMjUgQyA5MS44LDI1IDk1LDI1IDk1LDI1IgogICAgICAgaWQ9InBhdGgzMDU5IgogICAgICAgc29kaXBvZGk6bm9kZXR5cGVzPSJjYyIgLz4KICAgIDxwYXRoCiAgICAgICBzdHlsZT0iZmlsbDpub25lO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDoyO3N0cm9rZS1saW5lY2FwOmJ1dHQ7c3Ryb2tlLWxpbmVqb2luOm1pdGVyO3N0cm9rZS1vcGFjaXR5OjEiCiAgICAgICBkPSJNIDMxLDE1IDUsMTUiCiAgICAgICBpZD0icGF0aDMwNjEiIC8+CiAgICA8cGF0aAogICAgICAgc3R5bGU9ImZpbGw6bm9uZTtzdHJva2U6IzAwMDAwMDtzdHJva2Utd2lkdGg6MS45OTk5OTk4ODtzdHJva2UtbGluZWNhcDpidXR0O3N0cm9rZS1saW5lam9pbjptaXRlcjtzdHJva2Utb3BhY2l0eToxIgogICAgICAgZD0iTSAzMiwzNSA1LDM1IgogICAgICAgaWQ9InBhdGgzOTQ0IiAvPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmb250LXNpemU6bWVkaXVtO2ZvbnQtc3R5bGU6bm9ybWFsO2ZvbnQtdmFyaWFudDpub3JtYWw7Zm9udC13ZWlnaHQ6bm9ybWFsO2ZvbnQtc3RyZXRjaDpub3JtYWw7dGV4dC1pbmRlbnQ6MDt0ZXh0LWFsaWduOnN0YXJ0O3RleHQtZGVjb3JhdGlvbjpub25lO2xpbmUtaGVpZ2h0Om5vcm1hbDtsZXR0ZXItc3BhY2luZzpub3JtYWw7d29yZC1zcGFjaW5nOm5vcm1hbDt0ZXh0LXRyYW5zZm9ybTpub25lO2RpcmVjdGlvbjpsdHI7YmxvY2stcHJvZ3Jlc3Npb246dGI7d3JpdGluZy1tb2RlOmxyLXRiO3RleHQtYW5jaG9yOnN0YXJ0O2ZpbGw6IzAwMDAwMDtmaWxsLW9wYWNpdHk6MTtzdHJva2U6bm9uZTtzdHJva2Utd2lkdGg6MzttYXJrZXI6bm9uZTt2aXNpYmlsaXR5OnZpc2libGU7ZGlzcGxheTppbmxpbmU7b3ZlcmZsb3c6dmlzaWJsZTtlbmFibGUtYmFja2dyb3VuZDphY2N1bXVsYXRlO2ZvbnQtZmFtaWx5OkJpdHN0cmVhbSBWZXJhIFNhbnM7LWlua3NjYXBlLWZvbnQtc3BlY2lmaWNhdGlvbjpCaXRzdHJlYW0gVmVyYSBTYW5zIgogICAgICAgZD0iTSAzMCw1IEwgMzAsNi40Mjg1NzE0IEwgMzAsNDMuNTcxNDI5IEwgMzAsNDUgTCAzMS40Mjg1NzEsNDUgTCA1MC40NzYxOSw0NSBDIDYxLjc0NDA5OCw0NSA3MC40NzYxOSwzNS45OTk5NTUgNzAuNDc2MTksMjUgQyA3MC40NzYxOSwxNC4wMDAwNDUgNjEuNzQ0MDk5LDUuMDAwMDAwMiA1MC40NzYxOSw1IEMgNTAuNDc2MTksNSA1MC40NzYxOSw1IDMxLjQyODU3MSw1IEwgMzAsNSB6IE0gMzIuODU3MTQzLDcuODU3MTQyOSBDIDQwLjgzNDI2NCw3Ljg1NzE0MjkgNDUuOTE4MzY4LDcuODU3MTQyOSA0OC4wOTUyMzgsNy44NTcxNDI5IEMgNDkuMjg1NzE0LDcuODU3MTQyOSA0OS44ODA5NTIsNy44NTcxNDI5IDUwLjE3ODU3MSw3Ljg1NzE0MjkgQyA1MC4zMjczODEsNy44NTcxNDI5IDUwLjQwOTIyNyw3Ljg1NzE0MjkgNTAuNDQ2NDI5LDcuODU3MTQyOSBDIDUwLjQ2NTAyOSw3Ljg1NzE0MjkgNTAuNDcxNTQzLDcuODU3MTQyOSA1MC40NzYxOSw3Ljg1NzE0MjkgQyA2MC4yMzY4NTMsNy44NTcxNDMgNjcuMTQyODU3LDE1LjQ5NzA5OCA2Ny4xNDI4NTcsMjUgQyA2Ny4xNDI4NTcsMzQuNTAyOTAyIDU5Ljc2MDY2Miw0Mi4xNDI4NTcgNTAsNDIuMTQyODU3IEwgMzIuODU3MTQzLDQyLjE0Mjg1NyBMIDMyLjg1NzE0Myw3Ljg1NzE0MjkgeiIKICAgICAgIGlkPSJwYXRoMjg4NCIKICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2NjY2Njc2NjY2Nzc3Nzc2NjYyIgLz4KICAgIDxwYXRoCiAgICAgICBzb2RpcG9kaTp0eXBlPSJhcmMiCiAgICAgICBzdHlsZT0iZmlsbDpub25lO2ZpbGwtb3BhY2l0eToxO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDozO3N0cm9rZS1saW5lam9pbjptaXRlcjttYXJrZXI6bm9uZTtzdHJva2Utb3BhY2l0eToxO3Zpc2liaWxpdHk6dmlzaWJsZTtkaXNwbGF5OmlubGluZTtvdmVyZmxvdzp2aXNpYmxlO2VuYWJsZS1iYWNrZ3JvdW5kOmFjY3VtdWxhdGUiCiAgICAgICBpZD0icGF0aDQwMDgiCiAgICAgICBzb2RpcG9kaTpjeD0iNzUiCiAgICAgICBzb2RpcG9kaTpjeT0iMjUiCiAgICAgICBzb2RpcG9kaTpyeD0iNCIKICAgICAgIHNvZGlwb2RpOnJ5PSI0IgogICAgICAgZD0iTSA3OSwyNSBBIDQsNCAwIDEgMSA3MSwyNSBBIDQsNCAwIDEgMSA3OSwyNSB6IiAvPgogIDwvZz4KPC9zdmc+Cg==' }} + }, { + operation: function(input1, input2) { + return !(input1 && input2); + } + }); + + var Xor = Gate21.define('logic.Xor', { + attrs: { image: { 'xlink:href': 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjwhLS0gQ3JlYXRlZCB3aXRoIElua3NjYXBlIChodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy8pIC0tPgo8c3ZnCiAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgeG1sbnM6Y2M9Imh0dHA6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL25zIyIKICAgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIgogICB4bWxuczpzdmc9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zOnNvZGlwb2RpPSJodHRwOi8vc29kaXBvZGkuc291cmNlZm9yZ2UubmV0L0RURC9zb2RpcG9kaS0wLmR0ZCIKICAgeG1sbnM6aW5rc2NhcGU9Imh0dHA6Ly93d3cuaW5rc2NhcGUub3JnL25hbWVzcGFjZXMvaW5rc2NhcGUiCiAgIHdpZHRoPSIxMDAiCiAgIGhlaWdodD0iNTAiCiAgIGlkPSJzdmcyIgogICBzb2RpcG9kaTp2ZXJzaW9uPSIwLjMyIgogICBpbmtzY2FwZTp2ZXJzaW9uPSIwLjQ2IgogICB2ZXJzaW9uPSIxLjAiCiAgIHNvZGlwb2RpOmRvY25hbWU9IlhPUiBBTlNJLnN2ZyIKICAgaW5rc2NhcGU6b3V0cHV0X2V4dGVuc2lvbj0ib3JnLmlua3NjYXBlLm91dHB1dC5zdmcuaW5rc2NhcGUiPgogIDxkZWZzCiAgICAgaWQ9ImRlZnM0Ij4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiAxNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF96PSI1MCA6IDE1IDogMSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIyNSA6IDEwIDogMSIKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI3MTQiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMC41IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEgOiAwLjUgOiAxIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjAuNSA6IDAuMzMzMzMzMzMgOiAxIgogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgwNiIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjgxOSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIzNzIuMDQ3MjQgOiAzNTAuNzg3MzkgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNzQ0LjA5NDQ4IDogNTI2LjE4MTA5IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MjYuMTgxMDkgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMjc3NyIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSI3NSA6IDQwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjE1MCA6IDYwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA2MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmUzMjc1IgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjUwIDogMzMuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjEwMCA6IDUwIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiA1MCA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmU1NTMzIgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjMyIDogMjEuMzMzMzMzIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjY0IDogMzIgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDMyIDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI1NTciCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMjUgOiAxNi42NjY2NjcgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfej0iNTAgOiAyNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMjUgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICA8L2RlZnM+CiAgPHNvZGlwb2RpOm5hbWVkdmlldwogICAgIGlkPSJiYXNlIgogICAgIHBhZ2Vjb2xvcj0iI2ZmZmZmZiIKICAgICBib3JkZXJjb2xvcj0iIzY2NjY2NiIKICAgICBib3JkZXJvcGFjaXR5PSIxLjAiCiAgICAgaW5rc2NhcGU6cGFnZW9wYWNpdHk9IjAuMCIKICAgICBpbmtzY2FwZTpwYWdlc2hhZG93PSIyIgogICAgIGlua3NjYXBlOnpvb209IjUuNjU2ODU0MiIKICAgICBpbmtzY2FwZTpjeD0iMjUuOTM4MTE2IgogICAgIGlua3NjYXBlOmN5PSIxNy4yMzAwNSIKICAgICBpbmtzY2FwZTpkb2N1bWVudC11bml0cz0icHgiCiAgICAgaW5rc2NhcGU6Y3VycmVudC1sYXllcj0ibGF5ZXIxIgogICAgIHNob3dncmlkPSJ0cnVlIgogICAgIGlua3NjYXBlOmdyaWQtYmJveD0idHJ1ZSIKICAgICBpbmtzY2FwZTpncmlkLXBvaW50cz0idHJ1ZSIKICAgICBncmlkdG9sZXJhbmNlPSIxMDAwMCIKICAgICBpbmtzY2FwZTp3aW5kb3ctd2lkdGg9IjEzOTkiCiAgICAgaW5rc2NhcGU6d2luZG93LWhlaWdodD0iODc0IgogICAgIGlua3NjYXBlOndpbmRvdy14PSIzMyIKICAgICBpbmtzY2FwZTp3aW5kb3cteT0iMCIKICAgICBpbmtzY2FwZTpzbmFwLWJib3g9InRydWUiPgogICAgPGlua3NjYXBlOmdyaWQKICAgICAgIGlkPSJHcmlkRnJvbVByZTA0NlNldHRpbmdzIgogICAgICAgdHlwZT0ieHlncmlkIgogICAgICAgb3JpZ2lueD0iMHB4IgogICAgICAgb3JpZ2lueT0iMHB4IgogICAgICAgc3BhY2luZ3g9IjFweCIKICAgICAgIHNwYWNpbmd5PSIxcHgiCiAgICAgICBjb2xvcj0iIzAwMDBmZiIKICAgICAgIGVtcGNvbG9yPSIjMDAwMGZmIgogICAgICAgb3BhY2l0eT0iMC4yIgogICAgICAgZW1wb3BhY2l0eT0iMC40IgogICAgICAgZW1wc3BhY2luZz0iNSIKICAgICAgIHZpc2libGU9InRydWUiCiAgICAgICBlbmFibGVkPSJ0cnVlIiAvPgogIDwvc29kaXBvZGk6bmFtZWR2aWV3PgogIDxtZXRhZGF0YQogICAgIGlkPSJtZXRhZGF0YTciPgogICAgPHJkZjpSREY+CiAgICAgIDxjYzpXb3JrCiAgICAgICAgIHJkZjphYm91dD0iIj4KICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3N2Zyt4bWw8L2RjOmZvcm1hdD4KICAgICAgICA8ZGM6dHlwZQogICAgICAgICAgIHJkZjpyZXNvdXJjZT0iaHR0cDovL3B1cmwub3JnL2RjL2RjbWl0eXBlL1N0aWxsSW1hZ2UiIC8+CiAgICAgIDwvY2M6V29yaz4KICAgIDwvcmRmOlJERj4KICA8L21ldGFkYXRhPgogIDxnCiAgICAgaW5rc2NhcGU6bGFiZWw9IkxheWVyIDEiCiAgICAgaW5rc2NhcGU6Z3JvdXBtb2RlPSJsYXllciIKICAgICBpZD0ibGF5ZXIxIj4KICAgIDxwYXRoCiAgICAgICBzdHlsZT0iZmlsbDpub25lO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDoyO3N0cm9rZS1saW5lY2FwOmJ1dHQ7c3Ryb2tlLWxpbmVqb2luOm1pdGVyO3N0cm9rZS1vcGFjaXR5OjEiCiAgICAgICBkPSJtIDcwLDI1IGMgMjAsMCAyNSwwIDI1LDAiCiAgICAgICBpZD0icGF0aDMwNTkiCiAgICAgICBzb2RpcG9kaTpub2RldHlwZXM9ImNjIiAvPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmaWxsOm5vbmU7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjEuOTk5OTk5ODg7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgIGQ9Ik0gMzAuMzg1NzE3LDE1IEwgNC45OTk5OTk4LDE1IgogICAgICAgaWQ9InBhdGgzMDYxIiAvPgogICAgPHBhdGgKICAgICAgIHN0eWxlPSJmaWxsOm5vbmU7c3Ryb2tlOiMwMDAwMDA7c3Ryb2tlLXdpZHRoOjEuOTk5OTk5NzY7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgIGQ9Ik0gMzEuMzYyMDkxLDM1IEwgNC45OTk5OTk4LDM1IgogICAgICAgaWQ9InBhdGgzOTQ0IiAvPgogICAgPGcKICAgICAgIGlkPSJnMjU2MCIKICAgICAgIGlua3NjYXBlOmxhYmVsPSJMYXllciAxIgogICAgICAgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMjYuNSwtMzkuNSkiPgogICAgICA8cGF0aAogICAgICAgICBpZD0icGF0aDM1MTYiCiAgICAgICAgIHN0eWxlPSJmaWxsOiMwMDAwMDA7ZmlsbC1vcGFjaXR5OjE7ZmlsbC1ydWxlOmV2ZW5vZGQ7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjM7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgICAgZD0iTSAtMi4yNSw4MS41MDAwMDUgQyAtMy44NDczNzQsODQuMTQ0NDA1IC00LjUsODQuNTAwMDA1IC00LjUsODQuNTAwMDA1IEwgLTguMTU2MjUsODQuNTAwMDA1IEwgLTYuMTU2MjUsODIuMDYyNTA1IEMgLTYuMTU2MjUsODIuMDYyNTA1IC0wLjUsNzUuMDYyNDUxIC0wLjUsNjQuNSBDIC0wLjUsNTMuOTM3NTQ5IC02LjE1NjI1LDQ2LjkzNzUgLTYuMTU2MjUsNDYuOTM3NSBMIC04LjE1NjI1LDQ0LjUgTCAtNC41LDQ0LjUgQyAtMy43MTg3NSw0NS40Mzc1IC0zLjA3ODEyNSw0Ni4xNTYyNSAtMi4yODEyNSw0Ny41IEMgLTAuNDA4NTMxLDUwLjU5OTgxNSAyLjUsNTYuNTI2NjQ2IDIuNSw2NC41IEMgMi41LDcyLjQ1MDY1IC0wLjM5NjY5Nyw3OC4zNzk0MjUgLTIuMjUsODEuNTAwMDA1IHoiCiAgICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2NjY3NjY2Njc2MiIC8+CiAgICAgIDxwYXRoCiAgICAgICAgIHN0eWxlPSJmaWxsOiMwMDAwMDA7ZmlsbC1vcGFjaXR5OjE7ZmlsbC1ydWxlOmV2ZW5vZGQ7c3Ryb2tlOm5vbmU7c3Ryb2tlLXdpZHRoOjM7c3Ryb2tlLWxpbmVjYXA6YnV0dDtzdHJva2UtbGluZWpvaW46bWl0ZXI7c3Ryb2tlLW9wYWNpdHk6MSIKICAgICAgICAgZD0iTSAtMi40MDYyNSw0NC41IEwgLTAuNDA2MjUsNDYuOTM3NSBDIC0wLjQwNjI1LDQ2LjkzNzUgNS4yNSw1My45Mzc1NDkgNS4yNSw2NC41IEMgNS4yNSw3NS4wNjI0NTEgLTAuNDA2MjUsODIuMDYyNSAtMC40MDYyNSw4Mi4wNjI1IEwgLTIuNDA2MjUsODQuNSBMIDAuNzUsODQuNSBMIDE0Ljc1LDg0LjUgQyAxNy4xNTgwNzYsODQuNTAwMDAxIDIyLjQzOTY5OSw4NC41MjQ1MTQgMjguMzc1LDgyLjA5Mzc1IEMgMzQuMzEwMzAxLDc5LjY2Mjk4NiA0MC45MTE1MzYsNzQuNzUwNDg0IDQ2LjA2MjUsNjUuMjE4NzUgTCA0NC43NSw2NC41IEwgNDYuMDYyNSw2My43ODEyNSBDIDM1Ljc1OTM4Nyw0NC43MTU1OSAxOS41MDY1NzQsNDQuNSAxNC43NSw0NC41IEwgMC43NSw0NC41IEwgLTIuNDA2MjUsNDQuNSB6IE0gMy40Njg3NSw0Ny41IEwgMTQuNzUsNDcuNSBDIDE5LjQzNDE3Myw0Ny41IDMzLjAzNjg1LDQ3LjM2OTc5MyA0Mi43MTg3NSw2NC41IEMgMzcuOTUxOTY0LDcyLjkyOTA3NSAzMi4xOTc0NjksNzcuMTgzOTEgMjcsNzkuMzEyNSBDIDIxLjYzOTMzOSw4MS41MDc5MjQgMTcuMTU4MDc1LDgxLjUwMDAwMSAxNC43NSw4MS41IEwgMy41LDgxLjUgQyA1LjM3MzU4ODQsNzguMzkxNTY2IDguMjUsNzIuNDUwNjUgOC4yNSw2NC41IEMgOC4yNSw1Ni41MjY2NDYgNS4zNDE0Njg2LDUwLjU5OTgxNSAzLjQ2ODc1LDQ3LjUgeiIKICAgICAgICAgaWQ9InBhdGg0OTczIgogICAgICAgICBzb2RpcG9kaTpub2RldHlwZXM9ImNjc2NjY2NzY2NjY2NjY2Njc2Njc2MiIC8+CiAgICA8L2c+CiAgPC9nPgo8L3N2Zz4K' }} + }, { + operation: function(input1, input2) { + return (!input1 || input2) && (input1 || !input2); + } + }); + + var Xnor = Gate21.define('logic.Xnor', { + attrs: { image: { 'xlink:href': 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjwhLS0gQ3JlYXRlZCB3aXRoIElua3NjYXBlIChodHRwOi8vd3d3Lmlua3NjYXBlLm9yZy8pIC0tPgo8c3ZnCiAgIHhtbG5zOmRjPSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIKICAgeG1sbnM6Y2M9Imh0dHA6Ly9jcmVhdGl2ZWNvbW1vbnMub3JnL25zIyIKICAgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIgogICB4bWxuczpzdmc9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIgogICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zOnNvZGlwb2RpPSJodHRwOi8vc29kaXBvZGkuc291cmNlZm9yZ2UubmV0L0RURC9zb2RpcG9kaS0wLmR0ZCIKICAgeG1sbnM6aW5rc2NhcGU9Imh0dHA6Ly93d3cuaW5rc2NhcGUub3JnL25hbWVzcGFjZXMvaW5rc2NhcGUiCiAgIHdpZHRoPSIxMDAiCiAgIGhlaWdodD0iNTAiCiAgIGlkPSJzdmcyIgogICBzb2RpcG9kaTp2ZXJzaW9uPSIwLjMyIgogICBpbmtzY2FwZTp2ZXJzaW9uPSIwLjQ2IgogICB2ZXJzaW9uPSIxLjAiCiAgIHNvZGlwb2RpOmRvY25hbWU9IlhOT1IgQU5TSS5zdmciCiAgIGlua3NjYXBlOm91dHB1dF9leHRlbnNpb249Im9yZy5pbmtzY2FwZS5vdXRwdXQuc3ZnLmlua3NjYXBlIj4KICA8ZGVmcwogICAgIGlkPSJkZWZzNCI+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogMTUgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfej0iNTAgOiAxNSA6IDEiCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMjUgOiAxMCA6IDEiCiAgICAgICBpZD0icGVyc3BlY3RpdmUyNzE0IiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDAuNSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF96PSIxIDogMC41IDogMSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIwLjUgOiAwLjMzMzMzMzMzIDogMSIKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI4MDYiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI4MTkiCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iMzcyLjA0NzI0IDogMzUwLjc4NzM5IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9Ijc0NC4wOTQ0OCA6IDUyNi4xODEwOSA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogNTI2LjE4MTA5IDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgICA8aW5rc2NhcGU6cGVyc3BlY3RpdmUKICAgICAgIGlkPSJwZXJzcGVjdGl2ZTI3NzciCiAgICAgICBpbmtzY2FwZTpwZXJzcDNkLW9yaWdpbj0iNzUgOiA0MCA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF96PSIxNTAgOiA2MCA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogNjAgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlMzI3NSIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSI1MCA6IDMzLjMzMzMzMyA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF96PSIxMDAgOiA1MCA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF95PSIwIDogMTAwMCA6IDAiCiAgICAgICBpbmtzY2FwZTp2cF94PSIwIDogNTAgOiAxIgogICAgICAgc29kaXBvZGk6dHlwZT0iaW5rc2NhcGU6cGVyc3AzZCIgLz4KICAgIDxpbmtzY2FwZTpwZXJzcGVjdGl2ZQogICAgICAgaWQ9InBlcnNwZWN0aXZlNTUzMyIKICAgICAgIGlua3NjYXBlOnBlcnNwM2Qtb3JpZ2luPSIzMiA6IDIxLjMzMzMzMyA6IDEiCiAgICAgICBpbmtzY2FwZTp2cF96PSI2NCA6IDMyIDogMSIKICAgICAgIGlua3NjYXBlOnZwX3k9IjAgOiAxMDAwIDogMCIKICAgICAgIGlua3NjYXBlOnZwX3g9IjAgOiAzMiA6IDEiCiAgICAgICBzb2RpcG9kaTp0eXBlPSJpbmtzY2FwZTpwZXJzcDNkIiAvPgogICAgPGlua3NjYXBlOnBlcnNwZWN0aXZlCiAgICAgICBpZD0icGVyc3BlY3RpdmUyNTU3IgogICAgICAgaW5rc2NhcGU6cGVyc3AzZC1vcmlnaW49IjI1IDogMTYuNjY2NjY3IDogMSIKICAgICAgIGlua3NjYXBlOnZwX3o9IjUwIDogMjUgOiAxIgogICAgICAgaW5rc2NhcGU6dnBfeT0iMCA6IDEwMDAgOiAwIgogICAgICAgaW5rc2NhcGU6dnBfeD0iMCA6IDI1IDogMSIKICAgICAgIHNvZGlwb2RpOnR5cGU9Imlua3NjYXBlOnBlcnNwM2QiIC8+CiAgPC9kZWZzPgogIDxzb2RpcG9kaTpuYW1lZHZpZXcKICAgICBpZD0iYmFzZSIKICAgICBwYWdlY29sb3I9IiNmZmZmZmYiCiAgICAgYm9yZGVyY29sb3I9IiM2NjY2NjYiCiAgICAgYm9yZGVyb3BhY2l0eT0iMS4wIgogICAgIGlua3NjYXBlOnBhZ2VvcGFjaXR5PSIwLjAiCiAgICAgaW5rc2NhcGU6cGFnZXNoYWRvdz0iMiIKICAgICBpbmtzY2FwZTp6b29tPSI0IgogICAgIGlua3NjYXBlOmN4PSI5NS43MjM2NiIKICAgICBpbmtzY2FwZTpjeT0iLTI2Ljc3NTAyMyIKICAgICBpbmtzY2FwZTpkb2N1bWVudC11bml0cz0icHgiCiAgICAgaW5rc2NhcGU6Y3VycmVudC1sYXllcj0ibGF5ZXIxIgogICAgIHNob3dncmlkPSJ0cnVlIgogICAgIGlua3NjYXBlOmdyaWQtYmJveD0idHJ1ZSIKICAgICBpbmtzY2FwZTpncmlkLXBvaW50cz0idHJ1ZSIKICAgICBncmlkdG9sZXJhbmNlPSIxMDAwMCIKICAgICBpbmtzY2FwZTp3aW5kb3ctd2lkdGg9IjEzOTkiCiAgICAgaW5rc2NhcGU6d2luZG93LWhlaWdodD0iODc0IgogICAgIGlua3NjYXBlOndpbmRvdy14PSIzMyIKICAgICBpbmtzY2FwZTp3aW5kb3cteT0iMCIKICAgICBpbmtzY2FwZTpzbmFwLWJib3g9InRydWUiPgogICAgPGlua3NjYXBlOmdyaWQKICAgICAgIGlkPSJHcmlkRnJvbVByZTA0NlNldHRpbmdzIgogICAgICAgdHlwZT0ieHlncmlkIgogICAgICAgb3JpZ2lueD0iMHB4IgogICAgICAgb3JpZ2lueT0iMHB4IgogICAgICAgc3BhY2luZ3g9IjFweCIKICAgICAgIHNwYWNpbmd5PSIxcHgiCiAgICAgICBjb2xvcj0iIzAwMDBmZiIKICAgICAgIGVtcGNvbG9yPSIjMDAwMGZmIgogICAgICAgb3BhY2l0eT0iMC4yIgogICAgICAgZW1wb3BhY2l0eT0iMC40IgogICAgICAgZW1wc3BhY2luZz0iNSIKICAgICAgIHZpc2libGU9InRydWUiCiAgICAgICBlbmFibGVkPSJ0cnVlIiAvPgogIDwvc29kaXBvZGk6bmFtZWR2aWV3PgogIDxtZXRhZGF0YQogICAgIGlkPSJtZXRhZGF0YTciPgogICAgPHJkZjpSREY+CiAgICAgIDxjYzpXb3JrCiAgICAgICAgIHJkZjphYm91dD0iIj4KICAgICAgICA8ZGM6Zm9ybWF0PmltYWdlL3N2Zyt4bWw8L2RjOmZvcm1hdD4KICAgICAgICA8ZGM6dHlwZQogICAgICAgICAgIHJkZjpyZXNvdXJjZT0iaHR0cDovL3B1cmwub3JnL2RjL2RjbWl0eXBlL1N0aWxsSW1hZ2UiIC8+CiAgICAgIDwvY2M6V29yaz4KICAgIDwvcmRmOlJERj4KICA8L21ldGFkYXRhPgogIDxnCiAgICAgaW5rc2NhcGU6bGFiZWw9IkxheWVyIDEiCiAgICAgaW5rc2NhcGU6Z3JvdXBtb2RlPSJsYXllciIKICAgICBpZD0ibGF5ZXIxIj4KICAgIDxwYXRoCiAgICAgICBzdHlsZT0iZmlsbDpub25lO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDoyLjAwMDAwMDI0O3N0cm9rZS1saW5lY2FwOmJ1dHQ7c3Ryb2tlLWxpbmVqb2luOm1pdGVyO3N0cm9rZS1vcGFjaXR5OjEiCiAgICAgICBkPSJNIDc4LjMzMzMzMiwyNSBDIDkxLjY2NjY2NiwyNSA5NSwyNSA5NSwyNSIKICAgICAgIGlkPSJwYXRoMzA1OSIKICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2MiIC8+CiAgICA8cGF0aAogICAgICAgc3R5bGU9ImZpbGw6bm9uZTtzdHJva2U6IzAwMDAwMDtzdHJva2Utd2lkdGg6MS45OTk5OTk4ODtzdHJva2UtbGluZWNhcDpidXR0O3N0cm9rZS1saW5lam9pbjptaXRlcjtzdHJva2Utb3BhY2l0eToxIgogICAgICAgZD0iTSAzMC4zODU3MTcsMTUgTCA0Ljk5OTk5OTgsMTUiCiAgICAgICBpZD0icGF0aDMwNjEiIC8+CiAgICA8cGF0aAogICAgICAgc3R5bGU9ImZpbGw6bm9uZTtzdHJva2U6IzAwMDAwMDtzdHJva2Utd2lkdGg6MS45OTk5OTk3NjtzdHJva2UtbGluZWNhcDpidXR0O3N0cm9rZS1saW5lam9pbjptaXRlcjtzdHJva2Utb3BhY2l0eToxIgogICAgICAgZD0iTSAzMS4zNjIwOTEsMzUgTCA0Ljk5OTk5OTgsMzUiCiAgICAgICBpZD0icGF0aDM5NDQiIC8+CiAgICA8ZwogICAgICAgaWQ9ImcyNTYwIgogICAgICAgaW5rc2NhcGU6bGFiZWw9IkxheWVyIDEiCiAgICAgICB0cmFuc2Zvcm09InRyYW5zbGF0ZSgyNi41LC0zOS41KSI+CiAgICAgIDxwYXRoCiAgICAgICAgIGlkPSJwYXRoMzUxNiIKICAgICAgICAgc3R5bGU9ImZpbGw6IzAwMDAwMDtmaWxsLW9wYWNpdHk6MTtmaWxsLXJ1bGU6ZXZlbm9kZDtzdHJva2U6bm9uZTtzdHJva2Utd2lkdGg6MztzdHJva2UtbGluZWNhcDpidXR0O3N0cm9rZS1saW5lam9pbjptaXRlcjtzdHJva2Utb3BhY2l0eToxIgogICAgICAgICBkPSJNIC0yLjI1LDgxLjUwMDAwNSBDIC0zLjg0NzM3NCw4NC4xNDQ0MDUgLTQuNSw4NC41MDAwMDUgLTQuNSw4NC41MDAwMDUgTCAtOC4xNTYyNSw4NC41MDAwMDUgTCAtNi4xNTYyNSw4Mi4wNjI1MDUgQyAtNi4xNTYyNSw4Mi4wNjI1MDUgLTAuNSw3NS4wNjI0NTEgLTAuNSw2NC41IEMgLTAuNSw1My45Mzc1NDkgLTYuMTU2MjUsNDYuOTM3NSAtNi4xNTYyNSw0Ni45Mzc1IEwgLTguMTU2MjUsNDQuNSBMIC00LjUsNDQuNSBDIC0zLjcxODc1LDQ1LjQzNzUgLTMuMDc4MTI1LDQ2LjE1NjI1IC0yLjI4MTI1LDQ3LjUgQyAtMC40MDg1MzEsNTAuNTk5ODE1IDIuNSw1Ni41MjY2NDYgMi41LDY0LjUgQyAyLjUsNzIuNDUwNjUgLTAuMzk2Njk3LDc4LjM3OTQyNSAtMi4yNSw4MS41MDAwMDUgeiIKICAgICAgICAgc29kaXBvZGk6bm9kZXR5cGVzPSJjY2Njc2NjY2NzYyIgLz4KICAgICAgPHBhdGgKICAgICAgICAgc3R5bGU9ImZpbGw6IzAwMDAwMDtmaWxsLW9wYWNpdHk6MTtmaWxsLXJ1bGU6ZXZlbm9kZDtzdHJva2U6bm9uZTtzdHJva2Utd2lkdGg6MztzdHJva2UtbGluZWNhcDpidXR0O3N0cm9rZS1saW5lam9pbjptaXRlcjtzdHJva2Utb3BhY2l0eToxIgogICAgICAgICBkPSJNIC0yLjQwNjI1LDQ0LjUgTCAtMC40MDYyNSw0Ni45Mzc1IEMgLTAuNDA2MjUsNDYuOTM3NSA1LjI1LDUzLjkzNzU0OSA1LjI1LDY0LjUgQyA1LjI1LDc1LjA2MjQ1MSAtMC40MDYyNSw4Mi4wNjI1IC0wLjQwNjI1LDgyLjA2MjUgTCAtMi40MDYyNSw4NC41IEwgMC43NSw4NC41IEwgMTQuNzUsODQuNSBDIDE3LjE1ODA3Niw4NC41MDAwMDEgMjIuNDM5Njk5LDg0LjUyNDUxNCAyOC4zNzUsODIuMDkzNzUgQyAzNC4zMTAzMDEsNzkuNjYyOTg2IDQwLjkxMTUzNiw3NC43NTA0ODQgNDYuMDYyNSw2NS4yMTg3NSBMIDQ0Ljc1LDY0LjUgTCA0Ni4wNjI1LDYzLjc4MTI1IEMgMzUuNzU5Mzg3LDQ0LjcxNTU5IDE5LjUwNjU3NCw0NC41IDE0Ljc1LDQ0LjUgTCAwLjc1LDQ0LjUgTCAtMi40MDYyNSw0NC41IHogTSAzLjQ2ODc1LDQ3LjUgTCAxNC43NSw0Ny41IEMgMTkuNDM0MTczLDQ3LjUgMzMuMDM2ODUsNDcuMzY5NzkzIDQyLjcxODc1LDY0LjUgQyAzNy45NTE5NjQsNzIuOTI5MDc1IDMyLjE5NzQ2OSw3Ny4xODM5MSAyNyw3OS4zMTI1IEMgMjEuNjM5MzM5LDgxLjUwNzkyNCAxNy4xNTgwNzUsODEuNTAwMDAxIDE0Ljc1LDgxLjUgTCAzLjUsODEuNSBDIDUuMzczNTg4NCw3OC4zOTE1NjYgOC4yNSw3Mi40NTA2NSA4LjI1LDY0LjUgQyA4LjI1LDU2LjUyNjY0NiA1LjM0MTQ2ODYsNTAuNTk5ODE1IDMuNDY4NzUsNDcuNSB6IgogICAgICAgICBpZD0icGF0aDQ5NzMiCiAgICAgICAgIHNvZGlwb2RpOm5vZGV0eXBlcz0iY2NzY2NjY3NjY2NjY2NjY2NzY2NzYyIgLz4KICAgIDwvZz4KICAgIDxwYXRoCiAgICAgICBzb2RpcG9kaTp0eXBlPSJhcmMiCiAgICAgICBzdHlsZT0iZmlsbDpub25lO2ZpbGwtb3BhY2l0eToxO3N0cm9rZTojMDAwMDAwO3N0cm9rZS13aWR0aDozO3N0cm9rZS1saW5lam9pbjptaXRlcjttYXJrZXI6bm9uZTtzdHJva2Utb3BhY2l0eToxO3Zpc2liaWxpdHk6dmlzaWJsZTtkaXNwbGF5OmlubGluZTtvdmVyZmxvdzp2aXNpYmxlO2VuYWJsZS1iYWNrZ3JvdW5kOmFjY3VtdWxhdGUiCiAgICAgICBpZD0icGF0aDM1NTEiCiAgICAgICBzb2RpcG9kaTpjeD0iNzUiCiAgICAgICBzb2RpcG9kaTpjeT0iMjUiCiAgICAgICBzb2RpcG9kaTpyeD0iNCIKICAgICAgIHNvZGlwb2RpOnJ5PSI0IgogICAgICAgZD0iTSA3OSwyNSBBIDQsNCAwIDEgMSA3MSwyNSBBIDQsNCAwIDEgMSA3OSwyNSB6IiAvPgogIDwvZz4KPC9zdmc+Cg==' }} + }, { + operation: function(input1, input2) { + return (!input1 || !input2) && (input1 || input2); + } + }); + + var Wire = Link.define('logic.Wire', { + attrs: { + '.connection': { 'stroke-width': 2 }, + '.marker-vertex': { r: 7 } + }, + + router: { name: 'orthogonal' }, + connector: { name: 'rounded', args: { radius: 10 }} + }, { + arrowheadMarkup: [ + '', + '', + '' + ].join(''), + + vertexMarkup: [ + '', + '', + '', + '', + '', + 'Remove vertex.', + '', + '', + '' + ].join('') + }); + + var logic = ({ + Gate: Gate, + IO: IO, + Input: Input, + Output: Output, + Gate11: Gate11, + Gate21: Gate21, + Repeater: Repeater, + Not: Not, + Or: Or, + And: And, + Nor: Nor, + Nand: Nand, + Xor: Xor, + Xnor: Xnor, + Wire: Wire + }); + + var KingWhite = Generic.define('chess.KingWhite', { + size: { width: 42, height: 38 } + }, { + markup: ' ' + }); + + var KingBlack = Generic.define('chess.KingBlack', { + size: { width: 42, height: 38 } + }, { + markup: ' ' + }); + + var QueenWhite = Generic.define('chess.QueenWhite', { + size: { width: 42, height: 38 } + }, { + markup: ' ' + }); + + var QueenBlack = Generic.define('chess.QueenBlack', { + size: { width: 42, height: 38 } + }, { + markup: ' ' + }); + + var RookWhite = Generic.define('chess.RookWhite', { + size: { width: 32, height: 34 } + }, { + markup: ' ' + }); + + var RookBlack = Generic.define('chess.RookBlack', { + size: { width: 32, height: 34 } + }, { + markup: ' ' + }); + + var BishopWhite = Generic.define('chess.BishopWhite', { + size: { width: 38, height: 38 } + }, { + markup: ' ' + }); + + var BishopBlack = Generic.define('chess.BishopBlack', { + size: { width: 38, height: 38 } + }, { + markup: ' ' + }); + + var KnightWhite = Generic.define('chess.KnightWhite', { + size: { width: 38, height: 37 } + }, { + markup: ' ' + }); + + var KnightBlack = Generic.define('chess.KnightBlack', { + size: { width: 38, height: 37 } + }, { + markup: ' ' + }); + + var PawnWhite = Generic.define('chess.PawnWhite', { + size: { width: 28, height: 33 } + }, { + markup: '' + }); + + var PawnBlack = Generic.define('chess.PawnBlack', { + size: { width: 28, height: 33 } + }, { + markup: '' + }); + + var chess = ({ + KingWhite: KingWhite, + KingBlack: KingBlack, + QueenWhite: QueenWhite, + QueenBlack: QueenBlack, + RookWhite: RookWhite, + RookBlack: RookBlack, + BishopWhite: BishopWhite, + BishopBlack: BishopBlack, + KnightWhite: KnightWhite, + KnightBlack: KnightBlack, + PawnWhite: PawnWhite, + PawnBlack: PawnBlack + }); + + var Entity = Element$1.define('erd.Entity', { + size: { width: 150, height: 60 }, + attrs: { + '.outer': { + fill: '#2ECC71', stroke: '#27AE60', 'stroke-width': 2, + points: '100,0 100,60 0,60 0,0' + }, + '.inner': { + fill: '#2ECC71', stroke: '#27AE60', 'stroke-width': 2, + points: '95,5 95,55 5,55 5,5', + display: 'none' + }, + text: { + text: 'Entity', + 'font-family': 'Arial', 'font-size': 14, + 'ref-x': .5, 'ref-y': .5, + 'y-alignment': 'middle', 'text-anchor': 'middle' + } + } + }, { + markup: '', + }); + + var WeakEntity = Entity.define('erd.WeakEntity', { + attrs: { + '.inner': { display: 'auto' }, + text: { text: 'Weak Entity' } + } + }); + + var Relationship = Element$1.define('erd.Relationship', { + size: { width: 80, height: 80 }, + attrs: { + '.outer': { + fill: '#3498DB', stroke: '#2980B9', 'stroke-width': 2, + points: '40,0 80,40 40,80 0,40' + }, + '.inner': { + fill: '#3498DB', stroke: '#2980B9', 'stroke-width': 2, + points: '40,5 75,40 40,75 5,40', + display: 'none' + }, + text: { + text: 'Relationship', + 'font-family': 'Arial', 'font-size': 12, + 'ref-x': .5, 'ref-y': .5, + 'y-alignment': 'middle', 'text-anchor': 'middle' + } + } + }, { + markup: '', + }); + + var IdentifyingRelationship = Relationship.define('erd.IdentifyingRelationship', { + attrs: { + '.inner': { display: 'auto' }, + text: { text: 'Identifying' } + } + }); + + var Attribute = Element$1.define('erd.Attribute', { + size: { width: 100, height: 50 }, + attrs: { + 'ellipse': { + transform: 'translate(50, 25)' + }, + '.outer': { + stroke: '#D35400', 'stroke-width': 2, + cx: 0, cy: 0, rx: 50, ry: 25, + fill: '#E67E22' + }, + '.inner': { + stroke: '#D35400', 'stroke-width': 2, + cx: 0, cy: 0, rx: 45, ry: 20, + fill: '#E67E22', display: 'none' + }, + text: { + 'font-family': 'Arial', 'font-size': 14, + 'ref-x': .5, 'ref-y': .5, + 'y-alignment': 'middle', 'text-anchor': 'middle' + } + } + }, { + markup: '', + }); + + var Multivalued = Attribute.define('erd.Multivalued', { + attrs: { + '.inner': { display: 'block' }, + text: { text: 'multivalued' } + } + }); + + var Derived = Attribute.define('erd.Derived', { + attrs: { + '.outer': { 'stroke-dasharray': '3,5' }, + text: { text: 'derived' } + } + }); + + var Key = Attribute.define('erd.Key', { + attrs: { + ellipse: { 'stroke-width': 4 }, + text: { text: 'key', 'font-weight': '800', 'text-decoration': 'underline' } + } + }); + + var Normal = Attribute.define('erd.Normal', { + attrs: { text: { text: 'Normal' }} + }); + + var ISA = Element$1.define('erd.ISA', { + type: 'erd.ISA', + size: { width: 100, height: 50 }, + attrs: { + polygon: { + points: '0,0 50,50 100,0', + fill: '#F1C40F', stroke: '#F39C12', 'stroke-width': 2 + }, + text: { + text: 'ISA', 'font-size': 18, + 'ref-x': .5, 'ref-y': .3, + 'y-alignment': 'middle', 'text-anchor': 'middle' + } + } + }, { + markup: '', + }); + + var Line$1 = Link.define('erd.Line', {}, { + cardinality: function(value) { + this.set('labels', [{ position: -20, attrs: { text: { dy: -8, text: value }}}]); + } + }); + + var erd = ({ + Entity: Entity, + WeakEntity: WeakEntity, + Relationship: Relationship, + IdentifyingRelationship: IdentifyingRelationship, + Attribute: Attribute, + Multivalued: Multivalued, + Derived: Derived, + Key: Key, + Normal: Normal, + ISA: ISA, + Line: Line$1 + }); + + var State = Circle.define('fsa.State', { + attrs: { + circle: { 'stroke-width': 3 }, + text: { 'font-weight': '800' } + } + }); + + var StartState = Element$1.define('fsa.StartState', { + size: { width: 20, height: 20 }, + attrs: { + circle: { + transform: 'translate(10, 10)', + r: 10, + fill: '#000000' + } + } + }, { + markup: '', + }); + + var EndState = Element$1.define('fsa.EndState', { + size: { width: 20, height: 20 }, + attrs: { + '.outer': { + transform: 'translate(10, 10)', + r: 10, + fill: '#ffffff', + stroke: '#000000' + }, + + '.inner': { + transform: 'translate(10, 10)', + r: 6, + fill: '#000000' + } + } + }, { + markup: '', + }); + + var Arrow = Link.define('fsa.Arrow', { + attrs: { '.marker-target': { d: 'M 10 0 L 0 5 L 10 10 z' }}, + smooth: true + }); + + var fsa = ({ + State: State, + StartState: StartState, + EndState: EndState, + Arrow: Arrow + }); + + var Member = Element$1.define('org.Member', { + size: { width: 180, height: 70 }, + attrs: { + rect: { width: 170, height: 60 }, + + '.card': { + fill: '#FFFFFF', stroke: '#000000', 'stroke-width': 2, + 'pointer-events': 'visiblePainted', rx: 10, ry: 10 + }, + + image: { + width: 48, height: 48, + ref: '.card', 'ref-x': 10, 'ref-y': 5 + }, + + '.rank': { + 'text-decoration': 'underline', + ref: '.card', 'ref-x': 0.9, 'ref-y': 0.2, + 'font-family': 'Courier New', 'font-size': 14, + 'text-anchor': 'end' + }, + + '.name': { + 'font-weight': '800', + ref: '.card', 'ref-x': 0.9, 'ref-y': 0.6, + 'font-family': 'Courier New', 'font-size': 14, + 'text-anchor': 'end' + } + } + }, { + markup: '', + }); + + var Arrow$1 = Link.define('org.Arrow', { + source: { selector: '.card' }, target: { selector: '.card' }, + attrs: { '.connection': { stroke: '#585858', 'stroke-width': 3 }}, + z: -1 + }); + + var org = ({ + Member: Member, + Arrow: Arrow$1 + }); + + var Place = Generic.define('pn.Place', { + size: { width: 50, height: 50 }, + attrs: { + '.root': { + r: 25, + fill: '#ffffff', + stroke: '#000000', + transform: 'translate(25, 25)' + }, + '.label': { + 'text-anchor': 'middle', + 'ref-x': .5, + 'ref-y': -20, + ref: '.root', + fill: '#000000', + 'font-size': 12 + }, + '.tokens > circle': { + fill: '#000000', + r: 5 + }, + '.tokens.one > circle': { transform: 'translate(25, 25)' }, + + '.tokens.two > circle:nth-child(1)': { transform: 'translate(19, 25)' }, + '.tokens.two > circle:nth-child(2)': { transform: 'translate(31, 25)' }, + + '.tokens.three > circle:nth-child(1)': { transform: 'translate(18, 29)' }, + '.tokens.three > circle:nth-child(2)': { transform: 'translate(25, 19)' }, + '.tokens.three > circle:nth-child(3)': { transform: 'translate(32, 29)' }, + + '.tokens.alot > text': { + transform: 'translate(25, 18)', + 'text-anchor': 'middle', + fill: '#000000' + } + } + }, { + markup: '', + }); + + var PlaceView = ElementView.extend({ + + presentationAttributes: ElementView.addPresentationAttributes({ + tokens: ['TOKENS'] + }), + + initFlag: ElementView.prototype.initFlag.concat(['TOKENS']), + + confirmUpdate: function() { + var ref; + + var args = [], len = arguments.length; + while ( len-- ) args[ len ] = arguments[ len ]; + var flags = (ref = ElementView.prototype.confirmUpdate).call.apply(ref, [ this ].concat( args )); + if (this.hasFlag(flags, 'TOKENS')) { + this.renderTokens(); + this.update(); + flags = this.removeFlag(flags, 'TOKENS'); + } + return flags; + }, + + renderTokens: function() { + + var vTokens = this.vel.findOne('.tokens').empty(); + ['one', 'two', 'three', 'alot'].forEach(function(className) { + vTokens.removeClass(className); + }); + + var tokens = this.model.get('tokens'); + if (!tokens) { return; } + + switch (tokens) { + + case 1: + vTokens.addClass('one'); + vTokens.append(V('circle')); + break; + + case 2: + vTokens.addClass('two'); + vTokens.append([V('circle'), V('circle')]); + break; + + case 3: + vTokens.addClass('three'); + vTokens.append([V('circle'), V('circle'), V('circle')]); + break; + + default: + vTokens.addClass('alot'); + vTokens.append(V('text').text(tokens + '')); + break; + } + } + }); + + var Transition = Generic.define('pn.Transition', { + size: { width: 12, height: 50 }, + attrs: { + 'rect': { + width: 12, + height: 50, + fill: '#000000', + stroke: '#000000' + }, + '.label': { + 'text-anchor': 'middle', + 'ref-x': .5, + 'ref-y': -20, + ref: 'rect', + fill: '#000000', + 'font-size': 12 + } + } + }, { + markup: '', + }); + + var Link$3 = Link.define('pn.Link', { + attrs: { '.marker-target': { d: 'M 10 0 L 0 5 L 10 10 z' }} + }); + + var pn = ({ + Place: Place, + PlaceView: PlaceView, + Transition: Transition, + Link: Link$3 + }); + + var Class = Generic.define('uml.Class', { + attrs: { + rect: { 'width': 200 }, + + '.uml-class-name-rect': { 'stroke': 'black', 'stroke-width': 2, 'fill': '#3498db' }, + '.uml-class-attrs-rect': { 'stroke': 'black', 'stroke-width': 2, 'fill': '#2980b9' }, + '.uml-class-methods-rect': { 'stroke': 'black', 'stroke-width': 2, 'fill': '#2980b9' }, + + '.uml-class-name-text': { + 'ref': '.uml-class-name-rect', + 'ref-y': .5, + 'ref-x': .5, + 'text-anchor': 'middle', + 'y-alignment': 'middle', + 'font-weight': 'bold', + 'fill': 'black', + 'font-size': 12, + 'font-family': 'Times New Roman' + }, + '.uml-class-attrs-text': { + 'ref': '.uml-class-attrs-rect', 'ref-y': 5, 'ref-x': 5, + 'fill': 'black', 'font-size': 12, 'font-family': 'Times New Roman' + }, + '.uml-class-methods-text': { + 'ref': '.uml-class-methods-rect', 'ref-y': 5, 'ref-x': 5, + 'fill': 'black', 'font-size': 12, 'font-family': 'Times New Roman' + } + }, + + name: [], + attributes: [], + methods: [] + }, { + markup: [ + '', + '', + '', + '', + '', + '' + ].join(''), + + initialize: function() { + + this.on('change:name change:attributes change:methods', function() { + this.updateRectangles(); + this.trigger('uml-update'); + }, this); + + this.updateRectangles(); + + Generic.prototype.initialize.apply(this, arguments); + }, + + getClassName: function() { + return this.get('name'); + }, + + updateRectangles: function() { + + var attrs = this.get('attrs'); + + var rects = [ + { type: 'name', text: this.getClassName() }, + { type: 'attrs', text: this.get('attributes') }, + { type: 'methods', text: this.get('methods') } + ]; + + var offsetY = 0; + + rects.forEach(function(rect) { + + var lines = Array.isArray(rect.text) ? rect.text : [rect.text]; + var rectHeight = lines.length * 20 + 20; + + attrs['.uml-class-' + rect.type + '-text'].text = lines.join('\n'); + attrs['.uml-class-' + rect.type + '-rect'].height = rectHeight; + attrs['.uml-class-' + rect.type + '-rect'].transform = 'translate(0,' + offsetY + ')'; + + offsetY += rectHeight; + }); + } + + }); + + var ClassView = ElementView.extend({ + + initialize: function() { + + ElementView.prototype.initialize.apply(this, arguments); + + this.listenTo(this.model, 'uml-update', function() { + this.update(); + this.resize(); + }); + } + }); + + var Abstract = Class.define('uml.Abstract', { + attrs: { + '.uml-class-name-rect': { fill: '#e74c3c' }, + '.uml-class-attrs-rect': { fill: '#c0392b' }, + '.uml-class-methods-rect': { fill: '#c0392b' } + } + }, { + + getClassName: function() { + return ['<>', this.get('name')]; + } + + }); + var AbstractView = ClassView; + + var Interface = Class.define('uml.Interface', { + attrs: { + '.uml-class-name-rect': { fill: '#f1c40f' }, + '.uml-class-attrs-rect': { fill: '#f39c12' }, + '.uml-class-methods-rect': { fill: '#f39c12' } + } + }, { + getClassName: function() { + return ['<>', this.get('name')]; + } + }); + var InterfaceView = ClassView; + + var Generalization = Link.define('uml.Generalization', { + attrs: { '.marker-target': { d: 'M 20 0 L 0 10 L 20 20 z', fill: 'white' }} + }); + + var Implementation = Link.define('uml.Implementation', { + attrs: { + '.marker-target': { d: 'M 20 0 L 0 10 L 20 20 z', fill: 'white' }, + '.connection': { 'stroke-dasharray': '3,3' } + } + }); + + var Aggregation = Link.define('uml.Aggregation', { + attrs: { '.marker-target': { d: 'M 40 10 L 20 20 L 0 10 L 20 0 z', fill: 'white' }} + }); + + var Composition = Link.define('uml.Composition', { + attrs: { '.marker-target': { d: 'M 40 10 L 20 20 L 0 10 L 20 0 z', fill: 'black' }} + }); + + var Association = Link.define('uml.Association'); + + // Statechart + + var State$1 = Generic.define('uml.State', { + attrs: { + '.uml-state-body': { + 'width': 200, 'height': 200, 'rx': 10, 'ry': 10, + 'fill': '#ecf0f1', 'stroke': '#bdc3c7', 'stroke-width': 3 + }, + '.uml-state-separator': { + 'stroke': '#bdc3c7', 'stroke-width': 2 + }, + '.uml-state-name': { + 'ref': '.uml-state-body', 'ref-x': .5, 'ref-y': 5, 'text-anchor': 'middle', + 'fill': '#000000', 'font-family': 'Courier New', 'font-size': 14 + }, + '.uml-state-events': { + 'ref': '.uml-state-separator', 'ref-x': 5, 'ref-y': 5, + 'fill': '#000000', 'font-family': 'Courier New', 'font-size': 14 + } + }, + + name: 'State', + events: [] + + }, { + markup: [ + '', + '', + '', + '', + '', + '', + '', + '' + ].join(''), + + initialize: function() { + + this.on({ + 'change:name': this.updateName, + 'change:events': this.updateEvents, + 'change:size': this.updatePath + }, this); + + this.updateName(); + this.updateEvents(); + this.updatePath(); + + Generic.prototype.initialize.apply(this, arguments); + }, + + updateName: function() { + + this.attr('.uml-state-name/text', this.get('name')); + }, + + updateEvents: function() { + + this.attr('.uml-state-events/text', this.get('events').join('\n')); + }, + + updatePath: function() { + + var d = 'M 0 20 L ' + this.get('size').width + ' 20'; + + // We are using `silent: true` here because updatePath() is meant to be called + // on resize and there's no need to to update the element twice (`change:size` + // triggers also an update). + this.attr('.uml-state-separator/d', d, { silent: true }); + } + }); + + var StartState$1 = Circle.define('uml.StartState', { + type: 'uml.StartState', + attrs: { circle: { 'fill': '#34495e', 'stroke': '#2c3e50', 'stroke-width': 2, 'rx': 1 }} + }); + + var EndState$1 = Generic.define('uml.EndState', { + size: { width: 20, height: 20 }, + attrs: { + 'circle.outer': { + transform: 'translate(10, 10)', + r: 10, + fill: '#ffffff', + stroke: '#2c3e50' + }, + + 'circle.inner': { + transform: 'translate(10, 10)', + r: 6, + fill: '#34495e' + } + } + }, { + markup: '', + }); + + var Transition$1 = Link.define('uml.Transition', { + attrs: { + '.marker-target': { d: 'M 10 0 L 0 5 L 10 10 z', fill: '#34495e', stroke: '#2c3e50' }, + '.connection': { stroke: '#2c3e50' } + } + }); + + var uml = ({ + Class: Class, + ClassView: ClassView, + Abstract: Abstract, + AbstractView: AbstractView, + Interface: Interface, + InterfaceView: InterfaceView, + Generalization: Generalization, + Implementation: Implementation, + Aggregation: Aggregation, + Composition: Composition, + Association: Association, + State: State$1, + StartState: StartState$1, + EndState: EndState$1, + Transition: Transition$1 + }); + + + + var index$3 = ({ + basic: basic, + standard: standard, + devs: devs, + logic: logic, + chess: chess, + erd: erd, + fsa: fsa, + org: org, + pn: pn, + uml: uml + }); + + function abs2rel(absolute, max) { + + if (max === 0) { return '0%'; } + // round to 3 decimal places + var dp = 1000; + var relative = Math.round(absolute / max * 100 * dp) / dp; + return (relative + "%"); + } + + function pin(relative) { + + return function(end, view, magnet, coords) { + var fn = (view.isNodeConnection(magnet)) ? pinnedLinkEnd : pinnedElementEnd; + return fn(relative, end, view, magnet, coords); + }; + } + + function pinnedElementEnd(relative, end, view, magnet, coords) { + + var angle = view.model.angle(); + var bbox = view.getNodeUnrotatedBBox(magnet); + var origin = view.model.getBBox().center(); + coords.rotate(origin, angle); + var dx = coords.x - bbox.x; + var dy = coords.y - bbox.y; + + if (relative) { + dx = abs2rel(dx, bbox.width); + dy = abs2rel(dy, bbox.height); + } + + end.anchor = { + name: 'topLeft', + args: { + dx: dx, + dy: dy, + rotate: true + } + }; + + return end; + } + + function pinnedLinkEnd(relative, end, view, _magnet, coords) { + + var connection = view.getConnection(); + if (!connection) { return end; } + var length = connection.closestPointLength(coords); + if (relative) { + var totalLength = connection.length(); + end.anchor = { + name: 'connectionRatio', + args: { + ratio: length / totalLength + } + }; + } else { + end.anchor = { + name: 'connectionLength', + args: { + length: length + } + }; + } + return end; + } + + var useDefaults = noop; + var pinAbsolute = pin(false); + var pinRelative = pin(true); + + var index$4 = ({ + useDefaults: useDefaults, + pinAbsolute: pinAbsolute, + pinRelative: pinRelative + }); + + // Vertex Handles + var VertexHandle = View.extend({ + tagName: 'circle', + svgElement: true, + className: 'marker-vertex', + events: { + mousedown: 'onPointerDown', + touchstart: 'onPointerDown', + dblclick: 'onDoubleClick', + dbltap: 'onDoubleClick' + }, + documentEvents: { + mousemove: 'onPointerMove', + touchmove: 'onPointerMove', + mouseup: 'onPointerUp', + touchend: 'onPointerUp', + touchcancel: 'onPointerUp' + }, + attributes: { + 'r': 6, + 'fill': '#33334F', + 'stroke': '#FFFFFF', + 'stroke-width': 2, + 'cursor': 'move' + }, + position: function(x, y) { + var ref = this; + var vel = ref.vel; + var options = ref.options; + var scale = options.scale; + var matrix = V.createSVGMatrix().translate(x, y); + if (scale) { matrix = matrix.scale(scale); } + vel.transform(matrix, { absolute: true }); + }, + onPointerDown: function(evt) { + if (this.options.guard(evt)) { return; } + evt.stopPropagation(); + evt.preventDefault(); + this.options.paper.undelegateEvents(); + this.delegateDocumentEvents(null, evt.data); + this.trigger('will-change', this, evt); + }, + onPointerMove: function(evt) { + this.trigger('changing', this, evt); + }, + onDoubleClick: function(evt) { + this.trigger('remove', this, evt); + }, + onPointerUp: function(evt) { + this.trigger('changed', this, evt); + this.undelegateDocumentEvents(); + this.options.paper.delegateEvents(); + } + }); + + var Vertices = ToolView.extend({ + name: 'vertices', + options: { + handleClass: VertexHandle, + snapRadius: 20, + redundancyRemoval: true, + vertexAdding: true, + stopPropagation: true, + scale: null + }, + children: [{ + tagName: 'path', + selector: 'connection', + className: 'joint-vertices-path', + attributes: { + 'fill': 'none', + 'stroke': 'transparent', + 'stroke-width': 10, + 'cursor': 'cell' + } + }], + handles: null, + events: { + 'mousedown .joint-vertices-path': 'onPathPointerDown', + 'touchstart .joint-vertices-path': 'onPathPointerDown' + }, + onRender: function() { + if (this.options.vertexAdding) { + this.renderChildren(); + this.updatePath(); + } + this.resetHandles(); + this.renderHandles(); + return this; + }, + update: function() { + var relatedView = this.relatedView; + var vertices = relatedView.model.vertices(); + if (vertices.length === this.handles.length) { + this.updateHandles(); + } else { + this.resetHandles(); + this.renderHandles(); + } + if (this.options.vertexAdding) { + this.updatePath(); + } + return this; + }, + resetHandles: function() { + var handles = this.handles; + this.handles = []; + this.stopListening(); + if (!Array.isArray(handles)) { return; } + for (var i = 0, n = handles.length; i < n; i++) { + handles[i].remove(); + } + }, + renderHandles: function() { + var this$1 = this; + + var relatedView = this.relatedView; + var vertices = relatedView.model.vertices(); + for (var i = 0, n = vertices.length; i < n; i++) { + var vertex = vertices[i]; + var handle = new (this.options.handleClass)({ + index: i, + paper: this.paper, + scale: this.options.scale, + guard: function (evt) { return this$1.guard(evt); } + }); + handle.render(); + handle.position(vertex.x, vertex.y); + this.simulateRelatedView(handle.el); + handle.vel.appendTo(this.el); + this.handles.push(handle); + this.startHandleListening(handle); + } + }, + updateHandles: function() { + var relatedView = this.relatedView; + var vertices = relatedView.model.vertices(); + for (var i = 0, n = vertices.length; i < n; i++) { + var vertex = vertices[i]; + var handle = this.handles[i]; + if (!handle) { return; } + handle.position(vertex.x, vertex.y); + } + }, + updatePath: function() { + var connection = this.childNodes.connection; + if (connection) { connection.setAttribute('d', this.relatedView.getSerializedConnection()); } + }, + startHandleListening: function(handle) { + var relatedView = this.relatedView; + if (relatedView.can('vertexMove')) { + this.listenTo(handle, 'will-change', this.onHandleWillChange); + this.listenTo(handle, 'changing', this.onHandleChanging); + this.listenTo(handle, 'changed', this.onHandleChanged); + } + if (relatedView.can('vertexRemove')) { + this.listenTo(handle, 'remove', this.onHandleRemove); + } + }, + getNeighborPoints: function(index) { + var linkView = this.relatedView; + var vertices = linkView.model.vertices(); + var prev = (index > 0) ? vertices[index - 1] : linkView.sourceAnchor; + var next = (index < vertices.length - 1) ? vertices[index + 1] : linkView.targetAnchor; + return { + prev: new Point(prev), + next: new Point(next) + }; + }, + onHandleWillChange: function(_handle, evt) { + this.focus(); + var ref = this; + var relatedView = ref.relatedView; + var options = ref.options; + relatedView.model.startBatch('vertex-move', { ui: true, tool: this.cid }); + if (!options.stopPropagation) { relatedView.notifyPointerdown.apply(relatedView, relatedView.paper.getPointerArgs(evt)); } + }, + onHandleChanging: function(handle, evt) { + var ref = this; + var options = ref.options; + var linkView = ref.relatedView; + var index = handle.options.index; + var ref$1 = linkView.paper.getPointerArgs(evt); + var normalizedEvent = ref$1[0]; + var x = ref$1[1]; + var y = ref$1[2]; + var vertex = { x: x, y: y }; + this.snapVertex(vertex, index); + linkView.model.vertex(index, vertex, { ui: true, tool: this.cid }); + handle.position(vertex.x, vertex.y); + if (!options.stopPropagation) { linkView.notifyPointermove(normalizedEvent, x, y); } + }, + onHandleChanged: function(_handle, evt) { + var ref = this; + var options = ref.options; + var linkView = ref.relatedView; + if (options.vertexAdding) { this.updatePath(); } + if (!options.redundancyRemoval) { return; } + var verticesRemoved = linkView.removeRedundantLinearVertices({ ui: true, tool: this.cid }); + if (verticesRemoved) { this.render(); } + this.blur(); + linkView.model.stopBatch('vertex-move', { ui: true, tool: this.cid }); + if (this.eventData(evt).vertexAdded) { + linkView.model.stopBatch('vertex-add', { ui: true, tool: this.cid }); + } + var ref$1 = linkView.paper.getPointerArgs(evt); + var normalizedEvt = ref$1[0]; + var x = ref$1[1]; + var y = ref$1[2]; + if (!options.stopPropagation) { linkView.notifyPointerup(normalizedEvt, x, y); } + linkView.checkMouseleave(normalizedEvt); + }, + snapVertex: function(vertex, index) { + var snapRadius = this.options.snapRadius; + if (snapRadius > 0) { + var neighbors = this.getNeighborPoints(index); + var prev = neighbors.prev; + var next = neighbors.next; + if (Math.abs(vertex.x - prev.x) < snapRadius) { + vertex.x = prev.x; + } else if (Math.abs(vertex.x - next.x) < snapRadius) { + vertex.x = next.x; + } + if (Math.abs(vertex.y - prev.y) < snapRadius) { + vertex.y = neighbors.prev.y; + } else if (Math.abs(vertex.y - next.y) < snapRadius) { + vertex.y = next.y; + } + } + }, + onHandleRemove: function(handle, evt) { + var index$1 = handle.options.index; + var linkView = this.relatedView; + linkView.model.removeVertex(index$1, { ui: true }); + if (this.options.vertexAdding) { this.updatePath(); } + linkView.checkMouseleave(normalizeEvent(evt)); + }, + onPathPointerDown: function(evt) { + if (this.guard(evt)) { return; } + evt.stopPropagation(); + evt.preventDefault(); + var normalizedEvent = normalizeEvent(evt); + var vertex = this.paper.snapToGrid(normalizedEvent.clientX, normalizedEvent.clientY).toJSON(); + var relatedView = this.relatedView; + relatedView.model.startBatch('vertex-add', { ui: true, tool: this.cid }); + var index$1 = relatedView.getVertexIndex(vertex.x, vertex.y); + this.snapVertex(vertex, index$1); + relatedView.model.insertVertex(index$1, vertex, { ui: true, tool: this.cid }); + this.update(); + var handle = this.handles[index$1]; + this.eventData(normalizedEvent, { vertexAdded: true }); + handle.onPointerDown(normalizedEvent); + }, + onRemove: function() { + this.resetHandles(); + } + }, { + VertexHandle: VertexHandle // keep as class property + }); + + function getViewBBox(view, useModelGeometry) { + var model = view.model; + if (useModelGeometry) { return model.getBBox(); } + return (model.isLink()) ? view.getConnection().bbox() : view.getNodeUnrotatedBBox(view.el); + } + + function getAnchor(coords, view, magnet) { + // take advantage of an existing logic inside of the + // pin relative connection strategy + var end = pinRelative.call( + this.paper, + {}, + view, + magnet, + coords, + this.model + ); + return end.anchor; + } + + function snapAnchor(coords, view, magnet, type, relatedView, toolView) { + var snapRadius = toolView.options.snapRadius; + var isSource = (type === 'source'); + var refIndex = (isSource ? 0 : -1); + var ref = this.model.vertex(refIndex) || this.getEndAnchor(isSource ? 'target' : 'source'); + if (ref) { + if (Math.abs(ref.x - coords.x) < snapRadius) { coords.x = ref.x; } + if (Math.abs(ref.y - coords.y) < snapRadius) { coords.y = ref.y; } + } + return coords; + } + + var SegmentHandle = View.extend({ + tagName: 'g', + svgElement: true, + className: 'marker-segment', + events: { + mousedown: 'onPointerDown', + touchstart: 'onPointerDown' + }, + documentEvents: { + mousemove: 'onPointerMove', + touchmove: 'onPointerMove', + mouseup: 'onPointerUp', + touchend: 'onPointerUp', + touchcancel: 'onPointerUp' + }, + children: [{ + tagName: 'line', + selector: 'line', + attributes: { + 'stroke': '#33334F', + 'stroke-width': 2, + 'fill': 'none', + 'pointer-events': 'none' + } + }, { + tagName: 'rect', + selector: 'handle', + attributes: { + 'width': 20, + 'height': 8, + 'x': -10, + 'y': -4, + 'rx': 4, + 'ry': 4, + 'fill': '#33334F', + 'stroke': '#FFFFFF', + 'stroke-width': 2 + } + }], + onRender: function() { + this.renderChildren(); + }, + position: function(x, y, angle, view) { + var ref = this.options; + var scale = ref.scale; + var matrix = V.createSVGMatrix().translate(x, y).rotate(angle); + if (scale) { matrix = matrix.scale(scale); } + + var handle = this.childNodes.handle; + handle.setAttribute('transform', V.matrixToTransformString(matrix)); + handle.setAttribute('cursor', (angle % 180 === 0) ? 'row-resize' : 'col-resize'); + + var viewPoint = view.getClosestPoint(new Point(x, y)); + var line = this.childNodes.line; + line.setAttribute('x1', x); + line.setAttribute('y1', y); + line.setAttribute('x2', viewPoint.x); + line.setAttribute('y2', viewPoint.y); + }, + onPointerDown: function(evt) { + if (this.options.guard(evt)) { return; } + this.trigger('change:start', this, evt); + evt.stopPropagation(); + evt.preventDefault(); + this.options.paper.undelegateEvents(); + this.delegateDocumentEvents(null, evt.data); + }, + onPointerMove: function(evt) { + this.trigger('changing', this, evt); + }, + onPointerUp: function(evt) { + this.undelegateDocumentEvents(); + this.options.paper.delegateEvents(); + this.trigger('change:end', this, evt); + }, + show: function() { + this.el.style.display = ''; + }, + hide: function() { + this.el.style.display = 'none'; + } + }); + + var Segments = ToolView.extend({ + name: 'segments', + precision: .5, + options: { + handleClass: SegmentHandle, + segmentLengthThreshold: 40, + redundancyRemoval: true, + anchor: getAnchor, + snapRadius: 10, + snapHandle: true, + stopPropagation: true + }, + handles: null, + onRender: function() { + this.resetHandles(); + var relatedView = this.relatedView; + var vertices = relatedView.model.vertices(); + vertices.unshift(relatedView.sourcePoint); + vertices.push(relatedView.targetPoint); + for (var i = 0, n = vertices.length; i < n - 1; i++) { + var vertex = vertices[i]; + var nextVertex = vertices[i + 1]; + var handle = this.renderHandle(vertex, nextVertex); + this.simulateRelatedView(handle.el); + this.handles.push(handle); + handle.options.index = i; + } + return this; + }, + renderHandle: function(vertex, nextVertex) { + var this$1 = this; + + var handle = new (this.options.handleClass)({ + paper: this.paper, + scale: this.options.scale, + guard: function (evt) { return this$1.guard(evt); } + }); + handle.render(); + this.updateHandle(handle, vertex, nextVertex); + handle.vel.appendTo(this.el); + this.startHandleListening(handle); + return handle; + }, + update: function() { + this.render(); + return this; + }, + startHandleListening: function(handle) { + this.listenTo(handle, 'change:start', this.onHandleChangeStart); + this.listenTo(handle, 'changing', this.onHandleChanging); + this.listenTo(handle, 'change:end', this.onHandleChangeEnd); + }, + resetHandles: function() { + var handles = this.handles; + this.handles = []; + this.stopListening(); + if (!Array.isArray(handles)) { return; } + for (var i = 0, n = handles.length; i < n; i++) { + handles[i].remove(); + } + }, + shiftHandleIndexes: function(value) { + var handles = this.handles; + for (var i = 0, n = handles.length; i < n; i++) { handles[i].options.index += value; } + }, + resetAnchor: function(type, anchor) { + var relatedModel = this.relatedView.model; + if (anchor) { + relatedModel.prop([type, 'anchor'], anchor, { + rewrite: true, + ui: true, + tool: this.cid + }); + } else { + relatedModel.removeProp([type, 'anchor'], { + ui: true, + tool: this.cid + }); + } + }, + snapHandle: function(handle, position, data) { + + var index = handle.options.index; + var linkView = this.relatedView; + var link = linkView.model; + var vertices = link.vertices(); + var axis = handle.options.axis; + var prev = vertices[index - 2] || data.sourceAnchor; + var next = vertices[index + 1] || data.targetAnchor; + var snapRadius = this.options.snapRadius; + if (Math.abs(position[axis] - prev[axis]) < snapRadius) { + position[axis] = prev[axis]; + } else if (Math.abs(position[axis] - next[axis]) < snapRadius) { + position[axis] = next[axis]; + } + return position; + }, + + onHandleChanging: function(handle, evt) { + + var ref = this; + var options = ref.options; + var data = this.eventData(evt); + var relatedView = this.relatedView; + var paper = relatedView.paper; + var index$1 = handle.options.index - 1; + var normalizedEvent = normalizeEvent(evt); + var coords = paper.snapToGrid(normalizedEvent.clientX, normalizedEvent.clientY); + var position = this.snapHandle(handle, coords.clone(), data); + var axis = handle.options.axis; + var offset = (this.options.snapHandle) ? 0 : (coords[axis] - position[axis]); + var link = relatedView.model; + var vertices = cloneDeep(link.vertices()); + var anchorFn = this.options.anchor; + if (typeof anchorFn !== 'function') { anchorFn = null; } + + var handleIndex = handle.options.index; + + var vertexPoints = [relatedView.sourcePoint.clone() ].concat( vertices, [relatedView.targetPoint.clone()]); + var indexOffset = 0; + + // check if vertex before handle vertex exists + if (handleIndex - 1 >= 0) { + var v1 = vertexPoints[handleIndex - 1]; + var v2 = vertexPoints[handleIndex]; + + var theta = new Line(v1, v2).vector().theta(); + + // check only non-orthogonal segments + if (theta % 90 !== 0) { + vertices.splice(handleIndex - 1, 0, data.originalVertices[handleIndex - 1]); + indexOffset++; + this.shiftHandleIndexes(1); + } + } + + var vertex = vertices[index$1 + indexOffset]; + var nextVertex = vertices[index$1 + 1 + indexOffset]; + + // check if vertex after handle vertex exists + if (handleIndex + 2 < vertexPoints.length) { + var v1$1 = vertexPoints[handleIndex + 1]; + var v2$1 = vertexPoints[handleIndex + 2]; + + var theta$1 = new Line(v1$1, v2$1).vector().theta(); + + // check only non-orthogonal segments + if (theta$1 % 90 !== 0) { + var isSingleVertex = data.originalVertices.length === 1; + var origVIndex = isSingleVertex ? 0 : handleIndex; + var additionalOffset = data.firstHandleShifted && !isSingleVertex ? 1 : 0; + var nextVIndex = 1 + indexOffset; + vertices.splice(handleIndex + nextVIndex, 0, data.originalVertices[origVIndex - additionalOffset]); + } + } + + // First Segment + var sourceView = relatedView.sourceView; + var sourceBBox = relatedView.sourceBBox; + var changeSourceAnchor = false; + var deleteSourceAnchor = false; + if (!vertex) { + vertex = relatedView.sourceAnchor.toJSON(); + vertex[axis] = position[axis]; + if (sourceBBox.containsPoint(vertex)) { + vertex[axis] = position[axis]; + changeSourceAnchor = true; + } else { + // we left the area of the source magnet for the first time + vertices.unshift(vertex); + this.shiftHandleIndexes(1); + data.firstHandleShifted = true; + deleteSourceAnchor = true; + } + } else if (index$1 === 0) { + if (sourceBBox.containsPoint(vertex)) { + vertices.shift(); + this.shiftHandleIndexes(-1); + changeSourceAnchor = true; + } else { + vertex[axis] = position[axis]; + deleteSourceAnchor = true; + } + } else { + vertex[axis] = position[axis]; + } + + if (anchorFn && sourceView) { + if (changeSourceAnchor) { + var sourceAnchorPosition = data.sourceAnchor.clone(); + sourceAnchorPosition[axis] = position[axis]; + var sourceAnchor = anchorFn.call(relatedView, sourceAnchorPosition, sourceView, relatedView.sourceMagnet || sourceView.el, 'source', relatedView); + this.resetAnchor('source', sourceAnchor); + } + if (deleteSourceAnchor) { + this.resetAnchor('source', data.sourceAnchorDef); + } + } + + // Last segment + var targetView = relatedView.targetView; + var targetBBox = relatedView.targetBBox; + var changeTargetAnchor = false; + var deleteTargetAnchor = false; + if (!nextVertex) { + nextVertex = relatedView.targetAnchor.toJSON(); + nextVertex[axis] = position[axis]; + if (targetBBox.containsPoint(nextVertex)) { + changeTargetAnchor = true; + } else { + // we left the area of the target magnet for the first time + vertices.push(nextVertex); + deleteTargetAnchor = true; + } + } else if (index$1 === vertices.length - 2) { + if (targetBBox.containsPoint(nextVertex)) { + vertices.pop(); + changeTargetAnchor = true; + } else { + nextVertex[axis] = position[axis]; + deleteTargetAnchor = true; + } + } else { + nextVertex[axis] = position[axis]; + } + + if (anchorFn && targetView) { + if (changeTargetAnchor) { + var targetAnchorPosition = data.targetAnchor.clone(); + targetAnchorPosition[axis] = position[axis]; + var targetAnchor = anchorFn.call(relatedView, targetAnchorPosition, targetView, relatedView.targetMagnet || targetView.el, 'target', relatedView); + this.resetAnchor('target', targetAnchor); + } + if (deleteTargetAnchor) { + this.resetAnchor('target', data.targetAnchorDef); + } + } + link.vertices(vertices, { ui: true, tool: this.cid }); + this.updateHandle(handle, vertex, nextVertex, offset); + if (!options.stopPropagation) { relatedView.notifyPointermove(normalizedEvent, coords.x, coords.y); } + }, + onHandleChangeStart: function(handle, evt) { + var ref = this; + var options = ref.options; + var handles = ref.handles; + var linkView = ref.relatedView; + var model = linkView.model; + var paper = linkView.paper; + var index$1 = handle.options.index; + if (!Array.isArray(handles)) { return; } + for (var i = 0, n = handles.length; i < n; i++) { + if (i !== index$1) { handles[i].hide(); } + } + this.focus(); + this.eventData(evt, { + sourceAnchor: linkView.sourceAnchor.clone(), + targetAnchor: linkView.targetAnchor.clone(), + sourceAnchorDef: clone(model.prop(['source', 'anchor'])), + targetAnchorDef: clone(model.prop(['target', 'anchor'])), + originalVertices: cloneDeep(model.vertices()), + firstHandleShifted: false + }); + model.startBatch('segment-move', { ui: true, tool: this.cid }); + if (!options.stopPropagation) { linkView.notifyPointerdown.apply(linkView, paper.getPointerArgs(evt)); } + }, + onHandleChangeEnd: function(_handle, evt) { + var ref= this; + var options = ref.options; + var linkView = ref.relatedView; + var paper = linkView.paper; + var model = linkView.model; + if (options.redundancyRemoval) { + linkView.removeRedundantLinearVertices({ ui: true, tool: this.cid }); + } + var normalizedEvent = normalizeEvent(evt); + var coords = paper.snapToGrid(normalizedEvent.clientX, normalizedEvent.clientY); + this.render(); + this.blur(); + model.stopBatch('segment-move', { ui: true, tool: this.cid }); + if (!options.stopPropagation) { linkView.notifyPointerup(normalizedEvent, coords.x, coords.y); } + linkView.checkMouseleave(normalizedEvent); + }, + updateHandle: function(handle, vertex, nextVertex, offset) { + var vertical = Math.abs(vertex.x - nextVertex.x) < this.precision; + var horizontal = Math.abs(vertex.y - nextVertex.y) < this.precision; + if (vertical || horizontal) { + var segmentLine = new Line(vertex, nextVertex); + var length = segmentLine.length(); + if (length < this.options.segmentLengthThreshold) { + handle.hide(); + } else { + var position = segmentLine.midpoint(); + var axis = (vertical) ? 'x' : 'y'; + position[axis] += offset || 0; + var angle = segmentLine.vector().vectorAngle(new Point(1, 0)); + handle.position(position.x, position.y, angle, this.relatedView); + handle.show(); + handle.options.axis = axis; + } + } else { + handle.hide(); + } + }, + onRemove: function() { + this.resetHandles(); + } + }, { + SegmentHandle: SegmentHandle // keep as class property + }); + + // End Markers + var Arrowhead = ToolView.extend({ + tagName: 'path', + xAxisVector: new Point(1, 0), + events: { + mousedown: 'onPointerDown', + touchstart: 'onPointerDown' + }, + documentEvents: { + mousemove: 'onPointerMove', + touchmove: 'onPointerMove', + mouseup: 'onPointerUp', + touchend: 'onPointerUp', + touchcancel: 'onPointerUp' + }, + options: { + scale: null + }, + onRender: function() { + this.update(); + }, + update: function() { + var ratio = this.ratio; + var view = this.relatedView; + var tangent = view.getTangentAtRatio(ratio); + var position, angle; + if (tangent) { + position = tangent.start; + angle = tangent.vector().vectorAngle(this.xAxisVector) || 0; + } else { + position = view.getPointAtRatio(ratio); + angle = 0; + } + if (!position) { return this; } + var matrix = V.createSVGMatrix().translate(position.x, position.y).rotate(angle); + var ref = this.options; + var scale = ref.scale; + if (scale) { matrix = matrix.scale(scale); } + this.vel.transform(matrix, { absolute: true }); + return this; + }, + onPointerDown: function(evt) { + if (this.guard(evt)) { return; } + evt.stopPropagation(); + evt.preventDefault(); + var relatedView = this.relatedView; + relatedView.model.startBatch('arrowhead-move', { ui: true, tool: this.cid }); + if (relatedView.can('arrowheadMove')) { + relatedView.startArrowheadMove(this.arrowheadType); + this.delegateDocumentEvents(); + relatedView.paper.undelegateEvents(); + } + this.focus(); + this.el.style.pointerEvents = 'none'; + }, + onPointerMove: function(evt) { + var normalizedEvent = normalizeEvent(evt); + var coords = this.paper.snapToGrid(normalizedEvent.clientX, normalizedEvent.clientY); + this.relatedView.pointermove(normalizedEvent, coords.x, coords.y); + }, + onPointerUp: function(evt) { + this.undelegateDocumentEvents(); + var relatedView = this.relatedView; + var paper = relatedView.paper; + var normalizedEvent = normalizeEvent(evt); + var coords = paper.snapToGrid(normalizedEvent.clientX, normalizedEvent.clientY); + relatedView.pointerup(normalizedEvent, coords.x, coords.y); + paper.delegateEvents(); + this.blur(); + this.el.style.pointerEvents = ''; + relatedView.model.stopBatch('arrowhead-move', { ui: true, tool: this.cid }); + } + }); + + var TargetArrowhead = Arrowhead.extend({ + name: 'target-arrowhead', + ratio: 1, + arrowheadType: 'target', + attributes: { + 'd': 'M -10 -8 10 0 -10 8 Z', + 'fill': '#33334F', + 'stroke': '#FFFFFF', + 'stroke-width': 2, + 'cursor': 'move', + 'class': 'target-arrowhead' + } + }); + + var SourceArrowhead = Arrowhead.extend({ + name: 'source-arrowhead', + ratio: 0, + arrowheadType: 'source', + attributes: { + 'd': 'M 10 -8 -10 0 10 8 Z', + 'fill': '#33334F', + 'stroke': '#FFFFFF', + 'stroke-width': 2, + 'cursor': 'move', + 'class': 'source-arrowhead' + } + }); + + var Boundary = ToolView.extend({ + name: 'boundary', + tagName: 'rect', + options: { + padding: 10, + useModelGeometry: false, + }, + attributes: { + 'fill': 'none', + 'stroke': '#33334F', + 'stroke-width': .5, + 'stroke-dasharray': '5, 5', + 'pointer-events': 'none' + }, + onRender: function() { + this.update(); + }, + update: function() { + var ref = this; + var view = ref.relatedView; + var options = ref.options; + var vel = ref.vel; + var useModelGeometry = options.useModelGeometry; + var rotate = options.rotate; + var padding = normalizeSides(options.padding); + var bbox = getViewBBox(view, useModelGeometry).moveAndExpand({ + x: -padding.left, + y: -padding.top, + width: padding.left + padding.right, + height: padding.top + padding.bottom + }); + var model = view.model; + if (model.isElement()) { + var angle = model.angle(); + if (angle) { + if (rotate) { + var origin = model.getBBox().center(); + vel.rotate(angle, origin.x, origin.y, { absolute: true }); + } else { + bbox = bbox.bbox(angle); + } + } + } + vel.attr(bbox.toJSON()); + return this; + } + }); + + var Anchor = ToolView.extend({ + tagName: 'g', + type: null, + children: [{ + tagName: 'circle', + selector: 'anchor', + attributes: { + 'cursor': 'pointer' + } + }, { + tagName: 'rect', + selector: 'area', + attributes: { + 'pointer-events': 'none', + 'fill': 'none', + 'stroke': '#33334F', + 'stroke-dasharray': '2,4', + 'rx': 5, + 'ry': 5 + } + }], + events: { + mousedown: 'onPointerDown', + touchstart: 'onPointerDown', + dblclick: 'onPointerDblClick', + dbltap: 'onPointerDblClick' + }, + documentEvents: { + mousemove: 'onPointerMove', + touchmove: 'onPointerMove', + mouseup: 'onPointerUp', + touchend: 'onPointerUp', + touchcancel: 'onPointerUp' + }, + options: { + snap: snapAnchor, + anchor: getAnchor, + scale: null, + resetAnchor: true, + customAnchorAttributes: { + 'stroke-width': 4, + 'stroke': '#33334F', + 'fill': '#FFFFFF', + 'r': 5 + }, + defaultAnchorAttributes: { + 'stroke-width': 2, + 'stroke': '#FFFFFF', + 'fill': '#33334F', + 'r': 6 + }, + areaPadding: 6, + snapRadius: 10, + restrictArea: true, + redundancyRemoval: true + }, + onRender: function() { + this.renderChildren(); + this.toggleArea(false); + this.update(); + }, + update: function() { + var type = this.type; + var relatedView = this.relatedView; + var view = relatedView.getEndView(type); + if (view) { + this.updateAnchor(); + this.updateArea(); + this.el.style.display = ''; + } else { + this.el.style.display = 'none'; + } + return this; + }, + updateAnchor: function() { + var childNodes = this.childNodes; + if (!childNodes) { return; } + var anchorNode = childNodes.anchor; + if (!anchorNode) { return; } + var relatedView = this.relatedView; + var type = this.type; + var position = relatedView.getEndAnchor(type); + var options = this.options; + var customAnchor = relatedView.model.prop([type, 'anchor']); + var transformString = "translate(" + (position.x) + "," + (position.y) + ")"; + if (options.scale) { + transformString += " scale(" + (options.scale) + ")"; + } + anchorNode.setAttribute('transform', transformString); + var anchorAttributes = (customAnchor) ? options.customAnchorAttributes : options.defaultAnchorAttributes; + for (var attrName in anchorAttributes) { + anchorNode.setAttribute(attrName, anchorAttributes[attrName]); + } + }, + updateArea: function() { + var childNodes = this.childNodes; + if (!childNodes) { return; } + var areaNode = childNodes.area; + if (!areaNode) { return; } + var relatedView = this.relatedView; + var type = this.type; + var view = relatedView.getEndView(type); + var model = view.model; + var magnet = relatedView.getEndMagnet(type); + var padding = this.options.areaPadding; + if (!isFinite(padding)) { padding = 0; } + var bbox, angle, center; + if (view.isNodeConnection(magnet)) { + bbox = view.getNodeBBox(magnet); + angle = 0; + center = bbox.center(); + } else { + bbox = view.getNodeUnrotatedBBox(magnet); + angle = model.angle(); + center = bbox.center(); + if (angle) { center.rotate(model.getBBox().center(), -angle); } + // TODO: get the link's magnet rotation into account + } + bbox.inflate(padding); + areaNode.setAttribute('x', -bbox.width / 2); + areaNode.setAttribute('y', -bbox.height / 2); + areaNode.setAttribute('width', bbox.width); + areaNode.setAttribute('height', bbox.height); + areaNode.setAttribute('transform', 'translate(' + center.x + ',' + center.y + ') rotate(' + angle + ')'); + }, + toggleArea: function(visible) { + var childNodes = this.childNodes; + if (!childNodes) { return; } + var areaNode = childNodes.area; + if (!areaNode) { return; } + areaNode.style.display = (visible) ? '' : 'none'; + }, + onPointerDown: function(evt) { + if (this.guard(evt)) { return; } + evt.stopPropagation(); + evt.preventDefault(); + this.paper.undelegateEvents(); + this.delegateDocumentEvents(); + this.focus(); + this.toggleArea(this.options.restrictArea); + this.relatedView.model.startBatch('anchor-move', { ui: true, tool: this.cid }); + }, + resetAnchor: function(anchor) { + var type = this.type; + var relatedModel = this.relatedView.model; + if (anchor) { + relatedModel.prop([type, 'anchor'], anchor, { + rewrite: true, + ui: true, + tool: this.cid + }); + } else { + relatedModel.removeProp([type, 'anchor'], { + ui: true, + tool: this.cid + }); + } + }, + onPointerMove: function(evt) { + + var relatedView = this.relatedView; + var type = this.type; + var view = relatedView.getEndView(type); + var model = view.model; + var magnet = relatedView.getEndMagnet(type); + var normalizedEvent = normalizeEvent(evt); + var coords = this.paper.clientToLocalPoint(normalizedEvent.clientX, normalizedEvent.clientY); + var snapFn = this.options.snap; + if (typeof snapFn === 'function') { + coords = snapFn.call(relatedView, coords, view, magnet, type, relatedView, this); + coords = new Point(coords); + } + + if (this.options.restrictArea) { + if (view.isNodeConnection(magnet)) { + // snap coords to the link's connection + var pointAtConnection = view.getClosestPoint(coords); + if (pointAtConnection) { coords = pointAtConnection; } + } else { + // snap coords within node bbox + var bbox = view.getNodeUnrotatedBBox(magnet); + var angle = model.angle(); + var origin = model.getBBox().center(); + var rotatedCoords = coords.clone().rotate(origin, angle); + if (!bbox.containsPoint(rotatedCoords)) { + coords = bbox.pointNearestToPoint(rotatedCoords).rotate(origin, -angle); + } + } + } + + var anchor; + var anchorFn = this.options.anchor; + if (typeof anchorFn === 'function') { + anchor = anchorFn.call(relatedView, coords, view, magnet, type, relatedView); + } + + this.resetAnchor(anchor); + this.update(); + }, + + onPointerUp: function(evt) { + this.paper.delegateEvents(); + this.undelegateDocumentEvents(); + this.blur(); + this.toggleArea(false); + var linkView = this.relatedView; + if (this.options.redundancyRemoval) { linkView.removeRedundantLinearVertices({ ui: true, tool: this.cid }); } + linkView.model.stopBatch('anchor-move', { ui: true, tool: this.cid }); + }, + + onPointerDblClick: function() { + var anchor = this.options.resetAnchor; + if (anchor === false) { return; } // reset anchor disabled + if (anchor === true) { anchor = null; } // remove the current anchor + this.resetAnchor(cloneDeep(anchor)); + this.update(); + } + }); + + var SourceAnchor = Anchor.extend({ + name: 'source-anchor', + type: 'source' + }); + + var TargetAnchor = Anchor.extend({ + name: 'target-anchor', + type: 'target' + }); + + var Button = ToolView.extend({ + name: 'button', + events: { + 'mousedown': 'onPointerDown', + 'touchstart': 'onPointerDown' + }, + options: { + distance: 0, + offset: 0, + scale: null, + rotate: false + }, + onRender: function() { + this.renderChildren(this.options.markup); + this.update(); + }, + update: function() { + this.position(); + return this; + }, + position: function() { + var ref = this; + var vel = ref.vel; + vel.transform(this.getCellMatrix(), { absolute: true }); + }, + getCellMatrix: function getCellMatrix() { + return this.relatedView.model.isLink() ? this.getLinkMatrix() : this.getElementMatrix(); + }, + getElementMatrix: function getElementMatrix() { + var ref = this; + var view = ref.relatedView; + var options = ref.options; + var x = options.x; if ( x === void 0 ) x = 0; + var y = options.y; if ( y === void 0 ) y = 0; + var offset = options.offset; if ( offset === void 0 ) offset = {}; + var useModelGeometry = options.useModelGeometry; + var rotate = options.rotate; + var scale = options.scale; + var bbox = getViewBBox(view, useModelGeometry); + var angle = view.model.angle(); + if (!rotate) { bbox = bbox.bbox(angle); } + var offsetX = offset.x; if ( offsetX === void 0 ) offsetX = 0; + var offsetY = offset.y; if ( offsetY === void 0 ) offsetY = 0; + if (isPercentage(x)) { + x = parseFloat(x) / 100 * bbox.width; + } else if (isCalcAttribute(x)) { + x = Number(evalCalcAttribute(x, bbox)); + } + if (isPercentage(y)) { + y = parseFloat(y) / 100 * bbox.height; + } else if (isCalcAttribute(y)) { + y = Number(evalCalcAttribute(y, bbox)); + } + var matrix = V.createSVGMatrix().translate(bbox.x + bbox.width / 2, bbox.y + bbox.height / 2); + if (rotate) { matrix = matrix.rotate(angle); } + matrix = matrix.translate(x + offsetX - bbox.width / 2, y + offsetY - bbox.height / 2); + if (scale) { matrix = matrix.scale(scale); } + return matrix; + }, + getLinkMatrix: function getLinkMatrix() { + var ref = this; + var view = ref.relatedView; + var options = ref.options; + var offset = options.offset; if ( offset === void 0 ) offset = 0; + var distance = options.distance; if ( distance === void 0 ) distance = 0; + var rotate = options.rotate; + var scale = options.scale; + var tangent, position, angle; + if (isPercentage(distance)) { + tangent = view.getTangentAtRatio(parseFloat(distance) / 100); + } else { + tangent = view.getTangentAtLength(distance); + } + if (tangent) { + position = tangent.start; + angle = tangent.vector().vectorAngle(new Point(1, 0)) || 0; + } else { + position = view.getConnection().start; + angle = 0; + } + var matrix = V.createSVGMatrix() + .translate(position.x, position.y) + .rotate(angle) + .translate(0, offset); + if (!rotate) { matrix = matrix.rotate(-angle); } + if (scale) { matrix = matrix.scale(scale); } + return matrix; + }, + onPointerDown: function(evt) { + if (this.guard(evt)) { return; } + evt.stopPropagation(); + evt.preventDefault(); + var actionFn = this.options.action; + if (typeof actionFn === 'function') { + actionFn.call(this.relatedView, evt, this.relatedView, this); + } + } + }); + + var Remove = Button.extend({ + children: [{ + tagName: 'circle', + selector: 'button', + attributes: { + 'r': 7, + 'fill': '#FF1D00', + 'cursor': 'pointer' + } + }, { + tagName: 'path', + selector: 'icon', + attributes: { + 'd': 'M -3 -3 3 3 M -3 3 3 -3', + 'fill': 'none', + 'stroke': '#FFFFFF', + 'stroke-width': 2, + 'pointer-events': 'none' + } + }], + options: { + distance: 60, + offset: 0, + action: function(evt, view, tool) { + view.model.remove({ ui: true, tool: tool.cid }); + } + } + }); + + var Connect = Button.extend({ + name: 'connect', + documentEvents: { + mousemove: 'drag', + touchmove: 'drag', + mouseup: 'dragend', + touchend: 'dragend', + touchcancel: 'dragend' + }, + children: [{ + tagName: 'circle', + selector: 'button', + attributes: { + 'r': 7, + 'fill': '#333333', + 'cursor': 'pointer' + } + }, { + tagName: 'path', + selector: 'icon', + attributes: { + 'd': 'M -4 -1 L 0 -1 L 0 -4 L 4 0 L 0 4 0 1 -4 1 z', + 'fill': '#FFFFFF', + 'stroke': 'none', + 'stroke-width': 2, + 'pointer-events': 'none' + } + }], + options: { + distance: 80, + offset: 0, + magnet: function (view) { return view.el; }, + action: function (evt, _view, tool) { return tool.dragstart(evt); }, + }, + getMagnetNode: function() { + var assign; + + var ref = this; + var options = ref.options; + var relatedView = ref.relatedView; + var magnet = options.magnet; + var magnetNode; + switch (typeof magnet) { + case 'function': { + magnetNode = magnet.call(this, relatedView, this); + break; + } + case 'string': { + (assign = relatedView.findBySelector(magnet), magnetNode = assign[0]); + break; + } + default: { + magnetNode = magnet; + break; + } + } + if (!magnetNode) { magnetNode = relatedView.el; } + if (magnetNode instanceof SVGElement) { return magnetNode; } + throw new Error('Connect: magnet must be an SVGElement'); + }, + dragstart: function(evt) { + var ref = this; + var paper = ref.paper; + var relatedView = ref.relatedView; + var normalizedEvent = normalizeEvent(evt); + var ref$1 = paper.clientToLocalPoint(normalizedEvent.clientX, normalizedEvent.clientY); + var x = ref$1.x; + var y = ref$1.y; + relatedView.dragLinkStart(normalizedEvent, this.getMagnetNode(), x, y); + paper.undelegateEvents(); + this.delegateDocumentEvents(null, normalizedEvent.data); + this.focus(); + }, + drag: function(evt) { + var ref = this; + var paper = ref.paper; + var relatedView = ref.relatedView; + var normalizedEvent = normalizeEvent(evt); + var ref$1 = paper.snapToGrid(normalizedEvent.clientX, normalizedEvent.clientY); + var x = ref$1.x; + var y = ref$1.y; + relatedView.dragLink(normalizedEvent, x, y); + }, + dragend: function(evt) { + var ref = this; + var paper = ref.paper; + var relatedView = ref.relatedView; + var normalizedEvent = normalizeEvent(evt); + var ref$1 = paper.snapToGrid(normalizedEvent.clientX, normalizedEvent.clientY); + var x = ref$1.x; + var y = ref$1.y; + relatedView.dragLinkEnd(normalizedEvent, x, y); + this.undelegateDocumentEvents(); + paper.delegateEvents(); + this.blur(); + relatedView.checkMouseleave(normalizedEvent); + } + }); + + var HoverConnect = Connect.extend({ + + name: 'hover-connect', + + defaultMarkup: [ + { + tagName: 'circle', + attributes: { + 'r': 7, + 'fill': '#333333', + 'cursor': 'pointer' + } + }, + { + tagName: 'path', + attributes: { + 'd': 'M -4 -1 L 0 -1 L 0 -4 L 4 0 L 0 4 0 1 -4 1 z', + 'fill': '#FFFFFF', + 'stroke': 'none', + 'stroke-width': 2 + } + } + ], + + children: function children() { + var ref = this; + var options = ref.options; + var defaultMarkup = ref.defaultMarkup; + return [ + { + tagName: 'path', + selector: 'track', + attributes: { + 'fill': 'none', + 'stroke': 'transparent', + 'stroke-width': options.trackWidth || 15, + 'cursor': 'pointer' + } + }, + { + tagName: 'g', + selector: 'button', + attributes: { + 'pointer-events': 'none', + 'display': 'none' + }, + children: options.markup || defaultMarkup + } + ]; + }, + + events: Object.assign({ + mousemove: 'onMousemove', + mouseenter: 'onMouseenter', + mouseleave: 'onMouseleave' + }, Connect.prototype.events), + + onRender: function() { + this.renderChildren(); + this.update(); + }, + + trackPath: null, + + update: function update() { + var ref = this; + var childNodes = ref.childNodes; + this.trackPath = this.getTrackPath(); + Connect.prototype.update.apply(this, arguments); + childNodes.track.setAttribute( + 'd', + this.trackPath.serialize() + ); + }, + + position: function position() { + var ref = this; + var el = ref.el; + var childNodes = ref.childNodes; + childNodes.button.setAttribute( + 'transform', + V.matrixToTransformString(this.getButtonMatrix()) + ); + el.setAttribute( + 'transform', + V.matrixToTransformString(this.getTrackMatrix()) + ); + }, + + getButtonMatrix: function getButtonMatrix() { + var ref = this; + var options = ref.options; + var trackPath = ref.trackPath; + var offset = options.offset; if ( offset === void 0 ) offset = 0; + var distance = options.distance; if ( distance === void 0 ) distance = 0; + var rotate = options.rotate; + var scale = options.scale; + var tangent, position, angle; + if (isPercentage(distance)) { + tangent = trackPath.tangentAtRatio(parseFloat(distance) / 100); + } else { + tangent = trackPath.tangentAtLength(distance); + } + if (tangent) { + position = tangent.start; + angle = tangent.vector().vectorAngle(new Point(1, 0)) || 0; + } else { + position = trackPath.start; + angle = 0; + } + var matrix = V.createSVGMatrix() + .translate(position.x, position.y) + .rotate(angle) + .translate(0, offset); + if (!rotate) { matrix = matrix.rotate(-angle); } + if (scale) { matrix = matrix.scale(scale); } + return matrix; + }, + + getTrackPath: function getTrackPath() { + return this.relatedView.getConnection(); + }, + + getTrackMatrix: function getTrackMatrix() { + return V.createSVGMatrix(); + }, + + getTrackRatioFromEvent: function getTrackRatioFromEvent(evt) { + var ref = this; + var relatedView = ref.relatedView; + var trackPath = ref.trackPath; + var localPoint = relatedView.paper.clientToLocalPoint(evt.clientX, evt.clientY); + var trackPoint = V.transformPoint(localPoint, this.getTrackMatrix().inverse()); + return trackPath.closestPointLength(trackPoint); + }, + + canShowButton: function canShowButton() { + // Has been the paper events undelegated? If so, we can't show the button. + // TODO: add a method to the paper to check if the events are delegated. + return $._data(this.paper.el, 'events'); + }, + + showButton: function showButton() { + this.childNodes.button.style.display = 'block'; + }, + + hideButton: function hideButton() { + this.childNodes.button.style.display = ''; + }, + + onMousemove: function onMousemove(evt) { + var ref = this; + var trackPath = ref.trackPath; + if (!trackPath) { return; } + var ref$1 = this; + var options = ref$1.options; + options.distance = this.getTrackRatioFromEvent(evt); + this.position(); + }, + + onMouseenter: function onMouseenter() { + if (!this.canShowButton()) { return; } + this.showButton(); + }, + + onMouseleave: function onMouseleave() { + this.hideButton(); + } + }); + + + + var index$5 = ({ + Vertices: Vertices, + Segments: Segments, + TargetArrowhead: TargetArrowhead, + SourceArrowhead: SourceArrowhead, + Boundary: Boundary, + SourceAnchor: SourceAnchor, + TargetAnchor: TargetAnchor, + Button: Button, + Remove: Remove, + Connect: Connect, + HoverConnect: HoverConnect + }); + + var Control = ToolView.extend({ + tagName: 'g', + children: [{ + tagName: 'circle', + selector: 'handle', + attributes: { + 'cursor': 'pointer', + 'stroke-width': 2, + 'stroke': '#FFFFFF', + 'fill': '#33334F', + 'r': 6 + } + }, { + tagName: 'rect', + selector: 'extras', + attributes: { + 'pointer-events': 'none', + 'fill': 'none', + 'stroke': '#33334F', + 'stroke-dasharray': '2,4', + 'rx': 5, + 'ry': 5 + } + }], + events: { + mousedown: 'onPointerDown', + touchstart: 'onPointerDown', + dblclick: 'onPointerDblClick', + dbltap: 'onPointerDblClick' + }, + documentEvents: { + mousemove: 'onPointerMove', + touchmove: 'onPointerMove', + mouseup: 'onPointerUp', + touchend: 'onPointerUp', + touchcancel: 'onPointerUp' + }, + options: { + handleAttributes: null, + selector: 'root', + padding: 6, + scale: null + }, + + getPosition: function() { + // To be overridden + }, + setPosition: function() { + // To be overridden + }, + resetPosition: function() { + // To be overridden + }, + onRender: function() { + this.renderChildren(); + this.toggleExtras(false); + this.update(); + }, + update: function() { + var ref = this.childNodes; + var handle = ref.handle; + var extras = ref.extras; + if (handle) { + this.updateHandle(handle); + } else { + throw new Error('Control: markup selector `handle` is required'); + } + if (extras) { + this.updateExtras(extras); + } + return this; + }, + updateHandle: function(handleNode) { + var ref = this; + var relatedView = ref.relatedView; + var options = ref.options; + var model = relatedView.model; + var relativePos = this.getPosition(relatedView, this); + var absolutePos = model.getAbsolutePointFromRelative(relativePos); + var handleAttributes = options.handleAttributes; + var scale = options.scale; + var transformString = "translate(" + (absolutePos.x) + "," + (absolutePos.y) + ")"; + if (scale) { + transformString += " scale(" + scale + ")"; + } + handleNode.setAttribute('transform', transformString); + if (handleAttributes) { + for (var attrName in handleAttributes) { + handleNode.setAttribute(attrName, handleAttributes[attrName]); + } + } + }, + updateExtras: function(extrasNode) { + var ref = this; + var relatedView = ref.relatedView; + var options = ref.options; + var ref$1 = this.options; + var selector = ref$1.selector; + if (!selector) { + this.toggleExtras(false); + return; + } + var ref$2 = relatedView.findBySelector(selector); + var magnet = ref$2[0]; + if (!magnet) { throw new Error('Control: invalid selector.'); } + var padding = options.padding; + if (!isFinite(padding)) { padding = 0; } + var bbox = relatedView.getNodeUnrotatedBBox(magnet); + var model = relatedView.model; + var angle = model.angle(); + var center = bbox.center(); + if (angle) { center.rotate(model.getBBox().center(), -angle); } + bbox.inflate(padding); + extrasNode.setAttribute('x', -bbox.width / 2); + extrasNode.setAttribute('y', -bbox.height / 2); + extrasNode.setAttribute('width', bbox.width); + extrasNode.setAttribute('height', bbox.height); + extrasNode.setAttribute('transform', ("translate(" + (center.x) + "," + (center.y) + ") rotate(" + angle + ")")); + }, + toggleExtras: function(visible) { + var ref = this.childNodes; + var extras = ref.extras; + if (!extras) { return; } + extras.style.display = (visible) ? '' : 'none'; + }, + onPointerDown: function(evt) { + var ref = this; + var relatedView = ref.relatedView; + var paper = ref.paper; + if (this.guard(evt)) { return; } + evt.stopPropagation(); + evt.preventDefault(); + paper.undelegateEvents(); + this.delegateDocumentEvents(); + this.focus(); + this.toggleExtras(true); + relatedView.model.startBatch('control-move', { ui: true, tool: this.cid }); + }, + onPointerMove: function(evt) { + var ref = this; + var relatedView = ref.relatedView; + var paper = ref.paper; + var model = relatedView.model; + var ref$1 = normalizeEvent(evt); + var clientX = ref$1.clientX; + var clientY = ref$1.clientY; + var coords = paper.clientToLocalPoint(clientX, clientY); + var relativeCoords = model.getRelativePointFromAbsolute(coords); + this.setPosition(relatedView, relativeCoords, this); + this.update(); + }, + onPointerUp: function(_evt) { + var ref = this; + var relatedView = ref.relatedView; + var paper = ref.paper; + paper.delegateEvents(); + this.undelegateDocumentEvents(); + this.blur(); + this.toggleExtras(false); + relatedView.model.stopBatch('control-move', { ui: true, tool: this.cid }); + }, + onPointerDblClick: function() { + var ref = this; + var relatedView = ref.relatedView; + this.resetPosition(relatedView, this); + this.update(); + } + + }); + + var HoverConnect$1 = HoverConnect.extend({ + + getTrackPath: function getTrackPath() { + var ref = this; + var view = ref.relatedView; + var options = ref.options; + var useModelGeometry = options.useModelGeometry; + var trackPath = options.trackPath; if ( trackPath === void 0 ) trackPath = 'M 0 0 H calc(w) V calc(h) H 0 Z'; + if (typeof trackPath === 'function') { + trackPath = trackPath.call(this, view); + } + if (isCalcAttribute(trackPath)) { + var bbox = getViewBBox(view, useModelGeometry); + trackPath = evalCalcAttribute(trackPath, bbox); + } + return new Path(V.normalizePathData(trackPath)); + }, + + getTrackMatrix: function getTrackMatrix() { + var ref = this; + var view = ref.relatedView; + var options = ref.options; + var useModelGeometry = options.useModelGeometry; + var rotate = options.rotate; + var bbox = getViewBBox(view, useModelGeometry); + var angle = view.model.angle(); + if (!rotate) { bbox = bbox.bbox(angle); } + var matrix = V.createSVGMatrix().translate(bbox.x + bbox.width / 2, bbox.y + bbox.height / 2); + if (rotate) { matrix = matrix.rotate(angle); } + matrix = matrix.translate(- bbox.width / 2, - bbox.height / 2); + return matrix; + } + + }); + + + + var index$6 = ({ + Button: Button, + Remove: Remove, + Connect: Connect, + Boundary: Boundary, + HoverConnect: HoverConnect$1, + Control: Control + }); + + var version = "3.6.5"; + + var Vectorizer = V; + var layout = { PortLabel: PortLabel, Port: Port }; + var setTheme = function(theme, opt) { + + opt = opt || {}; + + invoke(views, 'setTheme', theme, opt); + + // Update the default theme on the view prototype. + View.prototype.defaultTheme = theme; + }; + + var layout$1 = { DirectedGraph: DirectedGraph, PortLabel: PortLabel, Port: Port }; + + // export empty namespaces - backward compatibility + var format$1 = {}; + var ui = {}; + + exports.V = V; + exports.Vectorizer = Vectorizer; + exports.anchors = anchors; + exports.config = config; + exports.connectionPoints = connectionPoints; + exports.connectionStrategies = index$4; + exports.connectors = connectors; + exports.dia = index$2; + exports.elementTools = index$6; + exports.env = env; + exports.format = format$1; + exports.g = g; + exports.highlighters = highlighters; + exports.layout = layout$1; + exports.linkAnchors = linkAnchors; + exports.linkTools = index$5; + exports.mvc = index$1; + exports.routers = routers; + exports.setTheme = setTheme; + exports.shapes = index$3; + exports.ui = ui; + exports.util = index; + exports.version = version; + + Object.defineProperty(exports, '__esModule', { value: true }); + +})); +if (typeof joint !== 'undefined') { var g = joint.g, V = joint.V, Vectorizer = joint.V; } diff --git a/structurizr/js/jquery-3.7.1.min.js b/structurizr/js/jquery-3.7.1.min.js new file mode 100644 index 0000000..7f37b5d --- /dev/null +++ b/structurizr/js/jquery-3.7.1.min.js @@ -0,0 +1,2 @@ +/*! jQuery v3.7.1 | (c) OpenJS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(ie,e){"use strict";var oe=[],r=Object.getPrototypeOf,ae=oe.slice,g=oe.flat?function(e){return oe.flat.call(e)}:function(e){return oe.concat.apply([],e)},s=oe.push,se=oe.indexOf,n={},i=n.toString,ue=n.hasOwnProperty,o=ue.toString,a=o.call(Object),le={},v=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},y=function(e){return null!=e&&e===e.window},C=ie.document,u={type:!0,src:!0,nonce:!0,noModule:!0};function m(e,t,n){var r,i,o=(n=n||C).createElement("script");if(o.text=e,t)for(r in u)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function x(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[i.call(e)]||"object":typeof e}var t="3.7.1",l=/HTML$/i,ce=function(e,t){return new ce.fn.init(e,t)};function c(e){var t=!!e&&"length"in e&&e.length,n=x(e);return!v(e)&&!y(e)&&("array"===n||0===t||"number"==typeof t&&0+~]|"+ge+")"+ge+"*"),x=new RegExp(ge+"|>"),j=new RegExp(g),A=new RegExp("^"+t+"$"),D={ID:new RegExp("^#("+t+")"),CLASS:new RegExp("^\\.("+t+")"),TAG:new RegExp("^("+t+"|[*])"),ATTR:new RegExp("^"+p),PSEUDO:new RegExp("^"+g),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+ge+"*(even|odd|(([+-]|)(\\d*)n|)"+ge+"*(?:([+-]|)"+ge+"*(\\d+)|))"+ge+"*\\)|)","i"),bool:new RegExp("^(?:"+f+")$","i"),needsContext:new RegExp("^"+ge+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+ge+"*((?:-\\d)?\\d*)"+ge+"*\\)|)(?=[^-]|$)","i")},N=/^(?:input|select|textarea|button)$/i,q=/^h\d$/i,L=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,H=/[+~]/,O=new RegExp("\\\\[\\da-fA-F]{1,6}"+ge+"?|\\\\([^\\r\\n\\f])","g"),P=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},M=function(){V()},R=J(function(e){return!0===e.disabled&&fe(e,"fieldset")},{dir:"parentNode",next:"legend"});try{k.apply(oe=ae.call(ye.childNodes),ye.childNodes),oe[ye.childNodes.length].nodeType}catch(e){k={apply:function(e,t){me.apply(e,ae.call(t))},call:function(e){me.apply(e,ae.call(arguments,1))}}}function I(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(V(e),e=e||T,C)){if(11!==p&&(u=L.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return k.call(n,a),n}else if(f&&(a=f.getElementById(i))&&I.contains(e,a)&&a.id===i)return k.call(n,a),n}else{if(u[2])return k.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&e.getElementsByClassName)return k.apply(n,e.getElementsByClassName(i)),n}if(!(h[t+" "]||d&&d.test(t))){if(c=t,f=e,1===p&&(x.test(t)||m.test(t))){(f=H.test(t)&&U(e.parentNode)||e)==e&&le.scope||((s=e.getAttribute("id"))?s=ce.escapeSelector(s):e.setAttribute("id",s=S)),o=(l=Y(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+Q(l[o]);c=l.join(",")}try{return k.apply(n,f.querySelectorAll(c)),n}catch(e){h(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return re(t.replace(ve,"$1"),e,n,r)}function W(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function F(e){return e[S]=!0,e}function $(e){var t=T.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function B(t){return function(e){return fe(e,"input")&&e.type===t}}function _(t){return function(e){return(fe(e,"input")||fe(e,"button"))&&e.type===t}}function z(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&R(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function X(a){return F(function(o){return o=+o,F(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function U(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}function V(e){var t,n=e?e.ownerDocument||e:ye;return n!=T&&9===n.nodeType&&n.documentElement&&(r=(T=n).documentElement,C=!ce.isXMLDoc(T),i=r.matches||r.webkitMatchesSelector||r.msMatchesSelector,r.msMatchesSelector&&ye!=T&&(t=T.defaultView)&&t.top!==t&&t.addEventListener("unload",M),le.getById=$(function(e){return r.appendChild(e).id=ce.expando,!T.getElementsByName||!T.getElementsByName(ce.expando).length}),le.disconnectedMatch=$(function(e){return i.call(e,"*")}),le.scope=$(function(){return T.querySelectorAll(":scope")}),le.cssHas=$(function(){try{return T.querySelector(":has(*,:jqfake)"),!1}catch(e){return!0}}),le.getById?(b.filter.ID=function(e){var t=e.replace(O,P);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&C){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(O,P);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&C){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):t.querySelectorAll(e)},b.find.CLASS=function(e,t){if("undefined"!=typeof t.getElementsByClassName&&C)return t.getElementsByClassName(e)},d=[],$(function(e){var t;r.appendChild(e).innerHTML="",e.querySelectorAll("[selected]").length||d.push("\\["+ge+"*(?:value|"+f+")"),e.querySelectorAll("[id~="+S+"-]").length||d.push("~="),e.querySelectorAll("a#"+S+"+*").length||d.push(".#.+[+~]"),e.querySelectorAll(":checked").length||d.push(":checked"),(t=T.createElement("input")).setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),r.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&d.push(":enabled",":disabled"),(t=T.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||d.push("\\["+ge+"*name"+ge+"*="+ge+"*(?:''|\"\")")}),le.cssHas||d.push(":has"),d=d.length&&new RegExp(d.join("|")),l=function(e,t){if(e===t)return a=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!le.sortDetached&&t.compareDocumentPosition(e)===n?e===T||e.ownerDocument==ye&&I.contains(ye,e)?-1:t===T||t.ownerDocument==ye&&I.contains(ye,t)?1:o?se.call(o,e)-se.call(o,t):0:4&n?-1:1)}),T}for(e in I.matches=function(e,t){return I(e,null,null,t)},I.matchesSelector=function(e,t){if(V(e),C&&!h[t+" "]&&(!d||!d.test(t)))try{var n=i.call(e,t);if(n||le.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){h(t,!0)}return 0":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(O,P),e[3]=(e[3]||e[4]||e[5]||"").replace(O,P),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||I.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&I.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return D.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&j.test(n)&&(t=Y(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(O,P).toLowerCase();return"*"===e?function(){return!0}:function(e){return fe(e,t)}},CLASS:function(e){var t=s[e+" "];return t||(t=new RegExp("(^|"+ge+")"+e+"("+ge+"|$)"))&&s(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=I.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function T(e,n,r){return v(n)?ce.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?ce.grep(e,function(e){return e===n!==r}):"string"!=typeof n?ce.grep(e,function(e){return-1)[^>]*|#([\w-]+))$/;(ce.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||k,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:S.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof ce?t[0]:t,ce.merge(this,ce.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:C,!0)),w.test(r[1])&&ce.isPlainObject(t))for(r in t)v(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=C.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):v(e)?void 0!==n.ready?n.ready(e):e(ce):ce.makeArray(e,this)}).prototype=ce.fn,k=ce(C);var E=/^(?:parents|prev(?:Until|All))/,j={children:!0,contents:!0,next:!0,prev:!0};function A(e,t){while((e=e[t])&&1!==e.nodeType);return e}ce.fn.extend({has:function(e){var t=ce(e,this),n=t.length;return this.filter(function(){for(var e=0;e\x20\t\r\n\f]*)/i,Ce=/^$|^module$|\/(?:java|ecma)script/i;xe=C.createDocumentFragment().appendChild(C.createElement("div")),(be=C.createElement("input")).setAttribute("type","radio"),be.setAttribute("checked","checked"),be.setAttribute("name","t"),xe.appendChild(be),le.checkClone=xe.cloneNode(!0).cloneNode(!0).lastChild.checked,xe.innerHTML="",le.noCloneChecked=!!xe.cloneNode(!0).lastChild.defaultValue,xe.innerHTML="",le.option=!!xe.lastChild;var ke={thead:[1,"","
    "],col:[2,"","
    "],tr:[2,"","
    "],td:[3,"","
    "],_default:[0,"",""]};function Se(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&fe(e,t)?ce.merge([e],n):n}function Ee(e,t){for(var n=0,r=e.length;n",""]);var je=/<|&#?\w+;/;function Ae(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d\s*$/g;function Re(e,t){return fe(e,"table")&&fe(11!==t.nodeType?t:t.firstChild,"tr")&&ce(e).children("tbody")[0]||e}function Ie(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function We(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Fe(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(_.hasData(e)&&(s=_.get(e).events))for(i in _.remove(t,"handle events"),s)for(n=0,r=s[i].length;n").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),C.head.appendChild(r[0])},abort:function(){i&&i()}}});var Jt,Kt=[],Zt=/(=)\?(?=&|$)|\?\?/;ce.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Kt.pop()||ce.expando+"_"+jt.guid++;return this[e]=!0,e}}),ce.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Zt.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Zt.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=v(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Zt,"$1"+r):!1!==e.jsonp&&(e.url+=(At.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||ce.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=ie[r],ie[r]=function(){o=arguments},n.always(function(){void 0===i?ce(ie).removeProp(r):ie[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,Kt.push(r)),o&&v(i)&&i(o[0]),o=i=void 0}),"script"}),le.createHTMLDocument=((Jt=C.implementation.createHTMLDocument("").body).innerHTML="
    ",2===Jt.childNodes.length),ce.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(le.createHTMLDocument?((r=(t=C.implementation.createHTMLDocument("")).createElement("base")).href=C.location.href,t.head.appendChild(r)):t=C),o=!n&&[],(i=w.exec(e))?[t.createElement(i[1])]:(i=Ae([e],t,o),o&&o.length&&ce(o).remove(),ce.merge([],i.childNodes)));var r,i,o},ce.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1").append(ce.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},ce.expr.pseudos.animated=function(t){return ce.grep(ce.timers,function(e){return t===e.elem}).length},ce.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=ce.css(e,"position"),c=ce(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=ce.css(e,"top"),u=ce.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),v(t)&&(t=t.call(e,n,ce.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},ce.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){ce.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===ce.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===ce.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=ce(e).offset()).top+=ce.css(e,"borderTopWidth",!0),i.left+=ce.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-ce.css(r,"marginTop",!0),left:t.left-i.left-ce.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===ce.css(e,"position"))e=e.offsetParent;return e||J})}}),ce.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;ce.fn[t]=function(e){return M(this,function(e,t,n){var r;if(y(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),ce.each(["top","left"],function(e,n){ce.cssHooks[n]=Ye(le.pixelPosition,function(e,t){if(t)return t=Ge(e,n),_e.test(t)?ce(e).position()[n]+"px":t})}),ce.each({Height:"height",Width:"width"},function(a,s){ce.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){ce.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return M(this,function(e,t,n){var r;return y(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?ce.css(e,t,i):ce.style(e,t,n,i)},s,n?e:void 0,n)}})}),ce.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){ce.fn[t]=function(e){return this.on(t,e)}}),ce.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.on("mouseenter",e).on("mouseleave",t||e)}}),ce.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){ce.fn[n]=function(e,t){return 0 + * Copyright OpenJS Foundation and other contributors + * Released under MIT license + * Based on Underscore.js 1.8.3 + * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors + */ +;(function() { + + /** Used as a safe reference for `undefined` in pre-ES5 environments. */ + var undefined; + + /** Used as the semantic version number. */ + var VERSION = '4.17.21'; + + /** Used as the size to enable large array optimizations. */ + var LARGE_ARRAY_SIZE = 200; + + /** Error message constants. */ + var CORE_ERROR_TEXT = 'Unsupported core-js use. Try https://npms.io/search?q=ponyfill.', + FUNC_ERROR_TEXT = 'Expected a function', + INVALID_TEMPL_VAR_ERROR_TEXT = 'Invalid `variable` option passed into `_.template`'; + + /** Used to stand-in for `undefined` hash values. */ + var HASH_UNDEFINED = '__lodash_hash_undefined__'; + + /** Used as the maximum memoize cache size. */ + var MAX_MEMOIZE_SIZE = 500; + + /** Used as the internal argument placeholder. */ + var PLACEHOLDER = '__lodash_placeholder__'; + + /** Used to compose bitmasks for cloning. */ + var CLONE_DEEP_FLAG = 1, + CLONE_FLAT_FLAG = 2, + CLONE_SYMBOLS_FLAG = 4; + + /** Used to compose bitmasks for value comparisons. */ + var COMPARE_PARTIAL_FLAG = 1, + COMPARE_UNORDERED_FLAG = 2; + + /** Used to compose bitmasks for function metadata. */ + var WRAP_BIND_FLAG = 1, + WRAP_BIND_KEY_FLAG = 2, + WRAP_CURRY_BOUND_FLAG = 4, + WRAP_CURRY_FLAG = 8, + WRAP_CURRY_RIGHT_FLAG = 16, + WRAP_PARTIAL_FLAG = 32, + WRAP_PARTIAL_RIGHT_FLAG = 64, + WRAP_ARY_FLAG = 128, + WRAP_REARG_FLAG = 256, + WRAP_FLIP_FLAG = 512; + + /** Used as default options for `_.truncate`. */ + var DEFAULT_TRUNC_LENGTH = 30, + DEFAULT_TRUNC_OMISSION = '...'; + + /** Used to detect hot functions by number of calls within a span of milliseconds. */ + var HOT_COUNT = 800, + HOT_SPAN = 16; + + /** Used to indicate the type of lazy iteratees. */ + var LAZY_FILTER_FLAG = 1, + LAZY_MAP_FLAG = 2, + LAZY_WHILE_FLAG = 3; + + /** Used as references for various `Number` constants. */ + var INFINITY = 1 / 0, + MAX_SAFE_INTEGER = 9007199254740991, + MAX_INTEGER = 1.7976931348623157e+308, + NAN = 0 / 0; + + /** Used as references for the maximum length and index of an array. */ + var MAX_ARRAY_LENGTH = 4294967295, + MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1, + HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1; + + /** Used to associate wrap methods with their bit flags. */ + var wrapFlags = [ + ['ary', WRAP_ARY_FLAG], + ['bind', WRAP_BIND_FLAG], + ['bindKey', WRAP_BIND_KEY_FLAG], + ['curry', WRAP_CURRY_FLAG], + ['curryRight', WRAP_CURRY_RIGHT_FLAG], + ['flip', WRAP_FLIP_FLAG], + ['partial', WRAP_PARTIAL_FLAG], + ['partialRight', WRAP_PARTIAL_RIGHT_FLAG], + ['rearg', WRAP_REARG_FLAG] + ]; + + /** `Object#toString` result references. */ + var argsTag = '[object Arguments]', + arrayTag = '[object Array]', + asyncTag = '[object AsyncFunction]', + boolTag = '[object Boolean]', + dateTag = '[object Date]', + domExcTag = '[object DOMException]', + errorTag = '[object Error]', + funcTag = '[object Function]', + genTag = '[object GeneratorFunction]', + mapTag = '[object Map]', + numberTag = '[object Number]', + nullTag = '[object Null]', + objectTag = '[object Object]', + promiseTag = '[object Promise]', + proxyTag = '[object Proxy]', + regexpTag = '[object RegExp]', + setTag = '[object Set]', + stringTag = '[object String]', + symbolTag = '[object Symbol]', + undefinedTag = '[object Undefined]', + weakMapTag = '[object WeakMap]', + weakSetTag = '[object WeakSet]'; + + var arrayBufferTag = '[object ArrayBuffer]', + dataViewTag = '[object DataView]', + float32Tag = '[object Float32Array]', + float64Tag = '[object Float64Array]', + int8Tag = '[object Int8Array]', + int16Tag = '[object Int16Array]', + int32Tag = '[object Int32Array]', + uint8Tag = '[object Uint8Array]', + uint8ClampedTag = '[object Uint8ClampedArray]', + uint16Tag = '[object Uint16Array]', + uint32Tag = '[object Uint32Array]'; + + /** Used to match empty string literals in compiled template source. */ + var reEmptyStringLeading = /\b__p \+= '';/g, + reEmptyStringMiddle = /\b(__p \+=) '' \+/g, + reEmptyStringTrailing = /(__e\(.*?\)|\b__t\)) \+\n'';/g; + + /** Used to match HTML entities and HTML characters. */ + var reEscapedHtml = /&(?:amp|lt|gt|quot|#39);/g, + reUnescapedHtml = /[&<>"']/g, + reHasEscapedHtml = RegExp(reEscapedHtml.source), + reHasUnescapedHtml = RegExp(reUnescapedHtml.source); + + /** Used to match template delimiters. */ + var reEscape = /<%-([\s\S]+?)%>/g, + reEvaluate = /<%([\s\S]+?)%>/g, + reInterpolate = /<%=([\s\S]+?)%>/g; + + /** Used to match property names within property paths. */ + var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/, + reIsPlainProp = /^\w*$/, + rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g; + + /** + * Used to match `RegExp` + * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns). + */ + var reRegExpChar = /[\\^$.*+?()[\]{}|]/g, + reHasRegExpChar = RegExp(reRegExpChar.source); + + /** Used to match leading whitespace. */ + var reTrimStart = /^\s+/; + + /** Used to match a single whitespace character. */ + var reWhitespace = /\s/; + + /** Used to match wrap detail comments. */ + var reWrapComment = /\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/, + reWrapDetails = /\{\n\/\* \[wrapped with (.+)\] \*/, + reSplitDetails = /,? & /; + + /** Used to match words composed of alphanumeric characters. */ + var reAsciiWord = /[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g; + + /** + * Used to validate the `validate` option in `_.template` variable. + * + * Forbids characters which could potentially change the meaning of the function argument definition: + * - "()," (modification of function parameters) + * - "=" (default value) + * - "[]{}" (destructuring of function parameters) + * - "/" (beginning of a comment) + * - whitespace + */ + var reForbiddenIdentifierChars = /[()=,{}\[\]\/\s]/; + + /** Used to match backslashes in property paths. */ + var reEscapeChar = /\\(\\)?/g; + + /** + * Used to match + * [ES template delimiters](http://ecma-international.org/ecma-262/7.0/#sec-template-literal-lexical-components). + */ + var reEsTemplate = /\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g; + + /** Used to match `RegExp` flags from their coerced string values. */ + var reFlags = /\w*$/; + + /** Used to detect bad signed hexadecimal string values. */ + var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; + + /** Used to detect binary string values. */ + var reIsBinary = /^0b[01]+$/i; + + /** Used to detect host constructors (Safari). */ + var reIsHostCtor = /^\[object .+?Constructor\]$/; + + /** Used to detect octal string values. */ + var reIsOctal = /^0o[0-7]+$/i; + + /** Used to detect unsigned integer values. */ + var reIsUint = /^(?:0|[1-9]\d*)$/; + + /** Used to match Latin Unicode letters (excluding mathematical operators). */ + var reLatin = /[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g; + + /** Used to ensure capturing order of template delimiters. */ + var reNoMatch = /($^)/; + + /** Used to match unescaped characters in compiled string literals. */ + var reUnescapedString = /['\n\r\u2028\u2029\\]/g; + + /** Used to compose unicode character classes. */ + var rsAstralRange = '\\ud800-\\udfff', + rsComboMarksRange = '\\u0300-\\u036f', + reComboHalfMarksRange = '\\ufe20-\\ufe2f', + rsComboSymbolsRange = '\\u20d0-\\u20ff', + rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange, + rsDingbatRange = '\\u2700-\\u27bf', + rsLowerRange = 'a-z\\xdf-\\xf6\\xf8-\\xff', + rsMathOpRange = '\\xac\\xb1\\xd7\\xf7', + rsNonCharRange = '\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf', + rsPunctuationRange = '\\u2000-\\u206f', + rsSpaceRange = ' \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000', + rsUpperRange = 'A-Z\\xc0-\\xd6\\xd8-\\xde', + rsVarRange = '\\ufe0e\\ufe0f', + rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange; + + /** Used to compose unicode capture groups. */ + var rsApos = "['\u2019]", + rsAstral = '[' + rsAstralRange + ']', + rsBreak = '[' + rsBreakRange + ']', + rsCombo = '[' + rsComboRange + ']', + rsDigits = '\\d+', + rsDingbat = '[' + rsDingbatRange + ']', + rsLower = '[' + rsLowerRange + ']', + rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']', + rsFitz = '\\ud83c[\\udffb-\\udfff]', + rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')', + rsNonAstral = '[^' + rsAstralRange + ']', + rsRegional = '(?:\\ud83c[\\udde6-\\uddff]){2}', + rsSurrPair = '[\\ud800-\\udbff][\\udc00-\\udfff]', + rsUpper = '[' + rsUpperRange + ']', + rsZWJ = '\\u200d'; + + /** Used to compose unicode regexes. */ + var rsMiscLower = '(?:' + rsLower + '|' + rsMisc + ')', + rsMiscUpper = '(?:' + rsUpper + '|' + rsMisc + ')', + rsOptContrLower = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?', + rsOptContrUpper = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?', + reOptMod = rsModifier + '?', + rsOptVar = '[' + rsVarRange + ']?', + rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*', + rsOrdLower = '\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])', + rsOrdUpper = '\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])', + rsSeq = rsOptVar + reOptMod + rsOptJoin, + rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq, + rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')'; + + /** Used to match apostrophes. */ + var reApos = RegExp(rsApos, 'g'); + + /** + * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and + * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols). + */ + var reComboMark = RegExp(rsCombo, 'g'); + + /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */ + var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g'); + + /** Used to match complex or compound words. */ + var reUnicodeWord = RegExp([ + rsUpper + '?' + rsLower + '+' + rsOptContrLower + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')', + rsMiscUpper + '+' + rsOptContrUpper + '(?=' + [rsBreak, rsUpper + rsMiscLower, '$'].join('|') + ')', + rsUpper + '?' + rsMiscLower + '+' + rsOptContrLower, + rsUpper + '+' + rsOptContrUpper, + rsOrdUpper, + rsOrdLower, + rsDigits, + rsEmoji + ].join('|'), 'g'); + + /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */ + var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']'); + + /** Used to detect strings that need a more robust regexp to match words. */ + var reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/; + + /** Used to assign default `context` object properties. */ + var contextProps = [ + 'Array', 'Buffer', 'DataView', 'Date', 'Error', 'Float32Array', 'Float64Array', + 'Function', 'Int8Array', 'Int16Array', 'Int32Array', 'Map', 'Math', 'Object', + 'Promise', 'RegExp', 'Set', 'String', 'Symbol', 'TypeError', 'Uint8Array', + 'Uint8ClampedArray', 'Uint16Array', 'Uint32Array', 'WeakMap', + '_', 'clearTimeout', 'isFinite', 'parseInt', 'setTimeout' + ]; + + /** Used to make template sourceURLs easier to identify. */ + var templateCounter = -1; + + /** Used to identify `toStringTag` values of typed arrays. */ + var typedArrayTags = {}; + typedArrayTags[float32Tag] = typedArrayTags[float64Tag] = + typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = + typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = + typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = + typedArrayTags[uint32Tag] = true; + typedArrayTags[argsTag] = typedArrayTags[arrayTag] = + typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = + typedArrayTags[dataViewTag] = typedArrayTags[dateTag] = + typedArrayTags[errorTag] = typedArrayTags[funcTag] = + typedArrayTags[mapTag] = typedArrayTags[numberTag] = + typedArrayTags[objectTag] = typedArrayTags[regexpTag] = + typedArrayTags[setTag] = typedArrayTags[stringTag] = + typedArrayTags[weakMapTag] = false; + + /** Used to identify `toStringTag` values supported by `_.clone`. */ + var cloneableTags = {}; + cloneableTags[argsTag] = cloneableTags[arrayTag] = + cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] = + cloneableTags[boolTag] = cloneableTags[dateTag] = + cloneableTags[float32Tag] = cloneableTags[float64Tag] = + cloneableTags[int8Tag] = cloneableTags[int16Tag] = + cloneableTags[int32Tag] = cloneableTags[mapTag] = + cloneableTags[numberTag] = cloneableTags[objectTag] = + cloneableTags[regexpTag] = cloneableTags[setTag] = + cloneableTags[stringTag] = cloneableTags[symbolTag] = + cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] = + cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true; + cloneableTags[errorTag] = cloneableTags[funcTag] = + cloneableTags[weakMapTag] = false; + + /** Used to map Latin Unicode letters to basic Latin letters. */ + var deburredLetters = { + // Latin-1 Supplement block. + '\xc0': 'A', '\xc1': 'A', '\xc2': 'A', '\xc3': 'A', '\xc4': 'A', '\xc5': 'A', + '\xe0': 'a', '\xe1': 'a', '\xe2': 'a', '\xe3': 'a', '\xe4': 'a', '\xe5': 'a', + '\xc7': 'C', '\xe7': 'c', + '\xd0': 'D', '\xf0': 'd', + '\xc8': 'E', '\xc9': 'E', '\xca': 'E', '\xcb': 'E', + '\xe8': 'e', '\xe9': 'e', '\xea': 'e', '\xeb': 'e', + '\xcc': 'I', '\xcd': 'I', '\xce': 'I', '\xcf': 'I', + '\xec': 'i', '\xed': 'i', '\xee': 'i', '\xef': 'i', + '\xd1': 'N', '\xf1': 'n', + '\xd2': 'O', '\xd3': 'O', '\xd4': 'O', '\xd5': 'O', '\xd6': 'O', '\xd8': 'O', + '\xf2': 'o', '\xf3': 'o', '\xf4': 'o', '\xf5': 'o', '\xf6': 'o', '\xf8': 'o', + '\xd9': 'U', '\xda': 'U', '\xdb': 'U', '\xdc': 'U', + '\xf9': 'u', '\xfa': 'u', '\xfb': 'u', '\xfc': 'u', + '\xdd': 'Y', '\xfd': 'y', '\xff': 'y', + '\xc6': 'Ae', '\xe6': 'ae', + '\xde': 'Th', '\xfe': 'th', + '\xdf': 'ss', + // Latin Extended-A block. + '\u0100': 'A', '\u0102': 'A', '\u0104': 'A', + '\u0101': 'a', '\u0103': 'a', '\u0105': 'a', + '\u0106': 'C', '\u0108': 'C', '\u010a': 'C', '\u010c': 'C', + '\u0107': 'c', '\u0109': 'c', '\u010b': 'c', '\u010d': 'c', + '\u010e': 'D', '\u0110': 'D', '\u010f': 'd', '\u0111': 'd', + '\u0112': 'E', '\u0114': 'E', '\u0116': 'E', '\u0118': 'E', '\u011a': 'E', + '\u0113': 'e', '\u0115': 'e', '\u0117': 'e', '\u0119': 'e', '\u011b': 'e', + '\u011c': 'G', '\u011e': 'G', '\u0120': 'G', '\u0122': 'G', + '\u011d': 'g', '\u011f': 'g', '\u0121': 'g', '\u0123': 'g', + '\u0124': 'H', '\u0126': 'H', '\u0125': 'h', '\u0127': 'h', + '\u0128': 'I', '\u012a': 'I', '\u012c': 'I', '\u012e': 'I', '\u0130': 'I', + '\u0129': 'i', '\u012b': 'i', '\u012d': 'i', '\u012f': 'i', '\u0131': 'i', + '\u0134': 'J', '\u0135': 'j', + '\u0136': 'K', '\u0137': 'k', '\u0138': 'k', + '\u0139': 'L', '\u013b': 'L', '\u013d': 'L', '\u013f': 'L', '\u0141': 'L', + '\u013a': 'l', '\u013c': 'l', '\u013e': 'l', '\u0140': 'l', '\u0142': 'l', + '\u0143': 'N', '\u0145': 'N', '\u0147': 'N', '\u014a': 'N', + '\u0144': 'n', '\u0146': 'n', '\u0148': 'n', '\u014b': 'n', + '\u014c': 'O', '\u014e': 'O', '\u0150': 'O', + '\u014d': 'o', '\u014f': 'o', '\u0151': 'o', + '\u0154': 'R', '\u0156': 'R', '\u0158': 'R', + '\u0155': 'r', '\u0157': 'r', '\u0159': 'r', + '\u015a': 'S', '\u015c': 'S', '\u015e': 'S', '\u0160': 'S', + '\u015b': 's', '\u015d': 's', '\u015f': 's', '\u0161': 's', + '\u0162': 'T', '\u0164': 'T', '\u0166': 'T', + '\u0163': 't', '\u0165': 't', '\u0167': 't', + '\u0168': 'U', '\u016a': 'U', '\u016c': 'U', '\u016e': 'U', '\u0170': 'U', '\u0172': 'U', + '\u0169': 'u', '\u016b': 'u', '\u016d': 'u', '\u016f': 'u', '\u0171': 'u', '\u0173': 'u', + '\u0174': 'W', '\u0175': 'w', + '\u0176': 'Y', '\u0177': 'y', '\u0178': 'Y', + '\u0179': 'Z', '\u017b': 'Z', '\u017d': 'Z', + '\u017a': 'z', '\u017c': 'z', '\u017e': 'z', + '\u0132': 'IJ', '\u0133': 'ij', + '\u0152': 'Oe', '\u0153': 'oe', + '\u0149': "'n", '\u017f': 's' + }; + + /** Used to map characters to HTML entities. */ + var htmlEscapes = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + "'": ''' + }; + + /** Used to map HTML entities to characters. */ + var htmlUnescapes = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + ''': "'" + }; + + /** Used to escape characters for inclusion in compiled string literals. */ + var stringEscapes = { + '\\': '\\', + "'": "'", + '\n': 'n', + '\r': 'r', + '\u2028': 'u2028', + '\u2029': 'u2029' + }; + + /** Built-in method references without a dependency on `root`. */ + var freeParseFloat = parseFloat, + freeParseInt = parseInt; + + /** Detect free variable `global` from Node.js. */ + var freeGlobal = typeof global == 'object' && global && global.Object === Object && global; + + /** Detect free variable `self`. */ + var freeSelf = typeof self == 'object' && self && self.Object === Object && self; + + /** Used as a reference to the global object. */ + var root = freeGlobal || freeSelf || Function('return this')(); + + /** Detect free variable `exports`. */ + var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; + + /** Detect free variable `module`. */ + var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module; + + /** Detect the popular CommonJS extension `module.exports`. */ + var moduleExports = freeModule && freeModule.exports === freeExports; + + /** Detect free variable `process` from Node.js. */ + var freeProcess = moduleExports && freeGlobal.process; + + /** Used to access faster Node.js helpers. */ + var nodeUtil = (function() { + try { + // Use `util.types` for Node.js 10+. + var types = freeModule && freeModule.require && freeModule.require('util').types; + + if (types) { + return types; + } + + // Legacy `process.binding('util')` for Node.js < 10. + return freeProcess && freeProcess.binding && freeProcess.binding('util'); + } catch (e) {} + }()); + + /* Node.js helper references. */ + var nodeIsArrayBuffer = nodeUtil && nodeUtil.isArrayBuffer, + nodeIsDate = nodeUtil && nodeUtil.isDate, + nodeIsMap = nodeUtil && nodeUtil.isMap, + nodeIsRegExp = nodeUtil && nodeUtil.isRegExp, + nodeIsSet = nodeUtil && nodeUtil.isSet, + nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray; + + /*--------------------------------------------------------------------------*/ + + /** + * A faster alternative to `Function#apply`, this function invokes `func` + * with the `this` binding of `thisArg` and the arguments of `args`. + * + * @private + * @param {Function} func The function to invoke. + * @param {*} thisArg The `this` binding of `func`. + * @param {Array} args The arguments to invoke `func` with. + * @returns {*} Returns the result of `func`. + */ + function apply(func, thisArg, args) { + switch (args.length) { + case 0: return func.call(thisArg); + case 1: return func.call(thisArg, args[0]); + case 2: return func.call(thisArg, args[0], args[1]); + case 3: return func.call(thisArg, args[0], args[1], args[2]); + } + return func.apply(thisArg, args); + } + + /** + * A specialized version of `baseAggregator` for arrays. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} setter The function to set `accumulator` values. + * @param {Function} iteratee The iteratee to transform keys. + * @param {Object} accumulator The initial aggregated object. + * @returns {Function} Returns `accumulator`. + */ + function arrayAggregator(array, setter, iteratee, accumulator) { + var index = -1, + length = array == null ? 0 : array.length; + + while (++index < length) { + var value = array[index]; + setter(accumulator, value, iteratee(value), array); + } + return accumulator; + } + + /** + * A specialized version of `_.forEach` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns `array`. + */ + function arrayEach(array, iteratee) { + var index = -1, + length = array == null ? 0 : array.length; + + while (++index < length) { + if (iteratee(array[index], index, array) === false) { + break; + } + } + return array; + } + + /** + * A specialized version of `_.forEachRight` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns `array`. + */ + function arrayEachRight(array, iteratee) { + var length = array == null ? 0 : array.length; + + while (length--) { + if (iteratee(array[length], length, array) === false) { + break; + } + } + return array; + } + + /** + * A specialized version of `_.every` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false`. + */ + function arrayEvery(array, predicate) { + var index = -1, + length = array == null ? 0 : array.length; + + while (++index < length) { + if (!predicate(array[index], index, array)) { + return false; + } + } + return true; + } + + /** + * A specialized version of `_.filter` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + */ + function arrayFilter(array, predicate) { + var index = -1, + length = array == null ? 0 : array.length, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (predicate(value, index, array)) { + result[resIndex++] = value; + } + } + return result; + } + + /** + * A specialized version of `_.includes` for arrays without support for + * specifying an index to search from. + * + * @private + * @param {Array} [array] The array to inspect. + * @param {*} target The value to search for. + * @returns {boolean} Returns `true` if `target` is found, else `false`. + */ + function arrayIncludes(array, value) { + var length = array == null ? 0 : array.length; + return !!length && baseIndexOf(array, value, 0) > -1; + } + + /** + * This function is like `arrayIncludes` except that it accepts a comparator. + * + * @private + * @param {Array} [array] The array to inspect. + * @param {*} target The value to search for. + * @param {Function} comparator The comparator invoked per element. + * @returns {boolean} Returns `true` if `target` is found, else `false`. + */ + function arrayIncludesWith(array, value, comparator) { + var index = -1, + length = array == null ? 0 : array.length; + + while (++index < length) { + if (comparator(value, array[index])) { + return true; + } + } + return false; + } + + /** + * A specialized version of `_.map` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ + function arrayMap(array, iteratee) { + var index = -1, + length = array == null ? 0 : array.length, + result = Array(length); + + while (++index < length) { + result[index] = iteratee(array[index], index, array); + } + return result; + } + + /** + * Appends the elements of `values` to `array`. + * + * @private + * @param {Array} array The array to modify. + * @param {Array} values The values to append. + * @returns {Array} Returns `array`. + */ + function arrayPush(array, values) { + var index = -1, + length = values.length, + offset = array.length; + + while (++index < length) { + array[offset + index] = values[index]; + } + return array; + } + + /** + * A specialized version of `_.reduce` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @param {boolean} [initAccum] Specify using the first element of `array` as + * the initial value. + * @returns {*} Returns the accumulated value. + */ + function arrayReduce(array, iteratee, accumulator, initAccum) { + var index = -1, + length = array == null ? 0 : array.length; + + if (initAccum && length) { + accumulator = array[++index]; + } + while (++index < length) { + accumulator = iteratee(accumulator, array[index], index, array); + } + return accumulator; + } + + /** + * A specialized version of `_.reduceRight` for arrays without support for + * iteratee shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @param {boolean} [initAccum] Specify using the last element of `array` as + * the initial value. + * @returns {*} Returns the accumulated value. + */ + function arrayReduceRight(array, iteratee, accumulator, initAccum) { + var length = array == null ? 0 : array.length; + if (initAccum && length) { + accumulator = array[--length]; + } + while (length--) { + accumulator = iteratee(accumulator, array[length], length, array); + } + return accumulator; + } + + /** + * A specialized version of `_.some` for arrays without support for iteratee + * shorthands. + * + * @private + * @param {Array} [array] The array to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + */ + function arraySome(array, predicate) { + var index = -1, + length = array == null ? 0 : array.length; + + while (++index < length) { + if (predicate(array[index], index, array)) { + return true; + } + } + return false; + } + + /** + * Gets the size of an ASCII `string`. + * + * @private + * @param {string} string The string inspect. + * @returns {number} Returns the string size. + */ + var asciiSize = baseProperty('length'); + + /** + * Converts an ASCII `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ + function asciiToArray(string) { + return string.split(''); + } + + /** + * Splits an ASCII `string` into an array of its words. + * + * @private + * @param {string} The string to inspect. + * @returns {Array} Returns the words of `string`. + */ + function asciiWords(string) { + return string.match(reAsciiWord) || []; + } + + /** + * The base implementation of methods like `_.findKey` and `_.findLastKey`, + * without support for iteratee shorthands, which iterates over `collection` + * using `eachFunc`. + * + * @private + * @param {Array|Object} collection The collection to inspect. + * @param {Function} predicate The function invoked per iteration. + * @param {Function} eachFunc The function to iterate over `collection`. + * @returns {*} Returns the found element or its key, else `undefined`. + */ + function baseFindKey(collection, predicate, eachFunc) { + var result; + eachFunc(collection, function(value, key, collection) { + if (predicate(value, key, collection)) { + result = key; + return false; + } + }); + return result; + } + + /** + * The base implementation of `_.findIndex` and `_.findLastIndex` without + * support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} predicate The function invoked per iteration. + * @param {number} fromIndex The index to search from. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function baseFindIndex(array, predicate, fromIndex, fromRight) { + var length = array.length, + index = fromIndex + (fromRight ? 1 : -1); + + while ((fromRight ? index-- : ++index < length)) { + if (predicate(array[index], index, array)) { + return index; + } + } + return -1; + } + + /** + * The base implementation of `_.indexOf` without `fromIndex` bounds checks. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function baseIndexOf(array, value, fromIndex) { + return value === value + ? strictIndexOf(array, value, fromIndex) + : baseFindIndex(array, baseIsNaN, fromIndex); + } + + /** + * This function is like `baseIndexOf` except that it accepts a comparator. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @param {Function} comparator The comparator invoked per element. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function baseIndexOfWith(array, value, fromIndex, comparator) { + var index = fromIndex - 1, + length = array.length; + + while (++index < length) { + if (comparator(array[index], value)) { + return index; + } + } + return -1; + } + + /** + * The base implementation of `_.isNaN` without support for number objects. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`. + */ + function baseIsNaN(value) { + return value !== value; + } + + /** + * The base implementation of `_.mean` and `_.meanBy` without support for + * iteratee shorthands. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {number} Returns the mean. + */ + function baseMean(array, iteratee) { + var length = array == null ? 0 : array.length; + return length ? (baseSum(array, iteratee) / length) : NAN; + } + + /** + * The base implementation of `_.property` without support for deep paths. + * + * @private + * @param {string} key The key of the property to get. + * @returns {Function} Returns the new accessor function. + */ + function baseProperty(key) { + return function(object) { + return object == null ? undefined : object[key]; + }; + } + + /** + * The base implementation of `_.propertyOf` without support for deep paths. + * + * @private + * @param {Object} object The object to query. + * @returns {Function} Returns the new accessor function. + */ + function basePropertyOf(object) { + return function(key) { + return object == null ? undefined : object[key]; + }; + } + + /** + * The base implementation of `_.reduce` and `_.reduceRight`, without support + * for iteratee shorthands, which iterates over `collection` using `eachFunc`. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {*} accumulator The initial value. + * @param {boolean} initAccum Specify using the first or last element of + * `collection` as the initial value. + * @param {Function} eachFunc The function to iterate over `collection`. + * @returns {*} Returns the accumulated value. + */ + function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) { + eachFunc(collection, function(value, index, collection) { + accumulator = initAccum + ? (initAccum = false, value) + : iteratee(accumulator, value, index, collection); + }); + return accumulator; + } + + /** + * The base implementation of `_.sortBy` which uses `comparer` to define the + * sort order of `array` and replaces criteria objects with their corresponding + * values. + * + * @private + * @param {Array} array The array to sort. + * @param {Function} comparer The function to define sort order. + * @returns {Array} Returns `array`. + */ + function baseSortBy(array, comparer) { + var length = array.length; + + array.sort(comparer); + while (length--) { + array[length] = array[length].value; + } + return array; + } + + /** + * The base implementation of `_.sum` and `_.sumBy` without support for + * iteratee shorthands. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {number} Returns the sum. + */ + function baseSum(array, iteratee) { + var result, + index = -1, + length = array.length; + + while (++index < length) { + var current = iteratee(array[index]); + if (current !== undefined) { + result = result === undefined ? current : (result + current); + } + } + return result; + } + + /** + * The base implementation of `_.times` without support for iteratee shorthands + * or max array length checks. + * + * @private + * @param {number} n The number of times to invoke `iteratee`. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the array of results. + */ + function baseTimes(n, iteratee) { + var index = -1, + result = Array(n); + + while (++index < n) { + result[index] = iteratee(index); + } + return result; + } + + /** + * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array + * of key-value pairs for `object` corresponding to the property names of `props`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} props The property names to get values for. + * @returns {Object} Returns the key-value pairs. + */ + function baseToPairs(object, props) { + return arrayMap(props, function(key) { + return [key, object[key]]; + }); + } + + /** + * The base implementation of `_.trim`. + * + * @private + * @param {string} string The string to trim. + * @returns {string} Returns the trimmed string. + */ + function baseTrim(string) { + return string + ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '') + : string; + } + + /** + * The base implementation of `_.unary` without support for storing metadata. + * + * @private + * @param {Function} func The function to cap arguments for. + * @returns {Function} Returns the new capped function. + */ + function baseUnary(func) { + return function(value) { + return func(value); + }; + } + + /** + * The base implementation of `_.values` and `_.valuesIn` which creates an + * array of `object` property values corresponding to the property names + * of `props`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} props The property names to get values for. + * @returns {Object} Returns the array of property values. + */ + function baseValues(object, props) { + return arrayMap(props, function(key) { + return object[key]; + }); + } + + /** + * Checks if a `cache` value for `key` exists. + * + * @private + * @param {Object} cache The cache to query. + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function cacheHas(cache, key) { + return cache.has(key); + } + + /** + * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol + * that is not found in the character symbols. + * + * @private + * @param {Array} strSymbols The string symbols to inspect. + * @param {Array} chrSymbols The character symbols to find. + * @returns {number} Returns the index of the first unmatched string symbol. + */ + function charsStartIndex(strSymbols, chrSymbols) { + var index = -1, + length = strSymbols.length; + + while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {} + return index; + } + + /** + * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol + * that is not found in the character symbols. + * + * @private + * @param {Array} strSymbols The string symbols to inspect. + * @param {Array} chrSymbols The character symbols to find. + * @returns {number} Returns the index of the last unmatched string symbol. + */ + function charsEndIndex(strSymbols, chrSymbols) { + var index = strSymbols.length; + + while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {} + return index; + } + + /** + * Gets the number of `placeholder` occurrences in `array`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} placeholder The placeholder to search for. + * @returns {number} Returns the placeholder count. + */ + function countHolders(array, placeholder) { + var length = array.length, + result = 0; + + while (length--) { + if (array[length] === placeholder) { + ++result; + } + } + return result; + } + + /** + * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A + * letters to basic Latin letters. + * + * @private + * @param {string} letter The matched letter to deburr. + * @returns {string} Returns the deburred letter. + */ + var deburrLetter = basePropertyOf(deburredLetters); + + /** + * Used by `_.escape` to convert characters to HTML entities. + * + * @private + * @param {string} chr The matched character to escape. + * @returns {string} Returns the escaped character. + */ + var escapeHtmlChar = basePropertyOf(htmlEscapes); + + /** + * Used by `_.template` to escape characters for inclusion in compiled string literals. + * + * @private + * @param {string} chr The matched character to escape. + * @returns {string} Returns the escaped character. + */ + function escapeStringChar(chr) { + return '\\' + stringEscapes[chr]; + } + + /** + * Gets the value at `key` of `object`. + * + * @private + * @param {Object} [object] The object to query. + * @param {string} key The key of the property to get. + * @returns {*} Returns the property value. + */ + function getValue(object, key) { + return object == null ? undefined : object[key]; + } + + /** + * Checks if `string` contains Unicode symbols. + * + * @private + * @param {string} string The string to inspect. + * @returns {boolean} Returns `true` if a symbol is found, else `false`. + */ + function hasUnicode(string) { + return reHasUnicode.test(string); + } + + /** + * Checks if `string` contains a word composed of Unicode symbols. + * + * @private + * @param {string} string The string to inspect. + * @returns {boolean} Returns `true` if a word is found, else `false`. + */ + function hasUnicodeWord(string) { + return reHasUnicodeWord.test(string); + } + + /** + * Converts `iterator` to an array. + * + * @private + * @param {Object} iterator The iterator to convert. + * @returns {Array} Returns the converted array. + */ + function iteratorToArray(iterator) { + var data, + result = []; + + while (!(data = iterator.next()).done) { + result.push(data.value); + } + return result; + } + + /** + * Converts `map` to its key-value pairs. + * + * @private + * @param {Object} map The map to convert. + * @returns {Array} Returns the key-value pairs. + */ + function mapToArray(map) { + var index = -1, + result = Array(map.size); + + map.forEach(function(value, key) { + result[++index] = [key, value]; + }); + return result; + } + + /** + * Creates a unary function that invokes `func` with its argument transformed. + * + * @private + * @param {Function} func The function to wrap. + * @param {Function} transform The argument transform. + * @returns {Function} Returns the new function. + */ + function overArg(func, transform) { + return function(arg) { + return func(transform(arg)); + }; + } + + /** + * Replaces all `placeholder` elements in `array` with an internal placeholder + * and returns an array of their indexes. + * + * @private + * @param {Array} array The array to modify. + * @param {*} placeholder The placeholder to replace. + * @returns {Array} Returns the new array of placeholder indexes. + */ + function replaceHolders(array, placeholder) { + var index = -1, + length = array.length, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (value === placeholder || value === PLACEHOLDER) { + array[index] = PLACEHOLDER; + result[resIndex++] = index; + } + } + return result; + } + + /** + * Converts `set` to an array of its values. + * + * @private + * @param {Object} set The set to convert. + * @returns {Array} Returns the values. + */ + function setToArray(set) { + var index = -1, + result = Array(set.size); + + set.forEach(function(value) { + result[++index] = value; + }); + return result; + } + + /** + * Converts `set` to its value-value pairs. + * + * @private + * @param {Object} set The set to convert. + * @returns {Array} Returns the value-value pairs. + */ + function setToPairs(set) { + var index = -1, + result = Array(set.size); + + set.forEach(function(value) { + result[++index] = [value, value]; + }); + return result; + } + + /** + * A specialized version of `_.indexOf` which performs strict equality + * comparisons of values, i.e. `===`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function strictIndexOf(array, value, fromIndex) { + var index = fromIndex - 1, + length = array.length; + + while (++index < length) { + if (array[index] === value) { + return index; + } + } + return -1; + } + + /** + * A specialized version of `_.lastIndexOf` which performs strict equality + * comparisons of values, i.e. `===`. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} fromIndex The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function strictLastIndexOf(array, value, fromIndex) { + var index = fromIndex + 1; + while (index--) { + if (array[index] === value) { + return index; + } + } + return index; + } + + /** + * Gets the number of symbols in `string`. + * + * @private + * @param {string} string The string to inspect. + * @returns {number} Returns the string size. + */ + function stringSize(string) { + return hasUnicode(string) + ? unicodeSize(string) + : asciiSize(string); + } + + /** + * Converts `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ + function stringToArray(string) { + return hasUnicode(string) + ? unicodeToArray(string) + : asciiToArray(string); + } + + /** + * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace + * character of `string`. + * + * @private + * @param {string} string The string to inspect. + * @returns {number} Returns the index of the last non-whitespace character. + */ + function trimmedEndIndex(string) { + var index = string.length; + + while (index-- && reWhitespace.test(string.charAt(index))) {} + return index; + } + + /** + * Used by `_.unescape` to convert HTML entities to characters. + * + * @private + * @param {string} chr The matched character to unescape. + * @returns {string} Returns the unescaped character. + */ + var unescapeHtmlChar = basePropertyOf(htmlUnescapes); + + /** + * Gets the size of a Unicode `string`. + * + * @private + * @param {string} string The string inspect. + * @returns {number} Returns the string size. + */ + function unicodeSize(string) { + var result = reUnicode.lastIndex = 0; + while (reUnicode.test(string)) { + ++result; + } + return result; + } + + /** + * Converts a Unicode `string` to an array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the converted array. + */ + function unicodeToArray(string) { + return string.match(reUnicode) || []; + } + + /** + * Splits a Unicode `string` into an array of its words. + * + * @private + * @param {string} The string to inspect. + * @returns {Array} Returns the words of `string`. + */ + function unicodeWords(string) { + return string.match(reUnicodeWord) || []; + } + + /*--------------------------------------------------------------------------*/ + + /** + * Create a new pristine `lodash` function using the `context` object. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Util + * @param {Object} [context=root] The context object. + * @returns {Function} Returns a new `lodash` function. + * @example + * + * _.mixin({ 'foo': _.constant('foo') }); + * + * var lodash = _.runInContext(); + * lodash.mixin({ 'bar': lodash.constant('bar') }); + * + * _.isFunction(_.foo); + * // => true + * _.isFunction(_.bar); + * // => false + * + * lodash.isFunction(lodash.foo); + * // => false + * lodash.isFunction(lodash.bar); + * // => true + * + * // Create a suped-up `defer` in Node.js. + * var defer = _.runInContext({ 'setTimeout': setImmediate }).defer; + */ + var runInContext = (function runInContext(context) { + context = context == null ? root : _.defaults(root.Object(), context, _.pick(root, contextProps)); + + /** Built-in constructor references. */ + var Array = context.Array, + Date = context.Date, + Error = context.Error, + Function = context.Function, + Math = context.Math, + Object = context.Object, + RegExp = context.RegExp, + String = context.String, + TypeError = context.TypeError; + + /** Used for built-in method references. */ + var arrayProto = Array.prototype, + funcProto = Function.prototype, + objectProto = Object.prototype; + + /** Used to detect overreaching core-js shims. */ + var coreJsData = context['__core-js_shared__']; + + /** Used to resolve the decompiled source of functions. */ + var funcToString = funcProto.toString; + + /** Used to check objects for own properties. */ + var hasOwnProperty = objectProto.hasOwnProperty; + + /** Used to generate unique IDs. */ + var idCounter = 0; + + /** Used to detect methods masquerading as native. */ + var maskSrcKey = (function() { + var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || ''); + return uid ? ('Symbol(src)_1.' + uid) : ''; + }()); + + /** + * Used to resolve the + * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring) + * of values. + */ + var nativeObjectToString = objectProto.toString; + + /** Used to infer the `Object` constructor. */ + var objectCtorString = funcToString.call(Object); + + /** Used to restore the original `_` reference in `_.noConflict`. */ + var oldDash = root._; + + /** Used to detect if a method is native. */ + var reIsNative = RegExp('^' + + funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\$&') + .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$' + ); + + /** Built-in value references. */ + var Buffer = moduleExports ? context.Buffer : undefined, + Symbol = context.Symbol, + Uint8Array = context.Uint8Array, + allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined, + getPrototype = overArg(Object.getPrototypeOf, Object), + objectCreate = Object.create, + propertyIsEnumerable = objectProto.propertyIsEnumerable, + splice = arrayProto.splice, + spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined, + symIterator = Symbol ? Symbol.iterator : undefined, + symToStringTag = Symbol ? Symbol.toStringTag : undefined; + + var defineProperty = (function() { + try { + var func = getNative(Object, 'defineProperty'); + func({}, '', {}); + return func; + } catch (e) {} + }()); + + /** Mocked built-ins. */ + var ctxClearTimeout = context.clearTimeout !== root.clearTimeout && context.clearTimeout, + ctxNow = Date && Date.now !== root.Date.now && Date.now, + ctxSetTimeout = context.setTimeout !== root.setTimeout && context.setTimeout; + + /* Built-in method references for those with the same name as other `lodash` methods. */ + var nativeCeil = Math.ceil, + nativeFloor = Math.floor, + nativeGetSymbols = Object.getOwnPropertySymbols, + nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined, + nativeIsFinite = context.isFinite, + nativeJoin = arrayProto.join, + nativeKeys = overArg(Object.keys, Object), + nativeMax = Math.max, + nativeMin = Math.min, + nativeNow = Date.now, + nativeParseInt = context.parseInt, + nativeRandom = Math.random, + nativeReverse = arrayProto.reverse; + + /* Built-in method references that are verified to be native. */ + var DataView = getNative(context, 'DataView'), + Map = getNative(context, 'Map'), + Promise = getNative(context, 'Promise'), + Set = getNative(context, 'Set'), + WeakMap = getNative(context, 'WeakMap'), + nativeCreate = getNative(Object, 'create'); + + /** Used to store function metadata. */ + var metaMap = WeakMap && new WeakMap; + + /** Used to lookup unminified function names. */ + var realNames = {}; + + /** Used to detect maps, sets, and weakmaps. */ + var dataViewCtorString = toSource(DataView), + mapCtorString = toSource(Map), + promiseCtorString = toSource(Promise), + setCtorString = toSource(Set), + weakMapCtorString = toSource(WeakMap); + + /** Used to convert symbols to primitives and strings. */ + var symbolProto = Symbol ? Symbol.prototype : undefined, + symbolValueOf = symbolProto ? symbolProto.valueOf : undefined, + symbolToString = symbolProto ? symbolProto.toString : undefined; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a `lodash` object which wraps `value` to enable implicit method + * chain sequences. Methods that operate on and return arrays, collections, + * and functions can be chained together. Methods that retrieve a single value + * or may return a primitive value will automatically end the chain sequence + * and return the unwrapped value. Otherwise, the value must be unwrapped + * with `_#value`. + * + * Explicit chain sequences, which must be unwrapped with `_#value`, may be + * enabled using `_.chain`. + * + * The execution of chained methods is lazy, that is, it's deferred until + * `_#value` is implicitly or explicitly called. + * + * Lazy evaluation allows several methods to support shortcut fusion. + * Shortcut fusion is an optimization to merge iteratee calls; this avoids + * the creation of intermediate arrays and can greatly reduce the number of + * iteratee executions. Sections of a chain sequence qualify for shortcut + * fusion if the section is applied to an array and iteratees accept only + * one argument. The heuristic for whether a section qualifies for shortcut + * fusion is subject to change. + * + * Chaining is supported in custom builds as long as the `_#value` method is + * directly or indirectly included in the build. + * + * In addition to lodash methods, wrappers have `Array` and `String` methods. + * + * The wrapper `Array` methods are: + * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift` + * + * The wrapper `String` methods are: + * `replace` and `split` + * + * The wrapper methods that support shortcut fusion are: + * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`, + * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`, + * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray` + * + * The chainable wrapper methods are: + * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`, + * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`, + * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`, + * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`, + * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`, + * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`, + * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`, + * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`, + * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`, + * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`, + * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`, + * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`, + * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`, + * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`, + * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`, + * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`, + * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`, + * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`, + * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`, + * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`, + * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`, + * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`, + * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`, + * `zipObject`, `zipObjectDeep`, and `zipWith` + * + * The wrapper methods that are **not** chainable by default are: + * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`, + * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`, + * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`, + * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`, + * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`, + * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`, + * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`, + * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`, + * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`, + * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`, + * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`, + * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`, + * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`, + * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`, + * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`, + * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`, + * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`, + * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`, + * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`, + * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`, + * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`, + * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`, + * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`, + * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`, + * `upperFirst`, `value`, and `words` + * + * @name _ + * @constructor + * @category Seq + * @param {*} value The value to wrap in a `lodash` instance. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * function square(n) { + * return n * n; + * } + * + * var wrapped = _([1, 2, 3]); + * + * // Returns an unwrapped value. + * wrapped.reduce(_.add); + * // => 6 + * + * // Returns a wrapped value. + * var squares = wrapped.map(square); + * + * _.isArray(squares); + * // => false + * + * _.isArray(squares.value()); + * // => true + */ + function lodash(value) { + if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) { + if (value instanceof LodashWrapper) { + return value; + } + if (hasOwnProperty.call(value, '__wrapped__')) { + return wrapperClone(value); + } + } + return new LodashWrapper(value); + } + + /** + * The base implementation of `_.create` without support for assigning + * properties to the created object. + * + * @private + * @param {Object} proto The object to inherit from. + * @returns {Object} Returns the new object. + */ + var baseCreate = (function() { + function object() {} + return function(proto) { + if (!isObject(proto)) { + return {}; + } + if (objectCreate) { + return objectCreate(proto); + } + object.prototype = proto; + var result = new object; + object.prototype = undefined; + return result; + }; + }()); + + /** + * The function whose prototype chain sequence wrappers inherit from. + * + * @private + */ + function baseLodash() { + // No operation performed. + } + + /** + * The base constructor for creating `lodash` wrapper objects. + * + * @private + * @param {*} value The value to wrap. + * @param {boolean} [chainAll] Enable explicit method chain sequences. + */ + function LodashWrapper(value, chainAll) { + this.__wrapped__ = value; + this.__actions__ = []; + this.__chain__ = !!chainAll; + this.__index__ = 0; + this.__values__ = undefined; + } + + /** + * By default, the template delimiters used by lodash are like those in + * embedded Ruby (ERB) as well as ES2015 template strings. Change the + * following template settings to use alternative delimiters. + * + * @static + * @memberOf _ + * @type {Object} + */ + lodash.templateSettings = { + + /** + * Used to detect `data` property values to be HTML-escaped. + * + * @memberOf _.templateSettings + * @type {RegExp} + */ + 'escape': reEscape, + + /** + * Used to detect code to be evaluated. + * + * @memberOf _.templateSettings + * @type {RegExp} + */ + 'evaluate': reEvaluate, + + /** + * Used to detect `data` property values to inject. + * + * @memberOf _.templateSettings + * @type {RegExp} + */ + 'interpolate': reInterpolate, + + /** + * Used to reference the data object in the template text. + * + * @memberOf _.templateSettings + * @type {string} + */ + 'variable': '', + + /** + * Used to import variables into the compiled template. + * + * @memberOf _.templateSettings + * @type {Object} + */ + 'imports': { + + /** + * A reference to the `lodash` function. + * + * @memberOf _.templateSettings.imports + * @type {Function} + */ + '_': lodash + } + }; + + // Ensure wrappers are instances of `baseLodash`. + lodash.prototype = baseLodash.prototype; + lodash.prototype.constructor = lodash; + + LodashWrapper.prototype = baseCreate(baseLodash.prototype); + LodashWrapper.prototype.constructor = LodashWrapper; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation. + * + * @private + * @constructor + * @param {*} value The value to wrap. + */ + function LazyWrapper(value) { + this.__wrapped__ = value; + this.__actions__ = []; + this.__dir__ = 1; + this.__filtered__ = false; + this.__iteratees__ = []; + this.__takeCount__ = MAX_ARRAY_LENGTH; + this.__views__ = []; + } + + /** + * Creates a clone of the lazy wrapper object. + * + * @private + * @name clone + * @memberOf LazyWrapper + * @returns {Object} Returns the cloned `LazyWrapper` object. + */ + function lazyClone() { + var result = new LazyWrapper(this.__wrapped__); + result.__actions__ = copyArray(this.__actions__); + result.__dir__ = this.__dir__; + result.__filtered__ = this.__filtered__; + result.__iteratees__ = copyArray(this.__iteratees__); + result.__takeCount__ = this.__takeCount__; + result.__views__ = copyArray(this.__views__); + return result; + } + + /** + * Reverses the direction of lazy iteration. + * + * @private + * @name reverse + * @memberOf LazyWrapper + * @returns {Object} Returns the new reversed `LazyWrapper` object. + */ + function lazyReverse() { + if (this.__filtered__) { + var result = new LazyWrapper(this); + result.__dir__ = -1; + result.__filtered__ = true; + } else { + result = this.clone(); + result.__dir__ *= -1; + } + return result; + } + + /** + * Extracts the unwrapped value from its lazy wrapper. + * + * @private + * @name value + * @memberOf LazyWrapper + * @returns {*} Returns the unwrapped value. + */ + function lazyValue() { + var array = this.__wrapped__.value(), + dir = this.__dir__, + isArr = isArray(array), + isRight = dir < 0, + arrLength = isArr ? array.length : 0, + view = getView(0, arrLength, this.__views__), + start = view.start, + end = view.end, + length = end - start, + index = isRight ? end : (start - 1), + iteratees = this.__iteratees__, + iterLength = iteratees.length, + resIndex = 0, + takeCount = nativeMin(length, this.__takeCount__); + + if (!isArr || (!isRight && arrLength == length && takeCount == length)) { + return baseWrapperValue(array, this.__actions__); + } + var result = []; + + outer: + while (length-- && resIndex < takeCount) { + index += dir; + + var iterIndex = -1, + value = array[index]; + + while (++iterIndex < iterLength) { + var data = iteratees[iterIndex], + iteratee = data.iteratee, + type = data.type, + computed = iteratee(value); + + if (type == LAZY_MAP_FLAG) { + value = computed; + } else if (!computed) { + if (type == LAZY_FILTER_FLAG) { + continue outer; + } else { + break outer; + } + } + } + result[resIndex++] = value; + } + return result; + } + + // Ensure `LazyWrapper` is an instance of `baseLodash`. + LazyWrapper.prototype = baseCreate(baseLodash.prototype); + LazyWrapper.prototype.constructor = LazyWrapper; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a hash object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ + function Hash(entries) { + var index = -1, + length = entries == null ? 0 : entries.length; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } + } + + /** + * Removes all key-value entries from the hash. + * + * @private + * @name clear + * @memberOf Hash + */ + function hashClear() { + this.__data__ = nativeCreate ? nativeCreate(null) : {}; + this.size = 0; + } + + /** + * Removes `key` and its value from the hash. + * + * @private + * @name delete + * @memberOf Hash + * @param {Object} hash The hash to modify. + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ + function hashDelete(key) { + var result = this.has(key) && delete this.__data__[key]; + this.size -= result ? 1 : 0; + return result; + } + + /** + * Gets the hash value for `key`. + * + * @private + * @name get + * @memberOf Hash + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function hashGet(key) { + var data = this.__data__; + if (nativeCreate) { + var result = data[key]; + return result === HASH_UNDEFINED ? undefined : result; + } + return hasOwnProperty.call(data, key) ? data[key] : undefined; + } + + /** + * Checks if a hash value for `key` exists. + * + * @private + * @name has + * @memberOf Hash + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function hashHas(key) { + var data = this.__data__; + return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key); + } + + /** + * Sets the hash `key` to `value`. + * + * @private + * @name set + * @memberOf Hash + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the hash instance. + */ + function hashSet(key, value) { + var data = this.__data__; + this.size += this.has(key) ? 0 : 1; + data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value; + return this; + } + + // Add methods to `Hash`. + Hash.prototype.clear = hashClear; + Hash.prototype['delete'] = hashDelete; + Hash.prototype.get = hashGet; + Hash.prototype.has = hashHas; + Hash.prototype.set = hashSet; + + /*------------------------------------------------------------------------*/ + + /** + * Creates an list cache object. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ + function ListCache(entries) { + var index = -1, + length = entries == null ? 0 : entries.length; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } + } + + /** + * Removes all key-value entries from the list cache. + * + * @private + * @name clear + * @memberOf ListCache + */ + function listCacheClear() { + this.__data__ = []; + this.size = 0; + } + + /** + * Removes `key` and its value from the list cache. + * + * @private + * @name delete + * @memberOf ListCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ + function listCacheDelete(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + return false; + } + var lastIndex = data.length - 1; + if (index == lastIndex) { + data.pop(); + } else { + splice.call(data, index, 1); + } + --this.size; + return true; + } + + /** + * Gets the list cache value for `key`. + * + * @private + * @name get + * @memberOf ListCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function listCacheGet(key) { + var data = this.__data__, + index = assocIndexOf(data, key); + + return index < 0 ? undefined : data[index][1]; + } + + /** + * Checks if a list cache value for `key` exists. + * + * @private + * @name has + * @memberOf ListCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function listCacheHas(key) { + return assocIndexOf(this.__data__, key) > -1; + } + + /** + * Sets the list cache `key` to `value`. + * + * @private + * @name set + * @memberOf ListCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the list cache instance. + */ + function listCacheSet(key, value) { + var data = this.__data__, + index = assocIndexOf(data, key); + + if (index < 0) { + ++this.size; + data.push([key, value]); + } else { + data[index][1] = value; + } + return this; + } + + // Add methods to `ListCache`. + ListCache.prototype.clear = listCacheClear; + ListCache.prototype['delete'] = listCacheDelete; + ListCache.prototype.get = listCacheGet; + ListCache.prototype.has = listCacheHas; + ListCache.prototype.set = listCacheSet; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a map cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ + function MapCache(entries) { + var index = -1, + length = entries == null ? 0 : entries.length; + + this.clear(); + while (++index < length) { + var entry = entries[index]; + this.set(entry[0], entry[1]); + } + } + + /** + * Removes all key-value entries from the map. + * + * @private + * @name clear + * @memberOf MapCache + */ + function mapCacheClear() { + this.size = 0; + this.__data__ = { + 'hash': new Hash, + 'map': new (Map || ListCache), + 'string': new Hash + }; + } + + /** + * Removes `key` and its value from the map. + * + * @private + * @name delete + * @memberOf MapCache + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ + function mapCacheDelete(key) { + var result = getMapData(this, key)['delete'](key); + this.size -= result ? 1 : 0; + return result; + } + + /** + * Gets the map value for `key`. + * + * @private + * @name get + * @memberOf MapCache + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function mapCacheGet(key) { + return getMapData(this, key).get(key); + } + + /** + * Checks if a map value for `key` exists. + * + * @private + * @name has + * @memberOf MapCache + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function mapCacheHas(key) { + return getMapData(this, key).has(key); + } + + /** + * Sets the map `key` to `value`. + * + * @private + * @name set + * @memberOf MapCache + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the map cache instance. + */ + function mapCacheSet(key, value) { + var data = getMapData(this, key), + size = data.size; + + data.set(key, value); + this.size += data.size == size ? 0 : 1; + return this; + } + + // Add methods to `MapCache`. + MapCache.prototype.clear = mapCacheClear; + MapCache.prototype['delete'] = mapCacheDelete; + MapCache.prototype.get = mapCacheGet; + MapCache.prototype.has = mapCacheHas; + MapCache.prototype.set = mapCacheSet; + + /*------------------------------------------------------------------------*/ + + /** + * + * Creates an array cache object to store unique values. + * + * @private + * @constructor + * @param {Array} [values] The values to cache. + */ + function SetCache(values) { + var index = -1, + length = values == null ? 0 : values.length; + + this.__data__ = new MapCache; + while (++index < length) { + this.add(values[index]); + } + } + + /** + * Adds `value` to the array cache. + * + * @private + * @name add + * @memberOf SetCache + * @alias push + * @param {*} value The value to cache. + * @returns {Object} Returns the cache instance. + */ + function setCacheAdd(value) { + this.__data__.set(value, HASH_UNDEFINED); + return this; + } + + /** + * Checks if `value` is in the array cache. + * + * @private + * @name has + * @memberOf SetCache + * @param {*} value The value to search for. + * @returns {number} Returns `true` if `value` is found, else `false`. + */ + function setCacheHas(value) { + return this.__data__.has(value); + } + + // Add methods to `SetCache`. + SetCache.prototype.add = SetCache.prototype.push = setCacheAdd; + SetCache.prototype.has = setCacheHas; + + /*------------------------------------------------------------------------*/ + + /** + * Creates a stack cache object to store key-value pairs. + * + * @private + * @constructor + * @param {Array} [entries] The key-value pairs to cache. + */ + function Stack(entries) { + var data = this.__data__ = new ListCache(entries); + this.size = data.size; + } + + /** + * Removes all key-value entries from the stack. + * + * @private + * @name clear + * @memberOf Stack + */ + function stackClear() { + this.__data__ = new ListCache; + this.size = 0; + } + + /** + * Removes `key` and its value from the stack. + * + * @private + * @name delete + * @memberOf Stack + * @param {string} key The key of the value to remove. + * @returns {boolean} Returns `true` if the entry was removed, else `false`. + */ + function stackDelete(key) { + var data = this.__data__, + result = data['delete'](key); + + this.size = data.size; + return result; + } + + /** + * Gets the stack value for `key`. + * + * @private + * @name get + * @memberOf Stack + * @param {string} key The key of the value to get. + * @returns {*} Returns the entry value. + */ + function stackGet(key) { + return this.__data__.get(key); + } + + /** + * Checks if a stack value for `key` exists. + * + * @private + * @name has + * @memberOf Stack + * @param {string} key The key of the entry to check. + * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`. + */ + function stackHas(key) { + return this.__data__.has(key); + } + + /** + * Sets the stack `key` to `value`. + * + * @private + * @name set + * @memberOf Stack + * @param {string} key The key of the value to set. + * @param {*} value The value to set. + * @returns {Object} Returns the stack cache instance. + */ + function stackSet(key, value) { + var data = this.__data__; + if (data instanceof ListCache) { + var pairs = data.__data__; + if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) { + pairs.push([key, value]); + this.size = ++data.size; + return this; + } + data = this.__data__ = new MapCache(pairs); + } + data.set(key, value); + this.size = data.size; + return this; + } + + // Add methods to `Stack`. + Stack.prototype.clear = stackClear; + Stack.prototype['delete'] = stackDelete; + Stack.prototype.get = stackGet; + Stack.prototype.has = stackHas; + Stack.prototype.set = stackSet; + + /*------------------------------------------------------------------------*/ + + /** + * Creates an array of the enumerable property names of the array-like `value`. + * + * @private + * @param {*} value The value to query. + * @param {boolean} inherited Specify returning inherited property names. + * @returns {Array} Returns the array of property names. + */ + function arrayLikeKeys(value, inherited) { + var isArr = isArray(value), + isArg = !isArr && isArguments(value), + isBuff = !isArr && !isArg && isBuffer(value), + isType = !isArr && !isArg && !isBuff && isTypedArray(value), + skipIndexes = isArr || isArg || isBuff || isType, + result = skipIndexes ? baseTimes(value.length, String) : [], + length = result.length; + + for (var key in value) { + if ((inherited || hasOwnProperty.call(value, key)) && + !(skipIndexes && ( + // Safari 9 has enumerable `arguments.length` in strict mode. + key == 'length' || + // Node.js 0.10 has enumerable non-index properties on buffers. + (isBuff && (key == 'offset' || key == 'parent')) || + // PhantomJS 2 has enumerable non-index properties on typed arrays. + (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) || + // Skip index properties. + isIndex(key, length) + ))) { + result.push(key); + } + } + return result; + } + + /** + * A specialized version of `_.sample` for arrays. + * + * @private + * @param {Array} array The array to sample. + * @returns {*} Returns the random element. + */ + function arraySample(array) { + var length = array.length; + return length ? array[baseRandom(0, length - 1)] : undefined; + } + + /** + * A specialized version of `_.sampleSize` for arrays. + * + * @private + * @param {Array} array The array to sample. + * @param {number} n The number of elements to sample. + * @returns {Array} Returns the random elements. + */ + function arraySampleSize(array, n) { + return shuffleSelf(copyArray(array), baseClamp(n, 0, array.length)); + } + + /** + * A specialized version of `_.shuffle` for arrays. + * + * @private + * @param {Array} array The array to shuffle. + * @returns {Array} Returns the new shuffled array. + */ + function arrayShuffle(array) { + return shuffleSelf(copyArray(array)); + } + + /** + * This function is like `assignValue` except that it doesn't assign + * `undefined` values. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ + function assignMergeValue(object, key, value) { + if ((value !== undefined && !eq(object[key], value)) || + (value === undefined && !(key in object))) { + baseAssignValue(object, key, value); + } + } + + /** + * Assigns `value` to `key` of `object` if the existing value is not equivalent + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ + function assignValue(object, key, value) { + var objValue = object[key]; + if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) || + (value === undefined && !(key in object))) { + baseAssignValue(object, key, value); + } + } + + /** + * Gets the index at which the `key` is found in `array` of key-value pairs. + * + * @private + * @param {Array} array The array to inspect. + * @param {*} key The key to search for. + * @returns {number} Returns the index of the matched value, else `-1`. + */ + function assocIndexOf(array, key) { + var length = array.length; + while (length--) { + if (eq(array[length][0], key)) { + return length; + } + } + return -1; + } + + /** + * Aggregates elements of `collection` on `accumulator` with keys transformed + * by `iteratee` and values set by `setter`. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} setter The function to set `accumulator` values. + * @param {Function} iteratee The iteratee to transform keys. + * @param {Object} accumulator The initial aggregated object. + * @returns {Function} Returns `accumulator`. + */ + function baseAggregator(collection, setter, iteratee, accumulator) { + baseEach(collection, function(value, key, collection) { + setter(accumulator, value, iteratee(value), collection); + }); + return accumulator; + } + + /** + * The base implementation of `_.assign` without support for multiple sources + * or `customizer` functions. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @returns {Object} Returns `object`. + */ + function baseAssign(object, source) { + return object && copyObject(source, keys(source), object); + } + + /** + * The base implementation of `_.assignIn` without support for multiple sources + * or `customizer` functions. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @returns {Object} Returns `object`. + */ + function baseAssignIn(object, source) { + return object && copyObject(source, keysIn(source), object); + } + + /** + * The base implementation of `assignValue` and `assignMergeValue` without + * value checks. + * + * @private + * @param {Object} object The object to modify. + * @param {string} key The key of the property to assign. + * @param {*} value The value to assign. + */ + function baseAssignValue(object, key, value) { + if (key == '__proto__' && defineProperty) { + defineProperty(object, key, { + 'configurable': true, + 'enumerable': true, + 'value': value, + 'writable': true + }); + } else { + object[key] = value; + } + } + + /** + * The base implementation of `_.at` without support for individual paths. + * + * @private + * @param {Object} object The object to iterate over. + * @param {string[]} paths The property paths to pick. + * @returns {Array} Returns the picked elements. + */ + function baseAt(object, paths) { + var index = -1, + length = paths.length, + result = Array(length), + skip = object == null; + + while (++index < length) { + result[index] = skip ? undefined : get(object, paths[index]); + } + return result; + } + + /** + * The base implementation of `_.clamp` which doesn't coerce arguments. + * + * @private + * @param {number} number The number to clamp. + * @param {number} [lower] The lower bound. + * @param {number} upper The upper bound. + * @returns {number} Returns the clamped number. + */ + function baseClamp(number, lower, upper) { + if (number === number) { + if (upper !== undefined) { + number = number <= upper ? number : upper; + } + if (lower !== undefined) { + number = number >= lower ? number : lower; + } + } + return number; + } + + /** + * The base implementation of `_.clone` and `_.cloneDeep` which tracks + * traversed objects. + * + * @private + * @param {*} value The value to clone. + * @param {boolean} bitmask The bitmask flags. + * 1 - Deep clone + * 2 - Flatten inherited properties + * 4 - Clone symbols + * @param {Function} [customizer] The function to customize cloning. + * @param {string} [key] The key of `value`. + * @param {Object} [object] The parent object of `value`. + * @param {Object} [stack] Tracks traversed objects and their clone counterparts. + * @returns {*} Returns the cloned value. + */ + function baseClone(value, bitmask, customizer, key, object, stack) { + var result, + isDeep = bitmask & CLONE_DEEP_FLAG, + isFlat = bitmask & CLONE_FLAT_FLAG, + isFull = bitmask & CLONE_SYMBOLS_FLAG; + + if (customizer) { + result = object ? customizer(value, key, object, stack) : customizer(value); + } + if (result !== undefined) { + return result; + } + if (!isObject(value)) { + return value; + } + var isArr = isArray(value); + if (isArr) { + result = initCloneArray(value); + if (!isDeep) { + return copyArray(value, result); + } + } else { + var tag = getTag(value), + isFunc = tag == funcTag || tag == genTag; + + if (isBuffer(value)) { + return cloneBuffer(value, isDeep); + } + if (tag == objectTag || tag == argsTag || (isFunc && !object)) { + result = (isFlat || isFunc) ? {} : initCloneObject(value); + if (!isDeep) { + return isFlat + ? copySymbolsIn(value, baseAssignIn(result, value)) + : copySymbols(value, baseAssign(result, value)); + } + } else { + if (!cloneableTags[tag]) { + return object ? value : {}; + } + result = initCloneByTag(value, tag, isDeep); + } + } + // Check for circular references and return its corresponding clone. + stack || (stack = new Stack); + var stacked = stack.get(value); + if (stacked) { + return stacked; + } + stack.set(value, result); + + if (isSet(value)) { + value.forEach(function(subValue) { + result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack)); + }); + } else if (isMap(value)) { + value.forEach(function(subValue, key) { + result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack)); + }); + } + + var keysFunc = isFull + ? (isFlat ? getAllKeysIn : getAllKeys) + : (isFlat ? keysIn : keys); + + var props = isArr ? undefined : keysFunc(value); + arrayEach(props || value, function(subValue, key) { + if (props) { + key = subValue; + subValue = value[key]; + } + // Recursively populate clone (susceptible to call stack limits). + assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack)); + }); + return result; + } + + /** + * The base implementation of `_.conforms` which doesn't clone `source`. + * + * @private + * @param {Object} source The object of property predicates to conform to. + * @returns {Function} Returns the new spec function. + */ + function baseConforms(source) { + var props = keys(source); + return function(object) { + return baseConformsTo(object, source, props); + }; + } + + /** + * The base implementation of `_.conformsTo` which accepts `props` to check. + * + * @private + * @param {Object} object The object to inspect. + * @param {Object} source The object of property predicates to conform to. + * @returns {boolean} Returns `true` if `object` conforms, else `false`. + */ + function baseConformsTo(object, source, props) { + var length = props.length; + if (object == null) { + return !length; + } + object = Object(object); + while (length--) { + var key = props[length], + predicate = source[key], + value = object[key]; + + if ((value === undefined && !(key in object)) || !predicate(value)) { + return false; + } + } + return true; + } + + /** + * The base implementation of `_.delay` and `_.defer` which accepts `args` + * to provide to `func`. + * + * @private + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @param {Array} args The arguments to provide to `func`. + * @returns {number|Object} Returns the timer id or timeout object. + */ + function baseDelay(func, wait, args) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + return setTimeout(function() { func.apply(undefined, args); }, wait); + } + + /** + * The base implementation of methods like `_.difference` without support + * for excluding multiple arrays or iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Array} values The values to exclude. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of filtered values. + */ + function baseDifference(array, values, iteratee, comparator) { + var index = -1, + includes = arrayIncludes, + isCommon = true, + length = array.length, + result = [], + valuesLength = values.length; + + if (!length) { + return result; + } + if (iteratee) { + values = arrayMap(values, baseUnary(iteratee)); + } + if (comparator) { + includes = arrayIncludesWith; + isCommon = false; + } + else if (values.length >= LARGE_ARRAY_SIZE) { + includes = cacheHas; + isCommon = false; + values = new SetCache(values); + } + outer: + while (++index < length) { + var value = array[index], + computed = iteratee == null ? value : iteratee(value); + + value = (comparator || value !== 0) ? value : 0; + if (isCommon && computed === computed) { + var valuesIndex = valuesLength; + while (valuesIndex--) { + if (values[valuesIndex] === computed) { + continue outer; + } + } + result.push(value); + } + else if (!includes(values, computed, comparator)) { + result.push(value); + } + } + return result; + } + + /** + * The base implementation of `_.forEach` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + */ + var baseEach = createBaseEach(baseForOwn); + + /** + * The base implementation of `_.forEachRight` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + */ + var baseEachRight = createBaseEach(baseForOwnRight, true); + + /** + * The base implementation of `_.every` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false` + */ + function baseEvery(collection, predicate) { + var result = true; + baseEach(collection, function(value, index, collection) { + result = !!predicate(value, index, collection); + return result; + }); + return result; + } + + /** + * The base implementation of methods like `_.max` and `_.min` which accepts a + * `comparator` to determine the extremum value. + * + * @private + * @param {Array} array The array to iterate over. + * @param {Function} iteratee The iteratee invoked per iteration. + * @param {Function} comparator The comparator used to compare values. + * @returns {*} Returns the extremum value. + */ + function baseExtremum(array, iteratee, comparator) { + var index = -1, + length = array.length; + + while (++index < length) { + var value = array[index], + current = iteratee(value); + + if (current != null && (computed === undefined + ? (current === current && !isSymbol(current)) + : comparator(current, computed) + )) { + var computed = current, + result = value; + } + } + return result; + } + + /** + * The base implementation of `_.fill` without an iteratee call guard. + * + * @private + * @param {Array} array The array to fill. + * @param {*} value The value to fill `array` with. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns `array`. + */ + function baseFill(array, value, start, end) { + var length = array.length; + + start = toInteger(start); + if (start < 0) { + start = -start > length ? 0 : (length + start); + } + end = (end === undefined || end > length) ? length : toInteger(end); + if (end < 0) { + end += length; + } + end = start > end ? 0 : toLength(end); + while (start < end) { + array[start++] = value; + } + return array; + } + + /** + * The base implementation of `_.filter` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + */ + function baseFilter(collection, predicate) { + var result = []; + baseEach(collection, function(value, index, collection) { + if (predicate(value, index, collection)) { + result.push(value); + } + }); + return result; + } + + /** + * The base implementation of `_.flatten` with support for restricting flattening. + * + * @private + * @param {Array} array The array to flatten. + * @param {number} depth The maximum recursion depth. + * @param {boolean} [predicate=isFlattenable] The function invoked per iteration. + * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks. + * @param {Array} [result=[]] The initial result value. + * @returns {Array} Returns the new flattened array. + */ + function baseFlatten(array, depth, predicate, isStrict, result) { + var index = -1, + length = array.length; + + predicate || (predicate = isFlattenable); + result || (result = []); + + while (++index < length) { + var value = array[index]; + if (depth > 0 && predicate(value)) { + if (depth > 1) { + // Recursively flatten arrays (susceptible to call stack limits). + baseFlatten(value, depth - 1, predicate, isStrict, result); + } else { + arrayPush(result, value); + } + } else if (!isStrict) { + result[result.length] = value; + } + } + return result; + } + + /** + * The base implementation of `baseForOwn` which iterates over `object` + * properties returned by `keysFunc` and invokes `iteratee` for each property. + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {Function} keysFunc The function to get the keys of `object`. + * @returns {Object} Returns `object`. + */ + var baseFor = createBaseFor(); + + /** + * This function is like `baseFor` except that it iterates over properties + * in the opposite order. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @param {Function} keysFunc The function to get the keys of `object`. + * @returns {Object} Returns `object`. + */ + var baseForRight = createBaseFor(true); + + /** + * The base implementation of `_.forOwn` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ + function baseForOwn(object, iteratee) { + return object && baseFor(object, iteratee, keys); + } + + /** + * The base implementation of `_.forOwnRight` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Object} Returns `object`. + */ + function baseForOwnRight(object, iteratee) { + return object && baseForRight(object, iteratee, keys); + } + + /** + * The base implementation of `_.functions` which creates an array of + * `object` function property names filtered from `props`. + * + * @private + * @param {Object} object The object to inspect. + * @param {Array} props The property names to filter. + * @returns {Array} Returns the function names. + */ + function baseFunctions(object, props) { + return arrayFilter(props, function(key) { + return isFunction(object[key]); + }); + } + + /** + * The base implementation of `_.get` without support for default values. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to get. + * @returns {*} Returns the resolved value. + */ + function baseGet(object, path) { + path = castPath(path, object); + + var index = 0, + length = path.length; + + while (object != null && index < length) { + object = object[toKey(path[index++])]; + } + return (index && index == length) ? object : undefined; + } + + /** + * The base implementation of `getAllKeys` and `getAllKeysIn` which uses + * `keysFunc` and `symbolsFunc` to get the enumerable property names and + * symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Function} keysFunc The function to get the keys of `object`. + * @param {Function} symbolsFunc The function to get the symbols of `object`. + * @returns {Array} Returns the array of property names and symbols. + */ + function baseGetAllKeys(object, keysFunc, symbolsFunc) { + var result = keysFunc(object); + return isArray(object) ? result : arrayPush(result, symbolsFunc(object)); + } + + /** + * The base implementation of `getTag` without fallbacks for buggy environments. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. + */ + function baseGetTag(value) { + if (value == null) { + return value === undefined ? undefinedTag : nullTag; + } + return (symToStringTag && symToStringTag in Object(value)) + ? getRawTag(value) + : objectToString(value); + } + + /** + * The base implementation of `_.gt` which doesn't coerce arguments. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than `other`, + * else `false`. + */ + function baseGt(value, other) { + return value > other; + } + + /** + * The base implementation of `_.has` without support for deep paths. + * + * @private + * @param {Object} [object] The object to query. + * @param {Array|string} key The key to check. + * @returns {boolean} Returns `true` if `key` exists, else `false`. + */ + function baseHas(object, key) { + return object != null && hasOwnProperty.call(object, key); + } + + /** + * The base implementation of `_.hasIn` without support for deep paths. + * + * @private + * @param {Object} [object] The object to query. + * @param {Array|string} key The key to check. + * @returns {boolean} Returns `true` if `key` exists, else `false`. + */ + function baseHasIn(object, key) { + return object != null && key in Object(object); + } + + /** + * The base implementation of `_.inRange` which doesn't coerce arguments. + * + * @private + * @param {number} number The number to check. + * @param {number} start The start of the range. + * @param {number} end The end of the range. + * @returns {boolean} Returns `true` if `number` is in the range, else `false`. + */ + function baseInRange(number, start, end) { + return number >= nativeMin(start, end) && number < nativeMax(start, end); + } + + /** + * The base implementation of methods like `_.intersection`, without support + * for iteratee shorthands, that accepts an array of arrays to inspect. + * + * @private + * @param {Array} arrays The arrays to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of shared values. + */ + function baseIntersection(arrays, iteratee, comparator) { + var includes = comparator ? arrayIncludesWith : arrayIncludes, + length = arrays[0].length, + othLength = arrays.length, + othIndex = othLength, + caches = Array(othLength), + maxLength = Infinity, + result = []; + + while (othIndex--) { + var array = arrays[othIndex]; + if (othIndex && iteratee) { + array = arrayMap(array, baseUnary(iteratee)); + } + maxLength = nativeMin(array.length, maxLength); + caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120)) + ? new SetCache(othIndex && array) + : undefined; + } + array = arrays[0]; + + var index = -1, + seen = caches[0]; + + outer: + while (++index < length && result.length < maxLength) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + value = (comparator || value !== 0) ? value : 0; + if (!(seen + ? cacheHas(seen, computed) + : includes(result, computed, comparator) + )) { + othIndex = othLength; + while (--othIndex) { + var cache = caches[othIndex]; + if (!(cache + ? cacheHas(cache, computed) + : includes(arrays[othIndex], computed, comparator)) + ) { + continue outer; + } + } + if (seen) { + seen.push(computed); + } + result.push(value); + } + } + return result; + } + + /** + * The base implementation of `_.invert` and `_.invertBy` which inverts + * `object` with values transformed by `iteratee` and set by `setter`. + * + * @private + * @param {Object} object The object to iterate over. + * @param {Function} setter The function to set `accumulator` values. + * @param {Function} iteratee The iteratee to transform values. + * @param {Object} accumulator The initial inverted object. + * @returns {Function} Returns `accumulator`. + */ + function baseInverter(object, setter, iteratee, accumulator) { + baseForOwn(object, function(value, key, object) { + setter(accumulator, iteratee(value), key, object); + }); + return accumulator; + } + + /** + * The base implementation of `_.invoke` without support for individual + * method arguments. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path of the method to invoke. + * @param {Array} args The arguments to invoke the method with. + * @returns {*} Returns the result of the invoked method. + */ + function baseInvoke(object, path, args) { + path = castPath(path, object); + object = parent(object, path); + var func = object == null ? object : object[toKey(last(path))]; + return func == null ? undefined : apply(func, object, args); + } + + /** + * The base implementation of `_.isArguments`. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + */ + function baseIsArguments(value) { + return isObjectLike(value) && baseGetTag(value) == argsTag; + } + + /** + * The base implementation of `_.isArrayBuffer` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`. + */ + function baseIsArrayBuffer(value) { + return isObjectLike(value) && baseGetTag(value) == arrayBufferTag; + } + + /** + * The base implementation of `_.isDate` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a date object, else `false`. + */ + function baseIsDate(value) { + return isObjectLike(value) && baseGetTag(value) == dateTag; + } + + /** + * The base implementation of `_.isEqual` which supports partial comparisons + * and tracks traversed objects. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @param {boolean} bitmask The bitmask flags. + * 1 - Unordered comparison + * 2 - Partial comparison + * @param {Function} [customizer] The function to customize comparisons. + * @param {Object} [stack] Tracks traversed `value` and `other` objects. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + */ + function baseIsEqual(value, other, bitmask, customizer, stack) { + if (value === other) { + return true; + } + if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) { + return value !== value && other !== other; + } + return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack); + } + + /** + * A specialized version of `baseIsEqual` for arrays and objects which performs + * deep comparisons and tracks traversed objects enabling objects with circular + * references to be compared. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details. + * @param {Function} customizer The function to customize comparisons. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Object} [stack] Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ + function baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) { + var objIsArr = isArray(object), + othIsArr = isArray(other), + objTag = objIsArr ? arrayTag : getTag(object), + othTag = othIsArr ? arrayTag : getTag(other); + + objTag = objTag == argsTag ? objectTag : objTag; + othTag = othTag == argsTag ? objectTag : othTag; + + var objIsObj = objTag == objectTag, + othIsObj = othTag == objectTag, + isSameTag = objTag == othTag; + + if (isSameTag && isBuffer(object)) { + if (!isBuffer(other)) { + return false; + } + objIsArr = true; + objIsObj = false; + } + if (isSameTag && !objIsObj) { + stack || (stack = new Stack); + return (objIsArr || isTypedArray(object)) + ? equalArrays(object, other, bitmask, customizer, equalFunc, stack) + : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack); + } + if (!(bitmask & COMPARE_PARTIAL_FLAG)) { + var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'), + othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__'); + + if (objIsWrapped || othIsWrapped) { + var objUnwrapped = objIsWrapped ? object.value() : object, + othUnwrapped = othIsWrapped ? other.value() : other; + + stack || (stack = new Stack); + return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack); + } + } + if (!isSameTag) { + return false; + } + stack || (stack = new Stack); + return equalObjects(object, other, bitmask, customizer, equalFunc, stack); + } + + /** + * The base implementation of `_.isMap` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a map, else `false`. + */ + function baseIsMap(value) { + return isObjectLike(value) && getTag(value) == mapTag; + } + + /** + * The base implementation of `_.isMatch` without support for iteratee shorthands. + * + * @private + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @param {Array} matchData The property names, values, and compare flags to match. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + */ + function baseIsMatch(object, source, matchData, customizer) { + var index = matchData.length, + length = index, + noCustomizer = !customizer; + + if (object == null) { + return !length; + } + object = Object(object); + while (index--) { + var data = matchData[index]; + if ((noCustomizer && data[2]) + ? data[1] !== object[data[0]] + : !(data[0] in object) + ) { + return false; + } + } + while (++index < length) { + data = matchData[index]; + var key = data[0], + objValue = object[key], + srcValue = data[1]; + + if (noCustomizer && data[2]) { + if (objValue === undefined && !(key in object)) { + return false; + } + } else { + var stack = new Stack; + if (customizer) { + var result = customizer(objValue, srcValue, key, object, source, stack); + } + if (!(result === undefined + ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack) + : result + )) { + return false; + } + } + } + return true; + } + + /** + * The base implementation of `_.isNative` without bad shim checks. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, + * else `false`. + */ + function baseIsNative(value) { + if (!isObject(value) || isMasked(value)) { + return false; + } + var pattern = isFunction(value) ? reIsNative : reIsHostCtor; + return pattern.test(toSource(value)); + } + + /** + * The base implementation of `_.isRegExp` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a regexp, else `false`. + */ + function baseIsRegExp(value) { + return isObjectLike(value) && baseGetTag(value) == regexpTag; + } + + /** + * The base implementation of `_.isSet` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a set, else `false`. + */ + function baseIsSet(value) { + return isObjectLike(value) && getTag(value) == setTag; + } + + /** + * The base implementation of `_.isTypedArray` without Node.js optimizations. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. + */ + function baseIsTypedArray(value) { + return isObjectLike(value) && + isLength(value.length) && !!typedArrayTags[baseGetTag(value)]; + } + + /** + * The base implementation of `_.iteratee`. + * + * @private + * @param {*} [value=_.identity] The value to convert to an iteratee. + * @returns {Function} Returns the iteratee. + */ + function baseIteratee(value) { + // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9. + // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details. + if (typeof value == 'function') { + return value; + } + if (value == null) { + return identity; + } + if (typeof value == 'object') { + return isArray(value) + ? baseMatchesProperty(value[0], value[1]) + : baseMatches(value); + } + return property(value); + } + + /** + * The base implementation of `_.keys` which doesn't treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function baseKeys(object) { + if (!isPrototype(object)) { + return nativeKeys(object); + } + var result = []; + for (var key in Object(object)) { + if (hasOwnProperty.call(object, key) && key != 'constructor') { + result.push(key); + } + } + return result; + } + + /** + * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function baseKeysIn(object) { + if (!isObject(object)) { + return nativeKeysIn(object); + } + var isProto = isPrototype(object), + result = []; + + for (var key in object) { + if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { + result.push(key); + } + } + return result; + } + + /** + * The base implementation of `_.lt` which doesn't coerce arguments. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is less than `other`, + * else `false`. + */ + function baseLt(value, other) { + return value < other; + } + + /** + * The base implementation of `_.map` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} iteratee The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + */ + function baseMap(collection, iteratee) { + var index = -1, + result = isArrayLike(collection) ? Array(collection.length) : []; + + baseEach(collection, function(value, key, collection) { + result[++index] = iteratee(value, key, collection); + }); + return result; + } + + /** + * The base implementation of `_.matches` which doesn't clone `source`. + * + * @private + * @param {Object} source The object of property values to match. + * @returns {Function} Returns the new spec function. + */ + function baseMatches(source) { + var matchData = getMatchData(source); + if (matchData.length == 1 && matchData[0][2]) { + return matchesStrictComparable(matchData[0][0], matchData[0][1]); + } + return function(object) { + return object === source || baseIsMatch(object, source, matchData); + }; + } + + /** + * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`. + * + * @private + * @param {string} path The path of the property to get. + * @param {*} srcValue The value to match. + * @returns {Function} Returns the new spec function. + */ + function baseMatchesProperty(path, srcValue) { + if (isKey(path) && isStrictComparable(srcValue)) { + return matchesStrictComparable(toKey(path), srcValue); + } + return function(object) { + var objValue = get(object, path); + return (objValue === undefined && objValue === srcValue) + ? hasIn(object, path) + : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG); + }; + } + + /** + * The base implementation of `_.merge` without support for multiple sources. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @param {number} srcIndex The index of `source`. + * @param {Function} [customizer] The function to customize merged values. + * @param {Object} [stack] Tracks traversed source values and their merged + * counterparts. + */ + function baseMerge(object, source, srcIndex, customizer, stack) { + if (object === source) { + return; + } + baseFor(source, function(srcValue, key) { + stack || (stack = new Stack); + if (isObject(srcValue)) { + baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack); + } + else { + var newValue = customizer + ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack) + : undefined; + + if (newValue === undefined) { + newValue = srcValue; + } + assignMergeValue(object, key, newValue); + } + }, keysIn); + } + + /** + * A specialized version of `baseMerge` for arrays and objects which performs + * deep merges and tracks traversed objects enabling objects with circular + * references to be merged. + * + * @private + * @param {Object} object The destination object. + * @param {Object} source The source object. + * @param {string} key The key of the value to merge. + * @param {number} srcIndex The index of `source`. + * @param {Function} mergeFunc The function to merge values. + * @param {Function} [customizer] The function to customize assigned values. + * @param {Object} [stack] Tracks traversed source values and their merged + * counterparts. + */ + function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) { + var objValue = safeGet(object, key), + srcValue = safeGet(source, key), + stacked = stack.get(srcValue); + + if (stacked) { + assignMergeValue(object, key, stacked); + return; + } + var newValue = customizer + ? customizer(objValue, srcValue, (key + ''), object, source, stack) + : undefined; + + var isCommon = newValue === undefined; + + if (isCommon) { + var isArr = isArray(srcValue), + isBuff = !isArr && isBuffer(srcValue), + isTyped = !isArr && !isBuff && isTypedArray(srcValue); + + newValue = srcValue; + if (isArr || isBuff || isTyped) { + if (isArray(objValue)) { + newValue = objValue; + } + else if (isArrayLikeObject(objValue)) { + newValue = copyArray(objValue); + } + else if (isBuff) { + isCommon = false; + newValue = cloneBuffer(srcValue, true); + } + else if (isTyped) { + isCommon = false; + newValue = cloneTypedArray(srcValue, true); + } + else { + newValue = []; + } + } + else if (isPlainObject(srcValue) || isArguments(srcValue)) { + newValue = objValue; + if (isArguments(objValue)) { + newValue = toPlainObject(objValue); + } + else if (!isObject(objValue) || isFunction(objValue)) { + newValue = initCloneObject(srcValue); + } + } + else { + isCommon = false; + } + } + if (isCommon) { + // Recursively merge objects and arrays (susceptible to call stack limits). + stack.set(srcValue, newValue); + mergeFunc(newValue, srcValue, srcIndex, customizer, stack); + stack['delete'](srcValue); + } + assignMergeValue(object, key, newValue); + } + + /** + * The base implementation of `_.nth` which doesn't coerce arguments. + * + * @private + * @param {Array} array The array to query. + * @param {number} n The index of the element to return. + * @returns {*} Returns the nth element of `array`. + */ + function baseNth(array, n) { + var length = array.length; + if (!length) { + return; + } + n += n < 0 ? length : 0; + return isIndex(n, length) ? array[n] : undefined; + } + + /** + * The base implementation of `_.orderBy` without param guards. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by. + * @param {string[]} orders The sort orders of `iteratees`. + * @returns {Array} Returns the new sorted array. + */ + function baseOrderBy(collection, iteratees, orders) { + if (iteratees.length) { + iteratees = arrayMap(iteratees, function(iteratee) { + if (isArray(iteratee)) { + return function(value) { + return baseGet(value, iteratee.length === 1 ? iteratee[0] : iteratee); + } + } + return iteratee; + }); + } else { + iteratees = [identity]; + } + + var index = -1; + iteratees = arrayMap(iteratees, baseUnary(getIteratee())); + + var result = baseMap(collection, function(value, key, collection) { + var criteria = arrayMap(iteratees, function(iteratee) { + return iteratee(value); + }); + return { 'criteria': criteria, 'index': ++index, 'value': value }; + }); + + return baseSortBy(result, function(object, other) { + return compareMultiple(object, other, orders); + }); + } + + /** + * The base implementation of `_.pick` without support for individual + * property identifiers. + * + * @private + * @param {Object} object The source object. + * @param {string[]} paths The property paths to pick. + * @returns {Object} Returns the new object. + */ + function basePick(object, paths) { + return basePickBy(object, paths, function(value, path) { + return hasIn(object, path); + }); + } + + /** + * The base implementation of `_.pickBy` without support for iteratee shorthands. + * + * @private + * @param {Object} object The source object. + * @param {string[]} paths The property paths to pick. + * @param {Function} predicate The function invoked per property. + * @returns {Object} Returns the new object. + */ + function basePickBy(object, paths, predicate) { + var index = -1, + length = paths.length, + result = {}; + + while (++index < length) { + var path = paths[index], + value = baseGet(object, path); + + if (predicate(value, path)) { + baseSet(result, castPath(path, object), value); + } + } + return result; + } + + /** + * A specialized version of `baseProperty` which supports deep paths. + * + * @private + * @param {Array|string} path The path of the property to get. + * @returns {Function} Returns the new accessor function. + */ + function basePropertyDeep(path) { + return function(object) { + return baseGet(object, path); + }; + } + + /** + * The base implementation of `_.pullAllBy` without support for iteratee + * shorthands. + * + * @private + * @param {Array} array The array to modify. + * @param {Array} values The values to remove. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns `array`. + */ + function basePullAll(array, values, iteratee, comparator) { + var indexOf = comparator ? baseIndexOfWith : baseIndexOf, + index = -1, + length = values.length, + seen = array; + + if (array === values) { + values = copyArray(values); + } + if (iteratee) { + seen = arrayMap(array, baseUnary(iteratee)); + } + while (++index < length) { + var fromIndex = 0, + value = values[index], + computed = iteratee ? iteratee(value) : value; + + while ((fromIndex = indexOf(seen, computed, fromIndex, comparator)) > -1) { + if (seen !== array) { + splice.call(seen, fromIndex, 1); + } + splice.call(array, fromIndex, 1); + } + } + return array; + } + + /** + * The base implementation of `_.pullAt` without support for individual + * indexes or capturing the removed elements. + * + * @private + * @param {Array} array The array to modify. + * @param {number[]} indexes The indexes of elements to remove. + * @returns {Array} Returns `array`. + */ + function basePullAt(array, indexes) { + var length = array ? indexes.length : 0, + lastIndex = length - 1; + + while (length--) { + var index = indexes[length]; + if (length == lastIndex || index !== previous) { + var previous = index; + if (isIndex(index)) { + splice.call(array, index, 1); + } else { + baseUnset(array, index); + } + } + } + return array; + } + + /** + * The base implementation of `_.random` without support for returning + * floating-point numbers. + * + * @private + * @param {number} lower The lower bound. + * @param {number} upper The upper bound. + * @returns {number} Returns the random number. + */ + function baseRandom(lower, upper) { + return lower + nativeFloor(nativeRandom() * (upper - lower + 1)); + } + + /** + * The base implementation of `_.range` and `_.rangeRight` which doesn't + * coerce arguments. + * + * @private + * @param {number} start The start of the range. + * @param {number} end The end of the range. + * @param {number} step The value to increment or decrement by. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Array} Returns the range of numbers. + */ + function baseRange(start, end, step, fromRight) { + var index = -1, + length = nativeMax(nativeCeil((end - start) / (step || 1)), 0), + result = Array(length); + + while (length--) { + result[fromRight ? length : ++index] = start; + start += step; + } + return result; + } + + /** + * The base implementation of `_.repeat` which doesn't coerce arguments. + * + * @private + * @param {string} string The string to repeat. + * @param {number} n The number of times to repeat the string. + * @returns {string} Returns the repeated string. + */ + function baseRepeat(string, n) { + var result = ''; + if (!string || n < 1 || n > MAX_SAFE_INTEGER) { + return result; + } + // Leverage the exponentiation by squaring algorithm for a faster repeat. + // See https://en.wikipedia.org/wiki/Exponentiation_by_squaring for more details. + do { + if (n % 2) { + result += string; + } + n = nativeFloor(n / 2); + if (n) { + string += string; + } + } while (n); + + return result; + } + + /** + * The base implementation of `_.rest` which doesn't validate or coerce arguments. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @returns {Function} Returns the new function. + */ + function baseRest(func, start) { + return setToString(overRest(func, start, identity), func + ''); + } + + /** + * The base implementation of `_.sample`. + * + * @private + * @param {Array|Object} collection The collection to sample. + * @returns {*} Returns the random element. + */ + function baseSample(collection) { + return arraySample(values(collection)); + } + + /** + * The base implementation of `_.sampleSize` without param guards. + * + * @private + * @param {Array|Object} collection The collection to sample. + * @param {number} n The number of elements to sample. + * @returns {Array} Returns the random elements. + */ + function baseSampleSize(collection, n) { + var array = values(collection); + return shuffleSelf(array, baseClamp(n, 0, array.length)); + } + + /** + * The base implementation of `_.set`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {*} value The value to set. + * @param {Function} [customizer] The function to customize path creation. + * @returns {Object} Returns `object`. + */ + function baseSet(object, path, value, customizer) { + if (!isObject(object)) { + return object; + } + path = castPath(path, object); + + var index = -1, + length = path.length, + lastIndex = length - 1, + nested = object; + + while (nested != null && ++index < length) { + var key = toKey(path[index]), + newValue = value; + + if (key === '__proto__' || key === 'constructor' || key === 'prototype') { + return object; + } + + if (index != lastIndex) { + var objValue = nested[key]; + newValue = customizer ? customizer(objValue, key, nested) : undefined; + if (newValue === undefined) { + newValue = isObject(objValue) + ? objValue + : (isIndex(path[index + 1]) ? [] : {}); + } + } + assignValue(nested, key, newValue); + nested = nested[key]; + } + return object; + } + + /** + * The base implementation of `setData` without support for hot loop shorting. + * + * @private + * @param {Function} func The function to associate metadata with. + * @param {*} data The metadata. + * @returns {Function} Returns `func`. + */ + var baseSetData = !metaMap ? identity : function(func, data) { + metaMap.set(func, data); + return func; + }; + + /** + * The base implementation of `setToString` without support for hot loop shorting. + * + * @private + * @param {Function} func The function to modify. + * @param {Function} string The `toString` result. + * @returns {Function} Returns `func`. + */ + var baseSetToString = !defineProperty ? identity : function(func, string) { + return defineProperty(func, 'toString', { + 'configurable': true, + 'enumerable': false, + 'value': constant(string), + 'writable': true + }); + }; + + /** + * The base implementation of `_.shuffle`. + * + * @private + * @param {Array|Object} collection The collection to shuffle. + * @returns {Array} Returns the new shuffled array. + */ + function baseShuffle(collection) { + return shuffleSelf(values(collection)); + } + + /** + * The base implementation of `_.slice` without an iteratee call guard. + * + * @private + * @param {Array} array The array to slice. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the slice of `array`. + */ + function baseSlice(array, start, end) { + var index = -1, + length = array.length; + + if (start < 0) { + start = -start > length ? 0 : (length + start); + } + end = end > length ? length : end; + if (end < 0) { + end += length; + } + length = start > end ? 0 : ((end - start) >>> 0); + start >>>= 0; + + var result = Array(length); + while (++index < length) { + result[index] = array[index + start]; + } + return result; + } + + /** + * The base implementation of `_.some` without support for iteratee shorthands. + * + * @private + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} predicate The function invoked per iteration. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + */ + function baseSome(collection, predicate) { + var result; + + baseEach(collection, function(value, index, collection) { + result = predicate(value, index, collection); + return !result; + }); + return !!result; + } + + /** + * The base implementation of `_.sortedIndex` and `_.sortedLastIndex` which + * performs a binary search of `array` to determine the index at which `value` + * should be inserted into `array` in order to maintain its sort order. + * + * @private + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {boolean} [retHighest] Specify returning the highest qualified index. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + */ + function baseSortedIndex(array, value, retHighest) { + var low = 0, + high = array == null ? low : array.length; + + if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) { + while (low < high) { + var mid = (low + high) >>> 1, + computed = array[mid]; + + if (computed !== null && !isSymbol(computed) && + (retHighest ? (computed <= value) : (computed < value))) { + low = mid + 1; + } else { + high = mid; + } + } + return high; + } + return baseSortedIndexBy(array, value, identity, retHighest); + } + + /** + * The base implementation of `_.sortedIndexBy` and `_.sortedLastIndexBy` + * which invokes `iteratee` for `value` and each element of `array` to compute + * their sort ranking. The iteratee is invoked with one argument; (value). + * + * @private + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {Function} iteratee The iteratee invoked per element. + * @param {boolean} [retHighest] Specify returning the highest qualified index. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + */ + function baseSortedIndexBy(array, value, iteratee, retHighest) { + var low = 0, + high = array == null ? 0 : array.length; + if (high === 0) { + return 0; + } + + value = iteratee(value); + var valIsNaN = value !== value, + valIsNull = value === null, + valIsSymbol = isSymbol(value), + valIsUndefined = value === undefined; + + while (low < high) { + var mid = nativeFloor((low + high) / 2), + computed = iteratee(array[mid]), + othIsDefined = computed !== undefined, + othIsNull = computed === null, + othIsReflexive = computed === computed, + othIsSymbol = isSymbol(computed); + + if (valIsNaN) { + var setLow = retHighest || othIsReflexive; + } else if (valIsUndefined) { + setLow = othIsReflexive && (retHighest || othIsDefined); + } else if (valIsNull) { + setLow = othIsReflexive && othIsDefined && (retHighest || !othIsNull); + } else if (valIsSymbol) { + setLow = othIsReflexive && othIsDefined && !othIsNull && (retHighest || !othIsSymbol); + } else if (othIsNull || othIsSymbol) { + setLow = false; + } else { + setLow = retHighest ? (computed <= value) : (computed < value); + } + if (setLow) { + low = mid + 1; + } else { + high = mid; + } + } + return nativeMin(high, MAX_ARRAY_INDEX); + } + + /** + * The base implementation of `_.sortedUniq` and `_.sortedUniqBy` without + * support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @returns {Array} Returns the new duplicate free array. + */ + function baseSortedUniq(array, iteratee) { + var index = -1, + length = array.length, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + if (!index || !eq(computed, seen)) { + var seen = computed; + result[resIndex++] = value === 0 ? 0 : value; + } + } + return result; + } + + /** + * The base implementation of `_.toNumber` which doesn't ensure correct + * conversions of binary, hexadecimal, or octal string values. + * + * @private + * @param {*} value The value to process. + * @returns {number} Returns the number. + */ + function baseToNumber(value) { + if (typeof value == 'number') { + return value; + } + if (isSymbol(value)) { + return NAN; + } + return +value; + } + + /** + * The base implementation of `_.toString` which doesn't convert nullish + * values to empty strings. + * + * @private + * @param {*} value The value to process. + * @returns {string} Returns the string. + */ + function baseToString(value) { + // Exit early for strings to avoid a performance hit in some environments. + if (typeof value == 'string') { + return value; + } + if (isArray(value)) { + // Recursively convert values (susceptible to call stack limits). + return arrayMap(value, baseToString) + ''; + } + if (isSymbol(value)) { + return symbolToString ? symbolToString.call(value) : ''; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; + } + + /** + * The base implementation of `_.uniqBy` without support for iteratee shorthands. + * + * @private + * @param {Array} array The array to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new duplicate free array. + */ + function baseUniq(array, iteratee, comparator) { + var index = -1, + includes = arrayIncludes, + length = array.length, + isCommon = true, + result = [], + seen = result; + + if (comparator) { + isCommon = false; + includes = arrayIncludesWith; + } + else if (length >= LARGE_ARRAY_SIZE) { + var set = iteratee ? null : createSet(array); + if (set) { + return setToArray(set); + } + isCommon = false; + includes = cacheHas; + seen = new SetCache; + } + else { + seen = iteratee ? [] : result; + } + outer: + while (++index < length) { + var value = array[index], + computed = iteratee ? iteratee(value) : value; + + value = (comparator || value !== 0) ? value : 0; + if (isCommon && computed === computed) { + var seenIndex = seen.length; + while (seenIndex--) { + if (seen[seenIndex] === computed) { + continue outer; + } + } + if (iteratee) { + seen.push(computed); + } + result.push(value); + } + else if (!includes(seen, computed, comparator)) { + if (seen !== result) { + seen.push(computed); + } + result.push(value); + } + } + return result; + } + + /** + * The base implementation of `_.unset`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The property path to unset. + * @returns {boolean} Returns `true` if the property is deleted, else `false`. + */ + function baseUnset(object, path) { + path = castPath(path, object); + object = parent(object, path); + return object == null || delete object[toKey(last(path))]; + } + + /** + * The base implementation of `_.update`. + * + * @private + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to update. + * @param {Function} updater The function to produce the updated value. + * @param {Function} [customizer] The function to customize path creation. + * @returns {Object} Returns `object`. + */ + function baseUpdate(object, path, updater, customizer) { + return baseSet(object, path, updater(baseGet(object, path)), customizer); + } + + /** + * The base implementation of methods like `_.dropWhile` and `_.takeWhile` + * without support for iteratee shorthands. + * + * @private + * @param {Array} array The array to query. + * @param {Function} predicate The function invoked per iteration. + * @param {boolean} [isDrop] Specify dropping elements instead of taking them. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Array} Returns the slice of `array`. + */ + function baseWhile(array, predicate, isDrop, fromRight) { + var length = array.length, + index = fromRight ? length : -1; + + while ((fromRight ? index-- : ++index < length) && + predicate(array[index], index, array)) {} + + return isDrop + ? baseSlice(array, (fromRight ? 0 : index), (fromRight ? index + 1 : length)) + : baseSlice(array, (fromRight ? index + 1 : 0), (fromRight ? length : index)); + } + + /** + * The base implementation of `wrapperValue` which returns the result of + * performing a sequence of actions on the unwrapped `value`, where each + * successive action is supplied the return value of the previous. + * + * @private + * @param {*} value The unwrapped value. + * @param {Array} actions Actions to perform to resolve the unwrapped value. + * @returns {*} Returns the resolved value. + */ + function baseWrapperValue(value, actions) { + var result = value; + if (result instanceof LazyWrapper) { + result = result.value(); + } + return arrayReduce(actions, function(result, action) { + return action.func.apply(action.thisArg, arrayPush([result], action.args)); + }, result); + } + + /** + * The base implementation of methods like `_.xor`, without support for + * iteratee shorthands, that accepts an array of arrays to inspect. + * + * @private + * @param {Array} arrays The arrays to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of values. + */ + function baseXor(arrays, iteratee, comparator) { + var length = arrays.length; + if (length < 2) { + return length ? baseUniq(arrays[0]) : []; + } + var index = -1, + result = Array(length); + + while (++index < length) { + var array = arrays[index], + othIndex = -1; + + while (++othIndex < length) { + if (othIndex != index) { + result[index] = baseDifference(result[index] || array, arrays[othIndex], iteratee, comparator); + } + } + } + return baseUniq(baseFlatten(result, 1), iteratee, comparator); + } + + /** + * This base implementation of `_.zipObject` which assigns values using `assignFunc`. + * + * @private + * @param {Array} props The property identifiers. + * @param {Array} values The property values. + * @param {Function} assignFunc The function to assign values. + * @returns {Object} Returns the new object. + */ + function baseZipObject(props, values, assignFunc) { + var index = -1, + length = props.length, + valsLength = values.length, + result = {}; + + while (++index < length) { + var value = index < valsLength ? values[index] : undefined; + assignFunc(result, props[index], value); + } + return result; + } + + /** + * Casts `value` to an empty array if it's not an array like object. + * + * @private + * @param {*} value The value to inspect. + * @returns {Array|Object} Returns the cast array-like object. + */ + function castArrayLikeObject(value) { + return isArrayLikeObject(value) ? value : []; + } + + /** + * Casts `value` to `identity` if it's not a function. + * + * @private + * @param {*} value The value to inspect. + * @returns {Function} Returns cast function. + */ + function castFunction(value) { + return typeof value == 'function' ? value : identity; + } + + /** + * Casts `value` to a path array if it's not one. + * + * @private + * @param {*} value The value to inspect. + * @param {Object} [object] The object to query keys on. + * @returns {Array} Returns the cast property path array. + */ + function castPath(value, object) { + if (isArray(value)) { + return value; + } + return isKey(value, object) ? [value] : stringToPath(toString(value)); + } + + /** + * A `baseRest` alias which can be replaced with `identity` by module + * replacement plugins. + * + * @private + * @type {Function} + * @param {Function} func The function to apply a rest parameter to. + * @returns {Function} Returns the new function. + */ + var castRest = baseRest; + + /** + * Casts `array` to a slice if it's needed. + * + * @private + * @param {Array} array The array to inspect. + * @param {number} start The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the cast slice. + */ + function castSlice(array, start, end) { + var length = array.length; + end = end === undefined ? length : end; + return (!start && end >= length) ? array : baseSlice(array, start, end); + } + + /** + * A simple wrapper around the global [`clearTimeout`](https://mdn.io/clearTimeout). + * + * @private + * @param {number|Object} id The timer id or timeout object of the timer to clear. + */ + var clearTimeout = ctxClearTimeout || function(id) { + return root.clearTimeout(id); + }; + + /** + * Creates a clone of `buffer`. + * + * @private + * @param {Buffer} buffer The buffer to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Buffer} Returns the cloned buffer. + */ + function cloneBuffer(buffer, isDeep) { + if (isDeep) { + return buffer.slice(); + } + var length = buffer.length, + result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length); + + buffer.copy(result); + return result; + } + + /** + * Creates a clone of `arrayBuffer`. + * + * @private + * @param {ArrayBuffer} arrayBuffer The array buffer to clone. + * @returns {ArrayBuffer} Returns the cloned array buffer. + */ + function cloneArrayBuffer(arrayBuffer) { + var result = new arrayBuffer.constructor(arrayBuffer.byteLength); + new Uint8Array(result).set(new Uint8Array(arrayBuffer)); + return result; + } + + /** + * Creates a clone of `dataView`. + * + * @private + * @param {Object} dataView The data view to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned data view. + */ + function cloneDataView(dataView, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer; + return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength); + } + + /** + * Creates a clone of `regexp`. + * + * @private + * @param {Object} regexp The regexp to clone. + * @returns {Object} Returns the cloned regexp. + */ + function cloneRegExp(regexp) { + var result = new regexp.constructor(regexp.source, reFlags.exec(regexp)); + result.lastIndex = regexp.lastIndex; + return result; + } + + /** + * Creates a clone of the `symbol` object. + * + * @private + * @param {Object} symbol The symbol object to clone. + * @returns {Object} Returns the cloned symbol object. + */ + function cloneSymbol(symbol) { + return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {}; + } + + /** + * Creates a clone of `typedArray`. + * + * @private + * @param {Object} typedArray The typed array to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the cloned typed array. + */ + function cloneTypedArray(typedArray, isDeep) { + var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer; + return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length); + } + + /** + * Compares values to sort them in ascending order. + * + * @private + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {number} Returns the sort order indicator for `value`. + */ + function compareAscending(value, other) { + if (value !== other) { + var valIsDefined = value !== undefined, + valIsNull = value === null, + valIsReflexive = value === value, + valIsSymbol = isSymbol(value); + + var othIsDefined = other !== undefined, + othIsNull = other === null, + othIsReflexive = other === other, + othIsSymbol = isSymbol(other); + + if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) || + (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) || + (valIsNull && othIsDefined && othIsReflexive) || + (!valIsDefined && othIsReflexive) || + !valIsReflexive) { + return 1; + } + if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) || + (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) || + (othIsNull && valIsDefined && valIsReflexive) || + (!othIsDefined && valIsReflexive) || + !othIsReflexive) { + return -1; + } + } + return 0; + } + + /** + * Used by `_.orderBy` to compare multiple properties of a value to another + * and stable sort them. + * + * If `orders` is unspecified, all values are sorted in ascending order. Otherwise, + * specify an order of "desc" for descending or "asc" for ascending sort order + * of corresponding values. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {boolean[]|string[]} orders The order to sort by for each property. + * @returns {number} Returns the sort order indicator for `object`. + */ + function compareMultiple(object, other, orders) { + var index = -1, + objCriteria = object.criteria, + othCriteria = other.criteria, + length = objCriteria.length, + ordersLength = orders.length; + + while (++index < length) { + var result = compareAscending(objCriteria[index], othCriteria[index]); + if (result) { + if (index >= ordersLength) { + return result; + } + var order = orders[index]; + return result * (order == 'desc' ? -1 : 1); + } + } + // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications + // that causes it, under certain circumstances, to provide the same value for + // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247 + // for more details. + // + // This also ensures a stable sort in V8 and other engines. + // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details. + return object.index - other.index; + } + + /** + * Creates an array that is the composition of partially applied arguments, + * placeholders, and provided arguments into a single array of arguments. + * + * @private + * @param {Array} args The provided arguments. + * @param {Array} partials The arguments to prepend to those provided. + * @param {Array} holders The `partials` placeholder indexes. + * @params {boolean} [isCurried] Specify composing for a curried function. + * @returns {Array} Returns the new array of composed arguments. + */ + function composeArgs(args, partials, holders, isCurried) { + var argsIndex = -1, + argsLength = args.length, + holdersLength = holders.length, + leftIndex = -1, + leftLength = partials.length, + rangeLength = nativeMax(argsLength - holdersLength, 0), + result = Array(leftLength + rangeLength), + isUncurried = !isCurried; + + while (++leftIndex < leftLength) { + result[leftIndex] = partials[leftIndex]; + } + while (++argsIndex < holdersLength) { + if (isUncurried || argsIndex < argsLength) { + result[holders[argsIndex]] = args[argsIndex]; + } + } + while (rangeLength--) { + result[leftIndex++] = args[argsIndex++]; + } + return result; + } + + /** + * This function is like `composeArgs` except that the arguments composition + * is tailored for `_.partialRight`. + * + * @private + * @param {Array} args The provided arguments. + * @param {Array} partials The arguments to append to those provided. + * @param {Array} holders The `partials` placeholder indexes. + * @params {boolean} [isCurried] Specify composing for a curried function. + * @returns {Array} Returns the new array of composed arguments. + */ + function composeArgsRight(args, partials, holders, isCurried) { + var argsIndex = -1, + argsLength = args.length, + holdersIndex = -1, + holdersLength = holders.length, + rightIndex = -1, + rightLength = partials.length, + rangeLength = nativeMax(argsLength - holdersLength, 0), + result = Array(rangeLength + rightLength), + isUncurried = !isCurried; + + while (++argsIndex < rangeLength) { + result[argsIndex] = args[argsIndex]; + } + var offset = argsIndex; + while (++rightIndex < rightLength) { + result[offset + rightIndex] = partials[rightIndex]; + } + while (++holdersIndex < holdersLength) { + if (isUncurried || argsIndex < argsLength) { + result[offset + holders[holdersIndex]] = args[argsIndex++]; + } + } + return result; + } + + /** + * Copies the values of `source` to `array`. + * + * @private + * @param {Array} source The array to copy values from. + * @param {Array} [array=[]] The array to copy values to. + * @returns {Array} Returns `array`. + */ + function copyArray(source, array) { + var index = -1, + length = source.length; + + array || (array = Array(length)); + while (++index < length) { + array[index] = source[index]; + } + return array; + } + + /** + * Copies properties of `source` to `object`. + * + * @private + * @param {Object} source The object to copy properties from. + * @param {Array} props The property identifiers to copy. + * @param {Object} [object={}] The object to copy properties to. + * @param {Function} [customizer] The function to customize copied values. + * @returns {Object} Returns `object`. + */ + function copyObject(source, props, object, customizer) { + var isNew = !object; + object || (object = {}); + + var index = -1, + length = props.length; + + while (++index < length) { + var key = props[index]; + + var newValue = customizer + ? customizer(object[key], source[key], key, object, source) + : undefined; + + if (newValue === undefined) { + newValue = source[key]; + } + if (isNew) { + baseAssignValue(object, key, newValue); + } else { + assignValue(object, key, newValue); + } + } + return object; + } + + /** + * Copies own symbols of `source` to `object`. + * + * @private + * @param {Object} source The object to copy symbols from. + * @param {Object} [object={}] The object to copy symbols to. + * @returns {Object} Returns `object`. + */ + function copySymbols(source, object) { + return copyObject(source, getSymbols(source), object); + } + + /** + * Copies own and inherited symbols of `source` to `object`. + * + * @private + * @param {Object} source The object to copy symbols from. + * @param {Object} [object={}] The object to copy symbols to. + * @returns {Object} Returns `object`. + */ + function copySymbolsIn(source, object) { + return copyObject(source, getSymbolsIn(source), object); + } + + /** + * Creates a function like `_.groupBy`. + * + * @private + * @param {Function} setter The function to set accumulator values. + * @param {Function} [initializer] The accumulator object initializer. + * @returns {Function} Returns the new aggregator function. + */ + function createAggregator(setter, initializer) { + return function(collection, iteratee) { + var func = isArray(collection) ? arrayAggregator : baseAggregator, + accumulator = initializer ? initializer() : {}; + + return func(collection, setter, getIteratee(iteratee, 2), accumulator); + }; + } + + /** + * Creates a function like `_.assign`. + * + * @private + * @param {Function} assigner The function to assign values. + * @returns {Function} Returns the new assigner function. + */ + function createAssigner(assigner) { + return baseRest(function(object, sources) { + var index = -1, + length = sources.length, + customizer = length > 1 ? sources[length - 1] : undefined, + guard = length > 2 ? sources[2] : undefined; + + customizer = (assigner.length > 3 && typeof customizer == 'function') + ? (length--, customizer) + : undefined; + + if (guard && isIterateeCall(sources[0], sources[1], guard)) { + customizer = length < 3 ? undefined : customizer; + length = 1; + } + object = Object(object); + while (++index < length) { + var source = sources[index]; + if (source) { + assigner(object, source, index, customizer); + } + } + return object; + }); + } + + /** + * Creates a `baseEach` or `baseEachRight` function. + * + * @private + * @param {Function} eachFunc The function to iterate over a collection. + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ + function createBaseEach(eachFunc, fromRight) { + return function(collection, iteratee) { + if (collection == null) { + return collection; + } + if (!isArrayLike(collection)) { + return eachFunc(collection, iteratee); + } + var length = collection.length, + index = fromRight ? length : -1, + iterable = Object(collection); + + while ((fromRight ? index-- : ++index < length)) { + if (iteratee(iterable[index], index, iterable) === false) { + break; + } + } + return collection; + }; + } + + /** + * Creates a base function for methods like `_.forIn` and `_.forOwn`. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new base function. + */ + function createBaseFor(fromRight) { + return function(object, iteratee, keysFunc) { + var index = -1, + iterable = Object(object), + props = keysFunc(object), + length = props.length; + + while (length--) { + var key = props[fromRight ? length : ++index]; + if (iteratee(iterable[key], key, iterable) === false) { + break; + } + } + return object; + }; + } + + /** + * Creates a function that wraps `func` to invoke it with the optional `this` + * binding of `thisArg`. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} [thisArg] The `this` binding of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createBind(func, bitmask, thisArg) { + var isBind = bitmask & WRAP_BIND_FLAG, + Ctor = createCtor(func); + + function wrapper() { + var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + return fn.apply(isBind ? thisArg : this, arguments); + } + return wrapper; + } + + /** + * Creates a function like `_.lowerFirst`. + * + * @private + * @param {string} methodName The name of the `String` case method to use. + * @returns {Function} Returns the new case function. + */ + function createCaseFirst(methodName) { + return function(string) { + string = toString(string); + + var strSymbols = hasUnicode(string) + ? stringToArray(string) + : undefined; + + var chr = strSymbols + ? strSymbols[0] + : string.charAt(0); + + var trailing = strSymbols + ? castSlice(strSymbols, 1).join('') + : string.slice(1); + + return chr[methodName]() + trailing; + }; + } + + /** + * Creates a function like `_.camelCase`. + * + * @private + * @param {Function} callback The function to combine each word. + * @returns {Function} Returns the new compounder function. + */ + function createCompounder(callback) { + return function(string) { + return arrayReduce(words(deburr(string).replace(reApos, '')), callback, ''); + }; + } + + /** + * Creates a function that produces an instance of `Ctor` regardless of + * whether it was invoked as part of a `new` expression or by `call` or `apply`. + * + * @private + * @param {Function} Ctor The constructor to wrap. + * @returns {Function} Returns the new wrapped function. + */ + function createCtor(Ctor) { + return function() { + // Use a `switch` statement to work with class constructors. See + // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist + // for more details. + var args = arguments; + switch (args.length) { + case 0: return new Ctor; + case 1: return new Ctor(args[0]); + case 2: return new Ctor(args[0], args[1]); + case 3: return new Ctor(args[0], args[1], args[2]); + case 4: return new Ctor(args[0], args[1], args[2], args[3]); + case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]); + case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]); + case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]); + } + var thisBinding = baseCreate(Ctor.prototype), + result = Ctor.apply(thisBinding, args); + + // Mimic the constructor's `return` behavior. + // See https://es5.github.io/#x13.2.2 for more details. + return isObject(result) ? result : thisBinding; + }; + } + + /** + * Creates a function that wraps `func` to enable currying. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {number} arity The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createCurry(func, bitmask, arity) { + var Ctor = createCtor(func); + + function wrapper() { + var length = arguments.length, + args = Array(length), + index = length, + placeholder = getHolder(wrapper); + + while (index--) { + args[index] = arguments[index]; + } + var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder) + ? [] + : replaceHolders(args, placeholder); + + length -= holders.length; + if (length < arity) { + return createRecurry( + func, bitmask, createHybrid, wrapper.placeholder, undefined, + args, holders, undefined, undefined, arity - length); + } + var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + return apply(fn, this, args); + } + return wrapper; + } + + /** + * Creates a `_.find` or `_.findLast` function. + * + * @private + * @param {Function} findIndexFunc The function to find the collection index. + * @returns {Function} Returns the new find function. + */ + function createFind(findIndexFunc) { + return function(collection, predicate, fromIndex) { + var iterable = Object(collection); + if (!isArrayLike(collection)) { + var iteratee = getIteratee(predicate, 3); + collection = keys(collection); + predicate = function(key) { return iteratee(iterable[key], key, iterable); }; + } + var index = findIndexFunc(collection, predicate, fromIndex); + return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined; + }; + } + + /** + * Creates a `_.flow` or `_.flowRight` function. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new flow function. + */ + function createFlow(fromRight) { + return flatRest(function(funcs) { + var length = funcs.length, + index = length, + prereq = LodashWrapper.prototype.thru; + + if (fromRight) { + funcs.reverse(); + } + while (index--) { + var func = funcs[index]; + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + if (prereq && !wrapper && getFuncName(func) == 'wrapper') { + var wrapper = new LodashWrapper([], true); + } + } + index = wrapper ? index : length; + while (++index < length) { + func = funcs[index]; + + var funcName = getFuncName(func), + data = funcName == 'wrapper' ? getData(func) : undefined; + + if (data && isLaziable(data[0]) && + data[1] == (WRAP_ARY_FLAG | WRAP_CURRY_FLAG | WRAP_PARTIAL_FLAG | WRAP_REARG_FLAG) && + !data[4].length && data[9] == 1 + ) { + wrapper = wrapper[getFuncName(data[0])].apply(wrapper, data[3]); + } else { + wrapper = (func.length == 1 && isLaziable(func)) + ? wrapper[funcName]() + : wrapper.thru(func); + } + } + return function() { + var args = arguments, + value = args[0]; + + if (wrapper && args.length == 1 && isArray(value)) { + return wrapper.plant(value).value(); + } + var index = 0, + result = length ? funcs[index].apply(this, args) : value; + + while (++index < length) { + result = funcs[index].call(this, result); + } + return result; + }; + }); + } + + /** + * Creates a function that wraps `func` to invoke it with optional `this` + * binding of `thisArg`, partial application, and currying. + * + * @private + * @param {Function|string} func The function or method name to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} [thisArg] The `this` binding of `func`. + * @param {Array} [partials] The arguments to prepend to those provided to + * the new function. + * @param {Array} [holders] The `partials` placeholder indexes. + * @param {Array} [partialsRight] The arguments to append to those provided + * to the new function. + * @param {Array} [holdersRight] The `partialsRight` placeholder indexes. + * @param {Array} [argPos] The argument positions of the new function. + * @param {number} [ary] The arity cap of `func`. + * @param {number} [arity] The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) { + var isAry = bitmask & WRAP_ARY_FLAG, + isBind = bitmask & WRAP_BIND_FLAG, + isBindKey = bitmask & WRAP_BIND_KEY_FLAG, + isCurried = bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG), + isFlip = bitmask & WRAP_FLIP_FLAG, + Ctor = isBindKey ? undefined : createCtor(func); + + function wrapper() { + var length = arguments.length, + args = Array(length), + index = length; + + while (index--) { + args[index] = arguments[index]; + } + if (isCurried) { + var placeholder = getHolder(wrapper), + holdersCount = countHolders(args, placeholder); + } + if (partials) { + args = composeArgs(args, partials, holders, isCurried); + } + if (partialsRight) { + args = composeArgsRight(args, partialsRight, holdersRight, isCurried); + } + length -= holdersCount; + if (isCurried && length < arity) { + var newHolders = replaceHolders(args, placeholder); + return createRecurry( + func, bitmask, createHybrid, wrapper.placeholder, thisArg, + args, newHolders, argPos, ary, arity - length + ); + } + var thisBinding = isBind ? thisArg : this, + fn = isBindKey ? thisBinding[func] : func; + + length = args.length; + if (argPos) { + args = reorder(args, argPos); + } else if (isFlip && length > 1) { + args.reverse(); + } + if (isAry && ary < length) { + args.length = ary; + } + if (this && this !== root && this instanceof wrapper) { + fn = Ctor || createCtor(fn); + } + return fn.apply(thisBinding, args); + } + return wrapper; + } + + /** + * Creates a function like `_.invertBy`. + * + * @private + * @param {Function} setter The function to set accumulator values. + * @param {Function} toIteratee The function to resolve iteratees. + * @returns {Function} Returns the new inverter function. + */ + function createInverter(setter, toIteratee) { + return function(object, iteratee) { + return baseInverter(object, setter, toIteratee(iteratee), {}); + }; + } + + /** + * Creates a function that performs a mathematical operation on two values. + * + * @private + * @param {Function} operator The function to perform the operation. + * @param {number} [defaultValue] The value used for `undefined` arguments. + * @returns {Function} Returns the new mathematical operation function. + */ + function createMathOperation(operator, defaultValue) { + return function(value, other) { + var result; + if (value === undefined && other === undefined) { + return defaultValue; + } + if (value !== undefined) { + result = value; + } + if (other !== undefined) { + if (result === undefined) { + return other; + } + if (typeof value == 'string' || typeof other == 'string') { + value = baseToString(value); + other = baseToString(other); + } else { + value = baseToNumber(value); + other = baseToNumber(other); + } + result = operator(value, other); + } + return result; + }; + } + + /** + * Creates a function like `_.over`. + * + * @private + * @param {Function} arrayFunc The function to iterate over iteratees. + * @returns {Function} Returns the new over function. + */ + function createOver(arrayFunc) { + return flatRest(function(iteratees) { + iteratees = arrayMap(iteratees, baseUnary(getIteratee())); + return baseRest(function(args) { + var thisArg = this; + return arrayFunc(iteratees, function(iteratee) { + return apply(iteratee, thisArg, args); + }); + }); + }); + } + + /** + * Creates the padding for `string` based on `length`. The `chars` string + * is truncated if the number of characters exceeds `length`. + * + * @private + * @param {number} length The padding length. + * @param {string} [chars=' '] The string used as padding. + * @returns {string} Returns the padding for `string`. + */ + function createPadding(length, chars) { + chars = chars === undefined ? ' ' : baseToString(chars); + + var charsLength = chars.length; + if (charsLength < 2) { + return charsLength ? baseRepeat(chars, length) : chars; + } + var result = baseRepeat(chars, nativeCeil(length / stringSize(chars))); + return hasUnicode(chars) + ? castSlice(stringToArray(result), 0, length).join('') + : result.slice(0, length); + } + + /** + * Creates a function that wraps `func` to invoke it with the `this` binding + * of `thisArg` and `partials` prepended to the arguments it receives. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {*} thisArg The `this` binding of `func`. + * @param {Array} partials The arguments to prepend to those provided to + * the new function. + * @returns {Function} Returns the new wrapped function. + */ + function createPartial(func, bitmask, thisArg, partials) { + var isBind = bitmask & WRAP_BIND_FLAG, + Ctor = createCtor(func); + + function wrapper() { + var argsIndex = -1, + argsLength = arguments.length, + leftIndex = -1, + leftLength = partials.length, + args = Array(leftLength + argsLength), + fn = (this && this !== root && this instanceof wrapper) ? Ctor : func; + + while (++leftIndex < leftLength) { + args[leftIndex] = partials[leftIndex]; + } + while (argsLength--) { + args[leftIndex++] = arguments[++argsIndex]; + } + return apply(fn, isBind ? thisArg : this, args); + } + return wrapper; + } + + /** + * Creates a `_.range` or `_.rangeRight` function. + * + * @private + * @param {boolean} [fromRight] Specify iterating from right to left. + * @returns {Function} Returns the new range function. + */ + function createRange(fromRight) { + return function(start, end, step) { + if (step && typeof step != 'number' && isIterateeCall(start, end, step)) { + end = step = undefined; + } + // Ensure the sign of `-0` is preserved. + start = toFinite(start); + if (end === undefined) { + end = start; + start = 0; + } else { + end = toFinite(end); + } + step = step === undefined ? (start < end ? 1 : -1) : toFinite(step); + return baseRange(start, end, step, fromRight); + }; + } + + /** + * Creates a function that performs a relational operation on two values. + * + * @private + * @param {Function} operator The function to perform the operation. + * @returns {Function} Returns the new relational operation function. + */ + function createRelationalOperation(operator) { + return function(value, other) { + if (!(typeof value == 'string' && typeof other == 'string')) { + value = toNumber(value); + other = toNumber(other); + } + return operator(value, other); + }; + } + + /** + * Creates a function that wraps `func` to continue currying. + * + * @private + * @param {Function} func The function to wrap. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @param {Function} wrapFunc The function to create the `func` wrapper. + * @param {*} placeholder The placeholder value. + * @param {*} [thisArg] The `this` binding of `func`. + * @param {Array} [partials] The arguments to prepend to those provided to + * the new function. + * @param {Array} [holders] The `partials` placeholder indexes. + * @param {Array} [argPos] The argument positions of the new function. + * @param {number} [ary] The arity cap of `func`. + * @param {number} [arity] The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) { + var isCurry = bitmask & WRAP_CURRY_FLAG, + newHolders = isCurry ? holders : undefined, + newHoldersRight = isCurry ? undefined : holders, + newPartials = isCurry ? partials : undefined, + newPartialsRight = isCurry ? undefined : partials; + + bitmask |= (isCurry ? WRAP_PARTIAL_FLAG : WRAP_PARTIAL_RIGHT_FLAG); + bitmask &= ~(isCurry ? WRAP_PARTIAL_RIGHT_FLAG : WRAP_PARTIAL_FLAG); + + if (!(bitmask & WRAP_CURRY_BOUND_FLAG)) { + bitmask &= ~(WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG); + } + var newData = [ + func, bitmask, thisArg, newPartials, newHolders, newPartialsRight, + newHoldersRight, argPos, ary, arity + ]; + + var result = wrapFunc.apply(undefined, newData); + if (isLaziable(func)) { + setData(result, newData); + } + result.placeholder = placeholder; + return setWrapToString(result, func, bitmask); + } + + /** + * Creates a function like `_.round`. + * + * @private + * @param {string} methodName The name of the `Math` method to use when rounding. + * @returns {Function} Returns the new round function. + */ + function createRound(methodName) { + var func = Math[methodName]; + return function(number, precision) { + number = toNumber(number); + precision = precision == null ? 0 : nativeMin(toInteger(precision), 292); + if (precision && nativeIsFinite(number)) { + // Shift with exponential notation to avoid floating-point issues. + // See [MDN](https://mdn.io/round#Examples) for more details. + var pair = (toString(number) + 'e').split('e'), + value = func(pair[0] + 'e' + (+pair[1] + precision)); + + pair = (toString(value) + 'e').split('e'); + return +(pair[0] + 'e' + (+pair[1] - precision)); + } + return func(number); + }; + } + + /** + * Creates a set object of `values`. + * + * @private + * @param {Array} values The values to add to the set. + * @returns {Object} Returns the new set. + */ + var createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) { + return new Set(values); + }; + + /** + * Creates a `_.toPairs` or `_.toPairsIn` function. + * + * @private + * @param {Function} keysFunc The function to get the keys of a given object. + * @returns {Function} Returns the new pairs function. + */ + function createToPairs(keysFunc) { + return function(object) { + var tag = getTag(object); + if (tag == mapTag) { + return mapToArray(object); + } + if (tag == setTag) { + return setToPairs(object); + } + return baseToPairs(object, keysFunc(object)); + }; + } + + /** + * Creates a function that either curries or invokes `func` with optional + * `this` binding and partially applied arguments. + * + * @private + * @param {Function|string} func The function or method name to wrap. + * @param {number} bitmask The bitmask flags. + * 1 - `_.bind` + * 2 - `_.bindKey` + * 4 - `_.curry` or `_.curryRight` of a bound function + * 8 - `_.curry` + * 16 - `_.curryRight` + * 32 - `_.partial` + * 64 - `_.partialRight` + * 128 - `_.rearg` + * 256 - `_.ary` + * 512 - `_.flip` + * @param {*} [thisArg] The `this` binding of `func`. + * @param {Array} [partials] The arguments to be partially applied. + * @param {Array} [holders] The `partials` placeholder indexes. + * @param {Array} [argPos] The argument positions of the new function. + * @param {number} [ary] The arity cap of `func`. + * @param {number} [arity] The arity of `func`. + * @returns {Function} Returns the new wrapped function. + */ + function createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) { + var isBindKey = bitmask & WRAP_BIND_KEY_FLAG; + if (!isBindKey && typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + var length = partials ? partials.length : 0; + if (!length) { + bitmask &= ~(WRAP_PARTIAL_FLAG | WRAP_PARTIAL_RIGHT_FLAG); + partials = holders = undefined; + } + ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0); + arity = arity === undefined ? arity : toInteger(arity); + length -= holders ? holders.length : 0; + + if (bitmask & WRAP_PARTIAL_RIGHT_FLAG) { + var partialsRight = partials, + holdersRight = holders; + + partials = holders = undefined; + } + var data = isBindKey ? undefined : getData(func); + + var newData = [ + func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, + argPos, ary, arity + ]; + + if (data) { + mergeData(newData, data); + } + func = newData[0]; + bitmask = newData[1]; + thisArg = newData[2]; + partials = newData[3]; + holders = newData[4]; + arity = newData[9] = newData[9] === undefined + ? (isBindKey ? 0 : func.length) + : nativeMax(newData[9] - length, 0); + + if (!arity && bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG)) { + bitmask &= ~(WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG); + } + if (!bitmask || bitmask == WRAP_BIND_FLAG) { + var result = createBind(func, bitmask, thisArg); + } else if (bitmask == WRAP_CURRY_FLAG || bitmask == WRAP_CURRY_RIGHT_FLAG) { + result = createCurry(func, bitmask, arity); + } else if ((bitmask == WRAP_PARTIAL_FLAG || bitmask == (WRAP_BIND_FLAG | WRAP_PARTIAL_FLAG)) && !holders.length) { + result = createPartial(func, bitmask, thisArg, partials); + } else { + result = createHybrid.apply(undefined, newData); + } + var setter = data ? baseSetData : setData; + return setWrapToString(setter(result, newData), func, bitmask); + } + + /** + * Used by `_.defaults` to customize its `_.assignIn` use to assign properties + * of source objects to the destination object for all destination properties + * that resolve to `undefined`. + * + * @private + * @param {*} objValue The destination value. + * @param {*} srcValue The source value. + * @param {string} key The key of the property to assign. + * @param {Object} object The parent object of `objValue`. + * @returns {*} Returns the value to assign. + */ + function customDefaultsAssignIn(objValue, srcValue, key, object) { + if (objValue === undefined || + (eq(objValue, objectProto[key]) && !hasOwnProperty.call(object, key))) { + return srcValue; + } + return objValue; + } + + /** + * Used by `_.defaultsDeep` to customize its `_.merge` use to merge source + * objects into destination objects that are passed thru. + * + * @private + * @param {*} objValue The destination value. + * @param {*} srcValue The source value. + * @param {string} key The key of the property to merge. + * @param {Object} object The parent object of `objValue`. + * @param {Object} source The parent object of `srcValue`. + * @param {Object} [stack] Tracks traversed source values and their merged + * counterparts. + * @returns {*} Returns the value to assign. + */ + function customDefaultsMerge(objValue, srcValue, key, object, source, stack) { + if (isObject(objValue) && isObject(srcValue)) { + // Recursively merge objects and arrays (susceptible to call stack limits). + stack.set(srcValue, objValue); + baseMerge(objValue, srcValue, undefined, customDefaultsMerge, stack); + stack['delete'](srcValue); + } + return objValue; + } + + /** + * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain + * objects. + * + * @private + * @param {*} value The value to inspect. + * @param {string} key The key of the property to inspect. + * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`. + */ + function customOmitClone(value) { + return isPlainObject(value) ? undefined : value; + } + + /** + * A specialized version of `baseIsEqualDeep` for arrays with support for + * partial deep comparisons. + * + * @private + * @param {Array} array The array to compare. + * @param {Array} other The other array to compare. + * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details. + * @param {Function} customizer The function to customize comparisons. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Object} stack Tracks traversed `array` and `other` objects. + * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`. + */ + function equalArrays(array, other, bitmask, customizer, equalFunc, stack) { + var isPartial = bitmask & COMPARE_PARTIAL_FLAG, + arrLength = array.length, + othLength = other.length; + + if (arrLength != othLength && !(isPartial && othLength > arrLength)) { + return false; + } + // Check that cyclic values are equal. + var arrStacked = stack.get(array); + var othStacked = stack.get(other); + if (arrStacked && othStacked) { + return arrStacked == other && othStacked == array; + } + var index = -1, + result = true, + seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined; + + stack.set(array, other); + stack.set(other, array); + + // Ignore non-index properties. + while (++index < arrLength) { + var arrValue = array[index], + othValue = other[index]; + + if (customizer) { + var compared = isPartial + ? customizer(othValue, arrValue, index, other, array, stack) + : customizer(arrValue, othValue, index, array, other, stack); + } + if (compared !== undefined) { + if (compared) { + continue; + } + result = false; + break; + } + // Recursively compare arrays (susceptible to call stack limits). + if (seen) { + if (!arraySome(other, function(othValue, othIndex) { + if (!cacheHas(seen, othIndex) && + (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) { + return seen.push(othIndex); + } + })) { + result = false; + break; + } + } else if (!( + arrValue === othValue || + equalFunc(arrValue, othValue, bitmask, customizer, stack) + )) { + result = false; + break; + } + } + stack['delete'](array); + stack['delete'](other); + return result; + } + + /** + * A specialized version of `baseIsEqualDeep` for comparing objects of + * the same `toStringTag`. + * + * **Note:** This function only supports comparing values with tags of + * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {string} tag The `toStringTag` of the objects to compare. + * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details. + * @param {Function} customizer The function to customize comparisons. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ + function equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) { + switch (tag) { + case dataViewTag: + if ((object.byteLength != other.byteLength) || + (object.byteOffset != other.byteOffset)) { + return false; + } + object = object.buffer; + other = other.buffer; + + case arrayBufferTag: + if ((object.byteLength != other.byteLength) || + !equalFunc(new Uint8Array(object), new Uint8Array(other))) { + return false; + } + return true; + + case boolTag: + case dateTag: + case numberTag: + // Coerce booleans to `1` or `0` and dates to milliseconds. + // Invalid dates are coerced to `NaN`. + return eq(+object, +other); + + case errorTag: + return object.name == other.name && object.message == other.message; + + case regexpTag: + case stringTag: + // Coerce regexes to strings and treat strings, primitives and objects, + // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring + // for more details. + return object == (other + ''); + + case mapTag: + var convert = mapToArray; + + case setTag: + var isPartial = bitmask & COMPARE_PARTIAL_FLAG; + convert || (convert = setToArray); + + if (object.size != other.size && !isPartial) { + return false; + } + // Assume cyclic values are equal. + var stacked = stack.get(object); + if (stacked) { + return stacked == other; + } + bitmask |= COMPARE_UNORDERED_FLAG; + + // Recursively compare objects (susceptible to call stack limits). + stack.set(object, other); + var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack); + stack['delete'](object); + return result; + + case symbolTag: + if (symbolValueOf) { + return symbolValueOf.call(object) == symbolValueOf.call(other); + } + } + return false; + } + + /** + * A specialized version of `baseIsEqualDeep` for objects with support for + * partial deep comparisons. + * + * @private + * @param {Object} object The object to compare. + * @param {Object} other The other object to compare. + * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details. + * @param {Function} customizer The function to customize comparisons. + * @param {Function} equalFunc The function to determine equivalents of values. + * @param {Object} stack Tracks traversed `object` and `other` objects. + * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. + */ + function equalObjects(object, other, bitmask, customizer, equalFunc, stack) { + var isPartial = bitmask & COMPARE_PARTIAL_FLAG, + objProps = getAllKeys(object), + objLength = objProps.length, + othProps = getAllKeys(other), + othLength = othProps.length; + + if (objLength != othLength && !isPartial) { + return false; + } + var index = objLength; + while (index--) { + var key = objProps[index]; + if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) { + return false; + } + } + // Check that cyclic values are equal. + var objStacked = stack.get(object); + var othStacked = stack.get(other); + if (objStacked && othStacked) { + return objStacked == other && othStacked == object; + } + var result = true; + stack.set(object, other); + stack.set(other, object); + + var skipCtor = isPartial; + while (++index < objLength) { + key = objProps[index]; + var objValue = object[key], + othValue = other[key]; + + if (customizer) { + var compared = isPartial + ? customizer(othValue, objValue, key, other, object, stack) + : customizer(objValue, othValue, key, object, other, stack); + } + // Recursively compare objects (susceptible to call stack limits). + if (!(compared === undefined + ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack)) + : compared + )) { + result = false; + break; + } + skipCtor || (skipCtor = key == 'constructor'); + } + if (result && !skipCtor) { + var objCtor = object.constructor, + othCtor = other.constructor; + + // Non `Object` object instances with different constructors are not equal. + if (objCtor != othCtor && + ('constructor' in object && 'constructor' in other) && + !(typeof objCtor == 'function' && objCtor instanceof objCtor && + typeof othCtor == 'function' && othCtor instanceof othCtor)) { + result = false; + } + } + stack['delete'](object); + stack['delete'](other); + return result; + } + + /** + * A specialized version of `baseRest` which flattens the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @returns {Function} Returns the new function. + */ + function flatRest(func) { + return setToString(overRest(func, undefined, flatten), func + ''); + } + + /** + * Creates an array of own enumerable property names and symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names and symbols. + */ + function getAllKeys(object) { + return baseGetAllKeys(object, keys, getSymbols); + } + + /** + * Creates an array of own and inherited enumerable property names and + * symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names and symbols. + */ + function getAllKeysIn(object) { + return baseGetAllKeys(object, keysIn, getSymbolsIn); + } + + /** + * Gets metadata for `func`. + * + * @private + * @param {Function} func The function to query. + * @returns {*} Returns the metadata for `func`. + */ + var getData = !metaMap ? noop : function(func) { + return metaMap.get(func); + }; + + /** + * Gets the name of `func`. + * + * @private + * @param {Function} func The function to query. + * @returns {string} Returns the function name. + */ + function getFuncName(func) { + var result = (func.name + ''), + array = realNames[result], + length = hasOwnProperty.call(realNames, result) ? array.length : 0; + + while (length--) { + var data = array[length], + otherFunc = data.func; + if (otherFunc == null || otherFunc == func) { + return data.name; + } + } + return result; + } + + /** + * Gets the argument placeholder value for `func`. + * + * @private + * @param {Function} func The function to inspect. + * @returns {*} Returns the placeholder value. + */ + function getHolder(func) { + var object = hasOwnProperty.call(lodash, 'placeholder') ? lodash : func; + return object.placeholder; + } + + /** + * Gets the appropriate "iteratee" function. If `_.iteratee` is customized, + * this function returns the custom method, otherwise it returns `baseIteratee`. + * If arguments are provided, the chosen function is invoked with them and + * its result is returned. + * + * @private + * @param {*} [value] The value to convert to an iteratee. + * @param {number} [arity] The arity of the created iteratee. + * @returns {Function} Returns the chosen function or its result. + */ + function getIteratee() { + var result = lodash.iteratee || iteratee; + result = result === iteratee ? baseIteratee : result; + return arguments.length ? result(arguments[0], arguments[1]) : result; + } + + /** + * Gets the data for `map`. + * + * @private + * @param {Object} map The map to query. + * @param {string} key The reference key. + * @returns {*} Returns the map data. + */ + function getMapData(map, key) { + var data = map.__data__; + return isKeyable(key) + ? data[typeof key == 'string' ? 'string' : 'hash'] + : data.map; + } + + /** + * Gets the property names, values, and compare flags of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the match data of `object`. + */ + function getMatchData(object) { + var result = keys(object), + length = result.length; + + while (length--) { + var key = result[length], + value = object[key]; + + result[length] = [key, value, isStrictComparable(value)]; + } + return result; + } + + /** + * Gets the native function at `key` of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {string} key The key of the method to get. + * @returns {*} Returns the function if it's native, else `undefined`. + */ + function getNative(object, key) { + var value = getValue(object, key); + return baseIsNative(value) ? value : undefined; + } + + /** + * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the raw `toStringTag`. + */ + function getRawTag(value) { + var isOwn = hasOwnProperty.call(value, symToStringTag), + tag = value[symToStringTag]; + + try { + value[symToStringTag] = undefined; + var unmasked = true; + } catch (e) {} + + var result = nativeObjectToString.call(value); + if (unmasked) { + if (isOwn) { + value[symToStringTag] = tag; + } else { + delete value[symToStringTag]; + } + } + return result; + } + + /** + * Creates an array of the own enumerable symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. + */ + var getSymbols = !nativeGetSymbols ? stubArray : function(object) { + if (object == null) { + return []; + } + object = Object(object); + return arrayFilter(nativeGetSymbols(object), function(symbol) { + return propertyIsEnumerable.call(object, symbol); + }); + }; + + /** + * Creates an array of the own and inherited enumerable symbols of `object`. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of symbols. + */ + var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) { + var result = []; + while (object) { + arrayPush(result, getSymbols(object)); + object = getPrototype(object); + } + return result; + }; + + /** + * Gets the `toStringTag` of `value`. + * + * @private + * @param {*} value The value to query. + * @returns {string} Returns the `toStringTag`. + */ + var getTag = baseGetTag; + + // Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6. + if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) || + (Map && getTag(new Map) != mapTag) || + (Promise && getTag(Promise.resolve()) != promiseTag) || + (Set && getTag(new Set) != setTag) || + (WeakMap && getTag(new WeakMap) != weakMapTag)) { + getTag = function(value) { + var result = baseGetTag(value), + Ctor = result == objectTag ? value.constructor : undefined, + ctorString = Ctor ? toSource(Ctor) : ''; + + if (ctorString) { + switch (ctorString) { + case dataViewCtorString: return dataViewTag; + case mapCtorString: return mapTag; + case promiseCtorString: return promiseTag; + case setCtorString: return setTag; + case weakMapCtorString: return weakMapTag; + } + } + return result; + }; + } + + /** + * Gets the view, applying any `transforms` to the `start` and `end` positions. + * + * @private + * @param {number} start The start of the view. + * @param {number} end The end of the view. + * @param {Array} transforms The transformations to apply to the view. + * @returns {Object} Returns an object containing the `start` and `end` + * positions of the view. + */ + function getView(start, end, transforms) { + var index = -1, + length = transforms.length; + + while (++index < length) { + var data = transforms[index], + size = data.size; + + switch (data.type) { + case 'drop': start += size; break; + case 'dropRight': end -= size; break; + case 'take': end = nativeMin(end, start + size); break; + case 'takeRight': start = nativeMax(start, end - size); break; + } + } + return { 'start': start, 'end': end }; + } + + /** + * Extracts wrapper details from the `source` body comment. + * + * @private + * @param {string} source The source to inspect. + * @returns {Array} Returns the wrapper details. + */ + function getWrapDetails(source) { + var match = source.match(reWrapDetails); + return match ? match[1].split(reSplitDetails) : []; + } + + /** + * Checks if `path` exists on `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @param {Function} hasFunc The function to check properties. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + */ + function hasPath(object, path, hasFunc) { + path = castPath(path, object); + + var index = -1, + length = path.length, + result = false; + + while (++index < length) { + var key = toKey(path[index]); + if (!(result = object != null && hasFunc(object, key))) { + break; + } + object = object[key]; + } + if (result || ++index != length) { + return result; + } + length = object == null ? 0 : object.length; + return !!length && isLength(length) && isIndex(key, length) && + (isArray(object) || isArguments(object)); + } + + /** + * Initializes an array clone. + * + * @private + * @param {Array} array The array to clone. + * @returns {Array} Returns the initialized clone. + */ + function initCloneArray(array) { + var length = array.length, + result = new array.constructor(length); + + // Add properties assigned by `RegExp#exec`. + if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) { + result.index = array.index; + result.input = array.input; + } + return result; + } + + /** + * Initializes an object clone. + * + * @private + * @param {Object} object The object to clone. + * @returns {Object} Returns the initialized clone. + */ + function initCloneObject(object) { + return (typeof object.constructor == 'function' && !isPrototype(object)) + ? baseCreate(getPrototype(object)) + : {}; + } + + /** + * Initializes an object clone based on its `toStringTag`. + * + * **Note:** This function only supports cloning values with tags of + * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`. + * + * @private + * @param {Object} object The object to clone. + * @param {string} tag The `toStringTag` of the object to clone. + * @param {boolean} [isDeep] Specify a deep clone. + * @returns {Object} Returns the initialized clone. + */ + function initCloneByTag(object, tag, isDeep) { + var Ctor = object.constructor; + switch (tag) { + case arrayBufferTag: + return cloneArrayBuffer(object); + + case boolTag: + case dateTag: + return new Ctor(+object); + + case dataViewTag: + return cloneDataView(object, isDeep); + + case float32Tag: case float64Tag: + case int8Tag: case int16Tag: case int32Tag: + case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag: + return cloneTypedArray(object, isDeep); + + case mapTag: + return new Ctor; + + case numberTag: + case stringTag: + return new Ctor(object); + + case regexpTag: + return cloneRegExp(object); + + case setTag: + return new Ctor; + + case symbolTag: + return cloneSymbol(object); + } + } + + /** + * Inserts wrapper `details` in a comment at the top of the `source` body. + * + * @private + * @param {string} source The source to modify. + * @returns {Array} details The details to insert. + * @returns {string} Returns the modified source. + */ + function insertWrapDetails(source, details) { + var length = details.length; + if (!length) { + return source; + } + var lastIndex = length - 1; + details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex]; + details = details.join(length > 2 ? ', ' : ' '); + return source.replace(reWrapComment, '{\n/* [wrapped with ' + details + '] */\n'); + } + + /** + * Checks if `value` is a flattenable `arguments` object or array. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is flattenable, else `false`. + */ + function isFlattenable(value) { + return isArray(value) || isArguments(value) || + !!(spreadableSymbol && value && value[spreadableSymbol]); + } + + /** + * Checks if `value` is a valid array-like index. + * + * @private + * @param {*} value The value to check. + * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index. + * @returns {boolean} Returns `true` if `value` is a valid index, else `false`. + */ + function isIndex(value, length) { + var type = typeof value; + length = length == null ? MAX_SAFE_INTEGER : length; + + return !!length && + (type == 'number' || + (type != 'symbol' && reIsUint.test(value))) && + (value > -1 && value % 1 == 0 && value < length); + } + + /** + * Checks if the given arguments are from an iteratee call. + * + * @private + * @param {*} value The potential iteratee value argument. + * @param {*} index The potential iteratee index or key argument. + * @param {*} object The potential iteratee object argument. + * @returns {boolean} Returns `true` if the arguments are from an iteratee call, + * else `false`. + */ + function isIterateeCall(value, index, object) { + if (!isObject(object)) { + return false; + } + var type = typeof index; + if (type == 'number' + ? (isArrayLike(object) && isIndex(index, object.length)) + : (type == 'string' && index in object) + ) { + return eq(object[index], value); + } + return false; + } + + /** + * Checks if `value` is a property name and not a property path. + * + * @private + * @param {*} value The value to check. + * @param {Object} [object] The object to query keys on. + * @returns {boolean} Returns `true` if `value` is a property name, else `false`. + */ + function isKey(value, object) { + if (isArray(value)) { + return false; + } + var type = typeof value; + if (type == 'number' || type == 'symbol' || type == 'boolean' || + value == null || isSymbol(value)) { + return true; + } + return reIsPlainProp.test(value) || !reIsDeepProp.test(value) || + (object != null && value in Object(object)); + } + + /** + * Checks if `value` is suitable for use as unique object key. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is suitable, else `false`. + */ + function isKeyable(value) { + var type = typeof value; + return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean') + ? (value !== '__proto__') + : (value === null); + } + + /** + * Checks if `func` has a lazy counterpart. + * + * @private + * @param {Function} func The function to check. + * @returns {boolean} Returns `true` if `func` has a lazy counterpart, + * else `false`. + */ + function isLaziable(func) { + var funcName = getFuncName(func), + other = lodash[funcName]; + + if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) { + return false; + } + if (func === other) { + return true; + } + var data = getData(other); + return !!data && func === data[0]; + } + + /** + * Checks if `func` has its source masked. + * + * @private + * @param {Function} func The function to check. + * @returns {boolean} Returns `true` if `func` is masked, else `false`. + */ + function isMasked(func) { + return !!maskSrcKey && (maskSrcKey in func); + } + + /** + * Checks if `func` is capable of being masked. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `func` is maskable, else `false`. + */ + var isMaskable = coreJsData ? isFunction : stubFalse; + + /** + * Checks if `value` is likely a prototype object. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a prototype, else `false`. + */ + function isPrototype(value) { + var Ctor = value && value.constructor, + proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto; + + return value === proto; + } + + /** + * Checks if `value` is suitable for strict equality comparisons, i.e. `===`. + * + * @private + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` if suitable for strict + * equality comparisons, else `false`. + */ + function isStrictComparable(value) { + return value === value && !isObject(value); + } + + /** + * A specialized version of `matchesProperty` for source values suitable + * for strict equality comparisons, i.e. `===`. + * + * @private + * @param {string} key The key of the property to get. + * @param {*} srcValue The value to match. + * @returns {Function} Returns the new spec function. + */ + function matchesStrictComparable(key, srcValue) { + return function(object) { + if (object == null) { + return false; + } + return object[key] === srcValue && + (srcValue !== undefined || (key in Object(object))); + }; + } + + /** + * A specialized version of `_.memoize` which clears the memoized function's + * cache when it exceeds `MAX_MEMOIZE_SIZE`. + * + * @private + * @param {Function} func The function to have its output memoized. + * @returns {Function} Returns the new memoized function. + */ + function memoizeCapped(func) { + var result = memoize(func, function(key) { + if (cache.size === MAX_MEMOIZE_SIZE) { + cache.clear(); + } + return key; + }); + + var cache = result.cache; + return result; + } + + /** + * Merges the function metadata of `source` into `data`. + * + * Merging metadata reduces the number of wrappers used to invoke a function. + * This is possible because methods like `_.bind`, `_.curry`, and `_.partial` + * may be applied regardless of execution order. Methods like `_.ary` and + * `_.rearg` modify function arguments, making the order in which they are + * executed important, preventing the merging of metadata. However, we make + * an exception for a safe combined case where curried functions have `_.ary` + * and or `_.rearg` applied. + * + * @private + * @param {Array} data The destination metadata. + * @param {Array} source The source metadata. + * @returns {Array} Returns `data`. + */ + function mergeData(data, source) { + var bitmask = data[1], + srcBitmask = source[1], + newBitmask = bitmask | srcBitmask, + isCommon = newBitmask < (WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG | WRAP_ARY_FLAG); + + var isCombo = + ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_CURRY_FLAG)) || + ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_REARG_FLAG) && (data[7].length <= source[8])) || + ((srcBitmask == (WRAP_ARY_FLAG | WRAP_REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == WRAP_CURRY_FLAG)); + + // Exit early if metadata can't be merged. + if (!(isCommon || isCombo)) { + return data; + } + // Use source `thisArg` if available. + if (srcBitmask & WRAP_BIND_FLAG) { + data[2] = source[2]; + // Set when currying a bound function. + newBitmask |= bitmask & WRAP_BIND_FLAG ? 0 : WRAP_CURRY_BOUND_FLAG; + } + // Compose partial arguments. + var value = source[3]; + if (value) { + var partials = data[3]; + data[3] = partials ? composeArgs(partials, value, source[4]) : value; + data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4]; + } + // Compose partial right arguments. + value = source[5]; + if (value) { + partials = data[5]; + data[5] = partials ? composeArgsRight(partials, value, source[6]) : value; + data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6]; + } + // Use source `argPos` if available. + value = source[7]; + if (value) { + data[7] = value; + } + // Use source `ary` if it's smaller. + if (srcBitmask & WRAP_ARY_FLAG) { + data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]); + } + // Use source `arity` if one is not provided. + if (data[9] == null) { + data[9] = source[9]; + } + // Use source `func` and merge bitmasks. + data[0] = source[0]; + data[1] = newBitmask; + + return data; + } + + /** + * This function is like + * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) + * except that it includes inherited enumerable properties. + * + * @private + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + */ + function nativeKeysIn(object) { + var result = []; + if (object != null) { + for (var key in Object(object)) { + result.push(key); + } + } + return result; + } + + /** + * Converts `value` to a string using `Object.prototype.toString`. + * + * @private + * @param {*} value The value to convert. + * @returns {string} Returns the converted string. + */ + function objectToString(value) { + return nativeObjectToString.call(value); + } + + /** + * A specialized version of `baseRest` which transforms the rest array. + * + * @private + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @param {Function} transform The rest array transform. + * @returns {Function} Returns the new function. + */ + function overRest(func, start, transform) { + start = nativeMax(start === undefined ? (func.length - 1) : start, 0); + return function() { + var args = arguments, + index = -1, + length = nativeMax(args.length - start, 0), + array = Array(length); + + while (++index < length) { + array[index] = args[start + index]; + } + index = -1; + var otherArgs = Array(start + 1); + while (++index < start) { + otherArgs[index] = args[index]; + } + otherArgs[start] = transform(array); + return apply(func, this, otherArgs); + }; + } + + /** + * Gets the parent value at `path` of `object`. + * + * @private + * @param {Object} object The object to query. + * @param {Array} path The path to get the parent value of. + * @returns {*} Returns the parent value. + */ + function parent(object, path) { + return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1)); + } + + /** + * Reorder `array` according to the specified indexes where the element at + * the first index is assigned as the first element, the element at + * the second index is assigned as the second element, and so on. + * + * @private + * @param {Array} array The array to reorder. + * @param {Array} indexes The arranged array indexes. + * @returns {Array} Returns `array`. + */ + function reorder(array, indexes) { + var arrLength = array.length, + length = nativeMin(indexes.length, arrLength), + oldArray = copyArray(array); + + while (length--) { + var index = indexes[length]; + array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined; + } + return array; + } + + /** + * Gets the value at `key`, unless `key` is "__proto__" or "constructor". + * + * @private + * @param {Object} object The object to query. + * @param {string} key The key of the property to get. + * @returns {*} Returns the property value. + */ + function safeGet(object, key) { + if (key === 'constructor' && typeof object[key] === 'function') { + return; + } + + if (key == '__proto__') { + return; + } + + return object[key]; + } + + /** + * Sets metadata for `func`. + * + * **Note:** If this function becomes hot, i.e. is invoked a lot in a short + * period of time, it will trip its breaker and transition to an identity + * function to avoid garbage collection pauses in V8. See + * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070) + * for more details. + * + * @private + * @param {Function} func The function to associate metadata with. + * @param {*} data The metadata. + * @returns {Function} Returns `func`. + */ + var setData = shortOut(baseSetData); + + /** + * A simple wrapper around the global [`setTimeout`](https://mdn.io/setTimeout). + * + * @private + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @returns {number|Object} Returns the timer id or timeout object. + */ + var setTimeout = ctxSetTimeout || function(func, wait) { + return root.setTimeout(func, wait); + }; + + /** + * Sets the `toString` method of `func` to return `string`. + * + * @private + * @param {Function} func The function to modify. + * @param {Function} string The `toString` result. + * @returns {Function} Returns `func`. + */ + var setToString = shortOut(baseSetToString); + + /** + * Sets the `toString` method of `wrapper` to mimic the source of `reference` + * with wrapper details in a comment at the top of the source body. + * + * @private + * @param {Function} wrapper The function to modify. + * @param {Function} reference The reference function. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @returns {Function} Returns `wrapper`. + */ + function setWrapToString(wrapper, reference, bitmask) { + var source = (reference + ''); + return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask))); + } + + /** + * Creates a function that'll short out and invoke `identity` instead + * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN` + * milliseconds. + * + * @private + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new shortable function. + */ + function shortOut(func) { + var count = 0, + lastCalled = 0; + + return function() { + var stamp = nativeNow(), + remaining = HOT_SPAN - (stamp - lastCalled); + + lastCalled = stamp; + if (remaining > 0) { + if (++count >= HOT_COUNT) { + return arguments[0]; + } + } else { + count = 0; + } + return func.apply(undefined, arguments); + }; + } + + /** + * A specialized version of `_.shuffle` which mutates and sets the size of `array`. + * + * @private + * @param {Array} array The array to shuffle. + * @param {number} [size=array.length] The size of `array`. + * @returns {Array} Returns `array`. + */ + function shuffleSelf(array, size) { + var index = -1, + length = array.length, + lastIndex = length - 1; + + size = size === undefined ? length : size; + while (++index < size) { + var rand = baseRandom(index, lastIndex), + value = array[rand]; + + array[rand] = array[index]; + array[index] = value; + } + array.length = size; + return array; + } + + /** + * Converts `string` to a property path array. + * + * @private + * @param {string} string The string to convert. + * @returns {Array} Returns the property path array. + */ + var stringToPath = memoizeCapped(function(string) { + var result = []; + if (string.charCodeAt(0) === 46 /* . */) { + result.push(''); + } + string.replace(rePropName, function(match, number, quote, subString) { + result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match)); + }); + return result; + }); + + /** + * Converts `value` to a string key if it's not a string or symbol. + * + * @private + * @param {*} value The value to inspect. + * @returns {string|symbol} Returns the key. + */ + function toKey(value) { + if (typeof value == 'string' || isSymbol(value)) { + return value; + } + var result = (value + ''); + return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result; + } + + /** + * Converts `func` to its source code. + * + * @private + * @param {Function} func The function to convert. + * @returns {string} Returns the source code. + */ + function toSource(func) { + if (func != null) { + try { + return funcToString.call(func); + } catch (e) {} + try { + return (func + ''); + } catch (e) {} + } + return ''; + } + + /** + * Updates wrapper `details` based on `bitmask` flags. + * + * @private + * @returns {Array} details The details to modify. + * @param {number} bitmask The bitmask flags. See `createWrap` for more details. + * @returns {Array} Returns `details`. + */ + function updateWrapDetails(details, bitmask) { + arrayEach(wrapFlags, function(pair) { + var value = '_.' + pair[0]; + if ((bitmask & pair[1]) && !arrayIncludes(details, value)) { + details.push(value); + } + }); + return details.sort(); + } + + /** + * Creates a clone of `wrapper`. + * + * @private + * @param {Object} wrapper The wrapper to clone. + * @returns {Object} Returns the cloned wrapper. + */ + function wrapperClone(wrapper) { + if (wrapper instanceof LazyWrapper) { + return wrapper.clone(); + } + var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__); + result.__actions__ = copyArray(wrapper.__actions__); + result.__index__ = wrapper.__index__; + result.__values__ = wrapper.__values__; + return result; + } + + /*------------------------------------------------------------------------*/ + + /** + * Creates an array of elements split into groups the length of `size`. + * If `array` can't be split evenly, the final chunk will be the remaining + * elements. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to process. + * @param {number} [size=1] The length of each chunk + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the new array of chunks. + * @example + * + * _.chunk(['a', 'b', 'c', 'd'], 2); + * // => [['a', 'b'], ['c', 'd']] + * + * _.chunk(['a', 'b', 'c', 'd'], 3); + * // => [['a', 'b', 'c'], ['d']] + */ + function chunk(array, size, guard) { + if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) { + size = 1; + } else { + size = nativeMax(toInteger(size), 0); + } + var length = array == null ? 0 : array.length; + if (!length || size < 1) { + return []; + } + var index = 0, + resIndex = 0, + result = Array(nativeCeil(length / size)); + + while (index < length) { + result[resIndex++] = baseSlice(array, index, (index += size)); + } + return result; + } + + /** + * Creates an array with all falsey values removed. The values `false`, `null`, + * `0`, `""`, `undefined`, and `NaN` are falsey. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to compact. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * _.compact([0, 1, false, 2, '', 3]); + * // => [1, 2, 3] + */ + function compact(array) { + var index = -1, + length = array == null ? 0 : array.length, + resIndex = 0, + result = []; + + while (++index < length) { + var value = array[index]; + if (value) { + result[resIndex++] = value; + } + } + return result; + } + + /** + * Creates a new array concatenating `array` with any additional arrays + * and/or values. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to concatenate. + * @param {...*} [values] The values to concatenate. + * @returns {Array} Returns the new concatenated array. + * @example + * + * var array = [1]; + * var other = _.concat(array, 2, [3], [[4]]); + * + * console.log(other); + * // => [1, 2, 3, [4]] + * + * console.log(array); + * // => [1] + */ + function concat() { + var length = arguments.length; + if (!length) { + return []; + } + var args = Array(length - 1), + array = arguments[0], + index = length; + + while (index--) { + args[index - 1] = arguments[index]; + } + return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1)); + } + + /** + * Creates an array of `array` values not included in the other given arrays + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. The order and references of result values are + * determined by the first array. + * + * **Note:** Unlike `_.pullAll`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @returns {Array} Returns the new array of filtered values. + * @see _.without, _.xor + * @example + * + * _.difference([2, 1], [2, 3]); + * // => [1] + */ + var difference = baseRest(function(array, values) { + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true)) + : []; + }); + + /** + * This method is like `_.difference` except that it accepts `iteratee` which + * is invoked for each element of `array` and `values` to generate the criterion + * by which they're compared. The order and references of result values are + * determined by the first array. The iteratee is invoked with one argument: + * (value). + * + * **Note:** Unlike `_.pullAllBy`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * _.differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor); + * // => [1.2] + * + * // The `_.property` iteratee shorthand. + * _.differenceBy([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1 }], 'x'); + * // => [{ 'x': 2 }] + */ + var differenceBy = baseRest(function(array, values) { + var iteratee = last(values); + if (isArrayLikeObject(iteratee)) { + iteratee = undefined; + } + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), getIteratee(iteratee, 2)) + : []; + }); + + /** + * This method is like `_.difference` except that it accepts `comparator` + * which is invoked to compare elements of `array` to `values`. The order and + * references of result values are determined by the first array. The comparator + * is invoked with two arguments: (arrVal, othVal). + * + * **Note:** Unlike `_.pullAllWith`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...Array} [values] The values to exclude. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * + * _.differenceWith(objects, [{ 'x': 1, 'y': 2 }], _.isEqual); + * // => [{ 'x': 2, 'y': 1 }] + */ + var differenceWith = baseRest(function(array, values) { + var comparator = last(values); + if (isArrayLikeObject(comparator)) { + comparator = undefined; + } + return isArrayLikeObject(array) + ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), undefined, comparator) + : []; + }); + + /** + * Creates a slice of `array` with `n` elements dropped from the beginning. + * + * @static + * @memberOf _ + * @since 0.5.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to drop. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.drop([1, 2, 3]); + * // => [2, 3] + * + * _.drop([1, 2, 3], 2); + * // => [3] + * + * _.drop([1, 2, 3], 5); + * // => [] + * + * _.drop([1, 2, 3], 0); + * // => [1, 2, 3] + */ + function drop(array, n, guard) { + var length = array == null ? 0 : array.length; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + return baseSlice(array, n < 0 ? 0 : n, length); + } + + /** + * Creates a slice of `array` with `n` elements dropped from the end. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to drop. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.dropRight([1, 2, 3]); + * // => [1, 2] + * + * _.dropRight([1, 2, 3], 2); + * // => [1] + * + * _.dropRight([1, 2, 3], 5); + * // => [] + * + * _.dropRight([1, 2, 3], 0); + * // => [1, 2, 3] + */ + function dropRight(array, n, guard) { + var length = array == null ? 0 : array.length; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + n = length - n; + return baseSlice(array, 0, n < 0 ? 0 : n); + } + + /** + * Creates a slice of `array` excluding elements dropped from the end. + * Elements are dropped until `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': false } + * ]; + * + * _.dropRightWhile(users, function(o) { return !o.active; }); + * // => objects for ['barney'] + * + * // The `_.matches` iteratee shorthand. + * _.dropRightWhile(users, { 'user': 'pebbles', 'active': false }); + * // => objects for ['barney', 'fred'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.dropRightWhile(users, ['active', false]); + * // => objects for ['barney'] + * + * // The `_.property` iteratee shorthand. + * _.dropRightWhile(users, 'active'); + * // => objects for ['barney', 'fred', 'pebbles'] + */ + function dropRightWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, getIteratee(predicate, 3), true, true) + : []; + } + + /** + * Creates a slice of `array` excluding elements dropped from the beginning. + * Elements are dropped until `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.dropWhile(users, function(o) { return !o.active; }); + * // => objects for ['pebbles'] + * + * // The `_.matches` iteratee shorthand. + * _.dropWhile(users, { 'user': 'barney', 'active': false }); + * // => objects for ['fred', 'pebbles'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.dropWhile(users, ['active', false]); + * // => objects for ['pebbles'] + * + * // The `_.property` iteratee shorthand. + * _.dropWhile(users, 'active'); + * // => objects for ['barney', 'fred', 'pebbles'] + */ + function dropWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, getIteratee(predicate, 3), true) + : []; + } + + /** + * Fills elements of `array` with `value` from `start` up to, but not + * including, `end`. + * + * **Note:** This method mutates `array`. + * + * @static + * @memberOf _ + * @since 3.2.0 + * @category Array + * @param {Array} array The array to fill. + * @param {*} value The value to fill `array` with. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns `array`. + * @example + * + * var array = [1, 2, 3]; + * + * _.fill(array, 'a'); + * console.log(array); + * // => ['a', 'a', 'a'] + * + * _.fill(Array(3), 2); + * // => [2, 2, 2] + * + * _.fill([4, 6, 8, 10], '*', 1, 3); + * // => [4, '*', '*', 10] + */ + function fill(array, value, start, end) { + var length = array == null ? 0 : array.length; + if (!length) { + return []; + } + if (start && typeof start != 'number' && isIterateeCall(array, value, start)) { + start = 0; + end = length; + } + return baseFill(array, value, start, end); + } + + /** + * This method is like `_.find` except that it returns the index of the first + * element `predicate` returns truthy for instead of the element itself. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {number} Returns the index of the found element, else `-1`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.findIndex(users, function(o) { return o.user == 'barney'; }); + * // => 0 + * + * // The `_.matches` iteratee shorthand. + * _.findIndex(users, { 'user': 'fred', 'active': false }); + * // => 1 + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findIndex(users, ['active', false]); + * // => 0 + * + * // The `_.property` iteratee shorthand. + * _.findIndex(users, 'active'); + * // => 2 + */ + function findIndex(array, predicate, fromIndex) { + var length = array == null ? 0 : array.length; + if (!length) { + return -1; + } + var index = fromIndex == null ? 0 : toInteger(fromIndex); + if (index < 0) { + index = nativeMax(length + index, 0); + } + return baseFindIndex(array, getIteratee(predicate, 3), index); + } + + /** + * This method is like `_.findIndex` except that it iterates over elements + * of `collection` from right to left. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param {number} [fromIndex=array.length-1] The index to search from. + * @returns {number} Returns the index of the found element, else `-1`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': false } + * ]; + * + * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; }); + * // => 2 + * + * // The `_.matches` iteratee shorthand. + * _.findLastIndex(users, { 'user': 'barney', 'active': true }); + * // => 0 + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findLastIndex(users, ['active', false]); + * // => 2 + * + * // The `_.property` iteratee shorthand. + * _.findLastIndex(users, 'active'); + * // => 0 + */ + function findLastIndex(array, predicate, fromIndex) { + var length = array == null ? 0 : array.length; + if (!length) { + return -1; + } + var index = length - 1; + if (fromIndex !== undefined) { + index = toInteger(fromIndex); + index = fromIndex < 0 + ? nativeMax(length + index, 0) + : nativeMin(index, length - 1); + } + return baseFindIndex(array, getIteratee(predicate, 3), index, true); + } + + /** + * Flattens `array` a single level deep. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to flatten. + * @returns {Array} Returns the new flattened array. + * @example + * + * _.flatten([1, [2, [3, [4]], 5]]); + * // => [1, 2, [3, [4]], 5] + */ + function flatten(array) { + var length = array == null ? 0 : array.length; + return length ? baseFlatten(array, 1) : []; + } + + /** + * Recursively flattens `array`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to flatten. + * @returns {Array} Returns the new flattened array. + * @example + * + * _.flattenDeep([1, [2, [3, [4]], 5]]); + * // => [1, 2, 3, 4, 5] + */ + function flattenDeep(array) { + var length = array == null ? 0 : array.length; + return length ? baseFlatten(array, INFINITY) : []; + } + + /** + * Recursively flatten `array` up to `depth` times. + * + * @static + * @memberOf _ + * @since 4.4.0 + * @category Array + * @param {Array} array The array to flatten. + * @param {number} [depth=1] The maximum recursion depth. + * @returns {Array} Returns the new flattened array. + * @example + * + * var array = [1, [2, [3, [4]], 5]]; + * + * _.flattenDepth(array, 1); + * // => [1, 2, [3, [4]], 5] + * + * _.flattenDepth(array, 2); + * // => [1, 2, 3, [4], 5] + */ + function flattenDepth(array, depth) { + var length = array == null ? 0 : array.length; + if (!length) { + return []; + } + depth = depth === undefined ? 1 : toInteger(depth); + return baseFlatten(array, depth); + } + + /** + * The inverse of `_.toPairs`; this method returns an object composed + * from key-value `pairs`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} pairs The key-value pairs. + * @returns {Object} Returns the new object. + * @example + * + * _.fromPairs([['a', 1], ['b', 2]]); + * // => { 'a': 1, 'b': 2 } + */ + function fromPairs(pairs) { + var index = -1, + length = pairs == null ? 0 : pairs.length, + result = {}; + + while (++index < length) { + var pair = pairs[index]; + result[pair[0]] = pair[1]; + } + return result; + } + + /** + * Gets the first element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @alias first + * @category Array + * @param {Array} array The array to query. + * @returns {*} Returns the first element of `array`. + * @example + * + * _.head([1, 2, 3]); + * // => 1 + * + * _.head([]); + * // => undefined + */ + function head(array) { + return (array && array.length) ? array[0] : undefined; + } + + /** + * Gets the index at which the first occurrence of `value` is found in `array` + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. If `fromIndex` is negative, it's used as the + * offset from the end of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=0] The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.indexOf([1, 2, 1, 2], 2); + * // => 1 + * + * // Search from the `fromIndex`. + * _.indexOf([1, 2, 1, 2], 2, 2); + * // => 3 + */ + function indexOf(array, value, fromIndex) { + var length = array == null ? 0 : array.length; + if (!length) { + return -1; + } + var index = fromIndex == null ? 0 : toInteger(fromIndex); + if (index < 0) { + index = nativeMax(length + index, 0); + } + return baseIndexOf(array, value, index); + } + + /** + * Gets all but the last element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.initial([1, 2, 3]); + * // => [1, 2] + */ + function initial(array) { + var length = array == null ? 0 : array.length; + return length ? baseSlice(array, 0, -1) : []; + } + + /** + * Creates an array of unique values that are included in all given arrays + * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. The order and references of result values are + * determined by the first array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * _.intersection([2, 1], [2, 3]); + * // => [2] + */ + var intersection = baseRest(function(arrays) { + var mapped = arrayMap(arrays, castArrayLikeObject); + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped) + : []; + }); + + /** + * This method is like `_.intersection` except that it accepts `iteratee` + * which is invoked for each element of each `arrays` to generate the criterion + * by which they're compared. The order and references of result values are + * determined by the first array. The iteratee is invoked with one argument: + * (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor); + * // => [2.1] + * + * // The `_.property` iteratee shorthand. + * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x'); + * // => [{ 'x': 1 }] + */ + var intersectionBy = baseRest(function(arrays) { + var iteratee = last(arrays), + mapped = arrayMap(arrays, castArrayLikeObject); + + if (iteratee === last(mapped)) { + iteratee = undefined; + } else { + mapped.pop(); + } + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped, getIteratee(iteratee, 2)) + : []; + }); + + /** + * This method is like `_.intersection` except that it accepts `comparator` + * which is invoked to compare elements of `arrays`. The order and references + * of result values are determined by the first array. The comparator is + * invoked with two arguments: (arrVal, othVal). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of intersecting values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }]; + * + * _.intersectionWith(objects, others, _.isEqual); + * // => [{ 'x': 1, 'y': 2 }] + */ + var intersectionWith = baseRest(function(arrays) { + var comparator = last(arrays), + mapped = arrayMap(arrays, castArrayLikeObject); + + comparator = typeof comparator == 'function' ? comparator : undefined; + if (comparator) { + mapped.pop(); + } + return (mapped.length && mapped[0] === arrays[0]) + ? baseIntersection(mapped, undefined, comparator) + : []; + }); + + /** + * Converts all elements in `array` into a string separated by `separator`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to convert. + * @param {string} [separator=','] The element separator. + * @returns {string} Returns the joined string. + * @example + * + * _.join(['a', 'b', 'c'], '~'); + * // => 'a~b~c' + */ + function join(array, separator) { + return array == null ? '' : nativeJoin.call(array, separator); + } + + /** + * Gets the last element of `array`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @returns {*} Returns the last element of `array`. + * @example + * + * _.last([1, 2, 3]); + * // => 3 + */ + function last(array) { + var length = array == null ? 0 : array.length; + return length ? array[length - 1] : undefined; + } + + /** + * This method is like `_.indexOf` except that it iterates over elements of + * `array` from right to left. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=array.length-1] The index to search from. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.lastIndexOf([1, 2, 1, 2], 2); + * // => 3 + * + * // Search from the `fromIndex`. + * _.lastIndexOf([1, 2, 1, 2], 2, 2); + * // => 1 + */ + function lastIndexOf(array, value, fromIndex) { + var length = array == null ? 0 : array.length; + if (!length) { + return -1; + } + var index = length; + if (fromIndex !== undefined) { + index = toInteger(fromIndex); + index = index < 0 ? nativeMax(length + index, 0) : nativeMin(index, length - 1); + } + return value === value + ? strictLastIndexOf(array, value, index) + : baseFindIndex(array, baseIsNaN, index, true); + } + + /** + * Gets the element at index `n` of `array`. If `n` is negative, the nth + * element from the end is returned. + * + * @static + * @memberOf _ + * @since 4.11.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=0] The index of the element to return. + * @returns {*} Returns the nth element of `array`. + * @example + * + * var array = ['a', 'b', 'c', 'd']; + * + * _.nth(array, 1); + * // => 'b' + * + * _.nth(array, -2); + * // => 'c'; + */ + function nth(array, n) { + return (array && array.length) ? baseNth(array, toInteger(n)) : undefined; + } + + /** + * Removes all given values from `array` using + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * **Note:** Unlike `_.without`, this method mutates `array`. Use `_.remove` + * to remove elements from an array by predicate. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {...*} [values] The values to remove. + * @returns {Array} Returns `array`. + * @example + * + * var array = ['a', 'b', 'c', 'a', 'b', 'c']; + * + * _.pull(array, 'a', 'c'); + * console.log(array); + * // => ['b', 'b'] + */ + var pull = baseRest(pullAll); + + /** + * This method is like `_.pull` except that it accepts an array of values to remove. + * + * **Note:** Unlike `_.difference`, this method mutates `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {Array} values The values to remove. + * @returns {Array} Returns `array`. + * @example + * + * var array = ['a', 'b', 'c', 'a', 'b', 'c']; + * + * _.pullAll(array, ['a', 'c']); + * console.log(array); + * // => ['b', 'b'] + */ + function pullAll(array, values) { + return (array && array.length && values && values.length) + ? basePullAll(array, values) + : array; + } + + /** + * This method is like `_.pullAll` except that it accepts `iteratee` which is + * invoked for each element of `array` and `values` to generate the criterion + * by which they're compared. The iteratee is invoked with one argument: (value). + * + * **Note:** Unlike `_.differenceBy`, this method mutates `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {Array} values The values to remove. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns `array`. + * @example + * + * var array = [{ 'x': 1 }, { 'x': 2 }, { 'x': 3 }, { 'x': 1 }]; + * + * _.pullAllBy(array, [{ 'x': 1 }, { 'x': 3 }], 'x'); + * console.log(array); + * // => [{ 'x': 2 }] + */ + function pullAllBy(array, values, iteratee) { + return (array && array.length && values && values.length) + ? basePullAll(array, values, getIteratee(iteratee, 2)) + : array; + } + + /** + * This method is like `_.pullAll` except that it accepts `comparator` which + * is invoked to compare elements of `array` to `values`. The comparator is + * invoked with two arguments: (arrVal, othVal). + * + * **Note:** Unlike `_.differenceWith`, this method mutates `array`. + * + * @static + * @memberOf _ + * @since 4.6.0 + * @category Array + * @param {Array} array The array to modify. + * @param {Array} values The values to remove. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns `array`. + * @example + * + * var array = [{ 'x': 1, 'y': 2 }, { 'x': 3, 'y': 4 }, { 'x': 5, 'y': 6 }]; + * + * _.pullAllWith(array, [{ 'x': 3, 'y': 4 }], _.isEqual); + * console.log(array); + * // => [{ 'x': 1, 'y': 2 }, { 'x': 5, 'y': 6 }] + */ + function pullAllWith(array, values, comparator) { + return (array && array.length && values && values.length) + ? basePullAll(array, values, undefined, comparator) + : array; + } + + /** + * Removes elements from `array` corresponding to `indexes` and returns an + * array of removed elements. + * + * **Note:** Unlike `_.at`, this method mutates `array`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {...(number|number[])} [indexes] The indexes of elements to remove. + * @returns {Array} Returns the new array of removed elements. + * @example + * + * var array = ['a', 'b', 'c', 'd']; + * var pulled = _.pullAt(array, [1, 3]); + * + * console.log(array); + * // => ['a', 'c'] + * + * console.log(pulled); + * // => ['b', 'd'] + */ + var pullAt = flatRest(function(array, indexes) { + var length = array == null ? 0 : array.length, + result = baseAt(array, indexes); + + basePullAt(array, arrayMap(indexes, function(index) { + return isIndex(index, length) ? +index : index; + }).sort(compareAscending)); + + return result; + }); + + /** + * Removes all elements from `array` that `predicate` returns truthy for + * and returns an array of the removed elements. The predicate is invoked + * with three arguments: (value, index, array). + * + * **Note:** Unlike `_.filter`, this method mutates `array`. Use `_.pull` + * to pull elements from an array by value. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Array + * @param {Array} array The array to modify. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new array of removed elements. + * @example + * + * var array = [1, 2, 3, 4]; + * var evens = _.remove(array, function(n) { + * return n % 2 == 0; + * }); + * + * console.log(array); + * // => [1, 3] + * + * console.log(evens); + * // => [2, 4] + */ + function remove(array, predicate) { + var result = []; + if (!(array && array.length)) { + return result; + } + var index = -1, + indexes = [], + length = array.length; + + predicate = getIteratee(predicate, 3); + while (++index < length) { + var value = array[index]; + if (predicate(value, index, array)) { + result.push(value); + indexes.push(index); + } + } + basePullAt(array, indexes); + return result; + } + + /** + * Reverses `array` so that the first element becomes the last, the second + * element becomes the second to last, and so on. + * + * **Note:** This method mutates `array` and is based on + * [`Array#reverse`](https://mdn.io/Array/reverse). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to modify. + * @returns {Array} Returns `array`. + * @example + * + * var array = [1, 2, 3]; + * + * _.reverse(array); + * // => [3, 2, 1] + * + * console.log(array); + * // => [3, 2, 1] + */ + function reverse(array) { + return array == null ? array : nativeReverse.call(array); + } + + /** + * Creates a slice of `array` from `start` up to, but not including, `end`. + * + * **Note:** This method is used instead of + * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are + * returned. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to slice. + * @param {number} [start=0] The start position. + * @param {number} [end=array.length] The end position. + * @returns {Array} Returns the slice of `array`. + */ + function slice(array, start, end) { + var length = array == null ? 0 : array.length; + if (!length) { + return []; + } + if (end && typeof end != 'number' && isIterateeCall(array, start, end)) { + start = 0; + end = length; + } + else { + start = start == null ? 0 : toInteger(start); + end = end === undefined ? length : toInteger(end); + } + return baseSlice(array, start, end); + } + + /** + * Uses a binary search to determine the lowest index at which `value` + * should be inserted into `array` in order to maintain its sort order. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + * @example + * + * _.sortedIndex([30, 50], 40); + * // => 1 + */ + function sortedIndex(array, value) { + return baseSortedIndex(array, value); + } + + /** + * This method is like `_.sortedIndex` except that it accepts `iteratee` + * which is invoked for `value` and each element of `array` to compute their + * sort ranking. The iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + * @example + * + * var objects = [{ 'x': 4 }, { 'x': 5 }]; + * + * _.sortedIndexBy(objects, { 'x': 4 }, function(o) { return o.x; }); + * // => 0 + * + * // The `_.property` iteratee shorthand. + * _.sortedIndexBy(objects, { 'x': 4 }, 'x'); + * // => 0 + */ + function sortedIndexBy(array, value, iteratee) { + return baseSortedIndexBy(array, value, getIteratee(iteratee, 2)); + } + + /** + * This method is like `_.indexOf` except that it performs a binary + * search on a sorted `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.sortedIndexOf([4, 5, 5, 5, 6], 5); + * // => 1 + */ + function sortedIndexOf(array, value) { + var length = array == null ? 0 : array.length; + if (length) { + var index = baseSortedIndex(array, value); + if (index < length && eq(array[index], value)) { + return index; + } + } + return -1; + } + + /** + * This method is like `_.sortedIndex` except that it returns the highest + * index at which `value` should be inserted into `array` in order to + * maintain its sort order. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + * @example + * + * _.sortedLastIndex([4, 5, 5, 5, 6], 5); + * // => 4 + */ + function sortedLastIndex(array, value) { + return baseSortedIndex(array, value, true); + } + + /** + * This method is like `_.sortedLastIndex` except that it accepts `iteratee` + * which is invoked for `value` and each element of `array` to compute their + * sort ranking. The iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The sorted array to inspect. + * @param {*} value The value to evaluate. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {number} Returns the index at which `value` should be inserted + * into `array`. + * @example + * + * var objects = [{ 'x': 4 }, { 'x': 5 }]; + * + * _.sortedLastIndexBy(objects, { 'x': 4 }, function(o) { return o.x; }); + * // => 1 + * + * // The `_.property` iteratee shorthand. + * _.sortedLastIndexBy(objects, { 'x': 4 }, 'x'); + * // => 1 + */ + function sortedLastIndexBy(array, value, iteratee) { + return baseSortedIndexBy(array, value, getIteratee(iteratee, 2), true); + } + + /** + * This method is like `_.lastIndexOf` except that it performs a binary + * search on a sorted `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {*} value The value to search for. + * @returns {number} Returns the index of the matched value, else `-1`. + * @example + * + * _.sortedLastIndexOf([4, 5, 5, 5, 6], 5); + * // => 3 + */ + function sortedLastIndexOf(array, value) { + var length = array == null ? 0 : array.length; + if (length) { + var index = baseSortedIndex(array, value, true) - 1; + if (eq(array[index], value)) { + return index; + } + } + return -1; + } + + /** + * This method is like `_.uniq` except that it's designed and optimized + * for sorted arrays. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * _.sortedUniq([1, 1, 2]); + * // => [1, 2] + */ + function sortedUniq(array) { + return (array && array.length) + ? baseSortedUniq(array) + : []; + } + + /** + * This method is like `_.uniqBy` except that it's designed and optimized + * for sorted arrays. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [iteratee] The iteratee invoked per element. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * _.sortedUniqBy([1.1, 1.2, 2.3, 2.4], Math.floor); + * // => [1.1, 2.3] + */ + function sortedUniqBy(array, iteratee) { + return (array && array.length) + ? baseSortedUniq(array, getIteratee(iteratee, 2)) + : []; + } + + /** + * Gets all but the first element of `array`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to query. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.tail([1, 2, 3]); + * // => [2, 3] + */ + function tail(array) { + var length = array == null ? 0 : array.length; + return length ? baseSlice(array, 1, length) : []; + } + + /** + * Creates a slice of `array` with `n` elements taken from the beginning. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to take. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.take([1, 2, 3]); + * // => [1] + * + * _.take([1, 2, 3], 2); + * // => [1, 2] + * + * _.take([1, 2, 3], 5); + * // => [1, 2, 3] + * + * _.take([1, 2, 3], 0); + * // => [] + */ + function take(array, n, guard) { + if (!(array && array.length)) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + return baseSlice(array, 0, n < 0 ? 0 : n); + } + + /** + * Creates a slice of `array` with `n` elements taken from the end. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {number} [n=1] The number of elements to take. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the slice of `array`. + * @example + * + * _.takeRight([1, 2, 3]); + * // => [3] + * + * _.takeRight([1, 2, 3], 2); + * // => [2, 3] + * + * _.takeRight([1, 2, 3], 5); + * // => [1, 2, 3] + * + * _.takeRight([1, 2, 3], 0); + * // => [] + */ + function takeRight(array, n, guard) { + var length = array == null ? 0 : array.length; + if (!length) { + return []; + } + n = (guard || n === undefined) ? 1 : toInteger(n); + n = length - n; + return baseSlice(array, n < 0 ? 0 : n, length); + } + + /** + * Creates a slice of `array` with elements taken from the end. Elements are + * taken until `predicate` returns falsey. The predicate is invoked with + * three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': false } + * ]; + * + * _.takeRightWhile(users, function(o) { return !o.active; }); + * // => objects for ['fred', 'pebbles'] + * + * // The `_.matches` iteratee shorthand. + * _.takeRightWhile(users, { 'user': 'pebbles', 'active': false }); + * // => objects for ['pebbles'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.takeRightWhile(users, ['active', false]); + * // => objects for ['fred', 'pebbles'] + * + * // The `_.property` iteratee shorthand. + * _.takeRightWhile(users, 'active'); + * // => [] + */ + function takeRightWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, getIteratee(predicate, 3), false, true) + : []; + } + + /** + * Creates a slice of `array` with elements taken from the beginning. Elements + * are taken until `predicate` returns falsey. The predicate is invoked with + * three arguments: (value, index, array). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Array + * @param {Array} array The array to query. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the slice of `array`. + * @example + * + * var users = [ + * { 'user': 'barney', 'active': false }, + * { 'user': 'fred', 'active': false }, + * { 'user': 'pebbles', 'active': true } + * ]; + * + * _.takeWhile(users, function(o) { return !o.active; }); + * // => objects for ['barney', 'fred'] + * + * // The `_.matches` iteratee shorthand. + * _.takeWhile(users, { 'user': 'barney', 'active': false }); + * // => objects for ['barney'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.takeWhile(users, ['active', false]); + * // => objects for ['barney', 'fred'] + * + * // The `_.property` iteratee shorthand. + * _.takeWhile(users, 'active'); + * // => [] + */ + function takeWhile(array, predicate) { + return (array && array.length) + ? baseWhile(array, getIteratee(predicate, 3)) + : []; + } + + /** + * Creates an array of unique values, in order, from all given arrays using + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @returns {Array} Returns the new array of combined values. + * @example + * + * _.union([2], [1, 2]); + * // => [2, 1] + */ + var union = baseRest(function(arrays) { + return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true)); + }); + + /** + * This method is like `_.union` except that it accepts `iteratee` which is + * invoked for each element of each `arrays` to generate the criterion by + * which uniqueness is computed. Result values are chosen from the first + * array in which the value occurs. The iteratee is invoked with one argument: + * (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns the new array of combined values. + * @example + * + * _.unionBy([2.1], [1.2, 2.3], Math.floor); + * // => [2.1, 1.2] + * + * // The `_.property` iteratee shorthand. + * _.unionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x'); + * // => [{ 'x': 1 }, { 'x': 2 }] + */ + var unionBy = baseRest(function(arrays) { + var iteratee = last(arrays); + if (isArrayLikeObject(iteratee)) { + iteratee = undefined; + } + return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), getIteratee(iteratee, 2)); + }); + + /** + * This method is like `_.union` except that it accepts `comparator` which + * is invoked to compare elements of `arrays`. Result values are chosen from + * the first array in which the value occurs. The comparator is invoked + * with two arguments: (arrVal, othVal). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of combined values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }]; + * + * _.unionWith(objects, others, _.isEqual); + * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }] + */ + var unionWith = baseRest(function(arrays) { + var comparator = last(arrays); + comparator = typeof comparator == 'function' ? comparator : undefined; + return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), undefined, comparator); + }); + + /** + * Creates a duplicate-free version of an array, using + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons, in which only the first occurrence of each element + * is kept. The order of result values is determined by the order they occur + * in the array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * _.uniq([2, 1, 2]); + * // => [2, 1] + */ + function uniq(array) { + return (array && array.length) ? baseUniq(array) : []; + } + + /** + * This method is like `_.uniq` except that it accepts `iteratee` which is + * invoked for each element in `array` to generate the criterion by which + * uniqueness is computed. The order of result values is determined by the + * order they occur in the array. The iteratee is invoked with one argument: + * (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * _.uniqBy([2.1, 1.2, 2.3], Math.floor); + * // => [2.1, 1.2] + * + * // The `_.property` iteratee shorthand. + * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x'); + * // => [{ 'x': 1 }, { 'x': 2 }] + */ + function uniqBy(array, iteratee) { + return (array && array.length) ? baseUniq(array, getIteratee(iteratee, 2)) : []; + } + + /** + * This method is like `_.uniq` except that it accepts `comparator` which + * is invoked to compare elements of `array`. The order of result values is + * determined by the order they occur in the array.The comparator is invoked + * with two arguments: (arrVal, othVal). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new duplicate free array. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 2 }]; + * + * _.uniqWith(objects, _.isEqual); + * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }] + */ + function uniqWith(array, comparator) { + comparator = typeof comparator == 'function' ? comparator : undefined; + return (array && array.length) ? baseUniq(array, undefined, comparator) : []; + } + + /** + * This method is like `_.zip` except that it accepts an array of grouped + * elements and creates an array regrouping the elements to their pre-zip + * configuration. + * + * @static + * @memberOf _ + * @since 1.2.0 + * @category Array + * @param {Array} array The array of grouped elements to process. + * @returns {Array} Returns the new array of regrouped elements. + * @example + * + * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]); + * // => [['a', 1, true], ['b', 2, false]] + * + * _.unzip(zipped); + * // => [['a', 'b'], [1, 2], [true, false]] + */ + function unzip(array) { + if (!(array && array.length)) { + return []; + } + var length = 0; + array = arrayFilter(array, function(group) { + if (isArrayLikeObject(group)) { + length = nativeMax(group.length, length); + return true; + } + }); + return baseTimes(length, function(index) { + return arrayMap(array, baseProperty(index)); + }); + } + + /** + * This method is like `_.unzip` except that it accepts `iteratee` to specify + * how regrouped values should be combined. The iteratee is invoked with the + * elements of each group: (...group). + * + * @static + * @memberOf _ + * @since 3.8.0 + * @category Array + * @param {Array} array The array of grouped elements to process. + * @param {Function} [iteratee=_.identity] The function to combine + * regrouped values. + * @returns {Array} Returns the new array of regrouped elements. + * @example + * + * var zipped = _.zip([1, 2], [10, 20], [100, 200]); + * // => [[1, 10, 100], [2, 20, 200]] + * + * _.unzipWith(zipped, _.add); + * // => [3, 30, 300] + */ + function unzipWith(array, iteratee) { + if (!(array && array.length)) { + return []; + } + var result = unzip(array); + if (iteratee == null) { + return result; + } + return arrayMap(result, function(group) { + return apply(iteratee, undefined, group); + }); + } + + /** + * Creates an array excluding all given values using + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * for equality comparisons. + * + * **Note:** Unlike `_.pull`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {Array} array The array to inspect. + * @param {...*} [values] The values to exclude. + * @returns {Array} Returns the new array of filtered values. + * @see _.difference, _.xor + * @example + * + * _.without([2, 1, 2, 3], 1, 2); + * // => [3] + */ + var without = baseRest(function(array, values) { + return isArrayLikeObject(array) + ? baseDifference(array, values) + : []; + }); + + /** + * Creates an array of unique values that is the + * [symmetric difference](https://en.wikipedia.org/wiki/Symmetric_difference) + * of the given arrays. The order of result values is determined by the order + * they occur in the arrays. + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @returns {Array} Returns the new array of filtered values. + * @see _.difference, _.without + * @example + * + * _.xor([2, 1], [2, 3]); + * // => [1, 3] + */ + var xor = baseRest(function(arrays) { + return baseXor(arrayFilter(arrays, isArrayLikeObject)); + }); + + /** + * This method is like `_.xor` except that it accepts `iteratee` which is + * invoked for each element of each `arrays` to generate the criterion by + * which by which they're compared. The order of result values is determined + * by the order they occur in the arrays. The iteratee is invoked with one + * argument: (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * _.xorBy([2.1, 1.2], [2.3, 3.4], Math.floor); + * // => [1.2, 3.4] + * + * // The `_.property` iteratee shorthand. + * _.xorBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x'); + * // => [{ 'x': 2 }] + */ + var xorBy = baseRest(function(arrays) { + var iteratee = last(arrays); + if (isArrayLikeObject(iteratee)) { + iteratee = undefined; + } + return baseXor(arrayFilter(arrays, isArrayLikeObject), getIteratee(iteratee, 2)); + }); + + /** + * This method is like `_.xor` except that it accepts `comparator` which is + * invoked to compare elements of `arrays`. The order of result values is + * determined by the order they occur in the arrays. The comparator is invoked + * with two arguments: (arrVal, othVal). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Array + * @param {...Array} [arrays] The arrays to inspect. + * @param {Function} [comparator] The comparator invoked per element. + * @returns {Array} Returns the new array of filtered values. + * @example + * + * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]; + * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }]; + * + * _.xorWith(objects, others, _.isEqual); + * // => [{ 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }] + */ + var xorWith = baseRest(function(arrays) { + var comparator = last(arrays); + comparator = typeof comparator == 'function' ? comparator : undefined; + return baseXor(arrayFilter(arrays, isArrayLikeObject), undefined, comparator); + }); + + /** + * Creates an array of grouped elements, the first of which contains the + * first elements of the given arrays, the second of which contains the + * second elements of the given arrays, and so on. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Array + * @param {...Array} [arrays] The arrays to process. + * @returns {Array} Returns the new array of grouped elements. + * @example + * + * _.zip(['a', 'b'], [1, 2], [true, false]); + * // => [['a', 1, true], ['b', 2, false]] + */ + var zip = baseRest(unzip); + + /** + * This method is like `_.fromPairs` except that it accepts two arrays, + * one of property identifiers and one of corresponding values. + * + * @static + * @memberOf _ + * @since 0.4.0 + * @category Array + * @param {Array} [props=[]] The property identifiers. + * @param {Array} [values=[]] The property values. + * @returns {Object} Returns the new object. + * @example + * + * _.zipObject(['a', 'b'], [1, 2]); + * // => { 'a': 1, 'b': 2 } + */ + function zipObject(props, values) { + return baseZipObject(props || [], values || [], assignValue); + } + + /** + * This method is like `_.zipObject` except that it supports property paths. + * + * @static + * @memberOf _ + * @since 4.1.0 + * @category Array + * @param {Array} [props=[]] The property identifiers. + * @param {Array} [values=[]] The property values. + * @returns {Object} Returns the new object. + * @example + * + * _.zipObjectDeep(['a.b[0].c', 'a.b[1].d'], [1, 2]); + * // => { 'a': { 'b': [{ 'c': 1 }, { 'd': 2 }] } } + */ + function zipObjectDeep(props, values) { + return baseZipObject(props || [], values || [], baseSet); + } + + /** + * This method is like `_.zip` except that it accepts `iteratee` to specify + * how grouped values should be combined. The iteratee is invoked with the + * elements of each group: (...group). + * + * @static + * @memberOf _ + * @since 3.8.0 + * @category Array + * @param {...Array} [arrays] The arrays to process. + * @param {Function} [iteratee=_.identity] The function to combine + * grouped values. + * @returns {Array} Returns the new array of grouped elements. + * @example + * + * _.zipWith([1, 2], [10, 20], [100, 200], function(a, b, c) { + * return a + b + c; + * }); + * // => [111, 222] + */ + var zipWith = baseRest(function(arrays) { + var length = arrays.length, + iteratee = length > 1 ? arrays[length - 1] : undefined; + + iteratee = typeof iteratee == 'function' ? (arrays.pop(), iteratee) : undefined; + return unzipWith(arrays, iteratee); + }); + + /*------------------------------------------------------------------------*/ + + /** + * Creates a `lodash` wrapper instance that wraps `value` with explicit method + * chain sequences enabled. The result of such sequences must be unwrapped + * with `_#value`. + * + * @static + * @memberOf _ + * @since 1.3.0 + * @category Seq + * @param {*} value The value to wrap. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'pebbles', 'age': 1 } + * ]; + * + * var youngest = _ + * .chain(users) + * .sortBy('age') + * .map(function(o) { + * return o.user + ' is ' + o.age; + * }) + * .head() + * .value(); + * // => 'pebbles is 1' + */ + function chain(value) { + var result = lodash(value); + result.__chain__ = true; + return result; + } + + /** + * This method invokes `interceptor` and returns `value`. The interceptor + * is invoked with one argument; (value). The purpose of this method is to + * "tap into" a method chain sequence in order to modify intermediate results. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Seq + * @param {*} value The value to provide to `interceptor`. + * @param {Function} interceptor The function to invoke. + * @returns {*} Returns `value`. + * @example + * + * _([1, 2, 3]) + * .tap(function(array) { + * // Mutate input array. + * array.pop(); + * }) + * .reverse() + * .value(); + * // => [2, 1] + */ + function tap(value, interceptor) { + interceptor(value); + return value; + } + + /** + * This method is like `_.tap` except that it returns the result of `interceptor`. + * The purpose of this method is to "pass thru" values replacing intermediate + * results in a method chain sequence. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Seq + * @param {*} value The value to provide to `interceptor`. + * @param {Function} interceptor The function to invoke. + * @returns {*} Returns the result of `interceptor`. + * @example + * + * _(' abc ') + * .chain() + * .trim() + * .thru(function(value) { + * return [value]; + * }) + * .value(); + * // => ['abc'] + */ + function thru(value, interceptor) { + return interceptor(value); + } + + /** + * This method is the wrapper version of `_.at`. + * + * @name at + * @memberOf _ + * @since 1.0.0 + * @category Seq + * @param {...(string|string[])} [paths] The property paths to pick. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] }; + * + * _(object).at(['a[0].b.c', 'a[1]']).value(); + * // => [3, 4] + */ + var wrapperAt = flatRest(function(paths) { + var length = paths.length, + start = length ? paths[0] : 0, + value = this.__wrapped__, + interceptor = function(object) { return baseAt(object, paths); }; + + if (length > 1 || this.__actions__.length || + !(value instanceof LazyWrapper) || !isIndex(start)) { + return this.thru(interceptor); + } + value = value.slice(start, +start + (length ? 1 : 0)); + value.__actions__.push({ + 'func': thru, + 'args': [interceptor], + 'thisArg': undefined + }); + return new LodashWrapper(value, this.__chain__).thru(function(array) { + if (length && !array.length) { + array.push(undefined); + } + return array; + }); + }); + + /** + * Creates a `lodash` wrapper instance with explicit method chain sequences enabled. + * + * @name chain + * @memberOf _ + * @since 0.1.0 + * @category Seq + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 40 } + * ]; + * + * // A sequence without explicit chaining. + * _(users).head(); + * // => { 'user': 'barney', 'age': 36 } + * + * // A sequence with explicit chaining. + * _(users) + * .chain() + * .head() + * .pick('user') + * .value(); + * // => { 'user': 'barney' } + */ + function wrapperChain() { + return chain(this); + } + + /** + * Executes the chain sequence and returns the wrapped result. + * + * @name commit + * @memberOf _ + * @since 3.2.0 + * @category Seq + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var array = [1, 2]; + * var wrapped = _(array).push(3); + * + * console.log(array); + * // => [1, 2] + * + * wrapped = wrapped.commit(); + * console.log(array); + * // => [1, 2, 3] + * + * wrapped.last(); + * // => 3 + * + * console.log(array); + * // => [1, 2, 3] + */ + function wrapperCommit() { + return new LodashWrapper(this.value(), this.__chain__); + } + + /** + * Gets the next value on a wrapped object following the + * [iterator protocol](https://mdn.io/iteration_protocols#iterator). + * + * @name next + * @memberOf _ + * @since 4.0.0 + * @category Seq + * @returns {Object} Returns the next iterator value. + * @example + * + * var wrapped = _([1, 2]); + * + * wrapped.next(); + * // => { 'done': false, 'value': 1 } + * + * wrapped.next(); + * // => { 'done': false, 'value': 2 } + * + * wrapped.next(); + * // => { 'done': true, 'value': undefined } + */ + function wrapperNext() { + if (this.__values__ === undefined) { + this.__values__ = toArray(this.value()); + } + var done = this.__index__ >= this.__values__.length, + value = done ? undefined : this.__values__[this.__index__++]; + + return { 'done': done, 'value': value }; + } + + /** + * Enables the wrapper to be iterable. + * + * @name Symbol.iterator + * @memberOf _ + * @since 4.0.0 + * @category Seq + * @returns {Object} Returns the wrapper object. + * @example + * + * var wrapped = _([1, 2]); + * + * wrapped[Symbol.iterator]() === wrapped; + * // => true + * + * Array.from(wrapped); + * // => [1, 2] + */ + function wrapperToIterator() { + return this; + } + + /** + * Creates a clone of the chain sequence planting `value` as the wrapped value. + * + * @name plant + * @memberOf _ + * @since 3.2.0 + * @category Seq + * @param {*} value The value to plant. + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * function square(n) { + * return n * n; + * } + * + * var wrapped = _([1, 2]).map(square); + * var other = wrapped.plant([3, 4]); + * + * other.value(); + * // => [9, 16] + * + * wrapped.value(); + * // => [1, 4] + */ + function wrapperPlant(value) { + var result, + parent = this; + + while (parent instanceof baseLodash) { + var clone = wrapperClone(parent); + clone.__index__ = 0; + clone.__values__ = undefined; + if (result) { + previous.__wrapped__ = clone; + } else { + result = clone; + } + var previous = clone; + parent = parent.__wrapped__; + } + previous.__wrapped__ = value; + return result; + } + + /** + * This method is the wrapper version of `_.reverse`. + * + * **Note:** This method mutates the wrapped array. + * + * @name reverse + * @memberOf _ + * @since 0.1.0 + * @category Seq + * @returns {Object} Returns the new `lodash` wrapper instance. + * @example + * + * var array = [1, 2, 3]; + * + * _(array).reverse().value() + * // => [3, 2, 1] + * + * console.log(array); + * // => [3, 2, 1] + */ + function wrapperReverse() { + var value = this.__wrapped__; + if (value instanceof LazyWrapper) { + var wrapped = value; + if (this.__actions__.length) { + wrapped = new LazyWrapper(this); + } + wrapped = wrapped.reverse(); + wrapped.__actions__.push({ + 'func': thru, + 'args': [reverse], + 'thisArg': undefined + }); + return new LodashWrapper(wrapped, this.__chain__); + } + return this.thru(reverse); + } + + /** + * Executes the chain sequence to resolve the unwrapped value. + * + * @name value + * @memberOf _ + * @since 0.1.0 + * @alias toJSON, valueOf + * @category Seq + * @returns {*} Returns the resolved unwrapped value. + * @example + * + * _([1, 2, 3]).value(); + * // => [1, 2, 3] + */ + function wrapperValue() { + return baseWrapperValue(this.__wrapped__, this.__actions__); + } + + /*------------------------------------------------------------------------*/ + + /** + * Creates an object composed of keys generated from the results of running + * each element of `collection` thru `iteratee`. The corresponding value of + * each key is the number of times the key was returned by `iteratee`. The + * iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 0.5.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The iteratee to transform keys. + * @returns {Object} Returns the composed aggregate object. + * @example + * + * _.countBy([6.1, 4.2, 6.3], Math.floor); + * // => { '4': 1, '6': 2 } + * + * // The `_.property` iteratee shorthand. + * _.countBy(['one', 'two', 'three'], 'length'); + * // => { '3': 2, '5': 1 } + */ + var countBy = createAggregator(function(result, value, key) { + if (hasOwnProperty.call(result, key)) { + ++result[key]; + } else { + baseAssignValue(result, key, 1); + } + }); + + /** + * Checks if `predicate` returns truthy for **all** elements of `collection`. + * Iteration is stopped once `predicate` returns falsey. The predicate is + * invoked with three arguments: (value, index|key, collection). + * + * **Note:** This method returns `true` for + * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because + * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of + * elements of empty collections. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {boolean} Returns `true` if all elements pass the predicate check, + * else `false`. + * @example + * + * _.every([true, 1, null, 'yes'], Boolean); + * // => false + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': false }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * // The `_.matches` iteratee shorthand. + * _.every(users, { 'user': 'barney', 'active': false }); + * // => false + * + * // The `_.matchesProperty` iteratee shorthand. + * _.every(users, ['active', false]); + * // => true + * + * // The `_.property` iteratee shorthand. + * _.every(users, 'active'); + * // => false + */ + function every(collection, predicate, guard) { + var func = isArray(collection) ? arrayEvery : baseEvery; + if (guard && isIterateeCall(collection, predicate, guard)) { + predicate = undefined; + } + return func(collection, getIteratee(predicate, 3)); + } + + /** + * Iterates over elements of `collection`, returning an array of all elements + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * **Note:** Unlike `_.remove`, this method returns a new array. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + * @see _.reject + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false } + * ]; + * + * _.filter(users, function(o) { return !o.active; }); + * // => objects for ['fred'] + * + * // The `_.matches` iteratee shorthand. + * _.filter(users, { 'age': 36, 'active': true }); + * // => objects for ['barney'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.filter(users, ['active', false]); + * // => objects for ['fred'] + * + * // The `_.property` iteratee shorthand. + * _.filter(users, 'active'); + * // => objects for ['barney'] + * + * // Combining several predicates using `_.overEvery` or `_.overSome`. + * _.filter(users, _.overSome([{ 'age': 36 }, ['age', 40]])); + * // => objects for ['fred', 'barney'] + */ + function filter(collection, predicate) { + var func = isArray(collection) ? arrayFilter : baseFilter; + return func(collection, getIteratee(predicate, 3)); + } + + /** + * Iterates over elements of `collection`, returning the first element + * `predicate` returns truthy for. The predicate is invoked with three + * arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param {number} [fromIndex=0] The index to search from. + * @returns {*} Returns the matched element, else `undefined`. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': true }, + * { 'user': 'fred', 'age': 40, 'active': false }, + * { 'user': 'pebbles', 'age': 1, 'active': true } + * ]; + * + * _.find(users, function(o) { return o.age < 40; }); + * // => object for 'barney' + * + * // The `_.matches` iteratee shorthand. + * _.find(users, { 'age': 1, 'active': true }); + * // => object for 'pebbles' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.find(users, ['active', false]); + * // => object for 'fred' + * + * // The `_.property` iteratee shorthand. + * _.find(users, 'active'); + * // => object for 'barney' + */ + var find = createFind(findIndex); + + /** + * This method is like `_.find` except that it iterates over elements of + * `collection` from right to left. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Collection + * @param {Array|Object} collection The collection to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param {number} [fromIndex=collection.length-1] The index to search from. + * @returns {*} Returns the matched element, else `undefined`. + * @example + * + * _.findLast([1, 2, 3, 4], function(n) { + * return n % 2 == 1; + * }); + * // => 3 + */ + var findLast = createFind(findLastIndex); + + /** + * Creates a flattened array of values by running each element in `collection` + * thru `iteratee` and flattening the mapped results. The iteratee is invoked + * with three arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new flattened array. + * @example + * + * function duplicate(n) { + * return [n, n]; + * } + * + * _.flatMap([1, 2], duplicate); + * // => [1, 1, 2, 2] + */ + function flatMap(collection, iteratee) { + return baseFlatten(map(collection, iteratee), 1); + } + + /** + * This method is like `_.flatMap` except that it recursively flattens the + * mapped results. + * + * @static + * @memberOf _ + * @since 4.7.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new flattened array. + * @example + * + * function duplicate(n) { + * return [[[n, n]]]; + * } + * + * _.flatMapDeep([1, 2], duplicate); + * // => [1, 1, 2, 2] + */ + function flatMapDeep(collection, iteratee) { + return baseFlatten(map(collection, iteratee), INFINITY); + } + + /** + * This method is like `_.flatMap` except that it recursively flattens the + * mapped results up to `depth` times. + * + * @static + * @memberOf _ + * @since 4.7.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @param {number} [depth=1] The maximum recursion depth. + * @returns {Array} Returns the new flattened array. + * @example + * + * function duplicate(n) { + * return [[[n, n]]]; + * } + * + * _.flatMapDepth([1, 2], duplicate, 2); + * // => [[1, 1], [2, 2]] + */ + function flatMapDepth(collection, iteratee, depth) { + depth = depth === undefined ? 1 : toInteger(depth); + return baseFlatten(map(collection, iteratee), depth); + } + + /** + * Iterates over elements of `collection` and invokes `iteratee` for each element. + * The iteratee is invoked with three arguments: (value, index|key, collection). + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * **Note:** As with other "Collections" methods, objects with a "length" + * property are iterated like arrays. To avoid this behavior use `_.forIn` + * or `_.forOwn` for object iteration. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @alias each + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + * @see _.forEachRight + * @example + * + * _.forEach([1, 2], function(value) { + * console.log(value); + * }); + * // => Logs `1` then `2`. + * + * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a' then 'b' (iteration order is not guaranteed). + */ + function forEach(collection, iteratee) { + var func = isArray(collection) ? arrayEach : baseEach; + return func(collection, getIteratee(iteratee, 3)); + } + + /** + * This method is like `_.forEach` except that it iterates over elements of + * `collection` from right to left. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @alias eachRight + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array|Object} Returns `collection`. + * @see _.forEach + * @example + * + * _.forEachRight([1, 2], function(value) { + * console.log(value); + * }); + * // => Logs `2` then `1`. + */ + function forEachRight(collection, iteratee) { + var func = isArray(collection) ? arrayEachRight : baseEachRight; + return func(collection, getIteratee(iteratee, 3)); + } + + /** + * Creates an object composed of keys generated from the results of running + * each element of `collection` thru `iteratee`. The order of grouped values + * is determined by the order they occur in `collection`. The corresponding + * value of each key is an array of elements responsible for generating the + * key. The iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The iteratee to transform keys. + * @returns {Object} Returns the composed aggregate object. + * @example + * + * _.groupBy([6.1, 4.2, 6.3], Math.floor); + * // => { '4': [4.2], '6': [6.1, 6.3] } + * + * // The `_.property` iteratee shorthand. + * _.groupBy(['one', 'two', 'three'], 'length'); + * // => { '3': ['one', 'two'], '5': ['three'] } + */ + var groupBy = createAggregator(function(result, value, key) { + if (hasOwnProperty.call(result, key)) { + result[key].push(value); + } else { + baseAssignValue(result, key, [value]); + } + }); + + /** + * Checks if `value` is in `collection`. If `collection` is a string, it's + * checked for a substring of `value`, otherwise + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * is used for equality comparisons. If `fromIndex` is negative, it's used as + * the offset from the end of `collection`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object|string} collection The collection to inspect. + * @param {*} value The value to search for. + * @param {number} [fromIndex=0] The index to search from. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`. + * @returns {boolean} Returns `true` if `value` is found, else `false`. + * @example + * + * _.includes([1, 2, 3], 1); + * // => true + * + * _.includes([1, 2, 3], 1, 2); + * // => false + * + * _.includes({ 'a': 1, 'b': 2 }, 1); + * // => true + * + * _.includes('abcd', 'bc'); + * // => true + */ + function includes(collection, value, fromIndex, guard) { + collection = isArrayLike(collection) ? collection : values(collection); + fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0; + + var length = collection.length; + if (fromIndex < 0) { + fromIndex = nativeMax(length + fromIndex, 0); + } + return isString(collection) + ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1) + : (!!length && baseIndexOf(collection, value, fromIndex) > -1); + } + + /** + * Invokes the method at `path` of each element in `collection`, returning + * an array of the results of each invoked method. Any additional arguments + * are provided to each invoked method. If `path` is a function, it's invoked + * for, and `this` bound to, each element in `collection`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Array|Function|string} path The path of the method to invoke or + * the function invoked per iteration. + * @param {...*} [args] The arguments to invoke each method with. + * @returns {Array} Returns the array of results. + * @example + * + * _.invokeMap([[5, 1, 7], [3, 2, 1]], 'sort'); + * // => [[1, 5, 7], [1, 2, 3]] + * + * _.invokeMap([123, 456], String.prototype.split, ''); + * // => [['1', '2', '3'], ['4', '5', '6']] + */ + var invokeMap = baseRest(function(collection, path, args) { + var index = -1, + isFunc = typeof path == 'function', + result = isArrayLike(collection) ? Array(collection.length) : []; + + baseEach(collection, function(value) { + result[++index] = isFunc ? apply(path, value, args) : baseInvoke(value, path, args); + }); + return result; + }); + + /** + * Creates an object composed of keys generated from the results of running + * each element of `collection` thru `iteratee`. The corresponding value of + * each key is the last element responsible for generating the key. The + * iteratee is invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The iteratee to transform keys. + * @returns {Object} Returns the composed aggregate object. + * @example + * + * var array = [ + * { 'dir': 'left', 'code': 97 }, + * { 'dir': 'right', 'code': 100 } + * ]; + * + * _.keyBy(array, function(o) { + * return String.fromCharCode(o.code); + * }); + * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } } + * + * _.keyBy(array, 'dir'); + * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } } + */ + var keyBy = createAggregator(function(result, value, key) { + baseAssignValue(result, key, value); + }); + + /** + * Creates an array of values by running each element in `collection` thru + * `iteratee`. The iteratee is invoked with three arguments: + * (value, index|key, collection). + * + * Many lodash methods are guarded to work as iteratees for methods like + * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`. + * + * The guarded methods are: + * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`, + * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`, + * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`, + * `template`, `trim`, `trimEnd`, `trimStart`, and `words` + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new mapped array. + * @example + * + * function square(n) { + * return n * n; + * } + * + * _.map([4, 8], square); + * // => [16, 64] + * + * _.map({ 'a': 4, 'b': 8 }, square); + * // => [16, 64] (iteration order is not guaranteed) + * + * var users = [ + * { 'user': 'barney' }, + * { 'user': 'fred' } + * ]; + * + * // The `_.property` iteratee shorthand. + * _.map(users, 'user'); + * // => ['barney', 'fred'] + */ + function map(collection, iteratee) { + var func = isArray(collection) ? arrayMap : baseMap; + return func(collection, getIteratee(iteratee, 3)); + } + + /** + * This method is like `_.sortBy` except that it allows specifying the sort + * orders of the iteratees to sort by. If `orders` is unspecified, all values + * are sorted in ascending order. Otherwise, specify an order of "desc" for + * descending or "asc" for ascending sort order of corresponding values. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Array[]|Function[]|Object[]|string[]} [iteratees=[_.identity]] + * The iteratees to sort by. + * @param {string[]} [orders] The sort orders of `iteratees`. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`. + * @returns {Array} Returns the new sorted array. + * @example + * + * var users = [ + * { 'user': 'fred', 'age': 48 }, + * { 'user': 'barney', 'age': 34 }, + * { 'user': 'fred', 'age': 40 }, + * { 'user': 'barney', 'age': 36 } + * ]; + * + * // Sort by `user` in ascending order and by `age` in descending order. + * _.orderBy(users, ['user', 'age'], ['asc', 'desc']); + * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]] + */ + function orderBy(collection, iteratees, orders, guard) { + if (collection == null) { + return []; + } + if (!isArray(iteratees)) { + iteratees = iteratees == null ? [] : [iteratees]; + } + orders = guard ? undefined : orders; + if (!isArray(orders)) { + orders = orders == null ? [] : [orders]; + } + return baseOrderBy(collection, iteratees, orders); + } + + /** + * Creates an array of elements split into two groups, the first of which + * contains elements `predicate` returns truthy for, the second of which + * contains elements `predicate` returns falsey for. The predicate is + * invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the array of grouped elements. + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': false }, + * { 'user': 'fred', 'age': 40, 'active': true }, + * { 'user': 'pebbles', 'age': 1, 'active': false } + * ]; + * + * _.partition(users, function(o) { return o.active; }); + * // => objects for [['fred'], ['barney', 'pebbles']] + * + * // The `_.matches` iteratee shorthand. + * _.partition(users, { 'age': 1, 'active': false }); + * // => objects for [['pebbles'], ['barney', 'fred']] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.partition(users, ['active', false]); + * // => objects for [['barney', 'pebbles'], ['fred']] + * + * // The `_.property` iteratee shorthand. + * _.partition(users, 'active'); + * // => objects for [['fred'], ['barney', 'pebbles']] + */ + var partition = createAggregator(function(result, value, key) { + result[key ? 0 : 1].push(value); + }, function() { return [[], []]; }); + + /** + * Reduces `collection` to a value which is the accumulated result of running + * each element in `collection` thru `iteratee`, where each successive + * invocation is supplied the return value of the previous. If `accumulator` + * is not given, the first element of `collection` is used as the initial + * value. The iteratee is invoked with four arguments: + * (accumulator, value, index|key, collection). + * + * Many lodash methods are guarded to work as iteratees for methods like + * `_.reduce`, `_.reduceRight`, and `_.transform`. + * + * The guarded methods are: + * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`, + * and `sortBy` + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @returns {*} Returns the accumulated value. + * @see _.reduceRight + * @example + * + * _.reduce([1, 2], function(sum, n) { + * return sum + n; + * }, 0); + * // => 3 + * + * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) { + * (result[value] || (result[value] = [])).push(key); + * return result; + * }, {}); + * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed) + */ + function reduce(collection, iteratee, accumulator) { + var func = isArray(collection) ? arrayReduce : baseReduce, + initAccum = arguments.length < 3; + + return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEach); + } + + /** + * This method is like `_.reduce` except that it iterates over elements of + * `collection` from right to left. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @param {*} [accumulator] The initial value. + * @returns {*} Returns the accumulated value. + * @see _.reduce + * @example + * + * var array = [[0, 1], [2, 3], [4, 5]]; + * + * _.reduceRight(array, function(flattened, other) { + * return flattened.concat(other); + * }, []); + * // => [4, 5, 2, 3, 0, 1] + */ + function reduceRight(collection, iteratee, accumulator) { + var func = isArray(collection) ? arrayReduceRight : baseReduce, + initAccum = arguments.length < 3; + + return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEachRight); + } + + /** + * The opposite of `_.filter`; this method returns the elements of `collection` + * that `predicate` does **not** return truthy for. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {Array} Returns the new filtered array. + * @see _.filter + * @example + * + * var users = [ + * { 'user': 'barney', 'age': 36, 'active': false }, + * { 'user': 'fred', 'age': 40, 'active': true } + * ]; + * + * _.reject(users, function(o) { return !o.active; }); + * // => objects for ['fred'] + * + * // The `_.matches` iteratee shorthand. + * _.reject(users, { 'age': 40, 'active': true }); + * // => objects for ['barney'] + * + * // The `_.matchesProperty` iteratee shorthand. + * _.reject(users, ['active', false]); + * // => objects for ['fred'] + * + * // The `_.property` iteratee shorthand. + * _.reject(users, 'active'); + * // => objects for ['barney'] + */ + function reject(collection, predicate) { + var func = isArray(collection) ? arrayFilter : baseFilter; + return func(collection, negate(getIteratee(predicate, 3))); + } + + /** + * Gets a random element from `collection`. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Collection + * @param {Array|Object} collection The collection to sample. + * @returns {*} Returns the random element. + * @example + * + * _.sample([1, 2, 3, 4]); + * // => 2 + */ + function sample(collection) { + var func = isArray(collection) ? arraySample : baseSample; + return func(collection); + } + + /** + * Gets `n` random elements at unique keys from `collection` up to the + * size of `collection`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Collection + * @param {Array|Object} collection The collection to sample. + * @param {number} [n=1] The number of elements to sample. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Array} Returns the random elements. + * @example + * + * _.sampleSize([1, 2, 3], 2); + * // => [3, 1] + * + * _.sampleSize([1, 2, 3], 4); + * // => [2, 3, 1] + */ + function sampleSize(collection, n, guard) { + if ((guard ? isIterateeCall(collection, n, guard) : n === undefined)) { + n = 1; + } else { + n = toInteger(n); + } + var func = isArray(collection) ? arraySampleSize : baseSampleSize; + return func(collection, n); + } + + /** + * Creates an array of shuffled values, using a version of the + * [Fisher-Yates shuffle](https://en.wikipedia.org/wiki/Fisher-Yates_shuffle). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to shuffle. + * @returns {Array} Returns the new shuffled array. + * @example + * + * _.shuffle([1, 2, 3, 4]); + * // => [4, 1, 3, 2] + */ + function shuffle(collection) { + var func = isArray(collection) ? arrayShuffle : baseShuffle; + return func(collection); + } + + /** + * Gets the size of `collection` by returning its length for array-like + * values or the number of own enumerable string keyed properties for objects. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object|string} collection The collection to inspect. + * @returns {number} Returns the collection size. + * @example + * + * _.size([1, 2, 3]); + * // => 3 + * + * _.size({ 'a': 1, 'b': 2 }); + * // => 2 + * + * _.size('pebbles'); + * // => 7 + */ + function size(collection) { + if (collection == null) { + return 0; + } + if (isArrayLike(collection)) { + return isString(collection) ? stringSize(collection) : collection.length; + } + var tag = getTag(collection); + if (tag == mapTag || tag == setTag) { + return collection.size; + } + return baseKeys(collection).length; + } + + /** + * Checks if `predicate` returns truthy for **any** element of `collection`. + * Iteration is stopped once `predicate` returns truthy. The predicate is + * invoked with three arguments: (value, index|key, collection). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {boolean} Returns `true` if any element passes the predicate check, + * else `false`. + * @example + * + * _.some([null, 0, 'yes', false], Boolean); + * // => true + * + * var users = [ + * { 'user': 'barney', 'active': true }, + * { 'user': 'fred', 'active': false } + * ]; + * + * // The `_.matches` iteratee shorthand. + * _.some(users, { 'user': 'barney', 'active': false }); + * // => false + * + * // The `_.matchesProperty` iteratee shorthand. + * _.some(users, ['active', false]); + * // => true + * + * // The `_.property` iteratee shorthand. + * _.some(users, 'active'); + * // => true + */ + function some(collection, predicate, guard) { + var func = isArray(collection) ? arraySome : baseSome; + if (guard && isIterateeCall(collection, predicate, guard)) { + predicate = undefined; + } + return func(collection, getIteratee(predicate, 3)); + } + + /** + * Creates an array of elements, sorted in ascending order by the results of + * running each element in a collection thru each iteratee. This method + * performs a stable sort, that is, it preserves the original sort order of + * equal elements. The iteratees are invoked with one argument: (value). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Collection + * @param {Array|Object} collection The collection to iterate over. + * @param {...(Function|Function[])} [iteratees=[_.identity]] + * The iteratees to sort by. + * @returns {Array} Returns the new sorted array. + * @example + * + * var users = [ + * { 'user': 'fred', 'age': 48 }, + * { 'user': 'barney', 'age': 36 }, + * { 'user': 'fred', 'age': 30 }, + * { 'user': 'barney', 'age': 34 } + * ]; + * + * _.sortBy(users, [function(o) { return o.user; }]); + * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 30]] + * + * _.sortBy(users, ['user', 'age']); + * // => objects for [['barney', 34], ['barney', 36], ['fred', 30], ['fred', 48]] + */ + var sortBy = baseRest(function(collection, iteratees) { + if (collection == null) { + return []; + } + var length = iteratees.length; + if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) { + iteratees = []; + } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) { + iteratees = [iteratees[0]]; + } + return baseOrderBy(collection, baseFlatten(iteratees, 1), []); + }); + + /*------------------------------------------------------------------------*/ + + /** + * Gets the timestamp of the number of milliseconds that have elapsed since + * the Unix epoch (1 January 1970 00:00:00 UTC). + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Date + * @returns {number} Returns the timestamp. + * @example + * + * _.defer(function(stamp) { + * console.log(_.now() - stamp); + * }, _.now()); + * // => Logs the number of milliseconds it took for the deferred invocation. + */ + var now = ctxNow || function() { + return root.Date.now(); + }; + + /*------------------------------------------------------------------------*/ + + /** + * The opposite of `_.before`; this method creates a function that invokes + * `func` once it's called `n` or more times. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {number} n The number of calls before `func` is invoked. + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * var saves = ['profile', 'settings']; + * + * var done = _.after(saves.length, function() { + * console.log('done saving!'); + * }); + * + * _.forEach(saves, function(type) { + * asyncSave({ 'type': type, 'complete': done }); + * }); + * // => Logs 'done saving!' after the two async saves have completed. + */ + function after(n, func) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + n = toInteger(n); + return function() { + if (--n < 1) { + return func.apply(this, arguments); + } + }; + } + + /** + * Creates a function that invokes `func`, with up to `n` arguments, + * ignoring any additional arguments. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} func The function to cap arguments for. + * @param {number} [n=func.length] The arity cap. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the new capped function. + * @example + * + * _.map(['6', '8', '10'], _.ary(parseInt, 1)); + * // => [6, 8, 10] + */ + function ary(func, n, guard) { + n = guard ? undefined : n; + n = (func && n == null) ? func.length : n; + return createWrap(func, WRAP_ARY_FLAG, undefined, undefined, undefined, undefined, n); + } + + /** + * Creates a function that invokes `func`, with the `this` binding and arguments + * of the created function, while it's called less than `n` times. Subsequent + * calls to the created function return the result of the last `func` invocation. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {number} n The number of calls at which `func` is no longer invoked. + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * jQuery(element).on('click', _.before(5, addContactToList)); + * // => Allows adding up to 4 contacts to the list. + */ + function before(n, func) { + var result; + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + n = toInteger(n); + return function() { + if (--n > 0) { + result = func.apply(this, arguments); + } + if (n <= 1) { + func = undefined; + } + return result; + }; + } + + /** + * Creates a function that invokes `func` with the `this` binding of `thisArg` + * and `partials` prepended to the arguments it receives. + * + * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds, + * may be used as a placeholder for partially applied arguments. + * + * **Note:** Unlike native `Function#bind`, this method doesn't set the "length" + * property of bound functions. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to bind. + * @param {*} thisArg The `this` binding of `func`. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new bound function. + * @example + * + * function greet(greeting, punctuation) { + * return greeting + ' ' + this.user + punctuation; + * } + * + * var object = { 'user': 'fred' }; + * + * var bound = _.bind(greet, object, 'hi'); + * bound('!'); + * // => 'hi fred!' + * + * // Bound with placeholders. + * var bound = _.bind(greet, object, _, '!'); + * bound('hi'); + * // => 'hi fred!' + */ + var bind = baseRest(function(func, thisArg, partials) { + var bitmask = WRAP_BIND_FLAG; + if (partials.length) { + var holders = replaceHolders(partials, getHolder(bind)); + bitmask |= WRAP_PARTIAL_FLAG; + } + return createWrap(func, bitmask, thisArg, partials, holders); + }); + + /** + * Creates a function that invokes the method at `object[key]` with `partials` + * prepended to the arguments it receives. + * + * This method differs from `_.bind` by allowing bound functions to reference + * methods that may be redefined or don't yet exist. See + * [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern) + * for more details. + * + * The `_.bindKey.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for partially applied arguments. + * + * @static + * @memberOf _ + * @since 0.10.0 + * @category Function + * @param {Object} object The object to invoke the method on. + * @param {string} key The key of the method. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new bound function. + * @example + * + * var object = { + * 'user': 'fred', + * 'greet': function(greeting, punctuation) { + * return greeting + ' ' + this.user + punctuation; + * } + * }; + * + * var bound = _.bindKey(object, 'greet', 'hi'); + * bound('!'); + * // => 'hi fred!' + * + * object.greet = function(greeting, punctuation) { + * return greeting + 'ya ' + this.user + punctuation; + * }; + * + * bound('!'); + * // => 'hiya fred!' + * + * // Bound with placeholders. + * var bound = _.bindKey(object, 'greet', _, '!'); + * bound('hi'); + * // => 'hiya fred!' + */ + var bindKey = baseRest(function(object, key, partials) { + var bitmask = WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG; + if (partials.length) { + var holders = replaceHolders(partials, getHolder(bindKey)); + bitmask |= WRAP_PARTIAL_FLAG; + } + return createWrap(key, bitmask, object, partials, holders); + }); + + /** + * Creates a function that accepts arguments of `func` and either invokes + * `func` returning its result, if at least `arity` number of arguments have + * been provided, or returns a function that accepts the remaining `func` + * arguments, and so on. The arity of `func` may be specified if `func.length` + * is not sufficient. + * + * The `_.curry.placeholder` value, which defaults to `_` in monolithic builds, + * may be used as a placeholder for provided arguments. + * + * **Note:** This method doesn't set the "length" property of curried functions. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Function + * @param {Function} func The function to curry. + * @param {number} [arity=func.length] The arity of `func`. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the new curried function. + * @example + * + * var abc = function(a, b, c) { + * return [a, b, c]; + * }; + * + * var curried = _.curry(abc); + * + * curried(1)(2)(3); + * // => [1, 2, 3] + * + * curried(1, 2)(3); + * // => [1, 2, 3] + * + * curried(1, 2, 3); + * // => [1, 2, 3] + * + * // Curried with placeholders. + * curried(1)(_, 3)(2); + * // => [1, 2, 3] + */ + function curry(func, arity, guard) { + arity = guard ? undefined : arity; + var result = createWrap(func, WRAP_CURRY_FLAG, undefined, undefined, undefined, undefined, undefined, arity); + result.placeholder = curry.placeholder; + return result; + } + + /** + * This method is like `_.curry` except that arguments are applied to `func` + * in the manner of `_.partialRight` instead of `_.partial`. + * + * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for provided arguments. + * + * **Note:** This method doesn't set the "length" property of curried functions. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} func The function to curry. + * @param {number} [arity=func.length] The arity of `func`. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the new curried function. + * @example + * + * var abc = function(a, b, c) { + * return [a, b, c]; + * }; + * + * var curried = _.curryRight(abc); + * + * curried(3)(2)(1); + * // => [1, 2, 3] + * + * curried(2, 3)(1); + * // => [1, 2, 3] + * + * curried(1, 2, 3); + * // => [1, 2, 3] + * + * // Curried with placeholders. + * curried(3)(1, _)(2); + * // => [1, 2, 3] + */ + function curryRight(func, arity, guard) { + arity = guard ? undefined : arity; + var result = createWrap(func, WRAP_CURRY_RIGHT_FLAG, undefined, undefined, undefined, undefined, undefined, arity); + result.placeholder = curryRight.placeholder; + return result; + } + + /** + * Creates a debounced function that delays invoking `func` until after `wait` + * milliseconds have elapsed since the last time the debounced function was + * invoked. The debounced function comes with a `cancel` method to cancel + * delayed `func` invocations and a `flush` method to immediately invoke them. + * Provide `options` to indicate whether `func` should be invoked on the + * leading and/or trailing edge of the `wait` timeout. The `func` is invoked + * with the last arguments provided to the debounced function. Subsequent + * calls to the debounced function return the result of the last `func` + * invocation. + * + * **Note:** If `leading` and `trailing` options are `true`, `func` is + * invoked on the trailing edge of the timeout only if the debounced function + * is invoked more than once during the `wait` timeout. + * + * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred + * until to the next tick, similar to `setTimeout` with a timeout of `0`. + * + * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/) + * for details over the differences between `_.debounce` and `_.throttle`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to debounce. + * @param {number} [wait=0] The number of milliseconds to delay. + * @param {Object} [options={}] The options object. + * @param {boolean} [options.leading=false] + * Specify invoking on the leading edge of the timeout. + * @param {number} [options.maxWait] + * The maximum time `func` is allowed to be delayed before it's invoked. + * @param {boolean} [options.trailing=true] + * Specify invoking on the trailing edge of the timeout. + * @returns {Function} Returns the new debounced function. + * @example + * + * // Avoid costly calculations while the window size is in flux. + * jQuery(window).on('resize', _.debounce(calculateLayout, 150)); + * + * // Invoke `sendMail` when clicked, debouncing subsequent calls. + * jQuery(element).on('click', _.debounce(sendMail, 300, { + * 'leading': true, + * 'trailing': false + * })); + * + * // Ensure `batchLog` is invoked once after 1 second of debounced calls. + * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 }); + * var source = new EventSource('/stream'); + * jQuery(source).on('message', debounced); + * + * // Cancel the trailing debounced invocation. + * jQuery(window).on('popstate', debounced.cancel); + */ + function debounce(func, wait, options) { + var lastArgs, + lastThis, + maxWait, + result, + timerId, + lastCallTime, + lastInvokeTime = 0, + leading = false, + maxing = false, + trailing = true; + + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + wait = toNumber(wait) || 0; + if (isObject(options)) { + leading = !!options.leading; + maxing = 'maxWait' in options; + maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait; + trailing = 'trailing' in options ? !!options.trailing : trailing; + } + + function invokeFunc(time) { + var args = lastArgs, + thisArg = lastThis; + + lastArgs = lastThis = undefined; + lastInvokeTime = time; + result = func.apply(thisArg, args); + return result; + } + + function leadingEdge(time) { + // Reset any `maxWait` timer. + lastInvokeTime = time; + // Start the timer for the trailing edge. + timerId = setTimeout(timerExpired, wait); + // Invoke the leading edge. + return leading ? invokeFunc(time) : result; + } + + function remainingWait(time) { + var timeSinceLastCall = time - lastCallTime, + timeSinceLastInvoke = time - lastInvokeTime, + timeWaiting = wait - timeSinceLastCall; + + return maxing + ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke) + : timeWaiting; + } + + function shouldInvoke(time) { + var timeSinceLastCall = time - lastCallTime, + timeSinceLastInvoke = time - lastInvokeTime; + + // Either this is the first call, activity has stopped and we're at the + // trailing edge, the system time has gone backwards and we're treating + // it as the trailing edge, or we've hit the `maxWait` limit. + return (lastCallTime === undefined || (timeSinceLastCall >= wait) || + (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait)); + } + + function timerExpired() { + var time = now(); + if (shouldInvoke(time)) { + return trailingEdge(time); + } + // Restart the timer. + timerId = setTimeout(timerExpired, remainingWait(time)); + } + + function trailingEdge(time) { + timerId = undefined; + + // Only invoke if we have `lastArgs` which means `func` has been + // debounced at least once. + if (trailing && lastArgs) { + return invokeFunc(time); + } + lastArgs = lastThis = undefined; + return result; + } + + function cancel() { + if (timerId !== undefined) { + clearTimeout(timerId); + } + lastInvokeTime = 0; + lastArgs = lastCallTime = lastThis = timerId = undefined; + } + + function flush() { + return timerId === undefined ? result : trailingEdge(now()); + } + + function debounced() { + var time = now(), + isInvoking = shouldInvoke(time); + + lastArgs = arguments; + lastThis = this; + lastCallTime = time; + + if (isInvoking) { + if (timerId === undefined) { + return leadingEdge(lastCallTime); + } + if (maxing) { + // Handle invocations in a tight loop. + clearTimeout(timerId); + timerId = setTimeout(timerExpired, wait); + return invokeFunc(lastCallTime); + } + } + if (timerId === undefined) { + timerId = setTimeout(timerExpired, wait); + } + return result; + } + debounced.cancel = cancel; + debounced.flush = flush; + return debounced; + } + + /** + * Defers invoking the `func` until the current call stack has cleared. Any + * additional arguments are provided to `func` when it's invoked. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to defer. + * @param {...*} [args] The arguments to invoke `func` with. + * @returns {number} Returns the timer id. + * @example + * + * _.defer(function(text) { + * console.log(text); + * }, 'deferred'); + * // => Logs 'deferred' after one millisecond. + */ + var defer = baseRest(function(func, args) { + return baseDelay(func, 1, args); + }); + + /** + * Invokes `func` after `wait` milliseconds. Any additional arguments are + * provided to `func` when it's invoked. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to delay. + * @param {number} wait The number of milliseconds to delay invocation. + * @param {...*} [args] The arguments to invoke `func` with. + * @returns {number} Returns the timer id. + * @example + * + * _.delay(function(text) { + * console.log(text); + * }, 1000, 'later'); + * // => Logs 'later' after one second. + */ + var delay = baseRest(function(func, wait, args) { + return baseDelay(func, toNumber(wait) || 0, args); + }); + + /** + * Creates a function that invokes `func` with arguments reversed. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Function + * @param {Function} func The function to flip arguments for. + * @returns {Function} Returns the new flipped function. + * @example + * + * var flipped = _.flip(function() { + * return _.toArray(arguments); + * }); + * + * flipped('a', 'b', 'c', 'd'); + * // => ['d', 'c', 'b', 'a'] + */ + function flip(func) { + return createWrap(func, WRAP_FLIP_FLAG); + } + + /** + * Creates a function that memoizes the result of `func`. If `resolver` is + * provided, it determines the cache key for storing the result based on the + * arguments provided to the memoized function. By default, the first argument + * provided to the memoized function is used as the map cache key. The `func` + * is invoked with the `this` binding of the memoized function. + * + * **Note:** The cache is exposed as the `cache` property on the memoized + * function. Its creation may be customized by replacing the `_.memoize.Cache` + * constructor with one whose instances implement the + * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object) + * method interface of `clear`, `delete`, `get`, `has`, and `set`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to have its output memoized. + * @param {Function} [resolver] The function to resolve the cache key. + * @returns {Function} Returns the new memoized function. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * var other = { 'c': 3, 'd': 4 }; + * + * var values = _.memoize(_.values); + * values(object); + * // => [1, 2] + * + * values(other); + * // => [3, 4] + * + * object.a = 2; + * values(object); + * // => [1, 2] + * + * // Modify the result cache. + * values.cache.set(object, ['a', 'b']); + * values(object); + * // => ['a', 'b'] + * + * // Replace `_.memoize.Cache`. + * _.memoize.Cache = WeakMap; + */ + function memoize(func, resolver) { + if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) { + throw new TypeError(FUNC_ERROR_TEXT); + } + var memoized = function() { + var args = arguments, + key = resolver ? resolver.apply(this, args) : args[0], + cache = memoized.cache; + + if (cache.has(key)) { + return cache.get(key); + } + var result = func.apply(this, args); + memoized.cache = cache.set(key, result) || cache; + return result; + }; + memoized.cache = new (memoize.Cache || MapCache); + return memoized; + } + + // Expose `MapCache`. + memoize.Cache = MapCache; + + /** + * Creates a function that negates the result of the predicate `func`. The + * `func` predicate is invoked with the `this` binding and arguments of the + * created function. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} predicate The predicate to negate. + * @returns {Function} Returns the new negated function. + * @example + * + * function isEven(n) { + * return n % 2 == 0; + * } + * + * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven)); + * // => [1, 3, 5] + */ + function negate(predicate) { + if (typeof predicate != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + return function() { + var args = arguments; + switch (args.length) { + case 0: return !predicate.call(this); + case 1: return !predicate.call(this, args[0]); + case 2: return !predicate.call(this, args[0], args[1]); + case 3: return !predicate.call(this, args[0], args[1], args[2]); + } + return !predicate.apply(this, args); + }; + } + + /** + * Creates a function that is restricted to invoking `func` once. Repeat calls + * to the function return the value of the first invocation. The `func` is + * invoked with the `this` binding and arguments of the created function. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to restrict. + * @returns {Function} Returns the new restricted function. + * @example + * + * var initialize = _.once(createApplication); + * initialize(); + * initialize(); + * // => `createApplication` is invoked once + */ + function once(func) { + return before(2, func); + } + + /** + * Creates a function that invokes `func` with its arguments transformed. + * + * @static + * @since 4.0.0 + * @memberOf _ + * @category Function + * @param {Function} func The function to wrap. + * @param {...(Function|Function[])} [transforms=[_.identity]] + * The argument transforms. + * @returns {Function} Returns the new function. + * @example + * + * function doubled(n) { + * return n * 2; + * } + * + * function square(n) { + * return n * n; + * } + * + * var func = _.overArgs(function(x, y) { + * return [x, y]; + * }, [square, doubled]); + * + * func(9, 3); + * // => [81, 6] + * + * func(10, 5); + * // => [100, 10] + */ + var overArgs = castRest(function(func, transforms) { + transforms = (transforms.length == 1 && isArray(transforms[0])) + ? arrayMap(transforms[0], baseUnary(getIteratee())) + : arrayMap(baseFlatten(transforms, 1), baseUnary(getIteratee())); + + var funcsLength = transforms.length; + return baseRest(function(args) { + var index = -1, + length = nativeMin(args.length, funcsLength); + + while (++index < length) { + args[index] = transforms[index].call(this, args[index]); + } + return apply(func, this, args); + }); + }); + + /** + * Creates a function that invokes `func` with `partials` prepended to the + * arguments it receives. This method is like `_.bind` except it does **not** + * alter the `this` binding. + * + * The `_.partial.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for partially applied arguments. + * + * **Note:** This method doesn't set the "length" property of partially + * applied functions. + * + * @static + * @memberOf _ + * @since 0.2.0 + * @category Function + * @param {Function} func The function to partially apply arguments to. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new partially applied function. + * @example + * + * function greet(greeting, name) { + * return greeting + ' ' + name; + * } + * + * var sayHelloTo = _.partial(greet, 'hello'); + * sayHelloTo('fred'); + * // => 'hello fred' + * + * // Partially applied with placeholders. + * var greetFred = _.partial(greet, _, 'fred'); + * greetFred('hi'); + * // => 'hi fred' + */ + var partial = baseRest(function(func, partials) { + var holders = replaceHolders(partials, getHolder(partial)); + return createWrap(func, WRAP_PARTIAL_FLAG, undefined, partials, holders); + }); + + /** + * This method is like `_.partial` except that partially applied arguments + * are appended to the arguments it receives. + * + * The `_.partialRight.placeholder` value, which defaults to `_` in monolithic + * builds, may be used as a placeholder for partially applied arguments. + * + * **Note:** This method doesn't set the "length" property of partially + * applied functions. + * + * @static + * @memberOf _ + * @since 1.0.0 + * @category Function + * @param {Function} func The function to partially apply arguments to. + * @param {...*} [partials] The arguments to be partially applied. + * @returns {Function} Returns the new partially applied function. + * @example + * + * function greet(greeting, name) { + * return greeting + ' ' + name; + * } + * + * var greetFred = _.partialRight(greet, 'fred'); + * greetFred('hi'); + * // => 'hi fred' + * + * // Partially applied with placeholders. + * var sayHelloTo = _.partialRight(greet, 'hello', _); + * sayHelloTo('fred'); + * // => 'hello fred' + */ + var partialRight = baseRest(function(func, partials) { + var holders = replaceHolders(partials, getHolder(partialRight)); + return createWrap(func, WRAP_PARTIAL_RIGHT_FLAG, undefined, partials, holders); + }); + + /** + * Creates a function that invokes `func` with arguments arranged according + * to the specified `indexes` where the argument value at the first index is + * provided as the first argument, the argument value at the second index is + * provided as the second argument, and so on. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Function + * @param {Function} func The function to rearrange arguments for. + * @param {...(number|number[])} indexes The arranged argument indexes. + * @returns {Function} Returns the new function. + * @example + * + * var rearged = _.rearg(function(a, b, c) { + * return [a, b, c]; + * }, [2, 0, 1]); + * + * rearged('b', 'c', 'a') + * // => ['a', 'b', 'c'] + */ + var rearg = flatRest(function(func, indexes) { + return createWrap(func, WRAP_REARG_FLAG, undefined, undefined, undefined, indexes); + }); + + /** + * Creates a function that invokes `func` with the `this` binding of the + * created function and arguments from `start` and beyond provided as + * an array. + * + * **Note:** This method is based on the + * [rest parameter](https://mdn.io/rest_parameters). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Function + * @param {Function} func The function to apply a rest parameter to. + * @param {number} [start=func.length-1] The start position of the rest parameter. + * @returns {Function} Returns the new function. + * @example + * + * var say = _.rest(function(what, names) { + * return what + ' ' + _.initial(names).join(', ') + + * (_.size(names) > 1 ? ', & ' : '') + _.last(names); + * }); + * + * say('hello', 'fred', 'barney', 'pebbles'); + * // => 'hello fred, barney, & pebbles' + */ + function rest(func, start) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + start = start === undefined ? start : toInteger(start); + return baseRest(func, start); + } + + /** + * Creates a function that invokes `func` with the `this` binding of the + * create function and an array of arguments much like + * [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply). + * + * **Note:** This method is based on the + * [spread operator](https://mdn.io/spread_operator). + * + * @static + * @memberOf _ + * @since 3.2.0 + * @category Function + * @param {Function} func The function to spread arguments over. + * @param {number} [start=0] The start position of the spread. + * @returns {Function} Returns the new function. + * @example + * + * var say = _.spread(function(who, what) { + * return who + ' says ' + what; + * }); + * + * say(['fred', 'hello']); + * // => 'fred says hello' + * + * var numbers = Promise.all([ + * Promise.resolve(40), + * Promise.resolve(36) + * ]); + * + * numbers.then(_.spread(function(x, y) { + * return x + y; + * })); + * // => a Promise of 76 + */ + function spread(func, start) { + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + start = start == null ? 0 : nativeMax(toInteger(start), 0); + return baseRest(function(args) { + var array = args[start], + otherArgs = castSlice(args, 0, start); + + if (array) { + arrayPush(otherArgs, array); + } + return apply(func, this, otherArgs); + }); + } + + /** + * Creates a throttled function that only invokes `func` at most once per + * every `wait` milliseconds. The throttled function comes with a `cancel` + * method to cancel delayed `func` invocations and a `flush` method to + * immediately invoke them. Provide `options` to indicate whether `func` + * should be invoked on the leading and/or trailing edge of the `wait` + * timeout. The `func` is invoked with the last arguments provided to the + * throttled function. Subsequent calls to the throttled function return the + * result of the last `func` invocation. + * + * **Note:** If `leading` and `trailing` options are `true`, `func` is + * invoked on the trailing edge of the timeout only if the throttled function + * is invoked more than once during the `wait` timeout. + * + * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred + * until to the next tick, similar to `setTimeout` with a timeout of `0`. + * + * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/) + * for details over the differences between `_.throttle` and `_.debounce`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {Function} func The function to throttle. + * @param {number} [wait=0] The number of milliseconds to throttle invocations to. + * @param {Object} [options={}] The options object. + * @param {boolean} [options.leading=true] + * Specify invoking on the leading edge of the timeout. + * @param {boolean} [options.trailing=true] + * Specify invoking on the trailing edge of the timeout. + * @returns {Function} Returns the new throttled function. + * @example + * + * // Avoid excessively updating the position while scrolling. + * jQuery(window).on('scroll', _.throttle(updatePosition, 100)); + * + * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes. + * var throttled = _.throttle(renewToken, 300000, { 'trailing': false }); + * jQuery(element).on('click', throttled); + * + * // Cancel the trailing throttled invocation. + * jQuery(window).on('popstate', throttled.cancel); + */ + function throttle(func, wait, options) { + var leading = true, + trailing = true; + + if (typeof func != 'function') { + throw new TypeError(FUNC_ERROR_TEXT); + } + if (isObject(options)) { + leading = 'leading' in options ? !!options.leading : leading; + trailing = 'trailing' in options ? !!options.trailing : trailing; + } + return debounce(func, wait, { + 'leading': leading, + 'maxWait': wait, + 'trailing': trailing + }); + } + + /** + * Creates a function that accepts up to one argument, ignoring any + * additional arguments. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Function + * @param {Function} func The function to cap arguments for. + * @returns {Function} Returns the new capped function. + * @example + * + * _.map(['6', '8', '10'], _.unary(parseInt)); + * // => [6, 8, 10] + */ + function unary(func) { + return ary(func, 1); + } + + /** + * Creates a function that provides `value` to `wrapper` as its first + * argument. Any additional arguments provided to the function are appended + * to those provided to the `wrapper`. The wrapper is invoked with the `this` + * binding of the created function. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Function + * @param {*} value The value to wrap. + * @param {Function} [wrapper=identity] The wrapper function. + * @returns {Function} Returns the new function. + * @example + * + * var p = _.wrap(_.escape, function(func, text) { + * return '

    ' + func(text) + '

    '; + * }); + * + * p('fred, barney, & pebbles'); + * // => '

    fred, barney, & pebbles

    ' + */ + function wrap(value, wrapper) { + return partial(castFunction(wrapper), value); + } + + /*------------------------------------------------------------------------*/ + + /** + * Casts `value` as an array if it's not one. + * + * @static + * @memberOf _ + * @since 4.4.0 + * @category Lang + * @param {*} value The value to inspect. + * @returns {Array} Returns the cast array. + * @example + * + * _.castArray(1); + * // => [1] + * + * _.castArray({ 'a': 1 }); + * // => [{ 'a': 1 }] + * + * _.castArray('abc'); + * // => ['abc'] + * + * _.castArray(null); + * // => [null] + * + * _.castArray(undefined); + * // => [undefined] + * + * _.castArray(); + * // => [] + * + * var array = [1, 2, 3]; + * console.log(_.castArray(array) === array); + * // => true + */ + function castArray() { + if (!arguments.length) { + return []; + } + var value = arguments[0]; + return isArray(value) ? value : [value]; + } + + /** + * Creates a shallow clone of `value`. + * + * **Note:** This method is loosely based on the + * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm) + * and supports cloning arrays, array buffers, booleans, date objects, maps, + * numbers, `Object` objects, regexes, sets, strings, symbols, and typed + * arrays. The own enumerable properties of `arguments` objects are cloned + * as plain objects. An empty object is returned for uncloneable values such + * as error objects, functions, DOM nodes, and WeakMaps. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to clone. + * @returns {*} Returns the cloned value. + * @see _.cloneDeep + * @example + * + * var objects = [{ 'a': 1 }, { 'b': 2 }]; + * + * var shallow = _.clone(objects); + * console.log(shallow[0] === objects[0]); + * // => true + */ + function clone(value) { + return baseClone(value, CLONE_SYMBOLS_FLAG); + } + + /** + * This method is like `_.clone` except that it accepts `customizer` which + * is invoked to produce the cloned value. If `customizer` returns `undefined`, + * cloning is handled by the method instead. The `customizer` is invoked with + * up to four arguments; (value [, index|key, object, stack]). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to clone. + * @param {Function} [customizer] The function to customize cloning. + * @returns {*} Returns the cloned value. + * @see _.cloneDeepWith + * @example + * + * function customizer(value) { + * if (_.isElement(value)) { + * return value.cloneNode(false); + * } + * } + * + * var el = _.cloneWith(document.body, customizer); + * + * console.log(el === document.body); + * // => false + * console.log(el.nodeName); + * // => 'BODY' + * console.log(el.childNodes.length); + * // => 0 + */ + function cloneWith(value, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + return baseClone(value, CLONE_SYMBOLS_FLAG, customizer); + } + + /** + * This method is like `_.clone` except that it recursively clones `value`. + * + * @static + * @memberOf _ + * @since 1.0.0 + * @category Lang + * @param {*} value The value to recursively clone. + * @returns {*} Returns the deep cloned value. + * @see _.clone + * @example + * + * var objects = [{ 'a': 1 }, { 'b': 2 }]; + * + * var deep = _.cloneDeep(objects); + * console.log(deep[0] === objects[0]); + * // => false + */ + function cloneDeep(value) { + return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG); + } + + /** + * This method is like `_.cloneWith` except that it recursively clones `value`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to recursively clone. + * @param {Function} [customizer] The function to customize cloning. + * @returns {*} Returns the deep cloned value. + * @see _.cloneWith + * @example + * + * function customizer(value) { + * if (_.isElement(value)) { + * return value.cloneNode(true); + * } + * } + * + * var el = _.cloneDeepWith(document.body, customizer); + * + * console.log(el === document.body); + * // => false + * console.log(el.nodeName); + * // => 'BODY' + * console.log(el.childNodes.length); + * // => 20 + */ + function cloneDeepWith(value, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG, customizer); + } + + /** + * Checks if `object` conforms to `source` by invoking the predicate + * properties of `source` with the corresponding property values of `object`. + * + * **Note:** This method is equivalent to `_.conforms` when `source` is + * partially applied. + * + * @static + * @memberOf _ + * @since 4.14.0 + * @category Lang + * @param {Object} object The object to inspect. + * @param {Object} source The object of property predicates to conform to. + * @returns {boolean} Returns `true` if `object` conforms, else `false`. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * + * _.conformsTo(object, { 'b': function(n) { return n > 1; } }); + * // => true + * + * _.conformsTo(object, { 'b': function(n) { return n > 2; } }); + * // => false + */ + function conformsTo(object, source) { + return source == null || baseConformsTo(object, source, keys(source)); + } + + /** + * Performs a + * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero) + * comparison between two values to determine if they are equivalent. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.eq(object, object); + * // => true + * + * _.eq(object, other); + * // => false + * + * _.eq('a', 'a'); + * // => true + * + * _.eq('a', Object('a')); + * // => false + * + * _.eq(NaN, NaN); + * // => true + */ + function eq(value, other) { + return value === other || (value !== value && other !== other); + } + + /** + * Checks if `value` is greater than `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than `other`, + * else `false`. + * @see _.lt + * @example + * + * _.gt(3, 1); + * // => true + * + * _.gt(3, 3); + * // => false + * + * _.gt(1, 3); + * // => false + */ + var gt = createRelationalOperation(baseGt); + + /** + * Checks if `value` is greater than or equal to `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is greater than or equal to + * `other`, else `false`. + * @see _.lte + * @example + * + * _.gte(3, 1); + * // => true + * + * _.gte(3, 3); + * // => true + * + * _.gte(1, 3); + * // => false + */ + var gte = createRelationalOperation(function(value, other) { + return value >= other; + }); + + /** + * Checks if `value` is likely an `arguments` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an `arguments` object, + * else `false`. + * @example + * + * _.isArguments(function() { return arguments; }()); + * // => true + * + * _.isArguments([1, 2, 3]); + * // => false + */ + var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) { + return isObjectLike(value) && hasOwnProperty.call(value, 'callee') && + !propertyIsEnumerable.call(value, 'callee'); + }; + + /** + * Checks if `value` is classified as an `Array` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array, else `false`. + * @example + * + * _.isArray([1, 2, 3]); + * // => true + * + * _.isArray(document.body.children); + * // => false + * + * _.isArray('abc'); + * // => false + * + * _.isArray(_.noop); + * // => false + */ + var isArray = Array.isArray; + + /** + * Checks if `value` is classified as an `ArrayBuffer` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`. + * @example + * + * _.isArrayBuffer(new ArrayBuffer(2)); + * // => true + * + * _.isArrayBuffer(new Array(2)); + * // => false + */ + var isArrayBuffer = nodeIsArrayBuffer ? baseUnary(nodeIsArrayBuffer) : baseIsArrayBuffer; + + /** + * Checks if `value` is array-like. A value is considered array-like if it's + * not a function and has a `value.length` that's an integer greater than or + * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is array-like, else `false`. + * @example + * + * _.isArrayLike([1, 2, 3]); + * // => true + * + * _.isArrayLike(document.body.children); + * // => true + * + * _.isArrayLike('abc'); + * // => true + * + * _.isArrayLike(_.noop); + * // => false + */ + function isArrayLike(value) { + return value != null && isLength(value.length) && !isFunction(value); + } + + /** + * This method is like `_.isArrayLike` except that it also checks if `value` + * is an object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an array-like object, + * else `false`. + * @example + * + * _.isArrayLikeObject([1, 2, 3]); + * // => true + * + * _.isArrayLikeObject(document.body.children); + * // => true + * + * _.isArrayLikeObject('abc'); + * // => false + * + * _.isArrayLikeObject(_.noop); + * // => false + */ + function isArrayLikeObject(value) { + return isObjectLike(value) && isArrayLike(value); + } + + /** + * Checks if `value` is classified as a boolean primitive or object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a boolean, else `false`. + * @example + * + * _.isBoolean(false); + * // => true + * + * _.isBoolean(null); + * // => false + */ + function isBoolean(value) { + return value === true || value === false || + (isObjectLike(value) && baseGetTag(value) == boolTag); + } + + /** + * Checks if `value` is a buffer. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a buffer, else `false`. + * @example + * + * _.isBuffer(new Buffer(2)); + * // => true + * + * _.isBuffer(new Uint8Array(2)); + * // => false + */ + var isBuffer = nativeIsBuffer || stubFalse; + + /** + * Checks if `value` is classified as a `Date` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a date object, else `false`. + * @example + * + * _.isDate(new Date); + * // => true + * + * _.isDate('Mon April 23 2012'); + * // => false + */ + var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate; + + /** + * Checks if `value` is likely a DOM element. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a DOM element, else `false`. + * @example + * + * _.isElement(document.body); + * // => true + * + * _.isElement(''); + * // => false + */ + function isElement(value) { + return isObjectLike(value) && value.nodeType === 1 && !isPlainObject(value); + } + + /** + * Checks if `value` is an empty object, collection, map, or set. + * + * Objects are considered empty if they have no own enumerable string keyed + * properties. + * + * Array-like values such as `arguments` objects, arrays, buffers, strings, or + * jQuery-like collections are considered empty if they have a `length` of `0`. + * Similarly, maps and sets are considered empty if they have a `size` of `0`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is empty, else `false`. + * @example + * + * _.isEmpty(null); + * // => true + * + * _.isEmpty(true); + * // => true + * + * _.isEmpty(1); + * // => true + * + * _.isEmpty([1, 2, 3]); + * // => false + * + * _.isEmpty({ 'a': 1 }); + * // => false + */ + function isEmpty(value) { + if (value == null) { + return true; + } + if (isArrayLike(value) && + (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' || + isBuffer(value) || isTypedArray(value) || isArguments(value))) { + return !value.length; + } + var tag = getTag(value); + if (tag == mapTag || tag == setTag) { + return !value.size; + } + if (isPrototype(value)) { + return !baseKeys(value).length; + } + for (var key in value) { + if (hasOwnProperty.call(value, key)) { + return false; + } + } + return true; + } + + /** + * Performs a deep comparison between two values to determine if they are + * equivalent. + * + * **Note:** This method supports comparing arrays, array buffers, booleans, + * date objects, error objects, maps, numbers, `Object` objects, regexes, + * sets, strings, symbols, and typed arrays. `Object` objects are compared + * by their own, not inherited, enumerable properties. Functions and DOM + * nodes are compared by strict equality, i.e. `===`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * var object = { 'a': 1 }; + * var other = { 'a': 1 }; + * + * _.isEqual(object, other); + * // => true + * + * object === other; + * // => false + */ + function isEqual(value, other) { + return baseIsEqual(value, other); + } + + /** + * This method is like `_.isEqual` except that it accepts `customizer` which + * is invoked to compare values. If `customizer` returns `undefined`, comparisons + * are handled by the method instead. The `customizer` is invoked with up to + * six arguments: (objValue, othValue [, index|key, object, other, stack]). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if the values are equivalent, else `false`. + * @example + * + * function isGreeting(value) { + * return /^h(?:i|ello)$/.test(value); + * } + * + * function customizer(objValue, othValue) { + * if (isGreeting(objValue) && isGreeting(othValue)) { + * return true; + * } + * } + * + * var array = ['hello', 'goodbye']; + * var other = ['hi', 'goodbye']; + * + * _.isEqualWith(array, other, customizer); + * // => true + */ + function isEqualWith(value, other, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + var result = customizer ? customizer(value, other) : undefined; + return result === undefined ? baseIsEqual(value, other, undefined, customizer) : !!result; + } + + /** + * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`, + * `SyntaxError`, `TypeError`, or `URIError` object. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an error object, else `false`. + * @example + * + * _.isError(new Error); + * // => true + * + * _.isError(Error); + * // => false + */ + function isError(value) { + if (!isObjectLike(value)) { + return false; + } + var tag = baseGetTag(value); + return tag == errorTag || tag == domExcTag || + (typeof value.message == 'string' && typeof value.name == 'string' && !isPlainObject(value)); + } + + /** + * Checks if `value` is a finite primitive number. + * + * **Note:** This method is based on + * [`Number.isFinite`](https://mdn.io/Number/isFinite). + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a finite number, else `false`. + * @example + * + * _.isFinite(3); + * // => true + * + * _.isFinite(Number.MIN_VALUE); + * // => true + * + * _.isFinite(Infinity); + * // => false + * + * _.isFinite('3'); + * // => false + */ + function isFinite(value) { + return typeof value == 'number' && nativeIsFinite(value); + } + + /** + * Checks if `value` is classified as a `Function` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a function, else `false`. + * @example + * + * _.isFunction(_); + * // => true + * + * _.isFunction(/abc/); + * // => false + */ + function isFunction(value) { + if (!isObject(value)) { + return false; + } + // The use of `Object#toString` avoids issues with the `typeof` operator + // in Safari 9 which returns 'object' for typed arrays and other constructors. + var tag = baseGetTag(value); + return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag; + } + + /** + * Checks if `value` is an integer. + * + * **Note:** This method is based on + * [`Number.isInteger`](https://mdn.io/Number/isInteger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an integer, else `false`. + * @example + * + * _.isInteger(3); + * // => true + * + * _.isInteger(Number.MIN_VALUE); + * // => false + * + * _.isInteger(Infinity); + * // => false + * + * _.isInteger('3'); + * // => false + */ + function isInteger(value) { + return typeof value == 'number' && value == toInteger(value); + } + + /** + * Checks if `value` is a valid array-like length. + * + * **Note:** This method is loosely based on + * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a valid length, else `false`. + * @example + * + * _.isLength(3); + * // => true + * + * _.isLength(Number.MIN_VALUE); + * // => false + * + * _.isLength(Infinity); + * // => false + * + * _.isLength('3'); + * // => false + */ + function isLength(value) { + return typeof value == 'number' && + value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; + } + + /** + * Checks if `value` is the + * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types) + * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is an object, else `false`. + * @example + * + * _.isObject({}); + * // => true + * + * _.isObject([1, 2, 3]); + * // => true + * + * _.isObject(_.noop); + * // => true + * + * _.isObject(null); + * // => false + */ + function isObject(value) { + var type = typeof value; + return value != null && (type == 'object' || type == 'function'); + } + + /** + * Checks if `value` is object-like. A value is object-like if it's not `null` + * and has a `typeof` result of "object". + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is object-like, else `false`. + * @example + * + * _.isObjectLike({}); + * // => true + * + * _.isObjectLike([1, 2, 3]); + * // => true + * + * _.isObjectLike(_.noop); + * // => false + * + * _.isObjectLike(null); + * // => false + */ + function isObjectLike(value) { + return value != null && typeof value == 'object'; + } + + /** + * Checks if `value` is classified as a `Map` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a map, else `false`. + * @example + * + * _.isMap(new Map); + * // => true + * + * _.isMap(new WeakMap); + * // => false + */ + var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap; + + /** + * Performs a partial deep comparison between `object` and `source` to + * determine if `object` contains equivalent property values. + * + * **Note:** This method is equivalent to `_.matches` when `source` is + * partially applied. + * + * Partial comparisons will match empty array and empty object `source` + * values against any array or object value, respectively. See `_.isEqual` + * for a list of supported value comparisons. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + * @example + * + * var object = { 'a': 1, 'b': 2 }; + * + * _.isMatch(object, { 'b': 2 }); + * // => true + * + * _.isMatch(object, { 'b': 1 }); + * // => false + */ + function isMatch(object, source) { + return object === source || baseIsMatch(object, source, getMatchData(source)); + } + + /** + * This method is like `_.isMatch` except that it accepts `customizer` which + * is invoked to compare values. If `customizer` returns `undefined`, comparisons + * are handled by the method instead. The `customizer` is invoked with five + * arguments: (objValue, srcValue, index|key, object, source). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {Object} object The object to inspect. + * @param {Object} source The object of property values to match. + * @param {Function} [customizer] The function to customize comparisons. + * @returns {boolean} Returns `true` if `object` is a match, else `false`. + * @example + * + * function isGreeting(value) { + * return /^h(?:i|ello)$/.test(value); + * } + * + * function customizer(objValue, srcValue) { + * if (isGreeting(objValue) && isGreeting(srcValue)) { + * return true; + * } + * } + * + * var object = { 'greeting': 'hello' }; + * var source = { 'greeting': 'hi' }; + * + * _.isMatchWith(object, source, customizer); + * // => true + */ + function isMatchWith(object, source, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + return baseIsMatch(object, source, getMatchData(source), customizer); + } + + /** + * Checks if `value` is `NaN`. + * + * **Note:** This method is based on + * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as + * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for + * `undefined` and other non-number values. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`. + * @example + * + * _.isNaN(NaN); + * // => true + * + * _.isNaN(new Number(NaN)); + * // => true + * + * isNaN(undefined); + * // => true + * + * _.isNaN(undefined); + * // => false + */ + function isNaN(value) { + // An `NaN` primitive is the only value that is not equal to itself. + // Perform the `toStringTag` check first to avoid errors with some + // ActiveX objects in IE. + return isNumber(value) && value != +value; + } + + /** + * Checks if `value` is a pristine native function. + * + * **Note:** This method can't reliably detect native functions in the presence + * of the core-js package because core-js circumvents this kind of detection. + * Despite multiple requests, the core-js maintainer has made it clear: any + * attempt to fix the detection will be obstructed. As a result, we're left + * with little choice but to throw an error. Unfortunately, this also affects + * packages, like [babel-polyfill](https://www.npmjs.com/package/babel-polyfill), + * which rely on core-js. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a native function, + * else `false`. + * @example + * + * _.isNative(Array.prototype.push); + * // => true + * + * _.isNative(_); + * // => false + */ + function isNative(value) { + if (isMaskable(value)) { + throw new Error(CORE_ERROR_TEXT); + } + return baseIsNative(value); + } + + /** + * Checks if `value` is `null`. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `null`, else `false`. + * @example + * + * _.isNull(null); + * // => true + * + * _.isNull(void 0); + * // => false + */ + function isNull(value) { + return value === null; + } + + /** + * Checks if `value` is `null` or `undefined`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is nullish, else `false`. + * @example + * + * _.isNil(null); + * // => true + * + * _.isNil(void 0); + * // => true + * + * _.isNil(NaN); + * // => false + */ + function isNil(value) { + return value == null; + } + + /** + * Checks if `value` is classified as a `Number` primitive or object. + * + * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are + * classified as numbers, use the `_.isFinite` method. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a number, else `false`. + * @example + * + * _.isNumber(3); + * // => true + * + * _.isNumber(Number.MIN_VALUE); + * // => true + * + * _.isNumber(Infinity); + * // => true + * + * _.isNumber('3'); + * // => false + */ + function isNumber(value) { + return typeof value == 'number' || + (isObjectLike(value) && baseGetTag(value) == numberTag); + } + + /** + * Checks if `value` is a plain object, that is, an object created by the + * `Object` constructor or one with a `[[Prototype]]` of `null`. + * + * @static + * @memberOf _ + * @since 0.8.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a plain object, else `false`. + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * _.isPlainObject(new Foo); + * // => false + * + * _.isPlainObject([1, 2, 3]); + * // => false + * + * _.isPlainObject({ 'x': 0, 'y': 0 }); + * // => true + * + * _.isPlainObject(Object.create(null)); + * // => true + */ + function isPlainObject(value) { + if (!isObjectLike(value) || baseGetTag(value) != objectTag) { + return false; + } + var proto = getPrototype(value); + if (proto === null) { + return true; + } + var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor; + return typeof Ctor == 'function' && Ctor instanceof Ctor && + funcToString.call(Ctor) == objectCtorString; + } + + /** + * Checks if `value` is classified as a `RegExp` object. + * + * @static + * @memberOf _ + * @since 0.1.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a regexp, else `false`. + * @example + * + * _.isRegExp(/abc/); + * // => true + * + * _.isRegExp('/abc/'); + * // => false + */ + var isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp; + + /** + * Checks if `value` is a safe integer. An integer is safe if it's an IEEE-754 + * double precision number which isn't the result of a rounded unsafe integer. + * + * **Note:** This method is based on + * [`Number.isSafeInteger`](https://mdn.io/Number/isSafeInteger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a safe integer, else `false`. + * @example + * + * _.isSafeInteger(3); + * // => true + * + * _.isSafeInteger(Number.MIN_VALUE); + * // => false + * + * _.isSafeInteger(Infinity); + * // => false + * + * _.isSafeInteger('3'); + * // => false + */ + function isSafeInteger(value) { + return isInteger(value) && value >= -MAX_SAFE_INTEGER && value <= MAX_SAFE_INTEGER; + } + + /** + * Checks if `value` is classified as a `Set` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a set, else `false`. + * @example + * + * _.isSet(new Set); + * // => true + * + * _.isSet(new WeakSet); + * // => false + */ + var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet; + + /** + * Checks if `value` is classified as a `String` primitive or object. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a string, else `false`. + * @example + * + * _.isString('abc'); + * // => true + * + * _.isString(1); + * // => false + */ + function isString(value) { + return typeof value == 'string' || + (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag); + } + + /** + * Checks if `value` is classified as a `Symbol` primitive or object. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a symbol, else `false`. + * @example + * + * _.isSymbol(Symbol.iterator); + * // => true + * + * _.isSymbol('abc'); + * // => false + */ + function isSymbol(value) { + return typeof value == 'symbol' || + (isObjectLike(value) && baseGetTag(value) == symbolTag); + } + + /** + * Checks if `value` is classified as a typed array. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a typed array, else `false`. + * @example + * + * _.isTypedArray(new Uint8Array); + * // => true + * + * _.isTypedArray([]); + * // => false + */ + var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray; + + /** + * Checks if `value` is `undefined`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`. + * @example + * + * _.isUndefined(void 0); + * // => true + * + * _.isUndefined(null); + * // => false + */ + function isUndefined(value) { + return value === undefined; + } + + /** + * Checks if `value` is classified as a `WeakMap` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a weak map, else `false`. + * @example + * + * _.isWeakMap(new WeakMap); + * // => true + * + * _.isWeakMap(new Map); + * // => false + */ + function isWeakMap(value) { + return isObjectLike(value) && getTag(value) == weakMapTag; + } + + /** + * Checks if `value` is classified as a `WeakSet` object. + * + * @static + * @memberOf _ + * @since 4.3.0 + * @category Lang + * @param {*} value The value to check. + * @returns {boolean} Returns `true` if `value` is a weak set, else `false`. + * @example + * + * _.isWeakSet(new WeakSet); + * // => true + * + * _.isWeakSet(new Set); + * // => false + */ + function isWeakSet(value) { + return isObjectLike(value) && baseGetTag(value) == weakSetTag; + } + + /** + * Checks if `value` is less than `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is less than `other`, + * else `false`. + * @see _.gt + * @example + * + * _.lt(1, 3); + * // => true + * + * _.lt(3, 3); + * // => false + * + * _.lt(3, 1); + * // => false + */ + var lt = createRelationalOperation(baseLt); + + /** + * Checks if `value` is less than or equal to `other`. + * + * @static + * @memberOf _ + * @since 3.9.0 + * @category Lang + * @param {*} value The value to compare. + * @param {*} other The other value to compare. + * @returns {boolean} Returns `true` if `value` is less than or equal to + * `other`, else `false`. + * @see _.gte + * @example + * + * _.lte(1, 3); + * // => true + * + * _.lte(3, 3); + * // => true + * + * _.lte(3, 1); + * // => false + */ + var lte = createRelationalOperation(function(value, other) { + return value <= other; + }); + + /** + * Converts `value` to an array. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Lang + * @param {*} value The value to convert. + * @returns {Array} Returns the converted array. + * @example + * + * _.toArray({ 'a': 1, 'b': 2 }); + * // => [1, 2] + * + * _.toArray('abc'); + * // => ['a', 'b', 'c'] + * + * _.toArray(1); + * // => [] + * + * _.toArray(null); + * // => [] + */ + function toArray(value) { + if (!value) { + return []; + } + if (isArrayLike(value)) { + return isString(value) ? stringToArray(value) : copyArray(value); + } + if (symIterator && value[symIterator]) { + return iteratorToArray(value[symIterator]()); + } + var tag = getTag(value), + func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values); + + return func(value); + } + + /** + * Converts `value` to a finite number. + * + * @static + * @memberOf _ + * @since 4.12.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted number. + * @example + * + * _.toFinite(3.2); + * // => 3.2 + * + * _.toFinite(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toFinite(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toFinite('3.2'); + * // => 3.2 + */ + function toFinite(value) { + if (!value) { + return value === 0 ? value : 0; + } + value = toNumber(value); + if (value === INFINITY || value === -INFINITY) { + var sign = (value < 0 ? -1 : 1); + return sign * MAX_INTEGER; + } + return value === value ? value : 0; + } + + /** + * Converts `value` to an integer. + * + * **Note:** This method is loosely based on + * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. + * @example + * + * _.toInteger(3.2); + * // => 3 + * + * _.toInteger(Number.MIN_VALUE); + * // => 0 + * + * _.toInteger(Infinity); + * // => 1.7976931348623157e+308 + * + * _.toInteger('3.2'); + * // => 3 + */ + function toInteger(value) { + var result = toFinite(value), + remainder = result % 1; + + return result === result ? (remainder ? result - remainder : result) : 0; + } + + /** + * Converts `value` to an integer suitable for use as the length of an + * array-like object. + * + * **Note:** This method is based on + * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. + * @example + * + * _.toLength(3.2); + * // => 3 + * + * _.toLength(Number.MIN_VALUE); + * // => 0 + * + * _.toLength(Infinity); + * // => 4294967295 + * + * _.toLength('3.2'); + * // => 3 + */ + function toLength(value) { + return value ? baseClamp(toInteger(value), 0, MAX_ARRAY_LENGTH) : 0; + } + + /** + * Converts `value` to a number. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to process. + * @returns {number} Returns the number. + * @example + * + * _.toNumber(3.2); + * // => 3.2 + * + * _.toNumber(Number.MIN_VALUE); + * // => 5e-324 + * + * _.toNumber(Infinity); + * // => Infinity + * + * _.toNumber('3.2'); + * // => 3.2 + */ + function toNumber(value) { + if (typeof value == 'number') { + return value; + } + if (isSymbol(value)) { + return NAN; + } + if (isObject(value)) { + var other = typeof value.valueOf == 'function' ? value.valueOf() : value; + value = isObject(other) ? (other + '') : other; + } + if (typeof value != 'string') { + return value === 0 ? value : +value; + } + value = baseTrim(value); + var isBinary = reIsBinary.test(value); + return (isBinary || reIsOctal.test(value)) + ? freeParseInt(value.slice(2), isBinary ? 2 : 8) + : (reIsBadHex.test(value) ? NAN : +value); + } + + /** + * Converts `value` to a plain object flattening inherited enumerable string + * keyed properties of `value` to own properties of the plain object. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {Object} Returns the converted plain object. + * @example + * + * function Foo() { + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.assign({ 'a': 1 }, new Foo); + * // => { 'a': 1, 'b': 2 } + * + * _.assign({ 'a': 1 }, _.toPlainObject(new Foo)); + * // => { 'a': 1, 'b': 2, 'c': 3 } + */ + function toPlainObject(value) { + return copyObject(value, keysIn(value)); + } + + /** + * Converts `value` to a safe integer. A safe integer can be compared and + * represented correctly. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {number} Returns the converted integer. + * @example + * + * _.toSafeInteger(3.2); + * // => 3 + * + * _.toSafeInteger(Number.MIN_VALUE); + * // => 0 + * + * _.toSafeInteger(Infinity); + * // => 9007199254740991 + * + * _.toSafeInteger('3.2'); + * // => 3 + */ + function toSafeInteger(value) { + return value + ? baseClamp(toInteger(value), -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER) + : (value === 0 ? value : 0); + } + + /** + * Converts `value` to a string. An empty string is returned for `null` + * and `undefined` values. The sign of `-0` is preserved. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Lang + * @param {*} value The value to convert. + * @returns {string} Returns the converted string. + * @example + * + * _.toString(null); + * // => '' + * + * _.toString(-0); + * // => '-0' + * + * _.toString([1, 2, 3]); + * // => '1,2,3' + */ + function toString(value) { + return value == null ? '' : baseToString(value); + } + + /*------------------------------------------------------------------------*/ + + /** + * Assigns own enumerable string keyed properties of source objects to the + * destination object. Source objects are applied from left to right. + * Subsequent sources overwrite property assignments of previous sources. + * + * **Note:** This method mutates `object` and is loosely based on + * [`Object.assign`](https://mdn.io/Object/assign). + * + * @static + * @memberOf _ + * @since 0.10.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.assignIn + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * function Bar() { + * this.c = 3; + * } + * + * Foo.prototype.b = 2; + * Bar.prototype.d = 4; + * + * _.assign({ 'a': 0 }, new Foo, new Bar); + * // => { 'a': 1, 'c': 3 } + */ + var assign = createAssigner(function(object, source) { + if (isPrototype(source) || isArrayLike(source)) { + copyObject(source, keys(source), object); + return; + } + for (var key in source) { + if (hasOwnProperty.call(source, key)) { + assignValue(object, key, source[key]); + } + } + }); + + /** + * This method is like `_.assign` except that it iterates over own and + * inherited source properties. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias extend + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.assign + * @example + * + * function Foo() { + * this.a = 1; + * } + * + * function Bar() { + * this.c = 3; + * } + * + * Foo.prototype.b = 2; + * Bar.prototype.d = 4; + * + * _.assignIn({ 'a': 0 }, new Foo, new Bar); + * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 } + */ + var assignIn = createAssigner(function(object, source) { + copyObject(source, keysIn(source), object); + }); + + /** + * This method is like `_.assignIn` except that it accepts `customizer` + * which is invoked to produce the assigned values. If `customizer` returns + * `undefined`, assignment is handled by the method instead. The `customizer` + * is invoked with five arguments: (objValue, srcValue, key, object, source). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias extendWith + * @category Object + * @param {Object} object The destination object. + * @param {...Object} sources The source objects. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @see _.assignWith + * @example + * + * function customizer(objValue, srcValue) { + * return _.isUndefined(objValue) ? srcValue : objValue; + * } + * + * var defaults = _.partialRight(_.assignInWith, customizer); + * + * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ + var assignInWith = createAssigner(function(object, source, srcIndex, customizer) { + copyObject(source, keysIn(source), object, customizer); + }); + + /** + * This method is like `_.assign` except that it accepts `customizer` + * which is invoked to produce the assigned values. If `customizer` returns + * `undefined`, assignment is handled by the method instead. The `customizer` + * is invoked with five arguments: (objValue, srcValue, key, object, source). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} sources The source objects. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @see _.assignInWith + * @example + * + * function customizer(objValue, srcValue) { + * return _.isUndefined(objValue) ? srcValue : objValue; + * } + * + * var defaults = _.partialRight(_.assignWith, customizer); + * + * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ + var assignWith = createAssigner(function(object, source, srcIndex, customizer) { + copyObject(source, keys(source), object, customizer); + }); + + /** + * Creates an array of values corresponding to `paths` of `object`. + * + * @static + * @memberOf _ + * @since 1.0.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {...(string|string[])} [paths] The property paths to pick. + * @returns {Array} Returns the picked values. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] }; + * + * _.at(object, ['a[0].b.c', 'a[1]']); + * // => [3, 4] + */ + var at = flatRest(baseAt); + + /** + * Creates an object that inherits from the `prototype` object. If a + * `properties` object is given, its own enumerable string keyed properties + * are assigned to the created object. + * + * @static + * @memberOf _ + * @since 2.3.0 + * @category Object + * @param {Object} prototype The object to inherit from. + * @param {Object} [properties] The properties to assign to the object. + * @returns {Object} Returns the new object. + * @example + * + * function Shape() { + * this.x = 0; + * this.y = 0; + * } + * + * function Circle() { + * Shape.call(this); + * } + * + * Circle.prototype = _.create(Shape.prototype, { + * 'constructor': Circle + * }); + * + * var circle = new Circle; + * circle instanceof Circle; + * // => true + * + * circle instanceof Shape; + * // => true + */ + function create(prototype, properties) { + var result = baseCreate(prototype); + return properties == null ? result : baseAssign(result, properties); + } + + /** + * Assigns own and inherited enumerable string keyed properties of source + * objects to the destination object for all destination properties that + * resolve to `undefined`. Source objects are applied from left to right. + * Once a property is set, additional values of the same property are ignored. + * + * **Note:** This method mutates `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.defaultsDeep + * @example + * + * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 }); + * // => { 'a': 1, 'b': 2 } + */ + var defaults = baseRest(function(object, sources) { + object = Object(object); + + var index = -1; + var length = sources.length; + var guard = length > 2 ? sources[2] : undefined; + + if (guard && isIterateeCall(sources[0], sources[1], guard)) { + length = 1; + } + + while (++index < length) { + var source = sources[index]; + var props = keysIn(source); + var propsIndex = -1; + var propsLength = props.length; + + while (++propsIndex < propsLength) { + var key = props[propsIndex]; + var value = object[key]; + + if (value === undefined || + (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) { + object[key] = source[key]; + } + } + } + + return object; + }); + + /** + * This method is like `_.defaults` except that it recursively assigns + * default properties. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 3.10.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @see _.defaults + * @example + * + * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } }); + * // => { 'a': { 'b': 2, 'c': 3 } } + */ + var defaultsDeep = baseRest(function(args) { + args.push(undefined, customDefaultsMerge); + return apply(mergeWith, undefined, args); + }); + + /** + * This method is like `_.find` except that it returns the key of the first + * element `predicate` returns truthy for instead of the element itself. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category Object + * @param {Object} object The object to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {string|undefined} Returns the key of the matched element, + * else `undefined`. + * @example + * + * var users = { + * 'barney': { 'age': 36, 'active': true }, + * 'fred': { 'age': 40, 'active': false }, + * 'pebbles': { 'age': 1, 'active': true } + * }; + * + * _.findKey(users, function(o) { return o.age < 40; }); + * // => 'barney' (iteration order is not guaranteed) + * + * // The `_.matches` iteratee shorthand. + * _.findKey(users, { 'age': 1, 'active': true }); + * // => 'pebbles' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findKey(users, ['active', false]); + * // => 'fred' + * + * // The `_.property` iteratee shorthand. + * _.findKey(users, 'active'); + * // => 'barney' + */ + function findKey(object, predicate) { + return baseFindKey(object, getIteratee(predicate, 3), baseForOwn); + } + + /** + * This method is like `_.findKey` except that it iterates over elements of + * a collection in the opposite order. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Object + * @param {Object} object The object to inspect. + * @param {Function} [predicate=_.identity] The function invoked per iteration. + * @returns {string|undefined} Returns the key of the matched element, + * else `undefined`. + * @example + * + * var users = { + * 'barney': { 'age': 36, 'active': true }, + * 'fred': { 'age': 40, 'active': false }, + * 'pebbles': { 'age': 1, 'active': true } + * }; + * + * _.findLastKey(users, function(o) { return o.age < 40; }); + * // => returns 'pebbles' assuming `_.findKey` returns 'barney' + * + * // The `_.matches` iteratee shorthand. + * _.findLastKey(users, { 'age': 36, 'active': true }); + * // => 'barney' + * + * // The `_.matchesProperty` iteratee shorthand. + * _.findLastKey(users, ['active', false]); + * // => 'fred' + * + * // The `_.property` iteratee shorthand. + * _.findLastKey(users, 'active'); + * // => 'pebbles' + */ + function findLastKey(object, predicate) { + return baseFindKey(object, getIteratee(predicate, 3), baseForOwnRight); + } + + /** + * Iterates over own and inherited enumerable string keyed properties of an + * object and invokes `iteratee` for each property. The iteratee is invoked + * with three arguments: (value, key, object). Iteratee functions may exit + * iteration early by explicitly returning `false`. + * + * @static + * @memberOf _ + * @since 0.3.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forInRight + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forIn(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed). + */ + function forIn(object, iteratee) { + return object == null + ? object + : baseFor(object, getIteratee(iteratee, 3), keysIn); + } + + /** + * This method is like `_.forIn` except that it iterates over properties of + * `object` in the opposite order. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forIn + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forInRight(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'c', 'b', then 'a' assuming `_.forIn` logs 'a', 'b', then 'c'. + */ + function forInRight(object, iteratee) { + return object == null + ? object + : baseForRight(object, getIteratee(iteratee, 3), keysIn); + } + + /** + * Iterates over own enumerable string keyed properties of an object and + * invokes `iteratee` for each property. The iteratee is invoked with three + * arguments: (value, key, object). Iteratee functions may exit iteration + * early by explicitly returning `false`. + * + * @static + * @memberOf _ + * @since 0.3.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forOwnRight + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forOwn(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'a' then 'b' (iteration order is not guaranteed). + */ + function forOwn(object, iteratee) { + return object && baseForOwn(object, getIteratee(iteratee, 3)); + } + + /** + * This method is like `_.forOwn` except that it iterates over properties of + * `object` in the opposite order. + * + * @static + * @memberOf _ + * @since 2.0.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns `object`. + * @see _.forOwn + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.forOwnRight(new Foo, function(value, key) { + * console.log(key); + * }); + * // => Logs 'b' then 'a' assuming `_.forOwn` logs 'a' then 'b'. + */ + function forOwnRight(object, iteratee) { + return object && baseForOwnRight(object, getIteratee(iteratee, 3)); + } + + /** + * Creates an array of function property names from own enumerable properties + * of `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to inspect. + * @returns {Array} Returns the function names. + * @see _.functionsIn + * @example + * + * function Foo() { + * this.a = _.constant('a'); + * this.b = _.constant('b'); + * } + * + * Foo.prototype.c = _.constant('c'); + * + * _.functions(new Foo); + * // => ['a', 'b'] + */ + function functions(object) { + return object == null ? [] : baseFunctions(object, keys(object)); + } + + /** + * Creates an array of function property names from own and inherited + * enumerable properties of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to inspect. + * @returns {Array} Returns the function names. + * @see _.functions + * @example + * + * function Foo() { + * this.a = _.constant('a'); + * this.b = _.constant('b'); + * } + * + * Foo.prototype.c = _.constant('c'); + * + * _.functionsIn(new Foo); + * // => ['a', 'b', 'c'] + */ + function functionsIn(object) { + return object == null ? [] : baseFunctions(object, keysIn(object)); + } + + /** + * Gets the value at `path` of `object`. If the resolved value is + * `undefined`, the `defaultValue` is returned in its place. + * + * @static + * @memberOf _ + * @since 3.7.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to get. + * @param {*} [defaultValue] The value returned for `undefined` resolved values. + * @returns {*} Returns the resolved value. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }] }; + * + * _.get(object, 'a[0].b.c'); + * // => 3 + * + * _.get(object, ['a', '0', 'b', 'c']); + * // => 3 + * + * _.get(object, 'a.b.c', 'default'); + * // => 'default' + */ + function get(object, path, defaultValue) { + var result = object == null ? undefined : baseGet(object, path); + return result === undefined ? defaultValue : result; + } + + /** + * Checks if `path` is a direct property of `object`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + * @example + * + * var object = { 'a': { 'b': 2 } }; + * var other = _.create({ 'a': _.create({ 'b': 2 }) }); + * + * _.has(object, 'a'); + * // => true + * + * _.has(object, 'a.b'); + * // => true + * + * _.has(object, ['a', 'b']); + * // => true + * + * _.has(other, 'a'); + * // => false + */ + function has(object, path) { + return object != null && hasPath(object, path, baseHas); + } + + /** + * Checks if `path` is a direct or inherited property of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path to check. + * @returns {boolean} Returns `true` if `path` exists, else `false`. + * @example + * + * var object = _.create({ 'a': _.create({ 'b': 2 }) }); + * + * _.hasIn(object, 'a'); + * // => true + * + * _.hasIn(object, 'a.b'); + * // => true + * + * _.hasIn(object, ['a', 'b']); + * // => true + * + * _.hasIn(object, 'b'); + * // => false + */ + function hasIn(object, path) { + return object != null && hasPath(object, path, baseHasIn); + } + + /** + * Creates an object composed of the inverted keys and values of `object`. + * If `object` contains duplicate values, subsequent values overwrite + * property assignments of previous values. + * + * @static + * @memberOf _ + * @since 0.7.0 + * @category Object + * @param {Object} object The object to invert. + * @returns {Object} Returns the new inverted object. + * @example + * + * var object = { 'a': 1, 'b': 2, 'c': 1 }; + * + * _.invert(object); + * // => { '1': 'c', '2': 'b' } + */ + var invert = createInverter(function(result, value, key) { + if (value != null && + typeof value.toString != 'function') { + value = nativeObjectToString.call(value); + } + + result[value] = key; + }, constant(identity)); + + /** + * This method is like `_.invert` except that the inverted object is generated + * from the results of running each element of `object` thru `iteratee`. The + * corresponding inverted value of each inverted key is an array of keys + * responsible for generating the inverted value. The iteratee is invoked + * with one argument: (value). + * + * @static + * @memberOf _ + * @since 4.1.0 + * @category Object + * @param {Object} object The object to invert. + * @param {Function} [iteratee=_.identity] The iteratee invoked per element. + * @returns {Object} Returns the new inverted object. + * @example + * + * var object = { 'a': 1, 'b': 2, 'c': 1 }; + * + * _.invertBy(object); + * // => { '1': ['a', 'c'], '2': ['b'] } + * + * _.invertBy(object, function(value) { + * return 'group' + value; + * }); + * // => { 'group1': ['a', 'c'], 'group2': ['b'] } + */ + var invertBy = createInverter(function(result, value, key) { + if (value != null && + typeof value.toString != 'function') { + value = nativeObjectToString.call(value); + } + + if (hasOwnProperty.call(result, value)) { + result[value].push(key); + } else { + result[value] = [key]; + } + }, getIteratee); + + /** + * Invokes the method at `path` of `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the method to invoke. + * @param {...*} [args] The arguments to invoke the method with. + * @returns {*} Returns the result of the invoked method. + * @example + * + * var object = { 'a': [{ 'b': { 'c': [1, 2, 3, 4] } }] }; + * + * _.invoke(object, 'a[0].b.c.slice', 1, 3); + * // => [2, 3] + */ + var invoke = baseRest(baseInvoke); + + /** + * Creates an array of the own enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. See the + * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys) + * for more details. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keys(new Foo); + * // => ['a', 'b'] (iteration order is not guaranteed) + * + * _.keys('hi'); + * // => ['0', '1'] + */ + function keys(object) { + return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object); + } + + /** + * Creates an array of the own and inherited enumerable property names of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property names. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.keysIn(new Foo); + * // => ['a', 'b', 'c'] (iteration order is not guaranteed) + */ + function keysIn(object) { + return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object); + } + + /** + * The opposite of `_.mapValues`; this method creates an object with the + * same values as `object` and keys generated by running each own enumerable + * string keyed property of `object` thru `iteratee`. The iteratee is invoked + * with three arguments: (value, key, object). + * + * @static + * @memberOf _ + * @since 3.8.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns the new mapped object. + * @see _.mapValues + * @example + * + * _.mapKeys({ 'a': 1, 'b': 2 }, function(value, key) { + * return key + value; + * }); + * // => { 'a1': 1, 'b2': 2 } + */ + function mapKeys(object, iteratee) { + var result = {}; + iteratee = getIteratee(iteratee, 3); + + baseForOwn(object, function(value, key, object) { + baseAssignValue(result, iteratee(value, key, object), value); + }); + return result; + } + + /** + * Creates an object with the same keys as `object` and values generated + * by running each own enumerable string keyed property of `object` thru + * `iteratee`. The iteratee is invoked with three arguments: + * (value, key, object). + * + * @static + * @memberOf _ + * @since 2.4.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @returns {Object} Returns the new mapped object. + * @see _.mapKeys + * @example + * + * var users = { + * 'fred': { 'user': 'fred', 'age': 40 }, + * 'pebbles': { 'user': 'pebbles', 'age': 1 } + * }; + * + * _.mapValues(users, function(o) { return o.age; }); + * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed) + * + * // The `_.property` iteratee shorthand. + * _.mapValues(users, 'age'); + * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed) + */ + function mapValues(object, iteratee) { + var result = {}; + iteratee = getIteratee(iteratee, 3); + + baseForOwn(object, function(value, key, object) { + baseAssignValue(result, key, iteratee(value, key, object)); + }); + return result; + } + + /** + * This method is like `_.assign` except that it recursively merges own and + * inherited enumerable string keyed properties of source objects into the + * destination object. Source properties that resolve to `undefined` are + * skipped if a destination value exists. Array and plain object properties + * are merged recursively. Other objects and value types are overridden by + * assignment. Source objects are applied from left to right. Subsequent + * sources overwrite property assignments of previous sources. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 0.5.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + * @example + * + * var object = { + * 'a': [{ 'b': 2 }, { 'd': 4 }] + * }; + * + * var other = { + * 'a': [{ 'c': 3 }, { 'e': 5 }] + * }; + * + * _.merge(object, other); + * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] } + */ + var merge = createAssigner(function(object, source, srcIndex) { + baseMerge(object, source, srcIndex); + }); + + /** + * This method is like `_.merge` except that it accepts `customizer` which + * is invoked to produce the merged values of the destination and source + * properties. If `customizer` returns `undefined`, merging is handled by the + * method instead. The `customizer` is invoked with six arguments: + * (objValue, srcValue, key, object, source, stack). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The destination object. + * @param {...Object} sources The source objects. + * @param {Function} customizer The function to customize assigned values. + * @returns {Object} Returns `object`. + * @example + * + * function customizer(objValue, srcValue) { + * if (_.isArray(objValue)) { + * return objValue.concat(srcValue); + * } + * } + * + * var object = { 'a': [1], 'b': [2] }; + * var other = { 'a': [3], 'b': [4] }; + * + * _.mergeWith(object, other, customizer); + * // => { 'a': [1, 3], 'b': [2, 4] } + */ + var mergeWith = createAssigner(function(object, source, srcIndex, customizer) { + baseMerge(object, source, srcIndex, customizer); + }); + + /** + * The opposite of `_.pick`; this method creates an object composed of the + * own and inherited enumerable property paths of `object` that are not omitted. + * + * **Note:** This method is considerably slower than `_.pick`. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The source object. + * @param {...(string|string[])} [paths] The property paths to omit. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.omit(object, ['a', 'c']); + * // => { 'b': '2' } + */ + var omit = flatRest(function(object, paths) { + var result = {}; + if (object == null) { + return result; + } + var isDeep = false; + paths = arrayMap(paths, function(path) { + path = castPath(path, object); + isDeep || (isDeep = path.length > 1); + return path; + }); + copyObject(object, getAllKeysIn(object), result); + if (isDeep) { + result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone); + } + var length = paths.length; + while (length--) { + baseUnset(result, paths[length]); + } + return result; + }); + + /** + * The opposite of `_.pickBy`; this method creates an object composed of + * the own and inherited enumerable string keyed properties of `object` that + * `predicate` doesn't return truthy for. The predicate is invoked with two + * arguments: (value, key). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The source object. + * @param {Function} [predicate=_.identity] The function invoked per property. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.omitBy(object, _.isNumber); + * // => { 'b': '2' } + */ + function omitBy(object, predicate) { + return pickBy(object, negate(getIteratee(predicate))); + } + + /** + * Creates an object composed of the picked `object` properties. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The source object. + * @param {...(string|string[])} [paths] The property paths to pick. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.pick(object, ['a', 'c']); + * // => { 'a': 1, 'c': 3 } + */ + var pick = flatRest(function(object, paths) { + return object == null ? {} : basePick(object, paths); + }); + + /** + * Creates an object composed of the `object` properties `predicate` returns + * truthy for. The predicate is invoked with two arguments: (value, key). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The source object. + * @param {Function} [predicate=_.identity] The function invoked per property. + * @returns {Object} Returns the new object. + * @example + * + * var object = { 'a': 1, 'b': '2', 'c': 3 }; + * + * _.pickBy(object, _.isNumber); + * // => { 'a': 1, 'c': 3 } + */ + function pickBy(object, predicate) { + if (object == null) { + return {}; + } + var props = arrayMap(getAllKeysIn(object), function(prop) { + return [prop]; + }); + predicate = getIteratee(predicate); + return basePickBy(object, props, function(value, path) { + return predicate(value, path[0]); + }); + } + + /** + * This method is like `_.get` except that if the resolved value is a + * function it's invoked with the `this` binding of its parent object and + * its result is returned. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @param {Array|string} path The path of the property to resolve. + * @param {*} [defaultValue] The value returned for `undefined` resolved values. + * @returns {*} Returns the resolved value. + * @example + * + * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] }; + * + * _.result(object, 'a[0].b.c1'); + * // => 3 + * + * _.result(object, 'a[0].b.c2'); + * // => 4 + * + * _.result(object, 'a[0].b.c3', 'default'); + * // => 'default' + * + * _.result(object, 'a[0].b.c3', _.constant('default')); + * // => 'default' + */ + function result(object, path, defaultValue) { + path = castPath(path, object); + + var index = -1, + length = path.length; + + // Ensure the loop is entered when path is empty. + if (!length) { + length = 1; + object = undefined; + } + while (++index < length) { + var value = object == null ? undefined : object[toKey(path[index])]; + if (value === undefined) { + index = length; + value = defaultValue; + } + object = isFunction(value) ? value.call(object) : value; + } + return object; + } + + /** + * Sets the value at `path` of `object`. If a portion of `path` doesn't exist, + * it's created. Arrays are created for missing index properties while objects + * are created for all other missing properties. Use `_.setWith` to customize + * `path` creation. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 3.7.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {*} value The value to set. + * @returns {Object} Returns `object`. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }] }; + * + * _.set(object, 'a[0].b.c', 4); + * console.log(object.a[0].b.c); + * // => 4 + * + * _.set(object, ['x', '0', 'y', 'z'], 5); + * console.log(object.x[0].y.z); + * // => 5 + */ + function set(object, path, value) { + return object == null ? object : baseSet(object, path, value); + } + + /** + * This method is like `_.set` except that it accepts `customizer` which is + * invoked to produce the objects of `path`. If `customizer` returns `undefined` + * path creation is handled by the method instead. The `customizer` is invoked + * with three arguments: (nsValue, key, nsObject). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {*} value The value to set. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @example + * + * var object = {}; + * + * _.setWith(object, '[0][1]', 'a', Object); + * // => { '0': { '1': 'a' } } + */ + function setWith(object, path, value, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + return object == null ? object : baseSet(object, path, value, customizer); + } + + /** + * Creates an array of own enumerable string keyed-value pairs for `object` + * which can be consumed by `_.fromPairs`. If `object` is a map or set, its + * entries are returned. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias entries + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the key-value pairs. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.toPairs(new Foo); + * // => [['a', 1], ['b', 2]] (iteration order is not guaranteed) + */ + var toPairs = createToPairs(keys); + + /** + * Creates an array of own and inherited enumerable string keyed-value pairs + * for `object` which can be consumed by `_.fromPairs`. If `object` is a map + * or set, its entries are returned. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @alias entriesIn + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the key-value pairs. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.toPairsIn(new Foo); + * // => [['a', 1], ['b', 2], ['c', 3]] (iteration order is not guaranteed) + */ + var toPairsIn = createToPairs(keysIn); + + /** + * An alternative to `_.reduce`; this method transforms `object` to a new + * `accumulator` object which is the result of running each of its own + * enumerable string keyed properties thru `iteratee`, with each invocation + * potentially mutating the `accumulator` object. If `accumulator` is not + * provided, a new object with the same `[[Prototype]]` will be used. The + * iteratee is invoked with four arguments: (accumulator, value, key, object). + * Iteratee functions may exit iteration early by explicitly returning `false`. + * + * @static + * @memberOf _ + * @since 1.3.0 + * @category Object + * @param {Object} object The object to iterate over. + * @param {Function} [iteratee=_.identity] The function invoked per iteration. + * @param {*} [accumulator] The custom accumulator value. + * @returns {*} Returns the accumulated value. + * @example + * + * _.transform([2, 3, 4], function(result, n) { + * result.push(n *= n); + * return n % 2 == 0; + * }, []); + * // => [4, 9] + * + * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) { + * (result[value] || (result[value] = [])).push(key); + * }, {}); + * // => { '1': ['a', 'c'], '2': ['b'] } + */ + function transform(object, iteratee, accumulator) { + var isArr = isArray(object), + isArrLike = isArr || isBuffer(object) || isTypedArray(object); + + iteratee = getIteratee(iteratee, 4); + if (accumulator == null) { + var Ctor = object && object.constructor; + if (isArrLike) { + accumulator = isArr ? new Ctor : []; + } + else if (isObject(object)) { + accumulator = isFunction(Ctor) ? baseCreate(getPrototype(object)) : {}; + } + else { + accumulator = {}; + } + } + (isArrLike ? arrayEach : baseForOwn)(object, function(value, index, object) { + return iteratee(accumulator, value, index, object); + }); + return accumulator; + } + + /** + * Removes the property at `path` of `object`. + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to unset. + * @returns {boolean} Returns `true` if the property is deleted, else `false`. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 7 } }] }; + * _.unset(object, 'a[0].b.c'); + * // => true + * + * console.log(object); + * // => { 'a': [{ 'b': {} }] }; + * + * _.unset(object, ['a', '0', 'b', 'c']); + * // => true + * + * console.log(object); + * // => { 'a': [{ 'b': {} }] }; + */ + function unset(object, path) { + return object == null ? true : baseUnset(object, path); + } + + /** + * This method is like `_.set` except that accepts `updater` to produce the + * value to set. Use `_.updateWith` to customize `path` creation. The `updater` + * is invoked with one argument: (value). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.6.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {Function} updater The function to produce the updated value. + * @returns {Object} Returns `object`. + * @example + * + * var object = { 'a': [{ 'b': { 'c': 3 } }] }; + * + * _.update(object, 'a[0].b.c', function(n) { return n * n; }); + * console.log(object.a[0].b.c); + * // => 9 + * + * _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; }); + * console.log(object.x[0].y.z); + * // => 0 + */ + function update(object, path, updater) { + return object == null ? object : baseUpdate(object, path, castFunction(updater)); + } + + /** + * This method is like `_.update` except that it accepts `customizer` which is + * invoked to produce the objects of `path`. If `customizer` returns `undefined` + * path creation is handled by the method instead. The `customizer` is invoked + * with three arguments: (nsValue, key, nsObject). + * + * **Note:** This method mutates `object`. + * + * @static + * @memberOf _ + * @since 4.6.0 + * @category Object + * @param {Object} object The object to modify. + * @param {Array|string} path The path of the property to set. + * @param {Function} updater The function to produce the updated value. + * @param {Function} [customizer] The function to customize assigned values. + * @returns {Object} Returns `object`. + * @example + * + * var object = {}; + * + * _.updateWith(object, '[0][1]', _.constant('a'), Object); + * // => { '0': { '1': 'a' } } + */ + function updateWith(object, path, updater, customizer) { + customizer = typeof customizer == 'function' ? customizer : undefined; + return object == null ? object : baseUpdate(object, path, castFunction(updater), customizer); + } + + /** + * Creates an array of the own enumerable string keyed property values of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property values. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.values(new Foo); + * // => [1, 2] (iteration order is not guaranteed) + * + * _.values('hi'); + * // => ['h', 'i'] + */ + function values(object) { + return object == null ? [] : baseValues(object, keys(object)); + } + + /** + * Creates an array of the own and inherited enumerable string keyed property + * values of `object`. + * + * **Note:** Non-object values are coerced to objects. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category Object + * @param {Object} object The object to query. + * @returns {Array} Returns the array of property values. + * @example + * + * function Foo() { + * this.a = 1; + * this.b = 2; + * } + * + * Foo.prototype.c = 3; + * + * _.valuesIn(new Foo); + * // => [1, 2, 3] (iteration order is not guaranteed) + */ + function valuesIn(object) { + return object == null ? [] : baseValues(object, keysIn(object)); + } + + /*------------------------------------------------------------------------*/ + + /** + * Clamps `number` within the inclusive `lower` and `upper` bounds. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category Number + * @param {number} number The number to clamp. + * @param {number} [lower] The lower bound. + * @param {number} upper The upper bound. + * @returns {number} Returns the clamped number. + * @example + * + * _.clamp(-10, -5, 5); + * // => -5 + * + * _.clamp(10, -5, 5); + * // => 5 + */ + function clamp(number, lower, upper) { + if (upper === undefined) { + upper = lower; + lower = undefined; + } + if (upper !== undefined) { + upper = toNumber(upper); + upper = upper === upper ? upper : 0; + } + if (lower !== undefined) { + lower = toNumber(lower); + lower = lower === lower ? lower : 0; + } + return baseClamp(toNumber(number), lower, upper); + } + + /** + * Checks if `n` is between `start` and up to, but not including, `end`. If + * `end` is not specified, it's set to `start` with `start` then set to `0`. + * If `start` is greater than `end` the params are swapped to support + * negative ranges. + * + * @static + * @memberOf _ + * @since 3.3.0 + * @category Number + * @param {number} number The number to check. + * @param {number} [start=0] The start of the range. + * @param {number} end The end of the range. + * @returns {boolean} Returns `true` if `number` is in the range, else `false`. + * @see _.range, _.rangeRight + * @example + * + * _.inRange(3, 2, 4); + * // => true + * + * _.inRange(4, 8); + * // => true + * + * _.inRange(4, 2); + * // => false + * + * _.inRange(2, 2); + * // => false + * + * _.inRange(1.2, 2); + * // => true + * + * _.inRange(5.2, 4); + * // => false + * + * _.inRange(-3, -2, -6); + * // => true + */ + function inRange(number, start, end) { + start = toFinite(start); + if (end === undefined) { + end = start; + start = 0; + } else { + end = toFinite(end); + } + number = toNumber(number); + return baseInRange(number, start, end); + } + + /** + * Produces a random number between the inclusive `lower` and `upper` bounds. + * If only one argument is provided a number between `0` and the given number + * is returned. If `floating` is `true`, or either `lower` or `upper` are + * floats, a floating-point number is returned instead of an integer. + * + * **Note:** JavaScript follows the IEEE-754 standard for resolving + * floating-point values which can produce unexpected results. + * + * @static + * @memberOf _ + * @since 0.7.0 + * @category Number + * @param {number} [lower=0] The lower bound. + * @param {number} [upper=1] The upper bound. + * @param {boolean} [floating] Specify returning a floating-point number. + * @returns {number} Returns the random number. + * @example + * + * _.random(0, 5); + * // => an integer between 0 and 5 + * + * _.random(5); + * // => also an integer between 0 and 5 + * + * _.random(5, true); + * // => a floating-point number between 0 and 5 + * + * _.random(1.2, 5.2); + * // => a floating-point number between 1.2 and 5.2 + */ + function random(lower, upper, floating) { + if (floating && typeof floating != 'boolean' && isIterateeCall(lower, upper, floating)) { + upper = floating = undefined; + } + if (floating === undefined) { + if (typeof upper == 'boolean') { + floating = upper; + upper = undefined; + } + else if (typeof lower == 'boolean') { + floating = lower; + lower = undefined; + } + } + if (lower === undefined && upper === undefined) { + lower = 0; + upper = 1; + } + else { + lower = toFinite(lower); + if (upper === undefined) { + upper = lower; + lower = 0; + } else { + upper = toFinite(upper); + } + } + if (lower > upper) { + var temp = lower; + lower = upper; + upper = temp; + } + if (floating || lower % 1 || upper % 1) { + var rand = nativeRandom(); + return nativeMin(lower + (rand * (upper - lower + freeParseFloat('1e-' + ((rand + '').length - 1)))), upper); + } + return baseRandom(lower, upper); + } + + /*------------------------------------------------------------------------*/ + + /** + * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the camel cased string. + * @example + * + * _.camelCase('Foo Bar'); + * // => 'fooBar' + * + * _.camelCase('--foo-bar--'); + * // => 'fooBar' + * + * _.camelCase('__FOO_BAR__'); + * // => 'fooBar' + */ + var camelCase = createCompounder(function(result, word, index) { + word = word.toLowerCase(); + return result + (index ? capitalize(word) : word); + }); + + /** + * Converts the first character of `string` to upper case and the remaining + * to lower case. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to capitalize. + * @returns {string} Returns the capitalized string. + * @example + * + * _.capitalize('FRED'); + * // => 'Fred' + */ + function capitalize(string) { + return upperFirst(toString(string).toLowerCase()); + } + + /** + * Deburrs `string` by converting + * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table) + * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A) + * letters to basic Latin letters and removing + * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to deburr. + * @returns {string} Returns the deburred string. + * @example + * + * _.deburr('déjà vu'); + * // => 'deja vu' + */ + function deburr(string) { + string = toString(string); + return string && string.replace(reLatin, deburrLetter).replace(reComboMark, ''); + } + + /** + * Checks if `string` ends with the given target string. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to inspect. + * @param {string} [target] The string to search for. + * @param {number} [position=string.length] The position to search up to. + * @returns {boolean} Returns `true` if `string` ends with `target`, + * else `false`. + * @example + * + * _.endsWith('abc', 'c'); + * // => true + * + * _.endsWith('abc', 'b'); + * // => false + * + * _.endsWith('abc', 'b', 2); + * // => true + */ + function endsWith(string, target, position) { + string = toString(string); + target = baseToString(target); + + var length = string.length; + position = position === undefined + ? length + : baseClamp(toInteger(position), 0, length); + + var end = position; + position -= target.length; + return position >= 0 && string.slice(position, end) == target; + } + + /** + * Converts the characters "&", "<", ">", '"', and "'" in `string` to their + * corresponding HTML entities. + * + * **Note:** No other characters are escaped. To escape additional + * characters use a third-party library like [_he_](https://mths.be/he). + * + * Though the ">" character is escaped for symmetry, characters like + * ">" and "/" don't need escaping in HTML and have no special meaning + * unless they're part of a tag or unquoted attribute value. See + * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands) + * (under "semi-related fun fact") for more details. + * + * When working with HTML you should always + * [quote attribute values](http://wonko.com/post/html-escaping) to reduce + * XSS vectors. + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category String + * @param {string} [string=''] The string to escape. + * @returns {string} Returns the escaped string. + * @example + * + * _.escape('fred, barney, & pebbles'); + * // => 'fred, barney, & pebbles' + */ + function escape(string) { + string = toString(string); + return (string && reHasUnescapedHtml.test(string)) + ? string.replace(reUnescapedHtml, escapeHtmlChar) + : string; + } + + /** + * Escapes the `RegExp` special characters "^", "$", "\", ".", "*", "+", + * "?", "(", ")", "[", "]", "{", "}", and "|" in `string`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to escape. + * @returns {string} Returns the escaped string. + * @example + * + * _.escapeRegExp('[lodash](https://lodash.com/)'); + * // => '\[lodash\]\(https://lodash\.com/\)' + */ + function escapeRegExp(string) { + string = toString(string); + return (string && reHasRegExpChar.test(string)) + ? string.replace(reRegExpChar, '\\$&') + : string; + } + + /** + * Converts `string` to + * [kebab case](https://en.wikipedia.org/wiki/Letter_case#Special_case_styles). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the kebab cased string. + * @example + * + * _.kebabCase('Foo Bar'); + * // => 'foo-bar' + * + * _.kebabCase('fooBar'); + * // => 'foo-bar' + * + * _.kebabCase('__FOO_BAR__'); + * // => 'foo-bar' + */ + var kebabCase = createCompounder(function(result, word, index) { + return result + (index ? '-' : '') + word.toLowerCase(); + }); + + /** + * Converts `string`, as space separated words, to lower case. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the lower cased string. + * @example + * + * _.lowerCase('--Foo-Bar--'); + * // => 'foo bar' + * + * _.lowerCase('fooBar'); + * // => 'foo bar' + * + * _.lowerCase('__FOO_BAR__'); + * // => 'foo bar' + */ + var lowerCase = createCompounder(function(result, word, index) { + return result + (index ? ' ' : '') + word.toLowerCase(); + }); + + /** + * Converts the first character of `string` to lower case. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the converted string. + * @example + * + * _.lowerFirst('Fred'); + * // => 'fred' + * + * _.lowerFirst('FRED'); + * // => 'fRED' + */ + var lowerFirst = createCaseFirst('toLowerCase'); + + /** + * Pads `string` on the left and right sides if it's shorter than `length`. + * Padding characters are truncated if they can't be evenly divided by `length`. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to pad. + * @param {number} [length=0] The padding length. + * @param {string} [chars=' '] The string used as padding. + * @returns {string} Returns the padded string. + * @example + * + * _.pad('abc', 8); + * // => ' abc ' + * + * _.pad('abc', 8, '_-'); + * // => '_-abc_-_' + * + * _.pad('abc', 3); + * // => 'abc' + */ + function pad(string, length, chars) { + string = toString(string); + length = toInteger(length); + + var strLength = length ? stringSize(string) : 0; + if (!length || strLength >= length) { + return string; + } + var mid = (length - strLength) / 2; + return ( + createPadding(nativeFloor(mid), chars) + + string + + createPadding(nativeCeil(mid), chars) + ); + } + + /** + * Pads `string` on the right side if it's shorter than `length`. Padding + * characters are truncated if they exceed `length`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to pad. + * @param {number} [length=0] The padding length. + * @param {string} [chars=' '] The string used as padding. + * @returns {string} Returns the padded string. + * @example + * + * _.padEnd('abc', 6); + * // => 'abc ' + * + * _.padEnd('abc', 6, '_-'); + * // => 'abc_-_' + * + * _.padEnd('abc', 3); + * // => 'abc' + */ + function padEnd(string, length, chars) { + string = toString(string); + length = toInteger(length); + + var strLength = length ? stringSize(string) : 0; + return (length && strLength < length) + ? (string + createPadding(length - strLength, chars)) + : string; + } + + /** + * Pads `string` on the left side if it's shorter than `length`. Padding + * characters are truncated if they exceed `length`. + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to pad. + * @param {number} [length=0] The padding length. + * @param {string} [chars=' '] The string used as padding. + * @returns {string} Returns the padded string. + * @example + * + * _.padStart('abc', 6); + * // => ' abc' + * + * _.padStart('abc', 6, '_-'); + * // => '_-_abc' + * + * _.padStart('abc', 3); + * // => 'abc' + */ + function padStart(string, length, chars) { + string = toString(string); + length = toInteger(length); + + var strLength = length ? stringSize(string) : 0; + return (length && strLength < length) + ? (createPadding(length - strLength, chars) + string) + : string; + } + + /** + * Converts `string` to an integer of the specified radix. If `radix` is + * `undefined` or `0`, a `radix` of `10` is used unless `value` is a + * hexadecimal, in which case a `radix` of `16` is used. + * + * **Note:** This method aligns with the + * [ES5 implementation](https://es5.github.io/#x15.1.2.2) of `parseInt`. + * + * @static + * @memberOf _ + * @since 1.1.0 + * @category String + * @param {string} string The string to convert. + * @param {number} [radix=10] The radix to interpret `value` by. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {number} Returns the converted integer. + * @example + * + * _.parseInt('08'); + * // => 8 + * + * _.map(['6', '08', '10'], _.parseInt); + * // => [6, 8, 10] + */ + function parseInt(string, radix, guard) { + if (guard || radix == null) { + radix = 0; + } else if (radix) { + radix = +radix; + } + return nativeParseInt(toString(string).replace(reTrimStart, ''), radix || 0); + } + + /** + * Repeats the given string `n` times. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to repeat. + * @param {number} [n=1] The number of times to repeat the string. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {string} Returns the repeated string. + * @example + * + * _.repeat('*', 3); + * // => '***' + * + * _.repeat('abc', 2); + * // => 'abcabc' + * + * _.repeat('abc', 0); + * // => '' + */ + function repeat(string, n, guard) { + if ((guard ? isIterateeCall(string, n, guard) : n === undefined)) { + n = 1; + } else { + n = toInteger(n); + } + return baseRepeat(toString(string), n); + } + + /** + * Replaces matches for `pattern` in `string` with `replacement`. + * + * **Note:** This method is based on + * [`String#replace`](https://mdn.io/String/replace). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to modify. + * @param {RegExp|string} pattern The pattern to replace. + * @param {Function|string} replacement The match replacement. + * @returns {string} Returns the modified string. + * @example + * + * _.replace('Hi Fred', 'Fred', 'Barney'); + * // => 'Hi Barney' + */ + function replace() { + var args = arguments, + string = toString(args[0]); + + return args.length < 3 ? string : string.replace(args[1], args[2]); + } + + /** + * Converts `string` to + * [snake case](https://en.wikipedia.org/wiki/Snake_case). + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the snake cased string. + * @example + * + * _.snakeCase('Foo Bar'); + * // => 'foo_bar' + * + * _.snakeCase('fooBar'); + * // => 'foo_bar' + * + * _.snakeCase('--FOO-BAR--'); + * // => 'foo_bar' + */ + var snakeCase = createCompounder(function(result, word, index) { + return result + (index ? '_' : '') + word.toLowerCase(); + }); + + /** + * Splits `string` by `separator`. + * + * **Note:** This method is based on + * [`String#split`](https://mdn.io/String/split). + * + * @static + * @memberOf _ + * @since 4.0.0 + * @category String + * @param {string} [string=''] The string to split. + * @param {RegExp|string} separator The separator pattern to split by. + * @param {number} [limit] The length to truncate results to. + * @returns {Array} Returns the string segments. + * @example + * + * _.split('a-b-c', '-', 2); + * // => ['a', 'b'] + */ + function split(string, separator, limit) { + if (limit && typeof limit != 'number' && isIterateeCall(string, separator, limit)) { + separator = limit = undefined; + } + limit = limit === undefined ? MAX_ARRAY_LENGTH : limit >>> 0; + if (!limit) { + return []; + } + string = toString(string); + if (string && ( + typeof separator == 'string' || + (separator != null && !isRegExp(separator)) + )) { + separator = baseToString(separator); + if (!separator && hasUnicode(string)) { + return castSlice(stringToArray(string), 0, limit); + } + } + return string.split(separator, limit); + } + + /** + * Converts `string` to + * [start case](https://en.wikipedia.org/wiki/Letter_case#Stylistic_or_specialised_usage). + * + * @static + * @memberOf _ + * @since 3.1.0 + * @category String + * @param {string} [string=''] The string to convert. + * @returns {string} Returns the start cased string. + * @example + * + * _.startCase('--foo-bar--'); + * // => 'Foo Bar' + * + * _.startCase('fooBar'); + * // => 'Foo Bar' + * + * _.startCase('__FOO_BAR__'); + * // => 'FOO BAR' + */ + var startCase = createCompounder(function(result, word, index) { + return result + (index ? ' ' : '') + upperFirst(word); + }); + + /** + * Checks if `string` starts with the given target string. + * + * @static + * @memberOf _ + * @since 3.0.0 + * @category String + * @param {string} [string=''] The string to inspect. + * @param {string} [target] The string to search for. + * @param {number} [position=0] The position to search from. + * @returns {boolean} Returns `true` if `string` starts with `target`, + * else `false`. + * @example + * + * _.startsWith('abc', 'a'); + * // => true + * + * _.startsWith('abc', 'b'); + * // => false + * + * _.startsWith('abc', 'b', 1); + * // => true + */ + function startsWith(string, target, position) { + string = toString(string); + position = position == null + ? 0 + : baseClamp(toInteger(position), 0, string.length); + + target = baseToString(target); + return string.slice(position, position + target.length) == target; + } + + /** + * Creates a compiled template function that can interpolate data properties + * in "interpolate" delimiters, HTML-escape interpolated data properties in + * "escape" delimiters, and execute JavaScript in "evaluate" delimiters. Data + * properties may be accessed as free variables in the template. If a setting + * object is given, it takes precedence over `_.templateSettings` values. + * + * **Note:** In the development build `_.template` utilizes + * [sourceURLs](http://www.html5rocks.com/en/tutorials/developertools/sourcemaps/#toc-sourceurl) + * for easier debugging. + * + * For more information on precompiling templates see + * [lodash's custom builds documentation](https://lodash.com/custom-builds). + * + * For more information on Chrome extension sandboxes see + * [Chrome's extensions documentation](https://developer.chrome.com/extensions/sandboxingEval). + * + * @static + * @since 0.1.0 + * @memberOf _ + * @category String + * @param {string} [string=''] The template string. + * @param {Object} [options={}] The options object. + * @param {RegExp} [options.escape=_.templateSettings.escape] + * The HTML "escape" delimiter. + * @param {RegExp} [options.evaluate=_.templateSettings.evaluate] + * The "evaluate" delimiter. + * @param {Object} [options.imports=_.templateSettings.imports] + * An object to import into the template as free variables. + * @param {RegExp} [options.interpolate=_.templateSettings.interpolate] + * The "interpolate" delimiter. + * @param {string} [options.sourceURL='lodash.templateSources[n]'] + * The sourceURL of the compiled template. + * @param {string} [options.variable='obj'] + * The data object variable name. + * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`. + * @returns {Function} Returns the compiled template function. + * @example + * + * // Use the "interpolate" delimiter to create a compiled template. + * var compiled = _.template('hello <%= user %>!'); + * compiled({ 'user': 'fred' }); + * // => 'hello fred!' + * + * // Use the HTML "escape" delimiter to escape data property values. + * var compiled = _.template('<%- value %>'); + * compiled({ 'value': '