From f98377cec2f016e25b1612159784ce01bfc20071 Mon Sep 17 00:00:00 2001 From: blag Date: Tue, 14 Nov 2023 14:22:30 -0700 Subject: [PATCH 1/5] Remove Django 1.6 compat in tests/settings.py --- tests/settings.py | 5 ----- 1 file changed, 5 deletions(-) diff --git a/tests/settings.py b/tests/settings.py index 5e7b200..8cba6c1 100644 --- a/tests/settings.py +++ b/tests/settings.py @@ -1,8 +1,6 @@ # -*- coding: utf-8 -*- import os.path -import django - DEBUG = False RUNTESTS_DIR = os.path.abspath(os.path.dirname(__file__)) @@ -44,6 +42,3 @@ ] ROOT_URLCONF = "tests.urls" - -if django.VERSION[:2] < (1, 6): - TEST_RUNNER = "discover_runner.DiscoverRunner" From 303b66f3ebcb424f720fd19a0d753b45027bb55a Mon Sep 17 00:00:00 2001 From: blag Date: Tue, 14 Nov 2023 14:22:52 -0700 Subject: [PATCH 2/5] Use pathlib in tests/settings.py --- tests/settings.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/tests/settings.py b/tests/settings.py index 8cba6c1..2a408f4 100644 --- a/tests/settings.py +++ b/tests/settings.py @@ -1,9 +1,9 @@ # -*- coding: utf-8 -*- -import os.path +from pathlib import Path DEBUG = False -RUNTESTS_DIR = os.path.abspath(os.path.dirname(__file__)) +RUNTESTS_DIR = Path(__file__).parent.resolve() DATABASES = {"default": {"ENGINE": "django.db.backends.sqlite3"}} From 9d9606179f2c23cd6692f4769bd992438d50321c Mon Sep 17 00:00:00 2001 From: blag Date: Tue, 14 Nov 2023 14:23:28 -0700 Subject: [PATCH 3/5] Silence Django warning about AutoField --- tests/settings.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/tests/settings.py b/tests/settings.py index 2a408f4..cc5cc38 100644 --- a/tests/settings.py +++ b/tests/settings.py @@ -42,3 +42,5 @@ ] ROOT_URLCONF = "tests.urls" + +DEFAULT_AUTO_FIELD = "django.db.models.AutoField" From 5afc44e4b13d5688fdcb4d16f240f49b21c454f9 Mon Sep 17 00:00:00 2001 From: blag Date: Tue, 14 Nov 2023 14:23:52 -0700 Subject: [PATCH 4/5] Improve coverage for validators --- tests/test_validators.py | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/tests/test_validators.py b/tests/test_validators.py index 5efd6bc..033a5f7 100644 --- a/tests/test_validators.py +++ b/tests/test_validators.py @@ -9,6 +9,16 @@ class TestValidators(unittest.TestCase): def test_validate_latitude(self): + # This is quick + for i in range(-89, 91): + validate_latitude(i) + + validate_latitude(-89.9) + validate_latitude(-0.1) + validate_latitude(-0.0) + validate_latitude(0.1) + validate_latitude(90.0) + self.assertRaisesRegex( ValidationError, "invalid latitude", validate_latitude, 91 ) @@ -17,6 +27,16 @@ def test_validate_latitude(self): ) def test_validate_longitude(self): + # This is quick + for i in range(-179, 181): + validate_longitude(i) + + validate_longitude(-179.9) + validate_longitude(-0.1) + validate_longitude(-0.0) + validate_longitude(0.1) + validate_longitude(179.9) + self.assertRaisesRegex( ValidationError, "invalid longitude", validate_longitude, 181 ) From 5041bc8163552c676d3ac6ab811212297788949d Mon Sep 17 00:00:00 2001 From: Markus Holtermann Date: Sat, 15 Nov 2025 23:28:29 +0100 Subject: [PATCH 5/5] Update project packaging and dependencies --- .coveragerc | 6 - .editorconfig | 20 +- .github/CODE_OF_CONDUCT.md | 1 + .github/ISSUE_TEMPLATE/config.yml | 1 + .github/ISSUE_TEMPLATE/feature-request.yml | 10 + .github/ISSUE_TEMPLATE/issue.yml | 34 + .github/SECURITY.md | 1 + .github/dependabot.yml | 10 + .github/workflows/main.yml | 111 ++ .github/workflows/test-deploy.yml | 105 -- .pre-commit-config.yaml | 63 +- .readthedocs.yaml | 16 + .typos.toml | 16 + .yamlfmt | 4 + CHANGELOG.md | 7 + LICENSE | 4 +- MANIFEST.in | 6 +- README.md | 14 - README.rst | 32 + docs/make.bat | 2 +- docs/requirements.txt | 1 - docs/source/authors.rst | 5 - docs/source/conf.py | 7 +- docs/source/index.rst | 1 - docs/source/installation.rst | 13 +- docs/source/usage.rst | 32 +- example/example/admin.py | 6 +- example/example/migrations/0001_initial.py | 4 +- example/example/models.py | 2 + example/example/settings.py | 3 +- example/example/templates/example/base.html | 2 +- example/example/urls.py | 2 + example/example/views.py | 2 + example/example/wsgi.py | 2 + example/manage.py | 2 + osm_field/__init__.py | 6 - osm_field/apps.py | 2 + osm_field/fields.py | 40 +- osm_field/forms.py | 6 +- osm_field/static/css/osm_field.css | 1 - osm_field/static/js/osm_field.min.js | 2 +- .../static/js/vendor/jquery-2.1.0.min.js | 4 - .../static/js/vendor/jquery-3.5.0.min.js | 2 + osm_field/static/js/vendor/leaflet.js | 2 +- osm_field/validators.py | 3 +- osm_field/widgets.py | 7 +- pyproject.toml | 169 ++- setup.cfg | 2 - setup.py | 69 - tests/forms.py | 2 + tests/migrations/0001_initial.py | 266 ---- tests/migrations/__init__.py | 0 tests/models.py | 11 + tests/settings.py | 8 +- tests/test_fields.py | 33 +- tests/test_forms.py | 65 +- tests/test_validators.py | 2 +- tests/urls.py | 6 - tox.ini | 65 +- uv.lock | 1313 +++++++++++++++++ 60 files changed, 1953 insertions(+), 680 deletions(-) delete mode 100644 .coveragerc create mode 100644 .github/CODE_OF_CONDUCT.md create mode 100644 .github/ISSUE_TEMPLATE/config.yml create mode 100644 .github/ISSUE_TEMPLATE/feature-request.yml create mode 100644 .github/ISSUE_TEMPLATE/issue.yml create mode 100644 .github/SECURITY.md create mode 100644 .github/dependabot.yml create mode 100644 .github/workflows/main.yml delete mode 100644 .github/workflows/test-deploy.yml create mode 100644 .readthedocs.yaml create mode 100644 .typos.toml create mode 100644 .yamlfmt delete mode 100644 README.md create mode 100644 README.rst delete mode 100644 docs/requirements.txt delete mode 100644 docs/source/authors.rst delete mode 100644 osm_field/static/js/vendor/jquery-2.1.0.min.js create mode 100644 osm_field/static/js/vendor/jquery-3.5.0.min.js delete mode 100644 setup.cfg delete mode 100644 setup.py delete mode 100644 tests/migrations/0001_initial.py delete mode 100644 tests/migrations/__init__.py delete mode 100644 tests/urls.py create mode 100644 uv.lock diff --git a/.coveragerc b/.coveragerc deleted file mode 100644 index 16c16e5..0000000 --- a/.coveragerc +++ /dev/null @@ -1,6 +0,0 @@ -[run] -branch = True -source = osm_field/ - -[report] -show_missing = True diff --git a/.editorconfig b/.editorconfig index 33b2903..3939592 100644 --- a/.editorconfig +++ b/.editorconfig @@ -1,21 +1,17 @@ -# EditorConfig is awesome: http://EditorConfig.org +# http://editorconfig.org -# top-most EditorConfig file root = true -# Unix-style newlines with a newline ending every file [*] -end_of_line = lf +indent_style = space +indent_size = 2 +trim_trailing_whitespace = true insert_final_newline = true +charset = utf-8 +end_of_line = lf -# Matches multiple files with brace expansion notation -# Set default charset [*.{js,py}] -charset = utf-8 -indent_style = space indent_size = 4 -# Matches the exact files either package.json or .travis.yml -[{.travis.yml}] -indent_style = space -indent_size = 2 +[Makefile] +indent_style = tab diff --git a/.github/CODE_OF_CONDUCT.md b/.github/CODE_OF_CONDUCT.md new file mode 100644 index 0000000..40f4ac7 --- /dev/null +++ b/.github/CODE_OF_CONDUCT.md @@ -0,0 +1 @@ +This project follows [Django's Code of Conduct](https://www.djangoproject.com/conduct/). diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml new file mode 100644 index 0000000..3ba13e0 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/config.yml @@ -0,0 +1 @@ +blank_issues_enabled: false diff --git a/.github/ISSUE_TEMPLATE/feature-request.yml b/.github/ISSUE_TEMPLATE/feature-request.yml new file mode 100644 index 0000000..2a7f84f --- /dev/null +++ b/.github/ISSUE_TEMPLATE/feature-request.yml @@ -0,0 +1,10 @@ +name: Feature Request +description: Request an enhancement or new feature. +body: +- type: textarea + id: description + attributes: + label: Description + description: Please describe your feature request with appropriate detail. + validations: + required: true diff --git a/.github/ISSUE_TEMPLATE/issue.yml b/.github/ISSUE_TEMPLATE/issue.yml new file mode 100644 index 0000000..26d8ce4 --- /dev/null +++ b/.github/ISSUE_TEMPLATE/issue.yml @@ -0,0 +1,34 @@ +name: Issue +description: File an issue +body: +- type: input + id: python_version + attributes: + label: Python Version + description: Which version of Python were you using? + placeholder: 3.9.0 + validations: + required: false +- type: input + id: django_version + attributes: + label: Django Version + description: Which version of Django were you using? + placeholder: 3.2.0 + validations: + required: false +- type: input + id: package_version + attributes: + label: Package Version + description: Which version of this package were you using? If not the latest version, please check this issue has not since been resolved. + placeholder: 1.0.0 + validations: + required: false +- type: textarea + id: description + attributes: + label: Description + description: Please describe your issue. + validations: + required: true diff --git a/.github/SECURITY.md b/.github/SECURITY.md new file mode 100644 index 0000000..d0ef3bc --- /dev/null +++ b/.github/SECURITY.md @@ -0,0 +1 @@ +Please report security issues directly over email to info@markusholtermann.eu. diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 0000000..56b96e2 --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,10 @@ +version: 2 +updates: +- package-ecosystem: github-actions + directory: "/" + groups: + "GitHub Actions": + patterns: + - "*" + schedule: + interval: monthly diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml new file mode 100644 index 0000000..5173e00 --- /dev/null +++ b/.github/workflows/main.yml @@ -0,0 +1,111 @@ +name: CI + +on: + push: + branches: + - main + tags: + - '**' + pull_request: + +concurrency: + group: ${{ github.head_ref || github.run_id }} + cancel-in-progress: true + +jobs: + tests: + name: Python ${{ matrix.python-version }} + runs-on: ubuntu-24.04 + + strategy: + matrix: + python-version: + - '3.9' + - '3.10' + - '3.11' + - '3.12' + - '3.13' + - '3.14' + + steps: + - uses: actions/checkout@v5 + + - uses: actions/setup-python@v6 + with: + python-version: ${{ matrix.python-version }} + allow-prereleases: true + + - name: Install uv + uses: astral-sh/setup-uv@v7 + with: + enable-cache: true + + - name: Run tox targets for ${{ matrix.python-version }} + run: uvx --with tox-uv tox run -f py$(echo ${{ matrix.python-version }} | tr -d .) + + - name: Upload coverage data + uses: actions/upload-artifact@v5 + with: + name: coverage-data-${{ matrix.python-version }} + path: '${{ github.workspace }}/.coverage.*' + include-hidden-files: true + if-no-files-found: error + + coverage: + name: Coverage + runs-on: ubuntu-24.04 + needs: tests + steps: + - uses: actions/checkout@v5 + + - uses: actions/setup-python@v6 + with: + python-version: '3.13' + + - name: Install uv + uses: astral-sh/setup-uv@v7 + + - name: Install dependencies + run: uv pip install --system coverage[toml] + + - name: Download data + uses: actions/download-artifact@v6 + with: + path: ${{ github.workspace }} + pattern: coverage-data-* + merge-multiple: true + + - name: Combine coverage and fail if it's <100% + run: | + python -m coverage combine + python -m coverage html --skip-covered --skip-empty + python -m coverage report --fail-under=100 + echo "## Coverage summary" >> $GITHUB_STEP_SUMMARY + python -m coverage report --format=markdown >> $GITHUB_STEP_SUMMARY + + - name: Upload HTML report + if: ${{ failure() }} + uses: actions/upload-artifact@v5 + with: + name: html-report + path: htmlcov + + release: + needs: [coverage] + if: success() && startsWith(github.ref, 'refs/tags/') + runs-on: ubuntu-24.04 + environment: release + + permissions: + contents: read + id-token: write + + steps: + - uses: actions/checkout@v5 + + - uses: astral-sh/setup-uv@v7 + + - name: Build + run: uv build + + - uses: pypa/gh-action-pypi-publish@release/v1 diff --git a/.github/workflows/test-deploy.yml b/.github/workflows/test-deploy.yml deleted file mode 100644 index 98f87d5..0000000 --- a/.github/workflows/test-deploy.yml +++ /dev/null @@ -1,105 +0,0 @@ -name: Test & Deploy - -on: - push: - branches: - - main - tags: - - "[0-9]+.[0-9]+.[0-9]+" - pull_request: - branches: - - main - -jobs: - test: - runs-on: ubuntu-latest - name: "Test Python ${{ matrix.python-version }} & Django ${{ matrix.django-version }}" - strategy: - matrix: - django-version: ["2.2.0", "3.0.0", "3.1.0", "3.2.0", "4.0.0"] - python-version: ["3.5", "3.6", "3.7", "3.8", "3.9", "3.10"] - exclude: - # 3.0 - - django-version: "3.0.0" - python-version: "3.5" - - django-version: "3.0.0" - python-version: "3.10" - # 3.1 - - django-version: "3.1.0" - python-version: "3.5" - - django-version: "3.1.0" - python-version: "3.10" - # 3.2 - - django-version: "3.2.0" - python-version: "3.5" - # 4.0 - - django-version: "4.0.0" - python-version: "3.5" - - django-version: "4.0.0" - python-version: "3.6" - - django-version: "4.0.0" - python-version: "3.7" - fail-fast: false - steps: - - uses: actions/checkout@v2 - - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@v2 - with: - python-version: ${{ matrix.python-version }} - - uses: actions/cache@v2 - name: Configure pip caching - with: - path: ~/.cache/pip - key: ${{ runner.os }}-pip-${{ hashFiles('setup.py') }} - restore-keys: | - ${{ runner.os }}-pip- - - name: Install dependencies - run: | - python -m pip install -U pip - python -m pip install Django~=${{ matrix.django-version }} - python -m pip install '.[test]' - - name: Run tests - run: | - coverage run "$(command -v django-admin)" test --pythonpath . -v 2 --settings=tests.settings - coverage report - - name: Upload coverage to codecov.io - uses: codecov/codecov-action@v1 - with: - token: ${{ secrets.CODECOV_TOKEN }} - deploy: - if: ${{ github.event_name == 'push' && contains(github.ref, 'refs/tags/') }} - runs-on: ubuntu-latest - needs: [test] - steps: - - uses: actions/checkout@v2 - - name: Set up Python - uses: actions/setup-python@v2 - with: - python-version: "3.9" - - uses: actions/cache@v2 - name: Configure pip caching - with: - path: ~/.cache/pip - key: ${{ runner.os }}-publish-pip-${{ hashFiles('setup.py') }} - restore-keys: | - ${{ runner.os }}-publish-pip- - - name: Install dependencies - run: | - pip install -U pip - python -m pip install setuptools wheel twine - - name: Publish - env: - TWINE_USERNAME: __token__ - TWINE_PASSWORD: ${{ secrets.PYPI_TOKEN }} - run: | - python setup.py sdist bdist_wheel - twine upload dist/* - - name: Create Release - uses: actions/create-release@v1 - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - with: - tag_name: ${{ github.ref }} - release_name: Release ${{ github.ref }} - draft: false - prerelease: false diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index 202b920..9cf9b44 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -1,19 +1,58 @@ -# See https://pre-commit.com for more information -# See https://pre-commit.com/hooks.html for more hooks +ci: + autoupdate_schedule: monthly + +default_language_version: + python: python3.13 + repos: - repo: https://github.com/pre-commit/pre-commit-hooks - rev: v4.0.1 + rev: 3e8a8703264a2f4a69428a0aa4dcb512790b2c8c # frozen: v6.0.0 hooks: + - id: check-added-large-files + exclude: "^uv.lock$" + - id: check-case-conflict + - id: check-json + - id: check-merge-conflict + - id: check-symlinks + - id: check-toml + - id: end-of-file-fixer - id: trailing-whitespace -- repo: https://github.com/psf/black - rev: 21.9b0 +- repo: https://github.com/crate-ci/typos + rev: 1976b238f2710646b971e06bc25737249ee6406d # frozen: v1 hooks: - - id: black -- repo: https://github.com/PyCQA/flake8 - rev: "4.0.1" + - id: typos +- repo: https://github.com/tox-dev/pyproject-fmt + rev: 8a22e281b3f6d1bb298aaabfc165a943a943882c # frozen: v2.7.0 hooks: - - id: flake8 -- repo: https://github.com/PyCQA/isort - rev: "5.9.3" + - id: pyproject-fmt +- repo: https://github.com/tox-dev/tox-ini-fmt + rev: 4e2cb0e98735e1a57a027d9440b91663e31d10b0 # frozen: 1.6.0 hooks: - - id: isort + - id: tox-ini-fmt +- repo: https://github.com/rstcheck/rstcheck + rev: 27258fde1ee7d3b1e6a7bbc58f4c7b1dd0e719e5 # frozen: v6.2.5 + hooks: + - id: rstcheck + additional_dependencies: ['rstcheck[sphinx,toml]'] +- repo: https://github.com/adamchainz/django-upgrade + rev: c03f1b1e703cd967c5fd94e29c61f111e8b0eaf0 # frozen: 1.29.0 + hooks: + - id: django-upgrade +- repo: https://github.com/adamchainz/blacken-docs + rev: dda8db18cfc68df532abf33b185ecd12d5b7b326 # frozen: 1.20.0 + hooks: + - id: blacken-docs + additional_dependencies: + - black==25.1.0 +- repo: https://github.com/astral-sh/ruff-pre-commit + rev: 9c89adb347f6b973f4905a4be0051eb2ecf85dea # frozen: v0.13.3 + hooks: + - id: ruff-check + args: [--fix] + - id: ruff-format +# - repo: https://github.com/pre-commit/mirrors-mypy +# rev: 9f70dc58c23dfcca1b97af99eaeee3140a807c7e # frozen: v1.18.2 +# hooks: +# - id: mypy +# additional_dependencies: +# - django-stubs==5.1.2 diff --git a/.readthedocs.yaml b/.readthedocs.yaml new file mode 100644 index 0000000..baa0f5f --- /dev/null +++ b/.readthedocs.yaml @@ -0,0 +1,16 @@ +version: "2" + +build: + os: "ubuntu-24.04" + tools: + python: "3.13" + +python: + install: + - method: pip + path: . + extra_requirements: + - docs + +sphinx: + configuration: docs/source/conf.py diff --git a/.typos.toml b/.typos.toml new file mode 100644 index 0000000..98a0f67 --- /dev/null +++ b/.typos.toml @@ -0,0 +1,16 @@ +# Configuration file for 'typos' tool +# https://github.com/crate-ci/typos + +[default] +extend-ignore-re = [ + # Single line ignore comments + "(?Rm)^.*(#|//)\\s*typos: ignore$", + # Multi-line ignore comments + "(?s)(#|//)\\s*typos: off.*?\\n\\s*(#|//)\\s*typos: on", +] + +[files] +extend-exclude = [ + "osm_field/static/css/vendor/*.css", + "osm_field/static/js/vendor/*.js", +] diff --git a/.yamlfmt b/.yamlfmt new file mode 100644 index 0000000..029bb6c --- /dev/null +++ b/.yamlfmt @@ -0,0 +1,4 @@ +formatter: + type: basic + indentless_arrays: true + retain_line_breaks: true diff --git a/CHANGELOG.md b/CHANGELOG.md index 1aee726..263e1a2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,13 @@ ## Unreleased +* Major update to formally supported versions: + + - Python: 3.9, 3.10, 3.11, 3.12, 3.13, 3.14 + - Django 4.2, 5.0, 5.1, 5.2, and 6.0 + +* Updated to bundled jQuery file from 2.1.0 to 3.5.0. + ## 0.5.0 (2021-10-10) * Added support for Django 3.1, 3.2, and 4.0 with Python 3.9 and 3.10. diff --git a/LICENSE b/LICENSE index 4d5ccdb..92583a2 100644 --- a/LICENSE +++ b/LICENSE @@ -1,4 +1,6 @@ -Copyright (c) 2014-2020, Markus Holtermann, Thomas Schmidt +MIT License + +Copyright (c) 2014-2025, Markus Holtermann, Thomas Schmidt Copyright (c) 2014, Sinnwerkstatt Medienagentur GmbH Permission is hereby granted, free of charge, to any person obtaining a copy of diff --git a/MANIFEST.in b/MANIFEST.in index c41c07e..2359221 100644 --- a/MANIFEST.in +++ b/MANIFEST.in @@ -1,5 +1,9 @@ +prune tests include AUTHORS.rst -include CHANGES.rst +include CHANGELOG.md include LICENSE +include pyproject.toml +include README.rst +include src/*/py.typed recursive-include osm_field/static/css *.* recursive-include osm_field/static/js *.* diff --git a/README.md b/README.md deleted file mode 100644 index 0e29f43..0000000 --- a/README.md +++ /dev/null @@ -1,14 +0,0 @@ -# django-osm-field - -[![No Maintenance Intended](https://img.shields.io/badge/No%20Maintenance%20Intended-x-red.svg?style=for-the-badge)](http://unmaintained.tech/) -[![GitHub Workflow Status (branch)](https://img.shields.io/github/workflow/status/MarkusH/django-osm-field/Test%20&%20Deploy/main?style=for-the-badge)](https://github.com/MarkusH/django-osm-field/actions?query=branch%3Amain+event%3Apush) -[![Codecov branch](https://img.shields.io/codecov/c/gh/MarkusH/django-osm-field/main?style=for-the-badge)](https://app.codecov.io/gh/MarkusH/django-osm-field/branch/main) -[![Version](https://img.shields.io/pypi/v/django-osm-field?label=Version&style=for-the-badge)](https://pypi.org/project/django-osm-field/) -![License](https://img.shields.io/pypi/l/django-osm-field?style=for-the-badge) -![Python Versions](https://img.shields.io/pypi/pyversions/django-osm-field?label=Python&style=for-the-badge) -![Django Versions](https://img.shields.io/pypi/djversions/django-osm-field?color=%230C4B33&label=Django&style=for-the-badge) -[![Read the Docs](https://img.shields.io/readthedocs/django-osm-field?style=for-the-badge)](https://django-osm-field.readthedocs.io/) - -An OpenStreetMap field for Django. - -Documentation: https://django-osm-field.readthedocs.io/ diff --git a/README.rst b/README.rst new file mode 100644 index 0000000..006b543 --- /dev/null +++ b/README.rst @@ -0,0 +1,32 @@ +================ +django-osm-field +================ + +.. image:: https://img.shields.io/github/actions/workflow/status/MarkusH/django-osm-field/main.yml.svg?branch=main&style=for-the-badge + :target: https://github.com/MarkusH/django-osm-field/actions?workflow=CI + +.. image:: https://img.shields.io/badge/Coverage-100%25-success?style=for-the-badge + :target: https://github.com/MarkusH/django-osm-field/actions?workflow=CI + +.. image:: https://img.shields.io/pypi/v/django-osm-field.svg?style=for-the-badge + :target: https://pypi.org/project/django-osm-field/ + +.. image:: https://img.shields.io/badge/code%20style-black-000000.svg?style=for-the-badge + :target: https://github.com/psf/black + +.. image:: https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white&style=for-the-badge + :target: https://github.com/pre-commit/pre-commit + :alt: pre-commit + +An OpenStreetMap field for Django. + +---- + +Requirements +------------ + +Python 3.9 to 3.14 supported. + +Django 4.2 to 6.0 supported. + +Documentation: https://django-osm-field.readthedocs.io/ diff --git a/docs/make.bat b/docs/make.bat index 2b44764..2df9a8c 100644 --- a/docs/make.bat +++ b/docs/make.bat @@ -239,4 +239,4 @@ if "%1" == "pseudoxml" ( goto end ) -:end \ No newline at end of file +:end diff --git a/docs/requirements.txt b/docs/requirements.txt deleted file mode 100644 index 195b5bc..0000000 --- a/docs/requirements.txt +++ /dev/null @@ -1 +0,0 @@ -.[docs] \ No newline at end of file diff --git a/docs/source/authors.rst b/docs/source/authors.rst deleted file mode 100644 index bf9b271..0000000 --- a/docs/source/authors.rst +++ /dev/null @@ -1,5 +0,0 @@ -.. include:: ../../AUTHORS.rst - -Project has been started by `Sinnwerkstatt Medienagentur GmbH`_ in April 2014. - -.. _Sinnwerkstatt Medienagentur GmbH: https://www.sinnwerkstatt.com/ diff --git a/docs/source/conf.py b/docs/source/conf.py index 204b97f..0f31b68 100644 --- a/docs/source/conf.py +++ b/docs/source/conf.py @@ -1,10 +1,11 @@ #!/usr/bin/env python +from __future__ import annotations + import os import sys +from importlib.metadata import version as get_version from os.path import abspath, dirname, join -from pkg_resources import get_distribution - os.environ["DJANGO_SETTINGS_MODULE"] = "example.settings" sys.path.insert(0, abspath(join(dirname(__file__), "..", "..", "example"))) @@ -14,7 +15,7 @@ project = "django-osm-field" copyright = "2014, Markus Holtermann, et al" -version = release = get_distribution("django-osm-field").version +version = release = get_version("django-osm-field") extensions = ["sphinx.ext.autodoc", "sphinx.ext.intersphinx"] exclude_patterns = ["build"] diff --git a/docs/source/index.rst b/docs/source/index.rst index b1f38bf..34a8b6b 100644 --- a/docs/source/index.rst +++ b/docs/source/index.rst @@ -8,7 +8,6 @@ Contents: installation usage - authors ref/index diff --git a/docs/source/installation.rst b/docs/source/installation.rst index e601fba..d213791 100644 --- a/docs/source/installation.rst +++ b/docs/source/installation.rst @@ -4,16 +4,15 @@ Installation Install **django-osm-field** into your virtual environment or you site-packages using pip: -.. code-block:: console +.. code:: console $ pip install django-osm-field To make **django-osm-field** available in your Django project, you first have to add it to the INSTALLED_APPS in your settings.py. If you are unsure where to put it, just append it: -.. code-block:: python +.. code:: python - INSTALLED_APPS = ( - ... - 'osm_field', - ... - ) + INSTALLED_APPS = [ + # Your other Django apps. + "osm_field", + ] diff --git a/docs/source/usage.rst b/docs/source/usage.rst index 5efa7ac..be9043b 100644 --- a/docs/source/usage.rst +++ b/docs/source/usage.rst @@ -19,7 +19,7 @@ You need to add three model fields to your model: same name appended with ``_lat`` and ``_lon`` respectively. See the following example to get an idea: -.. code-block:: python +.. code:: python from django.db import models @@ -35,10 +35,10 @@ It is possible, though, to overwrite the default naming for latitude and longitude fields by giving their names as arguments to the :class:`~fields.OSMField`: -.. code-block:: python +.. code:: python class MyModel(models.Model): - location = OSMField(lat_field='latitude', lon_field='longitude') + location = OSMField(lat_field="latitude", lon_field="longitude") latitude = LatitudeField() longitude = LongitudeField() @@ -46,7 +46,7 @@ longitude fields by giving their names as arguments to the Form Layer ========== -.. code-block:: python +.. code:: python from django import forms @@ -56,14 +56,18 @@ Form Layer class MyModelForm(forms.ModelForm): class Meta: - fields = ('location', 'location_lat', 'location_lon', ) + fields = ( + "location", + "location_lat", + "location_lon", + ) model = MyModel View Layer ========== -.. code-block:: python +.. code:: python from django.views.generic import CreateView @@ -83,19 +87,19 @@ Template Layer **django-osm-field** shipps with a minimized `jQuery`_ version. To access it in a template use the ``static`` templatetag: -.. code-block:: django +.. code:: django - + You can of course load `jQuery`_ from a CDN as well: -.. code-block:: django +.. code:: django - + To get the front-end to work, you also need to include some CSS and JavaScript files. You can do this by simply using ``{{ form.media }}`` or by adding those lines explicitly: -.. code-block:: django +.. code:: django @@ -105,7 +109,7 @@ To get the front-end to work, you also need to include some CSS and JavaScript f In the end your template should look similar to this: -.. code-block:: django +.. code:: django {% load static %} @@ -113,9 +117,9 @@ In the end your template should look similar to this: - + - + {{ form.media }} diff --git a/example/example/admin.py b/example/example/admin.py index 273f92b..2ff27ed 100644 --- a/example/example/admin.py +++ b/example/example/admin.py @@ -1,10 +1,10 @@ +from __future__ import annotations + from django.contrib import admin from .models import ExampleModel +@admin.register(ExampleModel) class ExampleAdmin(admin.ModelAdmin): pass - - -admin.site.register(ExampleModel, ExampleAdmin) diff --git a/example/example/migrations/0001_initial.py b/example/example/migrations/0001_initial.py index b913d76..b28cdb2 100644 --- a/example/example/migrations/0001_initial.py +++ b/example/example/migrations/0001_initial.py @@ -1,5 +1,4 @@ -# -*- coding: utf-8 -*- -from __future__ import unicode_literals +from __future__ import annotations from django.db import migrations, models @@ -8,7 +7,6 @@ class Migration(migrations.Migration): - dependencies = [] operations = [ diff --git a/example/example/models.py b/example/example/models.py index 86802a4..8a29801 100644 --- a/example/example/models.py +++ b/example/example/models.py @@ -1,3 +1,5 @@ +from __future__ import annotations + from django.db import models from django.urls import reverse diff --git a/example/example/settings.py b/example/example/settings.py index 477e047..0947b39 100644 --- a/example/example/settings.py +++ b/example/example/settings.py @@ -9,6 +9,8 @@ """ # Build paths inside the project like this: os.path.join(BASE_DIR, ...) +from __future__ import annotations + import os BASE_DIR = os.path.dirname(os.path.dirname(__file__)) @@ -66,7 +68,6 @@ USE_I18N = True -USE_L10N = True USE_TZ = True diff --git a/example/example/templates/example/base.html b/example/example/templates/example/base.html index e4233bb..8d19023 100644 --- a/example/example/templates/example/base.html +++ b/example/example/templates/example/base.html @@ -3,7 +3,7 @@ - + {% block content %}{% endblock %} diff --git a/example/example/urls.py b/example/example/urls.py index eaf857e..f1c00a1 100644 --- a/example/example/urls.py +++ b/example/example/urls.py @@ -1,4 +1,6 @@ # from django.contrib.staticfiles.urls import staticfiles_urlpatterns +from __future__ import annotations + from django.urls import path from .views import create_view, delete_view, detail_view, list_view, update_view diff --git a/example/example/views.py b/example/example/views.py index b0d2ae8..df934fa 100644 --- a/example/example/views.py +++ b/example/example/views.py @@ -1,3 +1,5 @@ +from __future__ import annotations + from django.urls import reverse from django.views.generic import ( CreateView, diff --git a/example/example/wsgi.py b/example/example/wsgi.py index a3dcddb..a4f0ad8 100644 --- a/example/example/wsgi.py +++ b/example/example/wsgi.py @@ -7,6 +7,8 @@ https://docs.djangoproject.com/en/dev/howto/deployment/wsgi/ """ +from __future__ import annotations + import os from django.core.wsgi import get_wsgi_application diff --git a/example/manage.py b/example/manage.py index 2605e37..5b5e1b2 100755 --- a/example/manage.py +++ b/example/manage.py @@ -1,4 +1,6 @@ #!/usr/bin/env python +from __future__ import annotations + import os import sys diff --git a/osm_field/__init__.py b/osm_field/__init__.py index aca4f25..e69de29 100644 --- a/osm_field/__init__.py +++ b/osm_field/__init__.py @@ -1,6 +0,0 @@ -# -*- coding: utf-8 -*- - -__author__ = "Markus Holtermann, et al" -__email__ = "info@markusholtermann.eu" - -default_app_config = "osm_field.apps.OSMFieldConfig" diff --git a/osm_field/apps.py b/osm_field/apps.py index 03fbdd7..6645b72 100644 --- a/osm_field/apps.py +++ b/osm_field/apps.py @@ -1,3 +1,5 @@ +from __future__ import annotations + from django.apps import AppConfig diff --git a/osm_field/fields.py b/osm_field/fields.py index c766f32..9adc1d8 100644 --- a/osm_field/fields.py +++ b/osm_field/fields.py @@ -1,5 +1,4 @@ -# -*- coding: utf-8 -*- -from __future__ import unicode_literals +from __future__ import annotations from django.core import checks from django.core.exceptions import FieldDoesNotExist @@ -11,7 +10,7 @@ from .widgets import OSMWidget -class Location(object): +class Location: """ A wrapper class bundling the description of a location (``text``) and its geo coordinates, latitude (``lat``) and longitude (``lon``). @@ -36,15 +35,11 @@ def __str__(self): if self.text is not None: out.append(self.text) if self.lat is not None and self.lon is not None: - out.append("(%.6f, %.6f)" % (self.lat, self.lon)) + out.append(f"({self.lat:.6f}, {self.lon:.6f})") return " ".join(out) def __repr__(self): - return "" % ( - self.lat, - self.lon, - force_str(self.text), - ) + return f"" def __copy__(self): return self.__class__(self.lat, self.lon, self.text) @@ -75,7 +70,7 @@ def __init__(self, *args, **kwargs): kwargs.setdefault("validators", []) if validate_latitude not in kwargs["validators"]: kwargs["validators"].append(validate_latitude) - super(LatitudeField, self).__init__(*args, **kwargs) + super().__init__(*args, **kwargs) def formfield(self, **kwargs): """ @@ -83,7 +78,7 @@ def formfield(self, **kwargs): ``min_value`` -90. """ kwargs.update({"max_value": 90, "min_value": -90}) - return super(LatitudeField, self).formfield(**kwargs) + return super().formfield(**kwargs) class LongitudeField(FloatField): @@ -100,7 +95,7 @@ def __init__(self, *args, **kwargs): kwargs.setdefault("validators", []) if validate_longitude not in kwargs["validators"]: kwargs["validators"].append(validate_longitude) - super(LongitudeField, self).__init__(*args, **kwargs) + super().__init__(*args, **kwargs) def formfield(self, **kwargs): """ @@ -108,7 +103,7 @@ def formfield(self, **kwargs): ``min_value`` -180. """ kwargs.update({"max_value": 180, "min_value": -180}) - return super(LongitudeField, self).formfield(**kwargs) + return super().formfield(**kwargs) class OSMField(TextField): @@ -127,10 +122,10 @@ def __init__(self, *args, **kwargs): self._lat_field_name = kwargs.pop("lat_field", None) self._lon_field_name = kwargs.pop("lon_field", None) self.data_field_name = kwargs.pop("data_field", None) - super(OSMField, self).__init__(*args, **kwargs) + super().__init__(*args, **kwargs) def contribute_to_class(self, cls, name): - info_name = "get_%s_info" % name + info_name = f"get_{name}_info" if not hasattr(cls, info_name): def _func(obj): @@ -142,10 +137,10 @@ def _func(obj): setattr(cls, info_name, _func) - super(OSMField, self).contribute_to_class(cls, name) + super().contribute_to_class(cls, name) def check(self, **kwargs): - errors = super(OSMField, self).check(**kwargs) + errors = super().check(**kwargs) errors.extend(self._check_latitude_field()) errors.extend(self._check_longitude_field()) return errors @@ -157,8 +152,7 @@ def _check_latitude_field(self): except FieldDoesNotExist: return [ checks.Error( - "The OSMField '%s' references the non-existent latitude field '%s'." - % (self.name, self.latitude_field_name), + f"The OSMField '{self.name}' references the non-existent latitude field '{self.latitude_field_name}'.", hint=None, obj=self, id="osm_field.E001", @@ -174,8 +168,8 @@ def _check_longitude_field(self): except FieldDoesNotExist: return [ checks.Error( - "The OSMField '%s' references the non-existent " - "longitude field '%s'." % (self.name, self.longitude_field_name), + f"The OSMField '{self.name}' references the non-existent " + f"longitude field '{self.longitude_field_name}'.", hint=None, obj=self, id="osm_field.E002", @@ -185,7 +179,7 @@ def _check_longitude_field(self): return [] def deconstruct(self): - name, path, args, kwargs = super(OSMField, self).deconstruct() + name, path, args, kwargs = super().deconstruct() kwargs.update( { "lat_field": self.latitude_field_name, @@ -213,7 +207,7 @@ def formfield(self, **kwargs): } defaults.update(kwargs) - return super(OSMField, self).formfield(**defaults) + return super().formfield(**defaults) @property def latitude_field_name(self): diff --git a/osm_field/forms.py b/osm_field/forms.py index 1ce9d98..b05c882 100644 --- a/osm_field/forms.py +++ b/osm_field/forms.py @@ -1,3 +1,5 @@ +from __future__ import annotations + from django.forms import BoundField, CharField @@ -10,10 +12,10 @@ def as_widget(self, widget=None, attrs=None, only_initial=False): attrs = {} if attrs is None else attrs.copy() if self.form.prefix: attrs.update({"prefix": self.form.prefix}) - return super(PrefixedBoundField, self).as_widget(widget, attrs, only_initial) + return super().as_widget(widget, attrs, only_initial) -class PrefixedFormFieldMixin(object): +class PrefixedFormFieldMixin: """ A form field that binds to a custom bound field class, so we can pass the form's prefix into the widget's attrs diff --git a/osm_field/static/css/osm_field.css b/osm_field/static/css/osm_field.css index c5b1496..8518e3a 100644 --- a/osm_field/static/css/osm_field.css +++ b/osm_field/static/css/osm_field.css @@ -12,4 +12,3 @@ div.osmfield-map { top: 30px; z-index: 1000; } - diff --git a/osm_field/static/js/osm_field.min.js b/osm_field/static/js/osm_field.min.js index fcd9a7d..c5b700a 100644 --- a/osm_field/static/js/osm_field.min.js +++ b/osm_field/static/js/osm_field.min.js @@ -1 +1 @@ -!function(a){a.fn.osmfield=function(){return this.each(function(){var b,c,d,e,f=a(this).attr("id"),g=a(this).data("lat-field"),h=a(this).data("lon-field"),i=a(this).data("data-field"),j=a(this);if(g=void 0===g?"#"+f+"_lat":"#id_"+g,h=void 0===h?"#"+f+"_lon":"#id_"+h,i=void 0===i?"#"+f+"_data":"#id_"+i,a(this).addClass("osmfield-input"),a("#"+f+"-map").length||a(this).before('
'),a(this).data("lat-element",a(g)),a(this).data("lng-element",a(h)),a(this).data("data-element",a(i)),a(this).data("map-element",a("#"+f+"-map")),a(this).data("map-element").addClass("osmfield-map"),c=L.map(j.data("map-element")[0]).setView([0,0],15),e="http:"===window.location.protocol?"http://{s}.basemaps.cartocdn.com/light_all/{z}/{x}/{y}@2x.png":"https://cartodb-basemaps-{s}.global.ssl.fastly.net/light_all/{z}/{x}/{y}.png",L.tileLayer(e,{attribution:"CartoDB | Open Streetmap",maxZoom:18}).addTo(c),d=L.marker([0,0],{draggable:!0}).addTo(c),b=j.closest("[lang]").attr("lang"),b?(b=b.split("-"),b=b[0]):b="en",j.data("language",b),function(b){d.on("dragend",function(d){var e=b.data("language"),f=d.target.getLatLng(),g="https://nominatim.openstreetmap.org/reverse?json_callback=?",h=c.getZoom();c.panTo(f),b.data("lat-element").val(f.lat),b.data("lng-element").val(f.lng),a.getJSON(g,{format:"json",lat:f.lat,lon:f.lng,zoom:h,addressdetails:1,"accept-language":e},function(a){b.val(a.display_name),b.data("data-element").val(JSON.stringify(a))})})}(j),j.on("propertychange keyup input paste change",function(){function b(b){var e=b.data("language"),f="https://nominatim.openstreetmap.org/search?json_callback=?";!function(g){a.getJSON(f,{format:"json",q:b.val(),addressdetails:1,"accept-language":e},function(a){if(a.length){var b=a[0].lat,e=a[0].lon,f=new L.LatLng(b,e),h=JSON.stringify(a[0]);g.data("lat-element").val(b),g.data("lng-element").val(e),g.data("data-element").val(h),d.setLatLng(f),c.panTo(f)}else g.data("map-element").slideUp(),g.data("lat-element").val(""),g.data("lng-element").val(""),g.data("data-element").val("");g.is(":focus")&&g.data("lat-element").val()&&g.data("lng-element").val()?g.data("map-element").slideDown(function(){window.dispatchEvent(new Event("resize"))}):g.data("map-element").slideUp()})}(b)}if(a(this).data("oldvalue")!==a(this).val()){a(this).data("oldvalue",a(this).val()),clearTimeout(a.data(this,"timer"));var e=a(this),f=setTimeout(function(){b(e)},500);a(this).data("timer",f)}}),j.data("map-element").hide(),j.data("lat-element").val()&&j.data("lng-element").val()){var k=new L.LatLng(j.data("lat-element").val(),j.data("lng-element").val());d.setLatLng(k),c.panTo(k)}else j.trigger("change");a(document).click(function(b){var c=a(b.target).closest(".osmfield-input, .osmfield-map");c.length?(c.hasClass("osmfield-input")&&(c=c.data("map-element")),a(".osmfield-map").not(c).slideUp()):a(".osmfield-map").slideUp()}),function(a){a.focus(function(){a.data("lat-element").val()&&a.data("lng-element").val()&&a.data("map-element").slideDown(function(){window.dispatchEvent(new Event("resize"))})})}(j)})}}(jQuery); \ No newline at end of file +!function(a){a.fn.osmfield=function(){return this.each(function(){var b,c,d,e,f=a(this).attr("id"),g=a(this).data("lat-field"),h=a(this).data("lon-field"),i=a(this).data("data-field"),j=a(this);if(g=void 0===g?"#"+f+"_lat":"#id_"+g,h=void 0===h?"#"+f+"_lon":"#id_"+h,i=void 0===i?"#"+f+"_data":"#id_"+i,a(this).addClass("osmfield-input"),a("#"+f+"-map").length||a(this).before('
'),a(this).data("lat-element",a(g)),a(this).data("lng-element",a(h)),a(this).data("data-element",a(i)),a(this).data("map-element",a("#"+f+"-map")),a(this).data("map-element").addClass("osmfield-map"),c=L.map(j.data("map-element")[0]).setView([0,0],15),e="http:"===window.location.protocol?"http://{s}.basemaps.cartocdn.com/light_all/{z}/{x}/{y}@2x.png":"https://cartodb-basemaps-{s}.global.ssl.fastly.net/light_all/{z}/{x}/{y}.png",L.tileLayer(e,{attribution:"CartoDB | Open Streetmap",maxZoom:18}).addTo(c),d=L.marker([0,0],{draggable:!0}).addTo(c),b=j.closest("[lang]").attr("lang"),b?(b=b.split("-"),b=b[0]):b="en",j.data("language",b),function(b){d.on("dragend",function(d){var e=b.data("language"),f=d.target.getLatLng(),g="https://nominatim.openstreetmap.org/reverse?json_callback=?",h=c.getZoom();c.panTo(f),b.data("lat-element").val(f.lat),b.data("lng-element").val(f.lng),a.getJSON(g,{format:"json",lat:f.lat,lon:f.lng,zoom:h,addressdetails:1,"accept-language":e},function(a){b.val(a.display_name),b.data("data-element").val(JSON.stringify(a))})})}(j),j.on("propertychange keyup input paste change",function(){function b(b){var e=b.data("language"),f="https://nominatim.openstreetmap.org/search?json_callback=?";!function(g){a.getJSON(f,{format:"json",q:b.val(),addressdetails:1,"accept-language":e},function(a){if(a.length){var b=a[0].lat,e=a[0].lon,f=new L.LatLng(b,e),h=JSON.stringify(a[0]);g.data("lat-element").val(b),g.data("lng-element").val(e),g.data("data-element").val(h),d.setLatLng(f),c.panTo(f)}else g.data("map-element").slideUp(),g.data("lat-element").val(""),g.data("lng-element").val(""),g.data("data-element").val("");g.is(":focus")&&g.data("lat-element").val()&&g.data("lng-element").val()?g.data("map-element").slideDown(function(){window.dispatchEvent(new Event("resize"))}):g.data("map-element").slideUp()})}(b)}if(a(this).data("oldvalue")!==a(this).val()){a(this).data("oldvalue",a(this).val()),clearTimeout(a.data(this,"timer"));var e=a(this),f=setTimeout(function(){b(e)},500);a(this).data("timer",f)}}),j.data("map-element").hide(),j.data("lat-element").val()&&j.data("lng-element").val()){var k=new L.LatLng(j.data("lat-element").val(),j.data("lng-element").val());d.setLatLng(k),c.panTo(k)}else j.trigger("change");a(document).click(function(b){var c=a(b.target).closest(".osmfield-input, .osmfield-map");c.length?(c.hasClass("osmfield-input")&&(c=c.data("map-element")),a(".osmfield-map").not(c).slideUp()):a(".osmfield-map").slideUp()}),function(a){a.focus(function(){a.data("lat-element").val()&&a.data("lng-element").val()&&a.data("map-element").slideDown(function(){window.dispatchEvent(new Event("resize"))})})}(j)})}}(jQuery); diff --git a/osm_field/static/js/vendor/jquery-2.1.0.min.js b/osm_field/static/js/vendor/jquery-2.1.0.min.js deleted file mode 100644 index cbe6abe..0000000 --- a/osm_field/static/js/vendor/jquery-2.1.0.min.js +++ /dev/null @@ -1,4 +0,0 @@ -/*! jQuery v2.1.0 | (c) 2005, 2014 jQuery Foundation, Inc. | jquery.org/license */ -!function(a,b){"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){var c=[],d=c.slice,e=c.concat,f=c.push,g=c.indexOf,h={},i=h.toString,j=h.hasOwnProperty,k="".trim,l={},m=a.document,n="2.1.0",o=function(a,b){return new o.fn.init(a,b)},p=/^-ms-/,q=/-([\da-z])/gi,r=function(a,b){return b.toUpperCase()};o.fn=o.prototype={jquery:n,constructor:o,selector:"",length:0,toArray:function(){return d.call(this)},get:function(a){return null!=a?0>a?this[a+this.length]:this[a]:d.call(this)},pushStack:function(a){var b=o.merge(this.constructor(),a);return b.prevObject=this,b.context=this.context,b},each:function(a,b){return o.each(this,a,b)},map:function(a){return this.pushStack(o.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(0>a?b:0);return this.pushStack(c>=0&&b>c?[this[c]]:[])},end:function(){return this.prevObject||this.constructor(null)},push:f,sort:c.sort,splice:c.splice},o.extend=o.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||o.isFunction(g)||(g={}),h===i&&(g=this,h--);i>h;h++)if(null!=(a=arguments[h]))for(b in a)c=g[b],d=a[b],g!==d&&(j&&d&&(o.isPlainObject(d)||(e=o.isArray(d)))?(e?(e=!1,f=c&&o.isArray(c)?c:[]):f=c&&o.isPlainObject(c)?c:{},g[b]=o.extend(j,f,d)):void 0!==d&&(g[b]=d));return g},o.extend({expando:"jQuery"+(n+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===o.type(a)},isArray:Array.isArray,isWindow:function(a){return null!=a&&a===a.window},isNumeric:function(a){return a-parseFloat(a)>=0},isPlainObject:function(a){if("object"!==o.type(a)||a.nodeType||o.isWindow(a))return!1;try{if(a.constructor&&!j.call(a.constructor.prototype,"isPrototypeOf"))return!1}catch(b){return!1}return!0},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?h[i.call(a)]||"object":typeof a},globalEval:function(a){var b,c=eval;a=o.trim(a),a&&(1===a.indexOf("use strict")?(b=m.createElement("script"),b.text=a,m.head.appendChild(b).parentNode.removeChild(b)):c(a))},camelCase:function(a){return a.replace(p,"ms-").replace(q,r)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b,c){var d,e=0,f=a.length,g=s(a);if(c){if(g){for(;f>e;e++)if(d=b.apply(a[e],c),d===!1)break}else for(e in a)if(d=b.apply(a[e],c),d===!1)break}else if(g){for(;f>e;e++)if(d=b.call(a[e],e,a[e]),d===!1)break}else for(e in a)if(d=b.call(a[e],e,a[e]),d===!1)break;return a},trim:function(a){return null==a?"":k.call(a)},makeArray:function(a,b){var c=b||[];return null!=a&&(s(Object(a))?o.merge(c,"string"==typeof a?[a]:a):f.call(c,a)),c},inArray:function(a,b,c){return null==b?-1:g.call(b,a,c)},merge:function(a,b){for(var c=+b.length,d=0,e=a.length;c>d;d++)a[e++]=b[d];return a.length=e,a},grep:function(a,b,c){for(var d,e=[],f=0,g=a.length,h=!c;g>f;f++)d=!b(a[f],f),d!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,f=0,g=a.length,h=s(a),i=[];if(h)for(;g>f;f++)d=b(a[f],f,c),null!=d&&i.push(d);else for(f in a)d=b(a[f],f,c),null!=d&&i.push(d);return e.apply([],i)},guid:1,proxy:function(a,b){var c,e,f;return"string"==typeof b&&(c=a[b],b=a,a=c),o.isFunction(a)?(e=d.call(arguments,2),f=function(){return a.apply(b||this,e.concat(d.call(arguments)))},f.guid=a.guid=a.guid||o.guid++,f):void 0},now:Date.now,support:l}),o.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(a,b){h["[object "+b+"]"]=b.toLowerCase()});function s(a){var b=a.length,c=o.type(a);return"function"===c||o.isWindow(a)?!1:1===a.nodeType&&b?!0:"array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a}var t=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s="sizzle"+-new Date,t=a.document,u=0,v=0,w=eb(),x=eb(),y=eb(),z=function(a,b){return a===b&&(j=!0),0},A="undefined",B=1<<31,C={}.hasOwnProperty,D=[],E=D.pop,F=D.push,G=D.push,H=D.slice,I=D.indexOf||function(a){for(var b=0,c=this.length;c>b;b++)if(this[b]===a)return b;return-1},J="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",K="[\\x20\\t\\r\\n\\f]",L="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",M=L.replace("w","w#"),N="\\["+K+"*("+L+")"+K+"*(?:([*^$|!~]?=)"+K+"*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|("+M+")|)|)"+K+"*\\]",O=":("+L+")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|"+N.replace(3,8)+")*)|.*)\\)|)",P=new RegExp("^"+K+"+|((?:^|[^\\\\])(?:\\\\.)*)"+K+"+$","g"),Q=new RegExp("^"+K+"*,"+K+"*"),R=new RegExp("^"+K+"*([>+~]|"+K+")"+K+"*"),S=new RegExp("="+K+"*([^\\]'\"]*?)"+K+"*\\]","g"),T=new RegExp(O),U=new RegExp("^"+M+"$"),V={ID:new RegExp("^#("+L+")"),CLASS:new RegExp("^\\.("+L+")"),TAG:new RegExp("^("+L.replace("w","w*")+")"),ATTR:new RegExp("^"+N),PSEUDO:new RegExp("^"+O),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+K+"*(even|odd|(([+-]|)(\\d*)n|)"+K+"*(?:([+-]|)"+K+"*(\\d+)|))"+K+"*\\)|)","i"),bool:new RegExp("^(?:"+J+")$","i"),needsContext:new RegExp("^"+K+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+K+"*((?:-\\d)?\\d*)"+K+"*\\)|)(?=[^-]|$)","i")},W=/^(?:input|select|textarea|button)$/i,X=/^h\d$/i,Y=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,$=/[+~]/,_=/'|\\/g,ab=new RegExp("\\\\([\\da-f]{1,6}"+K+"?|("+K+")|.)","ig"),bb=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:0>d?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)};try{G.apply(D=H.call(t.childNodes),t.childNodes),D[t.childNodes.length].nodeType}catch(cb){G={apply:D.length?function(a,b){F.apply(a,H.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function db(a,b,d,e){var f,g,h,i,j,m,p,q,u,v;if((b?b.ownerDocument||b:t)!==l&&k(b),b=b||l,d=d||[],!a||"string"!=typeof a)return d;if(1!==(i=b.nodeType)&&9!==i)return[];if(n&&!e){if(f=Z.exec(a))if(h=f[1]){if(9===i){if(g=b.getElementById(h),!g||!g.parentNode)return d;if(g.id===h)return d.push(g),d}else if(b.ownerDocument&&(g=b.ownerDocument.getElementById(h))&&r(b,g)&&g.id===h)return d.push(g),d}else{if(f[2])return G.apply(d,b.getElementsByTagName(a)),d;if((h=f[3])&&c.getElementsByClassName&&b.getElementsByClassName)return G.apply(d,b.getElementsByClassName(h)),d}if(c.qsa&&(!o||!o.test(a))){if(q=p=s,u=b,v=9===i&&a,1===i&&"object"!==b.nodeName.toLowerCase()){m=ob(a),(p=b.getAttribute("id"))?q=p.replace(_,"\\$&"):b.setAttribute("id",q),q="[id='"+q+"'] ",j=m.length;while(j--)m[j]=q+pb(m[j]);u=$.test(a)&&mb(b.parentNode)||b,v=m.join(",")}if(v)try{return G.apply(d,u.querySelectorAll(v)),d}catch(w){}finally{p||b.removeAttribute("id")}}}return xb(a.replace(P,"$1"),b,d,e)}function eb(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function fb(a){return a[s]=!0,a}function gb(a){var b=l.createElement("div");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function hb(a,b){var c=a.split("|"),e=a.length;while(e--)d.attrHandle[c[e]]=b}function ib(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(~b.sourceIndex||B)-(~a.sourceIndex||B);if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function jb(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function kb(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function lb(a){return fb(function(b){return b=+b,fb(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function mb(a){return a&&typeof a.getElementsByTagName!==A&&a}c=db.support={},f=db.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?"HTML"!==b.nodeName:!1},k=db.setDocument=function(a){var b,e=a?a.ownerDocument||a:t,g=e.defaultView;return e!==l&&9===e.nodeType&&e.documentElement?(l=e,m=e.documentElement,n=!f(e),g&&g!==g.top&&(g.addEventListener?g.addEventListener("unload",function(){k()},!1):g.attachEvent&&g.attachEvent("onunload",function(){k()})),c.attributes=gb(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=gb(function(a){return a.appendChild(e.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=Y.test(e.getElementsByClassName)&&gb(function(a){return a.innerHTML="
",a.firstChild.className="i",2===a.getElementsByClassName("i").length}),c.getById=gb(function(a){return m.appendChild(a).id=s,!e.getElementsByName||!e.getElementsByName(s).length}),c.getById?(d.find.ID=function(a,b){if(typeof b.getElementById!==A&&n){var c=b.getElementById(a);return c&&c.parentNode?[c]:[]}},d.filter.ID=function(a){var b=a.replace(ab,bb);return function(a){return a.getAttribute("id")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(ab,bb);return function(a){var c=typeof a.getAttributeNode!==A&&a.getAttributeNode("id");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return typeof b.getElementsByTagName!==A?b.getElementsByTagName(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){return typeof b.getElementsByClassName!==A&&n?b.getElementsByClassName(a):void 0},p=[],o=[],(c.qsa=Y.test(e.querySelectorAll))&&(gb(function(a){a.innerHTML="",a.querySelectorAll("[t^='']").length&&o.push("[*^$]="+K+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||o.push("\\["+K+"*(?:value|"+J+")"),a.querySelectorAll(":checked").length||o.push(":checked")}),gb(function(a){var b=e.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&o.push("name"+K+"*[*^$|!~]?="),a.querySelectorAll(":enabled").length||o.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),o.push(",.*:")})),(c.matchesSelector=Y.test(q=m.webkitMatchesSelector||m.mozMatchesSelector||m.oMatchesSelector||m.msMatchesSelector))&&gb(function(a){c.disconnectedMatch=q.call(a,"div"),q.call(a,"[s!='']:x"),p.push("!=",O)}),o=o.length&&new RegExp(o.join("|")),p=p.length&&new RegExp(p.join("|")),b=Y.test(m.compareDocumentPosition),r=b||Y.test(m.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},z=b?function(a,b){if(a===b)return j=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===e||a.ownerDocument===t&&r(t,a)?-1:b===e||b.ownerDocument===t&&r(t,b)?1:i?I.call(i,a)-I.call(i,b):0:4&d?-1:1)}:function(a,b){if(a===b)return j=!0,0;var c,d=0,f=a.parentNode,g=b.parentNode,h=[a],k=[b];if(!f||!g)return a===e?-1:b===e?1:f?-1:g?1:i?I.call(i,a)-I.call(i,b):0;if(f===g)return ib(a,b);c=a;while(c=c.parentNode)h.unshift(c);c=b;while(c=c.parentNode)k.unshift(c);while(h[d]===k[d])d++;return d?ib(h[d],k[d]):h[d]===t?-1:k[d]===t?1:0},e):l},db.matches=function(a,b){return db(a,null,null,b)},db.matchesSelector=function(a,b){if((a.ownerDocument||a)!==l&&k(a),b=b.replace(S,"='$1']"),!(!c.matchesSelector||!n||p&&p.test(b)||o&&o.test(b)))try{var d=q.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return db(b,l,null,[a]).length>0},db.contains=function(a,b){return(a.ownerDocument||a)!==l&&k(a),r(a,b)},db.attr=function(a,b){(a.ownerDocument||a)!==l&&k(a);var e=d.attrHandle[b.toLowerCase()],f=e&&C.call(d.attrHandle,b.toLowerCase())?e(a,b,!n):void 0;return void 0!==f?f:c.attributes||!n?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},db.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},db.uniqueSort=function(a){var b,d=[],e=0,f=0;if(j=!c.detectDuplicates,i=!c.sortStable&&a.slice(0),a.sort(z),j){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return i=null,a},e=db.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=db.selectors={cacheLength:50,createPseudo:fb,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(ab,bb),a[3]=(a[4]||a[5]||"").replace(ab,bb),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||db.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&db.error(a[0]),a},PSEUDO:function(a){var b,c=!a[5]&&a[2];return V.CHILD.test(a[0])?null:(a[3]&&void 0!==a[4]?a[2]=a[4]:c&&T.test(c)&&(b=ob(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(ab,bb).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=w[a+" "];return b||(b=new RegExp("(^|"+K+")"+a+"("+K+"|$)"))&&w(a,function(a){return b.test("string"==typeof a.className&&a.className||typeof a.getAttribute!==A&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=db.attr(d,a);return null==e?"!="===b:b?(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e+" ").indexOf(c)>-1:"|="===b?e===c||e.slice(0,c.length+1)===c+"-":!1):!0}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),t=!i&&!h;if(q){if(f){while(p){l=b;while(l=l[p])if(h?l.nodeName.toLowerCase()===r:1===l.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&t){k=q[s]||(q[s]={}),j=k[a]||[],n=j[0]===u&&j[1],m=j[0]===u&&j[2],l=n&&q.childNodes[n];while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if(1===l.nodeType&&++m&&l===b){k[a]=[u,n,m];break}}else if(t&&(j=(b[s]||(b[s]={}))[a])&&j[0]===u)m=j[1];else while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if((h?l.nodeName.toLowerCase()===r:1===l.nodeType)&&++m&&(t&&((l[s]||(l[s]={}))[a]=[u,m]),l===b))break;return m-=e,m===d||m%d===0&&m/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||db.error("unsupported pseudo: "+a);return e[s]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?fb(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=I.call(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:fb(function(a){var b=[],c=[],d=g(a.replace(P,"$1"));return d[s]?fb(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),!c.pop()}}),has:fb(function(a){return function(b){return db(a,b).length>0}}),contains:fb(function(a){return function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:fb(function(a){return U.test(a||"")||db.error("unsupported lang: "+a),a=a.replace(ab,bb).toLowerCase(),function(b){var c;do if(c=n?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===m},focus:function(a){return a===l.activeElement&&(!l.hasFocus||l.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return X.test(a.nodeName)},input:function(a){return W.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:lb(function(){return[0]}),last:lb(function(a,b){return[b-1]}),eq:lb(function(a,b,c){return[0>c?c+b:c]}),even:lb(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:lb(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:lb(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:lb(function(a,b,c){for(var d=0>c?c+b:c;++db;b++)d+=a[b].value;return d}function qb(a,b,c){var d=b.dir,e=c&&"parentNode"===d,f=v++;return b.first?function(b,c,f){while(b=b[d])if(1===b.nodeType||e)return a(b,c,f)}:function(b,c,g){var h,i,j=[u,f];if(g){while(b=b[d])if((1===b.nodeType||e)&&a(b,c,g))return!0}else while(b=b[d])if(1===b.nodeType||e){if(i=b[s]||(b[s]={}),(h=i[d])&&h[0]===u&&h[1]===f)return j[2]=h[2];if(i[d]=j,j[2]=a(b,c,g))return!0}}}function rb(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function sb(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;i>h;h++)(f=a[h])&&(!c||c(f,d,e))&&(g.push(f),j&&b.push(h));return g}function tb(a,b,c,d,e,f){return d&&!d[s]&&(d=tb(d)),e&&!e[s]&&(e=tb(e,f)),fb(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||wb(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:sb(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=sb(r,n),d(j,[],h,i),k=j.length;while(k--)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l))}if(f){if(e||a){if(e){j=[],k=r.length;while(k--)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}k=r.length;while(k--)(l=r[k])&&(j=e?I.call(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=sb(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):G.apply(g,r)})}function ub(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],i=g||d.relative[" "],j=g?1:0,k=qb(function(a){return a===b},i,!0),l=qb(function(a){return I.call(b,a)>-1},i,!0),m=[function(a,c,d){return!g&&(d||c!==h)||((b=c).nodeType?k(a,c,d):l(a,c,d))}];f>j;j++)if(c=d.relative[a[j].type])m=[qb(rb(m),c)];else{if(c=d.filter[a[j].type].apply(null,a[j].matches),c[s]){for(e=++j;f>e;e++)if(d.relative[a[e].type])break;return tb(j>1&&rb(m),j>1&&pb(a.slice(0,j-1).concat({value:" "===a[j-2].type?"*":""})).replace(P,"$1"),c,e>j&&ub(a.slice(j,e)),f>e&&ub(a=a.slice(e)),f>e&&pb(a))}m.push(c)}return rb(m)}function vb(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,i,j,k){var m,n,o,p=0,q="0",r=f&&[],s=[],t=h,v=f||e&&d.find.TAG("*",k),w=u+=null==t?1:Math.random()||.1,x=v.length;for(k&&(h=g!==l&&g);q!==x&&null!=(m=v[q]);q++){if(e&&m){n=0;while(o=a[n++])if(o(m,g,i)){j.push(m);break}k&&(u=w)}c&&((m=!o&&m)&&p--,f&&r.push(m))}if(p+=q,c&&q!==p){n=0;while(o=b[n++])o(r,s,g,i);if(f){if(p>0)while(q--)r[q]||s[q]||(s[q]=E.call(j));s=sb(s)}G.apply(j,s),k&&!f&&s.length>0&&p+b.length>1&&db.uniqueSort(j)}return k&&(u=w,h=t),r};return c?fb(f):f}g=db.compile=function(a,b){var c,d=[],e=[],f=y[a+" "];if(!f){b||(b=ob(a)),c=b.length;while(c--)f=ub(b[c]),f[s]?d.push(f):e.push(f);f=y(a,vb(e,d))}return f};function wb(a,b,c){for(var d=0,e=b.length;e>d;d++)db(a,b[d],c);return c}function xb(a,b,e,f){var h,i,j,k,l,m=ob(a);if(!f&&1===m.length){if(i=m[0]=m[0].slice(0),i.length>2&&"ID"===(j=i[0]).type&&c.getById&&9===b.nodeType&&n&&d.relative[i[1].type]){if(b=(d.find.ID(j.matches[0].replace(ab,bb),b)||[])[0],!b)return e;a=a.slice(i.shift().value.length)}h=V.needsContext.test(a)?0:i.length;while(h--){if(j=i[h],d.relative[k=j.type])break;if((l=d.find[k])&&(f=l(j.matches[0].replace(ab,bb),$.test(i[0].type)&&mb(b.parentNode)||b))){if(i.splice(h,1),a=f.length&&pb(i),!a)return G.apply(e,f),e;break}}}return g(a,m)(f,b,!n,e,$.test(a)&&mb(b.parentNode)||b),e}return c.sortStable=s.split("").sort(z).join("")===s,c.detectDuplicates=!!j,k(),c.sortDetached=gb(function(a){return 1&a.compareDocumentPosition(l.createElement("div"))}),gb(function(a){return a.innerHTML="","#"===a.firstChild.getAttribute("href")})||hb("type|href|height|width",function(a,b,c){return c?void 0:a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&gb(function(a){return a.innerHTML="",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||hb("value",function(a,b,c){return c||"input"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),gb(function(a){return null==a.getAttribute("disabled")})||hb(J,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),db}(a);o.find=t,o.expr=t.selectors,o.expr[":"]=o.expr.pseudos,o.unique=t.uniqueSort,o.text=t.getText,o.isXMLDoc=t.isXML,o.contains=t.contains;var u=o.expr.match.needsContext,v=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,w=/^.[^:#\[\.,]*$/;function x(a,b,c){if(o.isFunction(b))return o.grep(a,function(a,d){return!!b.call(a,d,a)!==c});if(b.nodeType)return o.grep(a,function(a){return a===b!==c});if("string"==typeof b){if(w.test(b))return o.filter(b,a,c);b=o.filter(b,a)}return o.grep(a,function(a){return g.call(b,a)>=0!==c})}o.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?o.find.matchesSelector(d,a)?[d]:[]:o.find.matches(a,o.grep(b,function(a){return 1===a.nodeType}))},o.fn.extend({find:function(a){var b,c=this.length,d=[],e=this;if("string"!=typeof a)return this.pushStack(o(a).filter(function(){for(b=0;c>b;b++)if(o.contains(e[b],this))return!0}));for(b=0;c>b;b++)o.find(a,e[b],d);return d=this.pushStack(c>1?o.unique(d):d),d.selector=this.selector?this.selector+" "+a:a,d},filter:function(a){return this.pushStack(x(this,a||[],!1))},not:function(a){return this.pushStack(x(this,a||[],!0))},is:function(a){return!!x(this,"string"==typeof a&&u.test(a)?o(a):a||[],!1).length}});var y,z=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,A=o.fn.init=function(a,b){var c,d;if(!a)return this;if("string"==typeof a){if(c="<"===a[0]&&">"===a[a.length-1]&&a.length>=3?[null,a,null]:z.exec(a),!c||!c[1]&&b)return!b||b.jquery?(b||y).find(a):this.constructor(b).find(a);if(c[1]){if(b=b instanceof o?b[0]:b,o.merge(this,o.parseHTML(c[1],b&&b.nodeType?b.ownerDocument||b:m,!0)),v.test(c[1])&&o.isPlainObject(b))for(c in b)o.isFunction(this[c])?this[c](b[c]):this.attr(c,b[c]);return this}return d=m.getElementById(c[2]),d&&d.parentNode&&(this.length=1,this[0]=d),this.context=m,this.selector=a,this}return a.nodeType?(this.context=this[0]=a,this.length=1,this):o.isFunction(a)?"undefined"!=typeof y.ready?y.ready(a):a(o):(void 0!==a.selector&&(this.selector=a.selector,this.context=a.context),o.makeArray(a,this))};A.prototype=o.fn,y=o(m);var B=/^(?:parents|prev(?:Until|All))/,C={children:!0,contents:!0,next:!0,prev:!0};o.extend({dir:function(a,b,c){var d=[],e=void 0!==c;while((a=a[b])&&9!==a.nodeType)if(1===a.nodeType){if(e&&o(a).is(c))break;d.push(a)}return d},sibling:function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c}}),o.fn.extend({has:function(a){var b=o(a,this),c=b.length;return this.filter(function(){for(var a=0;c>a;a++)if(o.contains(this,b[a]))return!0})},closest:function(a,b){for(var c,d=0,e=this.length,f=[],g=u.test(a)||"string"!=typeof a?o(a,b||this.context):0;e>d;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&o.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?o.unique(f):f)},index:function(a){return a?"string"==typeof a?g.call(o(a),this[0]):g.call(this,a.jquery?a[0]:a):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(o.unique(o.merge(this.get(),o(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function D(a,b){while((a=a[b])&&1!==a.nodeType);return a}o.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return o.dir(a,"parentNode")},parentsUntil:function(a,b,c){return o.dir(a,"parentNode",c)},next:function(a){return D(a,"nextSibling")},prev:function(a){return D(a,"previousSibling")},nextAll:function(a){return o.dir(a,"nextSibling")},prevAll:function(a){return o.dir(a,"previousSibling")},nextUntil:function(a,b,c){return o.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return o.dir(a,"previousSibling",c)},siblings:function(a){return o.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return o.sibling(a.firstChild)},contents:function(a){return a.contentDocument||o.merge([],a.childNodes)}},function(a,b){o.fn[a]=function(c,d){var e=o.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=o.filter(d,e)),this.length>1&&(C[a]||o.unique(e),B.test(a)&&e.reverse()),this.pushStack(e)}});var E=/\S+/g,F={};function G(a){var b=F[a]={};return o.each(a.match(E)||[],function(a,c){b[c]=!0}),b}o.Callbacks=function(a){a="string"==typeof a?F[a]||G(a):o.extend({},a);var b,c,d,e,f,g,h=[],i=!a.once&&[],j=function(l){for(b=a.memory&&l,c=!0,g=e||0,e=0,f=h.length,d=!0;h&&f>g;g++)if(h[g].apply(l[0],l[1])===!1&&a.stopOnFalse){b=!1;break}d=!1,h&&(i?i.length&&j(i.shift()):b?h=[]:k.disable())},k={add:function(){if(h){var c=h.length;!function g(b){o.each(b,function(b,c){var d=o.type(c);"function"===d?a.unique&&k.has(c)||h.push(c):c&&c.length&&"string"!==d&&g(c)})}(arguments),d?f=h.length:b&&(e=c,j(b))}return this},remove:function(){return h&&o.each(arguments,function(a,b){var c;while((c=o.inArray(b,h,c))>-1)h.splice(c,1),d&&(f>=c&&f--,g>=c&&g--)}),this},has:function(a){return a?o.inArray(a,h)>-1:!(!h||!h.length)},empty:function(){return h=[],f=0,this},disable:function(){return h=i=b=void 0,this},disabled:function(){return!h},lock:function(){return i=void 0,b||k.disable(),this},locked:function(){return!i},fireWith:function(a,b){return!h||c&&!i||(b=b||[],b=[a,b.slice?b.slice():b],d?i.push(b):j(b)),this},fire:function(){return k.fireWith(this,arguments),this},fired:function(){return!!c}};return k},o.extend({Deferred:function(a){var b=[["resolve","done",o.Callbacks("once memory"),"resolved"],["reject","fail",o.Callbacks("once memory"),"rejected"],["notify","progress",o.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return o.Deferred(function(c){o.each(b,function(b,f){var g=o.isFunction(a[b])&&a[b];e[f[1]](function(){var a=g&&g.apply(this,arguments);a&&o.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f[0]+"With"](this===d?c.promise():this,g?[a]:arguments)})}),a=null}).promise()},promise:function(a){return null!=a?o.extend(a,d):d}},e={};return d.pipe=d.then,o.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[1^a][2].disable,b[2][2].lock),e[f[0]]=function(){return e[f[0]+"With"](this===e?d:this,arguments),this},e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var b=0,c=d.call(arguments),e=c.length,f=1!==e||a&&o.isFunction(a.promise)?e:0,g=1===f?a:o.Deferred(),h=function(a,b,c){return function(e){b[a]=this,c[a]=arguments.length>1?d.call(arguments):e,c===i?g.notifyWith(b,c):--f||g.resolveWith(b,c)}},i,j,k;if(e>1)for(i=new Array(e),j=new Array(e),k=new Array(e);e>b;b++)c[b]&&o.isFunction(c[b].promise)?c[b].promise().done(h(b,k,c)).fail(g.reject).progress(h(b,j,i)):--f;return f||g.resolveWith(k,c),g.promise()}});var H;o.fn.ready=function(a){return o.ready.promise().done(a),this},o.extend({isReady:!1,readyWait:1,holdReady:function(a){a?o.readyWait++:o.ready(!0)},ready:function(a){(a===!0?--o.readyWait:o.isReady)||(o.isReady=!0,a!==!0&&--o.readyWait>0||(H.resolveWith(m,[o]),o.fn.trigger&&o(m).trigger("ready").off("ready")))}});function I(){m.removeEventListener("DOMContentLoaded",I,!1),a.removeEventListener("load",I,!1),o.ready()}o.ready.promise=function(b){return H||(H=o.Deferred(),"complete"===m.readyState?setTimeout(o.ready):(m.addEventListener("DOMContentLoaded",I,!1),a.addEventListener("load",I,!1))),H.promise(b)},o.ready.promise();var J=o.access=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===o.type(c)){e=!0;for(h in c)o.access(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,o.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(o(a),c)})),b))for(;i>h;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f};o.acceptData=function(a){return 1===a.nodeType||9===a.nodeType||!+a.nodeType};function K(){Object.defineProperty(this.cache={},0,{get:function(){return{}}}),this.expando=o.expando+Math.random()}K.uid=1,K.accepts=o.acceptData,K.prototype={key:function(a){if(!K.accepts(a))return 0;var b={},c=a[this.expando];if(!c){c=K.uid++;try{b[this.expando]={value:c},Object.defineProperties(a,b)}catch(d){b[this.expando]=c,o.extend(a,b)}}return this.cache[c]||(this.cache[c]={}),c},set:function(a,b,c){var d,e=this.key(a),f=this.cache[e];if("string"==typeof b)f[b]=c;else if(o.isEmptyObject(f))o.extend(this.cache[e],b);else for(d in b)f[d]=b[d];return f},get:function(a,b){var c=this.cache[this.key(a)];return void 0===b?c:c[b]},access:function(a,b,c){var d;return void 0===b||b&&"string"==typeof b&&void 0===c?(d=this.get(a,b),void 0!==d?d:this.get(a,o.camelCase(b))):(this.set(a,b,c),void 0!==c?c:b)},remove:function(a,b){var c,d,e,f=this.key(a),g=this.cache[f];if(void 0===b)this.cache[f]={};else{o.isArray(b)?d=b.concat(b.map(o.camelCase)):(e=o.camelCase(b),b in g?d=[b,e]:(d=e,d=d in g?[d]:d.match(E)||[])),c=d.length;while(c--)delete g[d[c]]}},hasData:function(a){return!o.isEmptyObject(this.cache[a[this.expando]]||{})},discard:function(a){a[this.expando]&&delete this.cache[a[this.expando]]}};var L=new K,M=new K,N=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,O=/([A-Z])/g;function P(a,b,c){var d;if(void 0===c&&1===a.nodeType)if(d="data-"+b.replace(O,"-$1").toLowerCase(),c=a.getAttribute(d),"string"==typeof c){try{c="true"===c?!0:"false"===c?!1:"null"===c?null:+c+""===c?+c:N.test(c)?o.parseJSON(c):c}catch(e){}M.set(a,b,c)}else c=void 0;return c}o.extend({hasData:function(a){return M.hasData(a)||L.hasData(a)},data:function(a,b,c){return M.access(a,b,c)},removeData:function(a,b){M.remove(a,b)},_data:function(a,b,c){return L.access(a,b,c)},_removeData:function(a,b){L.remove(a,b)}}),o.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=M.get(f),1===f.nodeType&&!L.get(f,"hasDataAttrs"))){c=g.length; -while(c--)d=g[c].name,0===d.indexOf("data-")&&(d=o.camelCase(d.slice(5)),P(f,d,e[d]));L.set(f,"hasDataAttrs",!0)}return e}return"object"==typeof a?this.each(function(){M.set(this,a)}):J(this,function(b){var c,d=o.camelCase(a);if(f&&void 0===b){if(c=M.get(f,a),void 0!==c)return c;if(c=M.get(f,d),void 0!==c)return c;if(c=P(f,d,void 0),void 0!==c)return c}else this.each(function(){var c=M.get(this,d);M.set(this,d,b),-1!==a.indexOf("-")&&void 0!==c&&M.set(this,a,b)})},null,b,arguments.length>1,null,!0)},removeData:function(a){return this.each(function(){M.remove(this,a)})}}),o.extend({queue:function(a,b,c){var d;return a?(b=(b||"fx")+"queue",d=L.get(a,b),c&&(!d||o.isArray(c)?d=L.access(a,b,o.makeArray(c)):d.push(c)),d||[]):void 0},dequeue:function(a,b){b=b||"fx";var c=o.queue(a,b),d=c.length,e=c.shift(),f=o._queueHooks(a,b),g=function(){o.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return L.get(a,c)||L.access(a,c,{empty:o.Callbacks("once memory").add(function(){L.remove(a,[b+"queue",c])})})}}),o.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length",l.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,b.innerHTML="",l.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var U="undefined";l.focusinBubbles="onfocusin"in a;var V=/^key/,W=/^(?:mouse|contextmenu)|click/,X=/^(?:focusinfocus|focusoutblur)$/,Y=/^([^.]*)(?:\.(.+)|)$/;function Z(){return!0}function $(){return!1}function _(){try{return m.activeElement}catch(a){}}o.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,p,q,r=L.get(a);if(r){c.handler&&(f=c,c=f.handler,e=f.selector),c.guid||(c.guid=o.guid++),(i=r.events)||(i=r.events={}),(g=r.handle)||(g=r.handle=function(b){return typeof o!==U&&o.event.triggered!==b.type?o.event.dispatch.apply(a,arguments):void 0}),b=(b||"").match(E)||[""],j=b.length;while(j--)h=Y.exec(b[j])||[],n=q=h[1],p=(h[2]||"").split(".").sort(),n&&(l=o.event.special[n]||{},n=(e?l.delegateType:l.bindType)||n,l=o.event.special[n]||{},k=o.extend({type:n,origType:q,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&o.expr.match.needsContext.test(e),namespace:p.join(".")},f),(m=i[n])||(m=i[n]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,p,g)!==!1||a.addEventListener&&a.addEventListener(n,g,!1)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),o.event.global[n]=!0)}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,p,q,r=L.hasData(a)&&L.get(a);if(r&&(i=r.events)){b=(b||"").match(E)||[""],j=b.length;while(j--)if(h=Y.exec(b[j])||[],n=q=h[1],p=(h[2]||"").split(".").sort(),n){l=o.event.special[n]||{},n=(d?l.delegateType:l.bindType)||n,m=i[n]||[],h=h[2]&&new RegExp("(^|\\.)"+p.join("\\.(?:.*\\.|)")+"(\\.|$)"),g=f=m.length;while(f--)k=m[f],!e&&q!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&("**"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||o.removeEvent(a,n,r.handle),delete i[n])}else for(n in i)o.event.remove(a,n+b[j],c,d,!0);o.isEmptyObject(i)&&(delete r.handle,L.remove(a,"events"))}},trigger:function(b,c,d,e){var f,g,h,i,k,l,n,p=[d||m],q=j.call(b,"type")?b.type:b,r=j.call(b,"namespace")?b.namespace.split("."):[];if(g=h=d=d||m,3!==d.nodeType&&8!==d.nodeType&&!X.test(q+o.event.triggered)&&(q.indexOf(".")>=0&&(r=q.split("."),q=r.shift(),r.sort()),k=q.indexOf(":")<0&&"on"+q,b=b[o.expando]?b:new o.Event(q,"object"==typeof b&&b),b.isTrigger=e?2:3,b.namespace=r.join("."),b.namespace_re=b.namespace?new RegExp("(^|\\.)"+r.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=d),c=null==c?[b]:o.makeArray(c,[b]),n=o.event.special[q]||{},e||!n.trigger||n.trigger.apply(d,c)!==!1)){if(!e&&!n.noBubble&&!o.isWindow(d)){for(i=n.delegateType||q,X.test(i+q)||(g=g.parentNode);g;g=g.parentNode)p.push(g),h=g;h===(d.ownerDocument||m)&&p.push(h.defaultView||h.parentWindow||a)}f=0;while((g=p[f++])&&!b.isPropagationStopped())b.type=f>1?i:n.bindType||q,l=(L.get(g,"events")||{})[b.type]&&L.get(g,"handle"),l&&l.apply(g,c),l=k&&g[k],l&&l.apply&&o.acceptData(g)&&(b.result=l.apply(g,c),b.result===!1&&b.preventDefault());return b.type=q,e||b.isDefaultPrevented()||n._default&&n._default.apply(p.pop(),c)!==!1||!o.acceptData(d)||k&&o.isFunction(d[q])&&!o.isWindow(d)&&(h=d[k],h&&(d[k]=null),o.event.triggered=q,d[q](),o.event.triggered=void 0,h&&(d[k]=h)),b.result}},dispatch:function(a){a=o.event.fix(a);var b,c,e,f,g,h=[],i=d.call(arguments),j=(L.get(this,"events")||{})[a.type]||[],k=o.event.special[a.type]||{};if(i[0]=a,a.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,a)!==!1){h=o.event.handlers.call(this,a,j),b=0;while((f=h[b++])&&!a.isPropagationStopped()){a.currentTarget=f.elem,c=0;while((g=f.handlers[c++])&&!a.isImmediatePropagationStopped())(!a.namespace_re||a.namespace_re.test(g.namespace))&&(a.handleObj=g,a.data=g.data,e=((o.event.special[g.origType]||{}).handle||g.handler).apply(f.elem,i),void 0!==e&&(a.result=e)===!1&&(a.preventDefault(),a.stopPropagation()))}return k.postDispatch&&k.postDispatch.call(this,a),a.result}},handlers:function(a,b){var c,d,e,f,g=[],h=b.delegateCount,i=a.target;if(h&&i.nodeType&&(!a.button||"click"!==a.type))for(;i!==this;i=i.parentNode||this)if(i.disabled!==!0||"click"!==a.type){for(d=[],c=0;h>c;c++)f=b[c],e=f.selector+" ",void 0===d[e]&&(d[e]=f.needsContext?o(e,this).index(i)>=0:o.find(e,this,null,[i]).length),d[e]&&d.push(f);d.length&&g.push({elem:i,handlers:d})}return h]*)\/>/gi,bb=/<([\w:]+)/,cb=/<|&#?\w+;/,db=/<(?:script|style|link)/i,eb=/checked\s*(?:[^=]|=\s*.checked.)/i,fb=/^$|\/(?:java|ecma)script/i,gb=/^true\/(.*)/,hb=/^\s*\s*$/g,ib={option:[1,""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};ib.optgroup=ib.option,ib.tbody=ib.tfoot=ib.colgroup=ib.caption=ib.thead,ib.th=ib.td;function jb(a,b){return o.nodeName(a,"table")&&o.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function kb(a){return a.type=(null!==a.getAttribute("type"))+"/"+a.type,a}function lb(a){var b=gb.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function mb(a,b){for(var c=0,d=a.length;d>c;c++)L.set(a[c],"globalEval",!b||L.get(b[c],"globalEval"))}function nb(a,b){var c,d,e,f,g,h,i,j;if(1===b.nodeType){if(L.hasData(a)&&(f=L.access(a),g=L.set(b,f),j=f.events)){delete g.handle,g.events={};for(e in j)for(c=0,d=j[e].length;d>c;c++)o.event.add(b,e,j[e][c])}M.hasData(a)&&(h=M.access(a),i=o.extend({},h),M.set(b,i))}}function ob(a,b){var c=a.getElementsByTagName?a.getElementsByTagName(b||"*"):a.querySelectorAll?a.querySelectorAll(b||"*"):[];return void 0===b||b&&o.nodeName(a,b)?o.merge([a],c):c}function pb(a,b){var c=b.nodeName.toLowerCase();"input"===c&&T.test(a.type)?b.checked=a.checked:("input"===c||"textarea"===c)&&(b.defaultValue=a.defaultValue)}o.extend({clone:function(a,b,c){var d,e,f,g,h=a.cloneNode(!0),i=o.contains(a.ownerDocument,a);if(!(l.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||o.isXMLDoc(a)))for(g=ob(h),f=ob(a),d=0,e=f.length;e>d;d++)pb(f[d],g[d]);if(b)if(c)for(f=f||ob(a),g=g||ob(h),d=0,e=f.length;e>d;d++)nb(f[d],g[d]);else nb(a,h);return g=ob(h,"script"),g.length>0&&mb(g,!i&&ob(a,"script")),h},buildFragment:function(a,b,c,d){for(var e,f,g,h,i,j,k=b.createDocumentFragment(),l=[],m=0,n=a.length;n>m;m++)if(e=a[m],e||0===e)if("object"===o.type(e))o.merge(l,e.nodeType?[e]:e);else if(cb.test(e)){f=f||k.appendChild(b.createElement("div")),g=(bb.exec(e)||["",""])[1].toLowerCase(),h=ib[g]||ib._default,f.innerHTML=h[1]+e.replace(ab,"<$1>")+h[2],j=h[0];while(j--)f=f.lastChild;o.merge(l,f.childNodes),f=k.firstChild,f.textContent=""}else l.push(b.createTextNode(e));k.textContent="",m=0;while(e=l[m++])if((!d||-1===o.inArray(e,d))&&(i=o.contains(e.ownerDocument,e),f=ob(k.appendChild(e),"script"),i&&mb(f),c)){j=0;while(e=f[j++])fb.test(e.type||"")&&c.push(e)}return k},cleanData:function(a){for(var b,c,d,e,f,g,h=o.event.special,i=0;void 0!==(c=a[i]);i++){if(o.acceptData(c)&&(f=c[L.expando],f&&(b=L.cache[f]))){if(d=Object.keys(b.events||{}),d.length)for(g=0;void 0!==(e=d[g]);g++)h[e]?o.event.remove(c,e):o.removeEvent(c,e,b.handle);L.cache[f]&&delete L.cache[f]}delete M.cache[c[M.expando]]}}}),o.fn.extend({text:function(a){return J(this,function(a){return void 0===a?o.text(this):this.empty().each(function(){(1===this.nodeType||11===this.nodeType||9===this.nodeType)&&(this.textContent=a)})},null,a,arguments.length)},append:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=jb(this,a);b.appendChild(a)}})},prepend:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=jb(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},remove:function(a,b){for(var c,d=a?o.filter(a,this):this,e=0;null!=(c=d[e]);e++)b||1!==c.nodeType||o.cleanData(ob(c)),c.parentNode&&(b&&o.contains(c.ownerDocument,c)&&mb(ob(c,"script")),c.parentNode.removeChild(c));return this},empty:function(){for(var a,b=0;null!=(a=this[b]);b++)1===a.nodeType&&(o.cleanData(ob(a,!1)),a.textContent="");return this},clone:function(a,b){return a=null==a?!1:a,b=null==b?a:b,this.map(function(){return o.clone(this,a,b)})},html:function(a){return J(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a&&1===b.nodeType)return b.innerHTML;if("string"==typeof a&&!db.test(a)&&!ib[(bb.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(ab,"<$1>");try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(o.cleanData(ob(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=arguments[0];return this.domManip(arguments,function(b){a=this.parentNode,o.cleanData(ob(this)),a&&a.replaceChild(b,this)}),a&&(a.length||a.nodeType)?this:this.remove()},detach:function(a){return this.remove(a,!0)},domManip:function(a,b){a=e.apply([],a);var c,d,f,g,h,i,j=0,k=this.length,m=this,n=k-1,p=a[0],q=o.isFunction(p);if(q||k>1&&"string"==typeof p&&!l.checkClone&&eb.test(p))return this.each(function(c){var d=m.eq(c);q&&(a[0]=p.call(this,c,d.html())),d.domManip(a,b)});if(k&&(c=o.buildFragment(a,this[0].ownerDocument,!1,this),d=c.firstChild,1===c.childNodes.length&&(c=d),d)){for(f=o.map(ob(c,"script"),kb),g=f.length;k>j;j++)h=c,j!==n&&(h=o.clone(h,!0,!0),g&&o.merge(f,ob(h,"script"))),b.call(this[j],h,j);if(g)for(i=f[f.length-1].ownerDocument,o.map(f,lb),j=0;g>j;j++)h=f[j],fb.test(h.type||"")&&!L.access(h,"globalEval")&&o.contains(i,h)&&(h.src?o._evalUrl&&o._evalUrl(h.src):o.globalEval(h.textContent.replace(hb,"")))}return this}}),o.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){o.fn[a]=function(a){for(var c,d=[],e=o(a),g=e.length-1,h=0;g>=h;h++)c=h===g?this:this.clone(!0),o(e[h])[b](c),f.apply(d,c.get());return this.pushStack(d)}});var qb,rb={};function sb(b,c){var d=o(c.createElement(b)).appendTo(c.body),e=a.getDefaultComputedStyle?a.getDefaultComputedStyle(d[0]).display:o.css(d[0],"display");return d.detach(),e}function tb(a){var b=m,c=rb[a];return c||(c=sb(a,b),"none"!==c&&c||(qb=(qb||o("