@ -1,51 +0,0 @@ |
|||||
FROM alpine:3.10 |
|
||||
|
|
||||
ENV BUILD_PACKAGES postgresql-dev graphviz-dev graphviz build-base git pkgconfig \ |
|
||||
python3-dev libxml2-dev jpeg-dev libressl-dev libffi-dev libxslt-dev \ |
|
||||
nodejs py3-lxml py3-magic postgresql-client poppler-utils antiword \ |
|
||||
curl jq openssh-client vim bash postgresql-client cairo-dev |
|
||||
|
|
||||
RUN apk update --update-cache && apk upgrade |
|
||||
|
|
||||
RUN apk --update add fontconfig ttf-dejavu && fc-cache -fv |
|
||||
|
|
||||
RUN apk add --no-cache python3 nginx tzdata && \ |
|
||||
python3 -m ensurepip && \ |
|
||||
rm -r /usr/lib/python*/ensurepip && \ |
|
||||
pip3 install --upgrade pip setuptools && \ |
|
||||
pip3 install wheel && \ |
|
||||
rm -r /root/.cache && \ |
|
||||
rm -f /etc/nginx/conf.d/* |
|
||||
|
|
||||
RUN mkdir -p /var/interlegis/sapl && \ |
|
||||
apk add --update --no-cache $BUILD_PACKAGES |
|
||||
|
|
||||
WORKDIR /var/interlegis/sapl/ |
|
||||
|
|
||||
ADD . /var/interlegis/sapl/ |
|
||||
|
|
||||
COPY start.sh /var/interlegis/sapl/ |
|
||||
COPY config/nginx/sapl.conf /etc/nginx/conf.d |
|
||||
COPY config/nginx/nginx.conf /etc/nginx/nginx.conf |
|
||||
|
|
||||
RUN pip install -r /var/interlegis/sapl/requirements/dev-requirements.txt --upgrade setuptools && \ |
|
||||
rm -r /root/.cache |
|
||||
|
|
||||
COPY config/env_dockerfile /var/interlegis/sapl/sapl/.env |
|
||||
|
|
||||
RUN python3 manage.py collectstatic --noinput --clear |
|
||||
|
|
||||
# Remove .env(fake) e sapl.db da imagem |
|
||||
RUN rm -rf /var/interlegis/sapl/sapl/.env && \ |
|
||||
rm -rf /var/interlegis/sapl/sapl.db |
|
||||
|
|
||||
RUN chmod +x /var/interlegis/sapl/start.sh && \ |
|
||||
chmod +x /var/interlegis/sapl/check_solr.sh && \ |
|
||||
ln -sf /dev/stdout /var/log/nginx/access.log && \ |
|
||||
ln -sf /dev/stderr /var/log/nginx/error.log && \ |
|
||||
mkdir /var/log/sapl/ && touch /var/interlegis/sapl/sapl.log && \ |
|
||||
ln -s /var/interlegis/sapl/sapl.log /var/log/sapl/sapl.log |
|
||||
|
|
||||
VOLUME ["/var/interlegis/sapl/data", "/var/interlegis/sapl/media"] |
|
||||
|
|
||||
CMD ["/var/interlegis/sapl/start.sh"] |
|
@ -0,0 +1,72 @@ |
|||||
|
FROM python:3.7-slim-buster |
||||
|
|
||||
|
# Setup env |
||||
|
ENV LANG C.UTF-8 |
||||
|
ENV LC_ALL C.UTF-8 |
||||
|
ENV PYTHONDONTWRITEBYTECODE 1 |
||||
|
|
||||
|
#ENV PYTHONFAULTHANDLER 1 |
||||
|
|
||||
|
ENV DEBIAN_FRONTEND noninteractive |
||||
|
|
||||
|
ENV BUILD_PACKAGES apt-utils apt-file libpq-dev graphviz-dev build-essential git pkg-config \ |
||||
|
python3-dev libxml2-dev libjpeg-dev libssl-dev libffi-dev libxslt1-dev \ |
||||
|
libcairo2-dev software-properties-common python3-setuptools python3-pip |
||||
|
|
||||
|
ENV RUN_PACKAGES graphviz python3-lxml python3-magic postgresql-client python3-psycopg2 \ |
||||
|
poppler-utils curl jq bash python3-venv tzdata nodejs \ |
||||
|
fontconfig ttf-dejavu python nginx |
||||
|
|
||||
|
RUN mkdir -p /var/interlegis/sapl |
||||
|
|
||||
|
WORKDIR /var/interlegis/sapl/ |
||||
|
|
||||
|
ADD . /var/interlegis/sapl/ |
||||
|
|
||||
|
RUN apt-get update && \ |
||||
|
apt-get upgrade -y && \ |
||||
|
apt-get install -y --no-install-recommends $BUILD_PACKAGES $RUN_PACKAGES && \ |
||||
|
fc-cache -fv && \ |
||||
|
pip3 install --no-cache-dir --upgrade pip setuptools && \ |
||||
|
rm -f /etc/nginx/conf.d/* && \ |
||||
|
pip install --no-cache-dir -r /var/interlegis/sapl/requirements/dev-requirements.txt --upgrade setuptools && \ |
||||
|
SUDO_FORCE_REMOVE=yes apt-get purge -y --auto-remove $BUILD_PACKAGES && \ |
||||
|
apt-get autoremove && apt-get clean && rm -rf /var/lib/apt/lists/* |
||||
|
|
||||
|
ENV HOME=/var/interlegis/sapl |
||||
|
|
||||
|
COPY docker/start.sh $HOME |
||||
|
COPY docker/check_solr.sh $HOME |
||||
|
COPY docker/solr_api.py $HOME |
||||
|
COPY docker/busy-wait.sh $HOME |
||||
|
COPY docker/create_admin.py $HOME |
||||
|
COPY docker/genkey.py $HOME |
||||
|
COPY docker/gunicorn_start.sh $HOME |
||||
|
|
||||
|
COPY docker/config/nginx/sapl.conf /etc/nginx/conf.d |
||||
|
COPY docker/config/nginx/nginx.conf /etc/nginx/nginx.conf |
||||
|
COPY docker/config/env_dockerfile /var/interlegis/sapl/sapl/.env |
||||
|
|
||||
|
RUN python3 manage.py collectstatic --noinput --clear |
||||
|
|
||||
|
# Remove .env(fake) e sapl.db da imagem |
||||
|
RUN rm -rf /var/interlegis/sapl/sapl/.env && \ |
||||
|
rm -rf /var/interlegis/sapl/sapl.db |
||||
|
|
||||
|
RUN chmod +x /var/interlegis/sapl/start.sh && \ |
||||
|
chmod +x /var/interlegis/sapl/check_solr.sh && \ |
||||
|
ln -sf /dev/stdout /var/log/nginx/access.log && \ |
||||
|
ln -sf /dev/stderr /var/log/nginx/error.log && \ |
||||
|
mkdir /var/log/sapl/ && touch /var/interlegis/sapl/sapl.log && \ |
||||
|
ln -s /var/interlegis/sapl/sapl.log /var/log/sapl/sapl.log |
||||
|
|
||||
|
# Debian não possui usuário 'nginx' necessário para o Debian |
||||
|
RUN useradd --no-create-home nginx |
||||
|
|
||||
|
ENV DEBIAN_FRONTEND teletype |
||||
|
|
||||
|
EXPOSE 80/tcp 443/tcp |
||||
|
|
||||
|
VOLUME ["/var/interlegis/sapl/data", "/var/interlegis/sapl/media"] |
||||
|
|
||||
|
CMD ["/var/interlegis/sapl/start.sh"] |
@ -1,8 +1,9 @@ |
|||||
FROM python:3.7 |
FROM python:3.6 |
||||
ENV PYTHONUNBUFFERED 1 |
ENV PYTHONUNBUFFERED 1 |
||||
WORKDIR /sapl-dev |
WORKDIR /sapl-dev |
||||
COPY requirements ./requirements/ |
COPY ./requirements ./requirements/ |
||||
RUN apt update && \ |
RUN apt update && \ |
||||
apt -y install graphviz-dev && \ |
apt -y install graphviz-dev && \ |
||||
|
pip install --upgrade pip && \ |
||||
pip install -r ./requirements/dev-requirements.txt |
pip install -r ./requirements/dev-requirements.txt |
||||
EXPOSE 8000 |
EXPOSE 8000 |
@ -1,5 +1,5 @@ |
|||||
DATABASE_URL = postgresql://postgres:@sapldb:/sapl |
DATABASE_URL = postgresql://postgres:@sapldb:/sapl |
||||
KEY |
SECRET_KEY = 'mzp++@i1y-6y8ez_=^sfbr!dzuyry#^@v(3g^2d1k9%f=+mhlb' |
||||
DEBUG = False |
DEBUG = False |
||||
EMAIL_USE_TLS = True |
EMAIL_USE_TLS = True |
||||
EMAIL_PORT = 587 |
EMAIL_PORT = 587 |
@ -1,5 +1,5 @@ |
|||||
DATABASE_URL = sqlite:///sapl.db |
DATABASE_URL = sqlite:///sapl.db |
||||
SECRET_KEY = 'Dockerfile_Key' |
SECRET_KEY = 'mzp++@i1y-6y8ez_=^sfbr!dzuyry#^@v(3g^2d1k9%f=+mhlb' |
||||
DEBUG = False |
DEBUG = False |
||||
EMAIL_USE_TLS = True |
EMAIL_USE_TLS = True |
||||
EMAIL_PORT = 587 |
EMAIL_PORT = 587 |
@ -0,0 +1,9 @@ |
|||||
|
DATABASE_URL=postgresql://sapl:sapl@sapldb:/sapl |
||||
|
SECRET_KEY=test++@i1y-6y8ez_=^sfbr!dzuyry#^@v(3g^2d1k9%f=+mhlb |
||||
|
DEBUG=False |
||||
|
EMAIL_USE_TLS = True |
||||
|
EMAIL_PORT = 587 |
||||
|
EMAIL_HOST = '' |
||||
|
EMAIL_HOST_USER = '' |
||||
|
EMAIL_SEND_USER = '' |
||||
|
EMAIL_HOST_PASSWORD = '' |
@ -0,0 +1,19 @@ |
|||||
|
version: '3.7' |
||||
|
|
||||
|
services: |
||||
|
sapl-dev: |
||||
|
container_name: sapl-dev |
||||
|
image: sapl:dev |
||||
|
build: |
||||
|
context: ../ |
||||
|
dockerfile: ./docker/Dockerfile.dev |
||||
|
command: python3 manage.py runserver 0:8000 |
||||
|
volumes: |
||||
|
- ..:/sapl-dev |
||||
|
ports: |
||||
|
- "8000:8000" |
||||
|
environment: |
||||
|
SECRET_KEY: '$dkhxm-$zvxdox$g2-&w^1i!_z1juq0xwox6e3#gy6w_88!3t^' |
||||
|
DEBUG: 'True' |
||||
|
DATABASE_URL: postgresql://sapl:sapl@host.docker.internal:5432/sapl |
||||
|
TZ: America/Sao_Paulo |
@ -0,0 +1,38 @@ |
|||||
|
sudo: required |
||||
|
|
||||
|
services: |
||||
|
- docker |
||||
|
|
||||
|
env: |
||||
|
global: |
||||
|
- DOCKER_COMPOSE_VERSION=1.26.2 |
||||
|
|
||||
|
before_install: |
||||
|
# Install latest versions of docker and docker-compose |
||||
|
- curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - |
||||
|
- sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" |
||||
|
- sudo apt-get update |
||||
|
- sudo apt-get -y -o Dpkg::Options::="--force-confnew" install docker-ce |
||||
|
- sudo rm /usr/local/bin/docker-compose |
||||
|
- curl -L https://github.com/docker/compose/releases/download/${DOCKER_COMPOSE_VERSION}/docker-compose-`uname -s`-`uname -m` > docker-compose |
||||
|
- chmod +x docker-compose |
||||
|
- sudo mv docker-compose /usr/local/bin |
||||
|
- docker --version |
||||
|
- docker-compose --version |
||||
|
|
||||
|
install: |
||||
|
- sudo service postgresql stop || true |
||||
|
|
||||
|
script: |
||||
|
- cd $TRAVIS_BUILD_DIR/docker |
||||
|
# Build master images and run the webserver (tests end to end) |
||||
|
#- docker-compose -f docker-compose.test.yml build |
||||
|
#- docker-compose up -d |
||||
|
#- docker logs sapl |
||||
|
#- docker-compose rm -f -s -v |
||||
|
- docker-compose -f docker-compose-test.yml run --workdir="/var/interlegis/sapl" sapl bash -c "bash busy-wait.sh postgresql://sapl:sapl@sapldb:5432/sapl && cp docker/config/env_test .env && py.test --create-db" |
||||
|
|
||||
|
after_script: |
||||
|
# Cleanup docker containers, images, and volumes |
||||
|
- docker-compose rm -f -s -v |
||||
|
- docker system prune -a -f --volumes |
@ -0,0 +1,41 @@ |
|||||
|
# Ambiente de Desenvolvimento |
||||
|
|
||||
|
### Tópicos |
||||
|
|
||||
|
* [Rodar Docker Compose](#Rodar-Docker-Compose) |
||||
|
* [Configurar Banco de Dados PostgreSQL instalado na máquina](#Configurar-Banco-de-Dados-PostgreSQL-instalado-na-máquina) |
||||
|
* [Restaurar uma Base de Dados](#Restaurar-Base-de-Dados) |
||||
|
|
||||
|
##### A configuração do banco de dados e restauração da base de dados só devem ser feitas na primeira vez. |
||||
|
|
||||
|
|
||||
|
## Rodar Docker Compose |
||||
|
Para rodar o docker compose sem o conteiner postgresql, vá ao terminal e execute o comando: |
||||
|
```shell |
||||
|
docker-compose -f docker/docker-compose-dev.yml up |
||||
|
``` |
||||
|
Se quiser com o conteiner postgresql, execute o comando: |
||||
|
```shell |
||||
|
docker-compose -f docker/docker-compose-dev-db.yml up |
||||
|
``` |
||||
|
|
||||
|
## Configurar Banco de Dados PostgreSQL instalado na máquina |
||||
|
A configuração do banco de dados só é necessário com o postgresql na máquina local. Para configurá-lo, vá ao terminal e execute os comandos a seguir para criar o usuário "sapl", senha "sapl" e a base de dados "sapl": |
||||
|
```shell |
||||
|
sudo -u postgres psql -c "CREATE ROLE sapl LOGIN ENCRYPTED PASSWORD 'sapl' NOSUPERUSER INHERIT CREATEDB NOCREATEROLE NOREPLICATION;" |
||||
|
|
||||
|
sudo -u postgres psql -c "ALTER ROLE sapl VALID UNTIL 'infinity';" |
||||
|
|
||||
|
sudo -u postgres psql -c "CREATE DATABASE sapl WITH OWNER = sapl ENCODING = 'UTF8' TABLESPACE = pg_default LC_COLLATE = 'pt_BR.UTF-8' LC_CTYPE = 'pt_BR.UTF-8' CONNECTION LIMIT = -1 TEMPLATE template0;" |
||||
|
``` |
||||
|
Depois do banco de dados ter sido configurado, [restaure alguma base de dados](#Restaurar-Base-de-Dados). |
||||
|
|
||||
|
## Restaurar Base de Dados |
||||
|
No termianal, rode o comando no diretório raiz do projeto passando como parâmetro o caminho do backup: |
||||
|
```shell |
||||
|
./scripts/restore_db.sh -f <caminho-do-dump> |
||||
|
``` |
||||
|
Se o postgres estiver rodando no container, adicione a _flag_ "-p 5433": |
||||
|
```shell |
||||
|
./scripts/restore_db.sh -f <caminho-do-dump> -f 5433 |
||||
|
``` |
@ -0,0 +1,3 @@ |
|||||
|
> 1% |
||||
|
last 2 versions |
||||
|
not ie <= 8 |
@ -0,0 +1,31 @@ |
|||||
|
module.exports = { |
||||
|
root: true, |
||||
|
env: { |
||||
|
browser: true, |
||||
|
node: true, |
||||
|
jquery: true |
||||
|
}, |
||||
|
extends: [ |
||||
|
'plugin:vue/essential', |
||||
|
'standard' |
||||
|
], |
||||
|
rules: { |
||||
|
'generator-star-spacing': 'off', |
||||
|
//'no-console': process.env.NODE_ENV === 'production' ? 'error' : 'off',
|
||||
|
'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off', |
||||
|
camelcase: 0 |
||||
|
}, |
||||
|
// required to lint *.vue files
|
||||
|
plugins: [ |
||||
|
'vue' |
||||
|
], |
||||
|
parserOptions: { |
||||
|
parser: 'babel-eslint' |
||||
|
}, |
||||
|
|
||||
|
globals: { |
||||
|
$: true, |
||||
|
jQuery: true, |
||||
|
_: true |
||||
|
} |
||||
|
} |
@ -0,0 +1,22 @@ |
|||||
|
.DS_Store |
||||
|
node_modules |
||||
|
/dist |
||||
|
# local env files |
||||
|
.env.local |
||||
|
.env.*.local |
||||
|
|
||||
|
# Log files |
||||
|
npm-debug.log* |
||||
|
yarn-debug.log* |
||||
|
yarn-error.log* |
||||
|
|
||||
|
|
||||
|
# Editor directories and files |
||||
|
theme-dev |
||||
|
.idea |
||||
|
.vscode |
||||
|
*.suo |
||||
|
*.ntvs* |
||||
|
*.njsproj |
||||
|
*.sln |
||||
|
*.sw* |
@ -0,0 +1,6 @@ |
|||||
|
FROM node:lts-alpine |
||||
|
RUN apk add --no-cache bash |
||||
|
WORKDIR /sapl-frontend-dev |
||||
|
COPY package*.json ./ |
||||
|
RUN npm install |
||||
|
EXPOSE 8080 |
@ -0,0 +1,29 @@ |
|||||
|
# sapl-frontend |
||||
|
|
||||
|
## Project setup |
||||
|
``` |
||||
|
yarn install |
||||
|
``` |
||||
|
|
||||
|
### Compiles and hot-reloads for development |
||||
|
``` |
||||
|
yarn run serve |
||||
|
``` |
||||
|
|
||||
|
### Compiles and minifies for production |
||||
|
``` |
||||
|
yarn run build |
||||
|
``` |
||||
|
|
||||
|
### Run your tests |
||||
|
``` |
||||
|
yarn run test |
||||
|
``` |
||||
|
|
||||
|
### Lints and fixes files |
||||
|
``` |
||||
|
yarn run lint |
||||
|
``` |
||||
|
|
||||
|
### Customize configuration |
||||
|
See [Configuration Reference](https://cli.vuejs.org/config/). |
@ -0,0 +1,3 @@ |
|||||
|
module.exports = { |
||||
|
presets: ['@vue/app'] |
||||
|
} |
@ -0,0 +1,24 @@ |
|||||
|
version: '3.5' |
||||
|
|
||||
|
services: |
||||
|
sapl-frontend-dev: |
||||
|
container_name: sapl-frontend-dev |
||||
|
restart: always |
||||
|
image: sapl:dev |
||||
|
build: |
||||
|
context: . |
||||
|
dockerfile: Dockerfile.dev |
||||
|
volumes: |
||||
|
- .:/sapl-frontend-dev |
||||
|
- /sapl-frontend-dev/node_modules |
||||
|
ports: |
||||
|
- "8080:8080" |
||||
|
networks: |
||||
|
- sapl-net-dev |
||||
|
command: sh -c """yarn install && |
||||
|
yarn run serve""" |
||||
|
|
||||
|
networks: |
||||
|
sapl-net-dev: |
||||
|
name: sapl-net-dev |
||||
|
driver: bridge |
@ -0,0 +1,5 @@ |
|||||
|
module.exports = { |
||||
|
plugins: { |
||||
|
autoprefixer: {} |
||||
|
} |
||||
|
} |
After Width: | Height: | Size: 262 B |
After Width: | Height: | Size: 30 KiB |
After Width: | Height: | Size: 59 KiB |
After Width: | Height: | Size: 6.6 KiB |
After Width: | Height: | Size: 7.5 KiB |
After Width: | Height: | Size: 682 B |
After Width: | Height: | Size: 694 B |
After Width: | Height: | Size: 975 B |
After Width: | Height: | Size: 1021 B |
After Width: | Height: | Size: 502 B |
After Width: | Height: | Size: 3.0 KiB |
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 1.5 KiB |
After Width: | Height: | Size: 2.8 KiB |
After Width: | Height: | Size: 4.9 KiB |
After Width: | Height: | Size: 1.6 KiB |
After Width: | Height: | Size: 1.9 KiB |
After Width: | Height: | Size: 4.3 KiB |
After Width: | Height: | Size: 1.2 KiB |
After Width: | Height: | Size: 2.9 KiB |
After Width: | Height: | Size: 568 B |
After Width: | Height: | Size: 18 KiB |
After Width: | Height: | Size: 3.1 KiB |
After Width: | Height: | Size: 1.6 KiB |
After Width: | Height: | Size: 343 B |
After Width: | Height: | Size: 238 KiB |
After Width: | Height: | Size: 6.2 KiB |
After Width: | Height: | Size: 3.0 KiB |
After Width: | Height: | Size: 367 B |
After Width: | Height: | Size: 290 B |
@ -0,0 +1,331 @@ |
|||||
|
const _$ = window.$ |
||||
|
|
||||
|
function SetCookie (cookieName, cookieValue, nDays) { |
||||
|
const today = new Date() |
||||
|
const expire = new Date() |
||||
|
if (nDays === null || nDays === 0) nDays = 1 |
||||
|
expire.setTime(today.getTime() + 3600000 * 24 * nDays) |
||||
|
document.cookie = cookieName + '=' + escape(cookieValue) + |
||||
|
';expires=' + expire.toGMTString() |
||||
|
} |
||||
|
|
||||
|
function ReadCookie (cookieName) { |
||||
|
const theCookie = ' ' + document.cookie |
||||
|
let ind = theCookie.indexOf(' ' + cookieName + '=') |
||||
|
if (ind === -1) ind = theCookie.indexOf(';' + cookieName + '=') |
||||
|
if (ind === -1 || cookieName === '') return '' |
||||
|
let ind1 = theCookie.indexOf(';', ind + 1) |
||||
|
if (ind1 === -1) ind1 = theCookie.length |
||||
|
return unescape(theCookie.substring(ind + cookieName.length + 2, ind1)) |
||||
|
} |
||||
|
|
||||
|
function insertWaitAjax (element) { |
||||
|
// jQuery(element).append('<div style="text-align:center;'><img src="/static/img/ajax-loader.gif'></div>')
|
||||
|
_$(element).append('<div style="text-align:center;"><i style="font-size: 200%;" class="fa fa-refresh fa-spin"></i></div>') |
||||
|
} |
||||
|
|
||||
|
function DispositivoSearch (opts) { |
||||
|
_$(function () { |
||||
|
let formData = {} |
||||
|
let containerDs = _$('body').children('#container_ds') |
||||
|
if (containerDs.length > 0) { |
||||
|
_$(containerDs).remove() |
||||
|
} |
||||
|
containerDs = _$('<div id="container_ds"/>') |
||||
|
_$('body').prepend(containerDs) |
||||
|
|
||||
|
const fields = _$('[data-sapl-ta="DispositivoSearch"]') |
||||
|
fields.each(function () { |
||||
|
const field = _$(this) |
||||
|
const dataTypeSelection = field.attr('data-type-selection') |
||||
|
const dataField = field.attr('data-field') |
||||
|
const dataFunction = field.attr('data-function') |
||||
|
|
||||
|
const onChangeFieldSelects = function (event) { |
||||
|
if (dataTypeSelection === 'checkbox') { |
||||
|
const tas = field.find('input[name="ta_select_all"]') // tas - Textos Articulados
|
||||
|
tas.off() |
||||
|
|
||||
|
tas.on('change', function (event) { |
||||
|
_$(this).closest('ul').find('input[name="' + dataField + '"]').prop('checked', this.checked) |
||||
|
// _$(this).prop('checked', false)
|
||||
|
}) |
||||
|
} else { |
||||
|
const dpts = field.find('input') |
||||
|
dpts.off() |
||||
|
dpts.attr('type', 'hidden') |
||||
|
_$('<a class="text-danger">') |
||||
|
.insertBefore(dpts) |
||||
|
.append(_$('<span aria-hidden="true">×</span>')) |
||||
|
.on('click', function () { |
||||
|
if (_$(this).closest('ul').find('li').length === 2) { |
||||
|
_$(this).closest('ul').remove() |
||||
|
} else { |
||||
|
_$(this).closest('li').remove() |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
onChangeFieldSelects() |
||||
|
|
||||
|
const onChangeParamTA = function (event) { |
||||
|
const tipoTa = _$('select[name="tipo_ta"]').val() |
||||
|
const tipoModel = _$('select[name="tipo_model"]').val() |
||||
|
const numTa = _$('input[name="num_ta"]').val() |
||||
|
const anoTa = _$('input[name="ano_ta"]').val() |
||||
|
let tipoResultado = _$('input[name="tipo_resultado"]:checked').val() |
||||
|
const rotuloDispositivo = _$('input[name="rotulo_dispositivo"]').val() |
||||
|
const textoDispositivo = _$('input[name="texto_dispositivo"]').val() |
||||
|
const maxResults = _$('select[name="max_results"]').val() |
||||
|
let url = '' |
||||
|
|
||||
|
if (rotuloDispositivo.length > 0 || textoDispositivo.length > 0) { |
||||
|
_$('input[name="tipo_resultado"]').prop('disabled', false) |
||||
|
_$('input[name="tipo_resultado"]').each((idx, element) => { |
||||
|
element.parentElement.classList.remove('disabled') |
||||
|
}) |
||||
|
_$('input[name="tipo_resultado"]').closest('#div_id_tipo_resultado').css('opacity', '1') |
||||
|
} else { |
||||
|
_$('input[name="tipo_resultado"]').filter('[value="False"]').prop('checked', true) |
||||
|
_$('input[name="tipo_resultado"]').prop('disabled', true) |
||||
|
|
||||
|
_$('input[name="tipo_resultado"]').each((idx, element) => { |
||||
|
element.parentElement.classList.add('disabled') |
||||
|
}) |
||||
|
_$('input[name="tipo_resultado"]').closest('#div_id_tipo_resultado').css('opacity', '0.3') |
||||
|
tipoResultado = 'False' |
||||
|
} |
||||
|
formData = { |
||||
|
tipo_ta: tipoTa, |
||||
|
tipo_model: tipoModel, |
||||
|
num_ta: numTa, |
||||
|
ano_ta: anoTa, |
||||
|
texto: textoDispositivo, |
||||
|
rotulo: rotuloDispositivo, |
||||
|
tipo_resultado: tipoResultado, |
||||
|
max_results: maxResults, |
||||
|
data_type_selection: dataTypeSelection, |
||||
|
data_field: dataField, |
||||
|
data_function: dataFunction |
||||
|
} |
||||
|
|
||||
|
window.localStorage.setItem('dispositivo_search_form_data', JSON.stringify(formData)) |
||||
|
|
||||
|
url = '/ta/search_fragment_form' |
||||
|
_$('.result-busca-dispositivo').html('') |
||||
|
insertWaitAjax('.result-busca-dispositivo') |
||||
|
_$.get(url, formData).done(function (data) { |
||||
|
_$('.result-busca-dispositivo').html(data) |
||||
|
// OptionalCustomFrontEnd().init()
|
||||
|
if (dataTypeSelection === 'checkbox') { |
||||
|
const tas = _$('.result-busca-dispositivo').find('input[name="ta_select_all"]') |
||||
|
tas.off() |
||||
|
tas.on('change', function (event) { |
||||
|
_$(this).closest('ul').find('input[name="' + dataField + '"]').prop('checked', this.checked) |
||||
|
}) |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
const onKeyPressRotuloBuscaTextual = function (event) { |
||||
|
const rotuloDispositivo = _$('input[name="rotulo_dispositivo"]').val() |
||||
|
const textoDispositivo = _$('input[name="texto_dispositivo"]').val() |
||||
|
// let tipoResultado = _$('input[name="tipo_resultado"]:checked').val()
|
||||
|
|
||||
|
if (rotuloDispositivo.length > 0 || textoDispositivo.length > 0) { |
||||
|
_$('input[name="tipo_resultado"]').prop('disabled', false) |
||||
|
_$('input[name="tipo_resultado"]').each((idx, element) => { |
||||
|
element.parentElement.classList.remove('disabled') |
||||
|
}) |
||||
|
_$('input[name="tipo_resultado"]').closest('#div_id_tipo_resultado').css('opacity', '1') |
||||
|
} else { |
||||
|
_$('input[name="tipo_resultado"]').filter('[value="False"]').prop('checked', true) |
||||
|
_$('input[name="tipo_resultado"]').prop('disabled', true) |
||||
|
_$('input[name="tipo_resultado"]').each((idx, element) => { |
||||
|
element.parentElement.classList.add('disabled') |
||||
|
}) |
||||
|
_$('input[name="tipo_resultado"]').closest('#div_id_tipo_resultado').css('opacity', '0.3') |
||||
|
// tipoResultado = 'False'
|
||||
|
} |
||||
|
} |
||||
|
|
||||
|
let buttonDs = field.children('#buttonDs') |
||||
|
if (buttonDs.length > 0) { |
||||
|
_$(buttonDs).remove() |
||||
|
} |
||||
|
buttonDs = _$('<div id="buttonDs" class="clearfix"/>') |
||||
|
field.prepend(buttonDs) |
||||
|
|
||||
|
const btnOpenSearch = _$('<button>') |
||||
|
.text(opts.text_button) |
||||
|
.attr('type', 'button') |
||||
|
.attr('class', 'btn btn-sm btn-success btn-modal-open') |
||||
|
buttonDs.append(btnOpenSearch) |
||||
|
btnOpenSearch.on('click', function () { |
||||
|
_$.get(opts.url_form, function (data) { |
||||
|
containerDs.html(data) |
||||
|
const modalDs = _$('#modal-ds') |
||||
|
// OptionalCustomFrontEnd().init()
|
||||
|
|
||||
|
modalDs.find('select[name="tipo_ta"]').change(function (event) { |
||||
|
let url = '' |
||||
|
url = '/ta/search_fragment_form?action=get_tipos&tipo_ta=' + this.value |
||||
|
modalDs.find('label[for="id_tipo_model"]').html('Tipos de ' + this.children[this.selectedIndex].innerHTML) |
||||
|
|
||||
|
const select = modalDs.find('select[name="tipo_model"]') |
||||
|
select.empty() |
||||
|
_$('<option value="">Carregando...</option>').appendTo(select) |
||||
|
|
||||
|
_$.get(url).done(function (data) { |
||||
|
select.empty() |
||||
|
for (const item in data) { |
||||
|
for (const i in data[item]) { |
||||
|
select.append(_$('<option>').attr('value', i).text(data[item][i])) |
||||
|
} |
||||
|
} |
||||
|
setTimeout(function () { |
||||
|
_$('select[name="tipo_model"]').val(formData.tipo_model) |
||||
|
}, 200) |
||||
|
// select.change(onChangeParamTA)
|
||||
|
}) |
||||
|
}) |
||||
|
|
||||
|
/* modalDs.find('input[name="num_ta"], ' |
||||
|
+'input[name="ano_ta"], ' |
||||
|
+'select[name="tipo_model"], ' |
||||
|
+'input[name="texto_dispositivo"], ' |
||||
|
+'input[name="tipo_resultado"], ' |
||||
|
+'input[name="rotulo_dispositivo"]' |
||||
|
).change(onChangeParamTA); */ |
||||
|
modalDs.find('input[name="texto_dispositivo"], ' + |
||||
|
'input[name="rotulo_dispositivo"]') |
||||
|
.on('keyup', onKeyPressRotuloBuscaTextual) |
||||
|
|
||||
|
modalDs.find('.btn-busca').click(onChangeParamTA) |
||||
|
|
||||
|
modalDs.find('#btn-modal-select').click(function () { |
||||
|
// limpar selecionados se o tipo é radio
|
||||
|
const listas = field.find('ul') |
||||
|
if (dataTypeSelection === 'radio') { |
||||
|
listas.remove() |
||||
|
} |
||||
|
// adicionar itens selecionados na caixa modal
|
||||
|
const selecionados = modalDs.find('[name="' + dataField + '"]:checked') |
||||
|
|
||||
|
// com base nos selecionados, limpa seus ta's removendo os não selecionados
|
||||
|
selecionados.closest('ul').find('input:not(:checked)').filter('[name!="ta_select_all"]').closest('li').remove() |
||||
|
|
||||
|
selecionados.closest('ul').each(function () { |
||||
|
// insere na lista de selecionados os ta's não presentes
|
||||
|
const ulLista = field.find('#' + this.id) |
||||
|
if (ulLista.length === 0) { |
||||
|
field.append(this) |
||||
|
return |
||||
|
} |
||||
|
|
||||
|
// insere os dispositivos não presentes
|
||||
|
const inputForThis = _$(this).find('input') |
||||
|
|
||||
|
inputForThis.each(function () { |
||||
|
if (ulLista.find('#' + this.id).length > 0) { |
||||
|
return |
||||
|
} |
||||
|
ulLista.append(_$(this).closest('li')) |
||||
|
}) |
||||
|
}) |
||||
|
|
||||
|
onChangeFieldSelects() |
||||
|
|
||||
|
modalDs.modal('hide') |
||||
|
|
||||
|
if ('post_selected' in opts) { |
||||
|
opts.post_selected(opts.params_post_selected) |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
try { |
||||
|
formData = JSON.parse(window.localStorage.getItem('dispositivo_search_form_data')) |
||||
|
_$('input[name="num_ta"]').val(formData.num_ta) |
||||
|
_$('input[name="ano_ta"]').val(formData.ano_ta) |
||||
|
_$('input[name="rotulo_dispositivo"]').val(formData.rotulo) |
||||
|
_$('input[name="texto_dispositivo"]').val(formData.texto) |
||||
|
_$('select[name="max_results"]').val(formData.max_results) |
||||
|
|
||||
|
_$('input[name="tipo_resultado"]') |
||||
|
.filter(`[value="${formData.tipo_resultado}"]`) |
||||
|
.attr('checked', true) |
||||
|
} catch (e) { |
||||
|
// console.log(e)
|
||||
|
} |
||||
|
|
||||
|
setTimeout(function () { |
||||
|
try { |
||||
|
_$('select[name="tipo_ta"]').val(formData.tipo_ta) |
||||
|
_$('select[name="tipo_ta"]').trigger('change') |
||||
|
// modalDs.find('.btn-busca').trigger('click')
|
||||
|
// onChangeParamTA()
|
||||
|
} catch (e) { |
||||
|
// console.log(e)
|
||||
|
} |
||||
|
}, 200) |
||||
|
|
||||
|
modalDs.modal('show') |
||||
|
}) |
||||
|
}) |
||||
|
if ('autostart' in opts && opts.autostart) { |
||||
|
btnOpenSearch.trigger('click') |
||||
|
} |
||||
|
}) |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
function InitViewTAs () { |
||||
|
setTimeout(function () { |
||||
|
var href = location.href.split('#') |
||||
|
if (href.length === 2) { |
||||
|
try { |
||||
|
$('html, body').animate( |
||||
|
{ |
||||
|
scrollTop: |
||||
|
$('#dptt' + href[1]).offset().top - window.innerHeight / 9 |
||||
|
}, |
||||
|
0 |
||||
|
) |
||||
|
} catch (err) { |
||||
|
// console.log(err)
|
||||
|
} |
||||
|
} |
||||
|
}, 100) |
||||
|
|
||||
|
$('#btn_font_menos').click(function () { |
||||
|
$('.dpt').css('font-size', '-=1') |
||||
|
}) |
||||
|
$('#btn_font_mais').click(function () { |
||||
|
$('.dpt').css('font-size', '+=1') |
||||
|
}) |
||||
|
|
||||
|
$('.dpt.bloco_alteracao .dpt').each(function () { |
||||
|
var nivel = parseInt($(this).attr('nivel')) |
||||
|
$(this).css('z-index', 15 - nivel) |
||||
|
}) |
||||
|
|
||||
|
$('.cp-linha-vigencias > li:not(:first-child):not(:last-child) > a').click(function (event) { |
||||
|
$('.cp-linha-vigencias > li').removeClass('active') |
||||
|
$(this).closest('li').addClass('active') |
||||
|
event.preventDefault() |
||||
|
}) |
||||
|
|
||||
|
$('main').click(function (event) { |
||||
|
if (event.target === this || event.target === this.firstElementChild) { |
||||
|
$('.cp-linha-vigencias > li').removeClass('active') |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
export default { |
||||
|
SetCookie, |
||||
|
ReadCookie, |
||||
|
insertWaitAjax, |
||||
|
InitViewTAs, |
||||
|
DispositivoSearch |
||||
|
} |
@ -0,0 +1,584 @@ |
|||||
|
|
||||
|
const _$ = window.$ |
||||
|
|
||||
|
window.DispositivoEdit = function () { |
||||
|
// Função única - Singleton pattern - operador new sempre devolve o mesmo objeto
|
||||
|
let instance |
||||
|
|
||||
|
let editortype = 'textarea' |
||||
|
|
||||
|
if (!(this instanceof window.DispositivoEdit)) { |
||||
|
if (!instance) { |
||||
|
instance = new window.DispositivoEdit() |
||||
|
} |
||||
|
return instance |
||||
|
} |
||||
|
instance = this |
||||
|
window.DispositivoEdit = function () { |
||||
|
return instance |
||||
|
} |
||||
|
|
||||
|
instance.bindActionsEditorType = function (event) { |
||||
|
editortype = this.getAttribute('editortype') |
||||
|
window.SetCookie('editortype', editortype, 30) |
||||
|
const dpt = _$(this).closest('.dpt') |
||||
|
|
||||
|
const pk = dpt.attr('pk') |
||||
|
instance.clearEditSelected() |
||||
|
instance.triggerBtnDptEdit(pk) |
||||
|
event.preventDefault() |
||||
|
} |
||||
|
|
||||
|
instance.bindActionsClick = function (event) { |
||||
|
const pk = this.getAttribute('pk') |
||||
|
|
||||
|
const form_data = { |
||||
|
action: this.getAttribute('action'), |
||||
|
tipo_pk: this.getAttribute('tipo_pk'), |
||||
|
perfil_pk: this.getAttribute('perfil_pk'), |
||||
|
variacao: this.getAttribute('variacao'), |
||||
|
pk_bloco: this.getAttribute('pk_bloco') |
||||
|
} |
||||
|
|
||||
|
const url = pk + '/refresh' |
||||
|
instance.waitShow() |
||||
|
|
||||
|
_$.get(url, form_data).done(function (data) { |
||||
|
instance.clearEditSelected() |
||||
|
if (data.pk != null) { |
||||
|
instance.message(data) |
||||
|
} |
||||
|
}).fail(instance.waitHide).always(instance.waitHide) |
||||
|
} |
||||
|
|
||||
|
instance.clearEditSelected = function () { |
||||
|
_$('.dpt-selected > .dpt-form').html('') |
||||
|
_$('.dpt-actions, .dpt-actions-bottom').html('') |
||||
|
window.tinymce.remove() |
||||
|
_$('.dpt-selected').removeClass('dpt-selected') |
||||
|
} |
||||
|
|
||||
|
instance.editDispositivo = function (event) { |
||||
|
const obj_click = (event.target.classList.contains('dpt-link') |
||||
|
? event.target |
||||
|
: (event.target.parentElement.classList.contains('dpt-link') |
||||
|
? event.target.parentElement |
||||
|
: null)) |
||||
|
|
||||
|
if (obj_click && obj_click.getAttribute('href') && obj_click.getAttribute('href').length > 0) { return } |
||||
|
|
||||
|
const dpt = _$(this).closest('.dpt') |
||||
|
if (dpt.hasClass('dpt-selected')) { |
||||
|
if (this.getAttribute('action') === 'editor-close') { instance.clearEditSelected() } |
||||
|
return |
||||
|
} |
||||
|
instance.clearEditSelected() |
||||
|
instance.loadActionsEdit(dpt) |
||||
|
|
||||
|
const formtype = dpt.attr('formtype') |
||||
|
dpt.on(formtype, instance[formtype]) |
||||
|
instance.loadForm(dpt, formtype) |
||||
|
} |
||||
|
|
||||
|
instance.gc = function () { |
||||
|
setTimeout(function () { |
||||
|
_$('.dpt:not(.dpt-selected) > .dpt-form').html('') |
||||
|
}, 500) |
||||
|
} |
||||
|
|
||||
|
instance.get_form_base = function () { |
||||
|
const _this = _$(this) |
||||
|
_this.addClass('dpt-selected') |
||||
|
|
||||
|
const dpt_form = _this.children().filter('.dpt-form') |
||||
|
dpt_form.find('form').submit(instance.onSubmitEditFormBase) |
||||
|
|
||||
|
instance.scrollTo(_this) |
||||
|
_this.off('get_form_base') |
||||
|
|
||||
|
const btn_fechar = _this.find('.btn-fechar') |
||||
|
btn_fechar.on('click', function (event) { |
||||
|
instance.clearEditSelected() |
||||
|
event.preventDefault() |
||||
|
}) |
||||
|
|
||||
|
const btns_excluir = _this.find('.btns-excluir') |
||||
|
_this.find('.dpt-actions-bottom').first().append(btns_excluir) |
||||
|
|
||||
|
btns_excluir.find('.btn-outline-danger').on('click', instance.bindActionsClick) |
||||
|
} |
||||
|
|
||||
|
instance.get_form_alteracao = function () { |
||||
|
const _this = _$(this) |
||||
|
_this.off('get_form_alteracao') |
||||
|
_$('.dpt-actions, .dpt-actions-bottom').html('') |
||||
|
|
||||
|
const dpt_form = _this.children().filter('.dpt-form').children().first() |
||||
|
const url_search = dpt_form[0].id_dispositivo_search_form.value |
||||
|
window.DispositivoSearch({ |
||||
|
url_form: url_search, |
||||
|
text_button: 'Selecionar', |
||||
|
autostart: true |
||||
|
}) |
||||
|
|
||||
|
instance.scrollTo(_this) |
||||
|
dpt_form.submit(instance.onSubmitFormRegistraAlteracao) |
||||
|
|
||||
|
const btn_fechar = _this.find('.btn-fechar') |
||||
|
btn_fechar.on('click', function (event) { |
||||
|
instance.clearEditSelected() |
||||
|
instance.triggerBtnDptEdit(_this.attr('pk')) |
||||
|
event.preventDefault() |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
instance.get_form_inclusao = function () { |
||||
|
const _this = _$(this) |
||||
|
_this.off('get_form_inclusao') |
||||
|
_$('.dpt-actions, .dpt-actions-bottom').html('') |
||||
|
|
||||
|
const dpt_form = _this.children().filter('.dpt-form').children().first() |
||||
|
const url_search = dpt_form[0].id_dispositivo_search_form.value |
||||
|
window.DispositivoSearch({ |
||||
|
url_form: url_search, |
||||
|
text_button: 'Selecionar', |
||||
|
post_selected: instance.allowed_inserts_registro_inclusao, |
||||
|
params_post_selected: { pk_bloco: _this.attr('pk') }, |
||||
|
autostart: true |
||||
|
|
||||
|
}) |
||||
|
|
||||
|
instance.scrollTo(_this) |
||||
|
dpt_form.submit(instance.onSubmitFormRegistraInclusao) |
||||
|
|
||||
|
const btn_fechar = _this.find('.btn-fechar') |
||||
|
btn_fechar.on('click', function (event) { |
||||
|
instance.clearEditSelected() |
||||
|
instance.triggerBtnDptEdit(_this.attr('pk')) |
||||
|
event.preventDefault() |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
instance.get_form_revogacao = function () { |
||||
|
const _this = _$(this) |
||||
|
_this.off('get_form_revogacao') |
||||
|
_$('.dpt-actions, .dpt-actions-bottom').html('') |
||||
|
|
||||
|
const dpt_form = _this.children().filter('.dpt-form').children().first() |
||||
|
const url_search = dpt_form[0].id_dispositivo_search_form.value |
||||
|
window.DispositivoSearch({ |
||||
|
url_form: url_search, |
||||
|
text_button: 'Selecionar', |
||||
|
autostart: true |
||||
|
}) |
||||
|
|
||||
|
instance.scrollTo(_this) |
||||
|
dpt_form.submit(instance.onSubmitFormRegistraRevogacao) |
||||
|
|
||||
|
const btn_fechar = _this.find('.btn-fechar') |
||||
|
btn_fechar.on('click', function () { |
||||
|
instance.clearEditSelected() |
||||
|
instance.triggerBtnDptEdit(_this.attr('pk')) |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
instance.allowed_inserts_registro_inclusao = function (params) { |
||||
|
const dispositivo_base_para_inclusao = _$('#id' + params.pk_bloco + " input[name='dispositivo_base_para_inclusao']") |
||||
|
if (dispositivo_base_para_inclusao.length === 0) { return } |
||||
|
|
||||
|
const pk = dispositivo_base_para_inclusao[0].value |
||||
|
const form_data = { |
||||
|
action: 'get_actions_allowed_inserts_registro_inclusao', |
||||
|
pk_bloco: params.pk_bloco |
||||
|
} |
||||
|
|
||||
|
const url = pk + '/refresh' |
||||
|
instance.waitShow() |
||||
|
|
||||
|
_$.get(url, form_data).done(function (data) { |
||||
|
_$('.allowed_inserts').html(data) |
||||
|
_$('.allowed_inserts').find('.btn-action').on('click', instance.bindActionsClick) |
||||
|
}).fail(instance.waitHide).always(instance.waitHide) |
||||
|
} |
||||
|
|
||||
|
instance.loadActionsEdit = function (dpt) { |
||||
|
const pk = dpt.attr('pk') |
||||
|
const url = pk + '/refresh?action=get_actions' |
||||
|
_$.get(url).done(function (data) { |
||||
|
dpt.find('.dpt-actions').first().html(data) |
||||
|
dpt.find('.btn-action').on('click', instance.bindActionsClick) |
||||
|
// dpt.find('.btn-perfis').on('click', instance.bindActionsClick);
|
||||
|
dpt.find('.btn-compila').on('click', instance.loadFormsCompilacao) |
||||
|
dpt.find('.btn-editor-type').on('click', instance.bindActionsEditorType) |
||||
|
|
||||
|
if (editortype === 'construct') { |
||||
|
dpt.find('.btn-group-inserts').first().addClass('open show') |
||||
|
dpt.find('.btn-group-inserts ul').first().addClass('show') |
||||
|
} |
||||
|
|
||||
|
dpt.find('.btn-group-inserts button').mouseenter(function (event) { |
||||
|
dpt.find('.btn-group-inserts ul').removeClass('show') |
||||
|
dpt.find('.btn-group-inserts').removeClass('open show') |
||||
|
_$(this.parentElement).addClass('open show') |
||||
|
_$(this.parentElement).find('ul').addClass('show') |
||||
|
}) |
||||
|
|
||||
|
dpt.find('.btn-group-inserts').mouseleave(function (event) { |
||||
|
dpt.find('.btn-group-inserts ul').removeClass('show') |
||||
|
dpt.find('.btn-group-inserts').removeClass('open show') |
||||
|
}) |
||||
|
|
||||
|
// Para ativar image_cropping dentro do editor dinâmico descolmentar linha abaixo
|
||||
|
// e retirar restrição do backend que adiciona input image apenas o editor avançado
|
||||
|
// window.image_cropping.init()
|
||||
|
|
||||
|
instance.gc() |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
instance.loadForm = function (dpt, trigger) { |
||||
|
const pk = dpt.attr('pk') |
||||
|
const dpt_form = dpt.children().filter('.dpt-form') |
||||
|
if (dpt_form.length === 1) { |
||||
|
const url = pk + '/refresh?action=' + trigger |
||||
|
_$.get(url).done(function (data) { |
||||
|
if (editortype !== 'construct') { |
||||
|
dpt_form.html(data) |
||||
|
if (editortype === 'tinymce') { |
||||
|
window.initTextRichEditor() |
||||
|
} |
||||
|
// OptionalCustomFrontEnd().init()
|
||||
|
} |
||||
|
dpt.trigger(trigger) |
||||
|
}).always(function () { |
||||
|
instance.waitHide() |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
instance.loadFormsCompilacao = function (event) { |
||||
|
const dpt = _$(this).closest('.dpt') |
||||
|
const formtype = this.getAttribute('action') |
||||
|
dpt.on(formtype, instance[formtype]) |
||||
|
instance.loadForm(dpt, formtype) |
||||
|
} |
||||
|
|
||||
|
instance.modalMessage = function (message, alert, closeFunction) { |
||||
|
if (message !== null && message !== '') { |
||||
|
_$('#modal-message #message').html(message) |
||||
|
_$('#modal-message').modal('show') |
||||
|
_$('#modal-message, #modal-message .alert button').off() |
||||
|
_$('#modal-message .alert').removeClass('alert-success alert-info alert-warning alert-danger alert-danger') |
||||
|
_$('#modal-message .alert').addClass(alert) |
||||
|
|
||||
|
if (closeFunction != null) { _$('#modal-message').on('hidden.bs.modal', closeFunction) } |
||||
|
|
||||
|
_$('#modal-message .alert button').on('click', function () { |
||||
|
_$('#modal-message').modal('hide') |
||||
|
}) |
||||
|
return true |
||||
|
} |
||||
|
return false |
||||
|
} |
||||
|
|
||||
|
instance.message = function (data) { |
||||
|
if (data.message !== undefined) { |
||||
|
if (data.message.modal) { |
||||
|
instance.modalMessage(data.message.value, 'alert-' + data.message.type, function () { |
||||
|
instance.waitShow() |
||||
|
instance.refreshScreenFocusPk(data) |
||||
|
}) |
||||
|
} else { |
||||
|
instance.refreshScreenFocusPk(data) |
||||
|
if (!('message' in data)) { return } |
||||
|
const cp_notify = _$('.cp-notify') |
||||
|
cp_notify.removeClass('hide') |
||||
|
const msg = cp_notify.find('.message') |
||||
|
msg.html(data.message.value) |
||||
|
msg.removeClass('bg-primary bg-success bg-info bg-warning bg-danger').addClass('bg-' + data.message.type) |
||||
|
setTimeout(function () { |
||||
|
cp_notify.addClass('hide') |
||||
|
}, (data.message.time ? data.message.time : 3000)) |
||||
|
} |
||||
|
} else { |
||||
|
instance.refreshScreenFocusPk(data) |
||||
|
} |
||||
|
} |
||||
|
instance.offClicks = function () { |
||||
|
_$('.btn-dpt-edit').off() |
||||
|
} |
||||
|
instance.onClicks = function (container) { |
||||
|
let objects |
||||
|
if (container == null) { objects = _$('.btn-dpt-edit') } else { objects = _$(container).find('.btn-dpt-edit') } |
||||
|
objects.on('click', instance.editDispositivo) |
||||
|
} |
||||
|
|
||||
|
instance.onSubmitFormRegistraAlteracao = function (event) { |
||||
|
if (this.dispositivo_alterado === undefined) { |
||||
|
instance.modalMessage('Nenhum dispositivo selecionado', 'alert-info') |
||||
|
if (event != null) { event.preventDefault() } |
||||
|
return |
||||
|
} |
||||
|
const dispositivo_alterado = this.dispositivo_alterado.length === undefined ? [this.dispositivo_alterado] : Array.from(this.dispositivo_alterado) |
||||
|
const form_data = { |
||||
|
csrfmiddlewaretoken: this.csrfmiddlewaretoken.value, |
||||
|
dispositivo_alterado: dispositivo_alterado.filter( |
||||
|
function (elem, idx, array) { |
||||
|
return elem.checked |
||||
|
} |
||||
|
).map(function (dsp) { |
||||
|
return dsp.value |
||||
|
}), |
||||
|
formtype: 'get_form_alteracao' |
||||
|
} |
||||
|
const url = _$(this).closest('.dpt').attr('pk') + '/refresh' |
||||
|
|
||||
|
instance.waitShow() |
||||
|
|
||||
|
// eslint-disable-next-line
|
||||
|
_$.post(url, form_data) |
||||
|
.done(function (data) { |
||||
|
instance.clearEditSelected() |
||||
|
|
||||
|
if (data.pk != null) { |
||||
|
instance.message(data) |
||||
|
} else { |
||||
|
alert('Erro na resposta!') |
||||
|
} |
||||
|
}).always(function () { |
||||
|
instance.waitHide() |
||||
|
}) |
||||
|
if (event != null) { event.preventDefault() } |
||||
|
} |
||||
|
|
||||
|
instance.onSubmitFormRegistraInclusao = function (event) { |
||||
|
const form_data = { |
||||
|
csrfmiddlewaretoken: this.csrfmiddlewaretoken.value, |
||||
|
dispositivo_base_para_inclusao: this.dispositivo_base_para_inclusao.value, |
||||
|
formtype: 'get_form_inclusao' |
||||
|
} |
||||
|
const url = _$(this).closest('.dpt').attr('pk') + '/refresh' |
||||
|
|
||||
|
instance.waitShow() |
||||
|
|
||||
|
_$.post(url, form_data) |
||||
|
.done(function (data) { |
||||
|
instance.clearEditSelected() |
||||
|
|
||||
|
if (data.pk != null) { |
||||
|
instance.message(data) |
||||
|
} else { |
||||
|
alert('Erro na resposta!') |
||||
|
} |
||||
|
}).always(function () { |
||||
|
instance.waitHide() |
||||
|
}) |
||||
|
if (event != null) { event.preventDefault() } |
||||
|
} |
||||
|
|
||||
|
instance.onSubmitFormRegistraRevogacao = function (event) { |
||||
|
if (this.dispositivo_revogado === undefined) { |
||||
|
instance.modalMessage('Nenhum dispositivo selecionado', 'alert-info') |
||||
|
if (event != null) { event.preventDefault() } |
||||
|
return |
||||
|
} |
||||
|
const dispositivo_revogado = this.dispositivo_revogado.length === undefined ? [this.dispositivo_revogado] : Array.from(this.dispositivo_revogado) |
||||
|
const form_data = { |
||||
|
csrfmiddlewaretoken: this.csrfmiddlewaretoken.value, |
||||
|
dispositivo_revogado: dispositivo_revogado.filter( |
||||
|
function (elem, idx, array) { |
||||
|
return elem.checked |
||||
|
} |
||||
|
).map(function (dsp) { |
||||
|
return dsp.value |
||||
|
}), |
||||
|
revogacao_em_bloco: this.revogacao_em_bloco.value, |
||||
|
formtype: 'get_form_revogacao' |
||||
|
} |
||||
|
|
||||
|
const url = _$(this).closest('.dpt').attr('pk') + '/refresh' |
||||
|
|
||||
|
instance.waitShow() |
||||
|
|
||||
|
_$.post(url, form_data) |
||||
|
.done(function (data) { |
||||
|
instance.clearEditSelected() |
||||
|
|
||||
|
if (data.pk != null) { |
||||
|
instance.message(data) |
||||
|
} else { |
||||
|
alert('Erro na resposta!') |
||||
|
} |
||||
|
}).always(function (event) { |
||||
|
instance.waitHide() |
||||
|
}) |
||||
|
if (event != null) { event.preventDefault() } |
||||
|
} |
||||
|
|
||||
|
instance.onSubmitEditFormBase = function (event) { |
||||
|
const _this = this |
||||
|
let texto = '' |
||||
|
let texto_atualizador = '' |
||||
|
let visibilidade = '' |
||||
|
const editor_tiny_texto = window.tinymce.get('id_texto') |
||||
|
const editor_tiny_texto_atualizador = window.tinymce.get('id_texto_atualizador') |
||||
|
|
||||
|
if (editor_tiny_texto != null) { texto = editor_tiny_texto.getContent() } else { texto = this.id_texto.value } |
||||
|
|
||||
|
if (editor_tiny_texto_atualizador != null) { texto_atualizador = editor_tiny_texto_atualizador.getContent() } else if ('id_texto_atualizador' in this) { texto_atualizador = this.id_texto_atualizador.value } |
||||
|
|
||||
|
if ('visibilidade' in this) { visibilidade = this.visibilidade.value } |
||||
|
|
||||
|
const form_data = { |
||||
|
csrfmiddlewaretoken: this.csrfmiddlewaretoken.value, |
||||
|
texto: texto, |
||||
|
texto_atualizador: texto_atualizador, |
||||
|
visibilidade: visibilidade, |
||||
|
formtype: 'get_form_base' |
||||
|
} |
||||
|
|
||||
|
const url = _$(this).closest('.dpt').attr('pk') + '/refresh' |
||||
|
|
||||
|
instance.waitShow() |
||||
|
|
||||
|
_$.post(url, form_data) |
||||
|
.done(function (data) { |
||||
|
if (typeof data === 'string') { /* if obsoleto */ |
||||
|
let dpt = _$(_this).closest('.dpt') |
||||
|
dpt = _$('#' + dpt.replaceWith(data).attr('id')) |
||||
|
instance.onClicks(dpt) |
||||
|
instance.waitHide() |
||||
|
return |
||||
|
} |
||||
|
instance.clearEditSelected() |
||||
|
|
||||
|
if (data.pk != null) { |
||||
|
instance.message(data) |
||||
|
} else { |
||||
|
alert('Erro na resposta!') |
||||
|
} |
||||
|
}).always(function () { |
||||
|
instance.waitHide() |
||||
|
}) |
||||
|
if (event != null) { event.preventDefault() } |
||||
|
} |
||||
|
instance.refreshContent = function (pais, trigger_edit_pk) { |
||||
|
if (pais.length === 0) { |
||||
|
instance.waitHide() |
||||
|
return |
||||
|
} |
||||
|
const pk = pais.shift() |
||||
|
const url = pk + '/refresh' |
||||
|
|
||||
|
_$.get(url).done(function (data) { |
||||
|
let dpt = _$('#id' + pk).closest('.dpt') |
||||
|
dpt = _$('#' + dpt.replaceWith(data).attr('id')) |
||||
|
instance.onClicks(dpt) |
||||
|
instance.reloadFunctionsDraggables() |
||||
|
|
||||
|
if (trigger_edit_pk > 0) { instance.triggerBtnDptEdit(trigger_edit_pk) } |
||||
|
|
||||
|
instance.refreshContent(pais) |
||||
|
}) |
||||
|
} |
||||
|
instance.refreshScreenFocusPk = function (data) { |
||||
|
instance.waitShow() |
||||
|
if (data.pai[0] === -1) { |
||||
|
instance.waitShow() |
||||
|
const href = location.href.split('#')[0] |
||||
|
location.href = href + '#' + data.pk |
||||
|
location.reload(true) |
||||
|
} else { |
||||
|
instance.refreshContent(data.pai, data.pk) |
||||
|
|
||||
|
/* setTimeout(function() { |
||||
|
for (let pai = 1; pai < data.pai.length; pai++) |
||||
|
instance.refreshContent(data.pai[pai]); |
||||
|
instance.waitHide(); |
||||
|
}, 1000); */ |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
instance.reloadFunctionsDraggables = function () { |
||||
|
_$('.dpt-alts').sortable({ |
||||
|
revert: true, |
||||
|
distance: 15, |
||||
|
start: function (event, ui) { |
||||
|
}, |
||||
|
stop: function (event, ui) { |
||||
|
const pk = ui.item.attr('pk') |
||||
|
const bloco_pk = ui.item.closest('.dpt-alts').closest('.dpt').attr('pk') |
||||
|
|
||||
|
const url = pk + '/refresh?action=json_drag_move_dpt_alterado&index=' + ui.item.index() + '&bloco_pk=' + bloco_pk |
||||
|
_$.get(url).done(function (data) { |
||||
|
// console.log(pk + ' - ' + bloco_pk)
|
||||
|
// reloadFunctionsForObjectsOfCompilacao();
|
||||
|
}) |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
_$('.dpt-alts .dpt').draggable({ |
||||
|
connectToSortable: '.dpt-alts', |
||||
|
revert: 'invalid', |
||||
|
zIndex: 1, |
||||
|
distance: 15, |
||||
|
drag: function (event, ui) { |
||||
|
// _$('.dpt-comp-selected').removeClass('dpt-comp-selected');
|
||||
|
_$('.dpt-alts').addClass('drag') |
||||
|
}, |
||||
|
stop: function (event, ui) { |
||||
|
_$('.dpt-alts').removeClass('drag') |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
_$('.dpt-alts').disableSelection() |
||||
|
} |
||||
|
instance.scrollTo = function (dpt) { |
||||
|
try { |
||||
|
_$('html, body').animate({ |
||||
|
scrollTop: dpt.offset().top - window.innerHeight / 9 |
||||
|
}, 100) |
||||
|
} catch (err) { |
||||
|
} |
||||
|
} |
||||
|
instance.triggerBtnDptEdit = function (pk) { |
||||
|
let btn_dpt_edit = _$('#id' + pk + ' > .dpt-text.btn-dpt-edit') |
||||
|
if (btn_dpt_edit.length === 0) { btn_dpt_edit = _$('#id' + pk + ' > .dpt-actions-fixed > .btn-dpt-edit') } |
||||
|
btn_dpt_edit.first().trigger('click') |
||||
|
} |
||||
|
instance.waitHide = function () { |
||||
|
_$('#wait_message').addClass('displaynone') |
||||
|
} |
||||
|
instance.waitShow = function () { |
||||
|
_$('#wait_message').removeClass('displaynone') |
||||
|
} |
||||
|
|
||||
|
instance.init = function () { |
||||
|
_$('.dpt-actions-fixed').first().css('opacity', '1') |
||||
|
editortype = window.ReadCookie('editortype') |
||||
|
if (editortype === null || editortype === '') { |
||||
|
editortype = 'textarea' |
||||
|
window.SetCookie('editortype', editortype, 30) |
||||
|
} |
||||
|
// editortype = "textarea";
|
||||
|
instance.offClicks() |
||||
|
instance.onClicks() |
||||
|
instance.reloadFunctionsDraggables() |
||||
|
|
||||
|
const href = location.href.split('#') |
||||
|
if (href.length === 2 && href[1] !== '') { |
||||
|
instance.triggerBtnDptEdit(href[1]) |
||||
|
} |
||||
|
_$('main').click(function (event) { |
||||
|
if (event.target === this || event.target === this.firstElementChild) { instance.clearEditSelected() } |
||||
|
}) |
||||
|
instance.waitHide() |
||||
|
} |
||||
|
instance.init() |
||||
|
} |
||||
|
|
||||
|
_$(document).ready(function () { |
||||
|
if ($('.cpe').length > 0) { |
||||
|
window.DispositivoEdit() |
||||
|
} |
||||
|
}) |
@ -0,0 +1,136 @@ |
|||||
|
|
||||
|
const _$ = window.$ |
||||
|
|
||||
|
function onEventsDneExec (pk, model) { |
||||
|
_$('html, body').animate({ |
||||
|
scrollTop: _$('#dne' + pk).offset().top - window.innerHeight / 5 |
||||
|
}, 300) |
||||
|
|
||||
|
window.refreshDatePicker() |
||||
|
|
||||
|
_$('#dne' + pk + ' #button-id-submit-form').click(onSubmitEditNVForm) |
||||
|
_$('#dne' + pk + ' .btn-close-container').click(function () { |
||||
|
_$(this).closest('.dne-nota').removeClass('dne-nota') |
||||
|
_$(this).closest('.dne-form').html('') |
||||
|
}) |
||||
|
|
||||
|
if (model === 'nota') { |
||||
|
_$('#dne' + pk + ' select[name="tipo"]').change(function (event) { |
||||
|
let url = '' |
||||
|
url = 'text/' + pk + '/nota/create?action=modelo_nota&id_tipo=' + this.value |
||||
|
_$.get(url).done(function (data) { |
||||
|
_$('#dne' + pk + ' textarea[name="texto"]').val(data) |
||||
|
}) |
||||
|
}) |
||||
|
} else if (model === 'vide') { |
||||
|
window.DispositivoSearch({ |
||||
|
url_form: '/ta/search_form', |
||||
|
text_button: 'Definir Dispositivo' |
||||
|
}) |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
function onSubmitEditNVForm (event) { |
||||
|
let url = '' |
||||
|
let model = 'nota' |
||||
|
let idEdit = null |
||||
|
let idDispositivo = _$('#id_dispositivo').val() |
||||
|
|
||||
|
if (idDispositivo === undefined) { // trata-se de um vide
|
||||
|
// _$('#idDispositivo_ref').remove()
|
||||
|
idDispositivo = _$('#id_dispositivo_base').val() |
||||
|
model = 'vide' |
||||
|
} |
||||
|
|
||||
|
idEdit = _$('#id_pk').val() |
||||
|
url = 'text/' + idDispositivo + '/' + model + '/' |
||||
|
if (idEdit === null || idEdit === '') { |
||||
|
url += 'create' |
||||
|
} else { |
||||
|
url += idEdit + '/edit' |
||||
|
} |
||||
|
|
||||
|
// console.log(_$('#dne' + idDispositivo + ' form').serialize())
|
||||
|
|
||||
|
_$.post(url, _$('#dne' + idDispositivo + ' form').serialize(), function (data) { |
||||
|
if (typeof data === 'string') { |
||||
|
if (data.indexOf('<form') >= 0) { |
||||
|
_$('#dne' + idDispositivo + ' .dne-form').html(data) |
||||
|
onEventsDneExec(idDispositivo, model) |
||||
|
} else { |
||||
|
_$('#dne' + idDispositivo + ' .dne-form').closest('.dpt').html(data) |
||||
|
onReadyNotasVides() |
||||
|
try { |
||||
|
_$('html, body').animate({ |
||||
|
scrollTop: _$('#dne' + idDispositivo).offset().top - window.innerHeight / 3 |
||||
|
}, 300) |
||||
|
} catch (err) { |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
function onDelete (event) { |
||||
|
const model = _$(event).attr('model') |
||||
|
|
||||
|
const idDispositivo = _$(event).closest('.dn').attr('pk') |
||||
|
const idDelete = _$(event).attr('pk') |
||||
|
const url = 'text/' + idDispositivo + '/' + model + '/' + idDelete + '/delete' |
||||
|
|
||||
|
_$.get(url, function (data) { |
||||
|
_$('#dne' + idDispositivo + ' .dne-form').closest('.dpt').html(data) |
||||
|
onReadyNotasVides() |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
function getForm (_this) { |
||||
|
let url = '' |
||||
|
const model = _$(_this).attr('model') |
||||
|
let idDispositivo = _$('.dne-nota .dne-form').closest('.dne').attr('pk') |
||||
|
if (idDispositivo != null) { |
||||
|
_$('#dne' + idDispositivo).removeClass('dne-nota') |
||||
|
_$('#dne' + idDispositivo + ' .dne-form').html('') |
||||
|
} |
||||
|
|
||||
|
if (_this.className.indexOf('create') >= 0) { |
||||
|
idDispositivo = _$(_this).attr('pk') |
||||
|
url = 'text/' + idDispositivo + '/' + model + '/create' |
||||
|
} else if (_this.className.indexOf('edit') >= 0) { |
||||
|
const idEdit = _$(_this).attr('pk') |
||||
|
idDispositivo = _$(_this).closest('.dn').attr('pk') |
||||
|
url = 'text/' + idDispositivo + '/' + model + '/' + idEdit + '/edit' |
||||
|
} |
||||
|
|
||||
|
_$('#dne' + idDispositivo).addClass('dne-nota') |
||||
|
|
||||
|
_$.get(url).done(function (data) { |
||||
|
_$('#dne' + idDispositivo + ' .dne-form').html(data) |
||||
|
onEventsDneExec(idDispositivo, model) |
||||
|
}).fail(function () { |
||||
|
onReadyNotasVides() |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
function onReadyNotasVides () { |
||||
|
_$('.dne-nota').removeClass('dne-nota') |
||||
|
_$('.dne-form').html('') |
||||
|
|
||||
|
_$('.dne .btn-action').off() |
||||
|
_$('.dn .btn-action').off() |
||||
|
|
||||
|
_$('.dne .btn-action, .dn .btn-action').not('.btn-nota-delete').not('.btn-vide-delete').click(function () { |
||||
|
getForm(this) |
||||
|
}) |
||||
|
|
||||
|
_$('.dn .btn-nota-delete, .dn .btn-vide-delete').click(function () { |
||||
|
onDelete(this) |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
export default { |
||||
|
onEventsDneExec, |
||||
|
onSubmitEditNVForm, |
||||
|
onDelete, |
||||
|
onReadyNotasVides |
||||
|
} |
@ -0,0 +1,169 @@ |
|||||
|
const _$ = window.$ |
||||
|
const JsDiff = require('diff') |
||||
|
|
||||
|
function isElementInViewport (el) { |
||||
|
if (typeof jQuery === 'function' && el instanceof jQuery) { |
||||
|
el = el[0] |
||||
|
} |
||||
|
|
||||
|
const rect = el.getBoundingClientRect() |
||||
|
|
||||
|
return ( |
||||
|
rect.top >= 0 && |
||||
|
rect.left >= 0 && |
||||
|
rect.bottom <= |
||||
|
(window.innerHeight || document.documentElement.clientHeight) && |
||||
|
rect.right <= (window.innerWidth || document.documentElement.clientWidth) |
||||
|
) |
||||
|
} |
||||
|
|
||||
|
function textoMultiVigente (item, diff) { |
||||
|
let elv = null |
||||
|
const ldpts = _$('.dptt') |
||||
|
for (let i = 0; i < ldpts.length; i++) { |
||||
|
if (_$(ldpts[i]).hasClass('displaynone')) continue |
||||
|
if (isElementInViewport(ldpts[i])) { |
||||
|
if (i + 1 < ldpts.length) elv = ldpts[i + 1] |
||||
|
else { |
||||
|
elv = ldpts[i] |
||||
|
} |
||||
|
break |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
_$('.cp .tipo-vigencias a').removeClass('active') |
||||
|
_$(item).addClass('active') |
||||
|
_$('.dptt.desativado').removeClass('displaynone') |
||||
|
_$('.desativado > .dn').removeClass('displaynone') |
||||
|
_$('.desativado > .dpt-img').removeClass('displaynone') |
||||
|
_$('.dptt.revogado').removeClass('displaynone') |
||||
|
_$('.dtxt').removeClass('displaynone') |
||||
|
_$('.dtxt.diff').remove() |
||||
|
_$('.nota-alteracao').removeClass('displaynone') |
||||
|
|
||||
|
if (diff) { |
||||
|
_$('.dtxt[id^="da"').each(function () { |
||||
|
if (_$(this) |
||||
|
.html() |
||||
|
.search(/<\/\w+>/g) > 0) { |
||||
|
return |
||||
|
} |
||||
|
|
||||
|
const pk = _$(this).attr('pk') |
||||
|
const pks = _$(this).attr('pks') |
||||
|
|
||||
|
const a = _$('#d' + pks) |
||||
|
.contents() |
||||
|
.filter(function () { |
||||
|
return this.nodeType === Node.TEXT_NODE |
||||
|
}) |
||||
|
const b = _$('#da' + pk) |
||||
|
.contents() |
||||
|
.filter(function () { |
||||
|
return this.nodeType === Node.TEXT_NODE |
||||
|
}) |
||||
|
|
||||
|
const diff = JsDiff.diffWordsWithSpace(_$(a).text(), _$(b).text()) |
||||
|
|
||||
|
if (diff.length > 0) { |
||||
|
_$('#d' + pks) |
||||
|
.closest('.desativado') |
||||
|
.addClass('displaynone') |
||||
|
|
||||
|
const clone = _$('#da' + pk).clone() |
||||
|
_$('#da' + pk).after(clone) |
||||
|
_$('#da' + pk).addClass('displaynone') |
||||
|
_$(clone) |
||||
|
.addClass('diff') |
||||
|
.html('') |
||||
|
|
||||
|
diff.forEach(function (part) { |
||||
|
// let color = part.added ? '#018' : part.removed ? '#faa' : ''
|
||||
|
|
||||
|
const span = document.createElement('span') |
||||
|
|
||||
|
let value = part.value |
||||
|
|
||||
|
if (part.removed) { |
||||
|
_$(span).addClass('desativado') |
||||
|
value += ' ' |
||||
|
} else if (part.added) { |
||||
|
_$(span).addClass('added') |
||||
|
} |
||||
|
|
||||
|
span.appendChild(document.createTextNode(value)) |
||||
|
_$(clone).append(span) |
||||
|
}) |
||||
|
} |
||||
|
}) |
||||
|
// textoVigente(item, true)
|
||||
|
} |
||||
|
|
||||
|
if (elv) { |
||||
|
try { |
||||
|
_$('html, body').animate( |
||||
|
{ |
||||
|
scrollTop: |
||||
|
_$(elv) |
||||
|
.parent() |
||||
|
.offset().top - 60 |
||||
|
}, |
||||
|
0 |
||||
|
) |
||||
|
} catch (err) { |
||||
|
// console.log(err)
|
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
function textoVigente (item, link) { |
||||
|
let elv = null |
||||
|
const ldpts = _$('.dptt') |
||||
|
for (let i = 0; i < ldpts.length; i++) { |
||||
|
if (_$(ldpts[i]).hasClass('displaynone')) continue |
||||
|
if (isElementInViewport(ldpts[i])) { |
||||
|
if (i + 1 < ldpts.length) elv = ldpts[i + 1] |
||||
|
else { |
||||
|
elv = ldpts[i] |
||||
|
} |
||||
|
break |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
_$('.cp .tipo-vigencias a').removeClass('active') |
||||
|
_$(item).addClass('active') |
||||
|
_$('.dptt.desativado').addClass('displaynone') |
||||
|
_$('.desativado > .dn').addClass('displaynone') |
||||
|
_$('.desativado > .dpt-img').addClass('displaynone') |
||||
|
_$('.nota-alteracao').removeClass('displaynone') |
||||
|
_$('.dptt.revogado').removeClass('displaynone') |
||||
|
if (!link) _$('.nota-alteracao').addClass('displaynone') |
||||
|
|
||||
|
if (elv) { |
||||
|
try { |
||||
|
_$('html, body').animate( |
||||
|
{ |
||||
|
scrollTop: |
||||
|
_$(elv) |
||||
|
.parent() |
||||
|
.offset().top - 60 |
||||
|
}, |
||||
|
0 |
||||
|
) |
||||
|
} catch (err) { |
||||
|
// console.log(err)
|
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
function textoVigenteSemRevogados (item, link) { |
||||
|
textoVigente(item, link) |
||||
|
_$('.dptt.revogado').addClass('displaynone') |
||||
|
} |
||||
|
|
||||
|
export default { |
||||
|
isElementInViewport, |
||||
|
textoMultiVigente, |
||||
|
textoVigente, |
||||
|
textoVigenteSemRevogados |
||||
|
} |
@ -0,0 +1,18 @@ |
|||||
|
// TODO: migrar compilacao para VueJs
|
||||
|
|
||||
|
import './scss/compilacao.scss' |
||||
|
|
||||
|
import compilacao from './js/old/compilacao' |
||||
|
import compilacaoView from './js/old/compilacao_view' |
||||
|
import compilacaoNotas from './js/old/compilacao_notas' |
||||
|
|
||||
|
import './js/old/compilacao_edit' |
||||
|
|
||||
|
_.forEach(_.merge(_.merge(compilacao, compilacaoNotas), compilacaoView), function (func, key) { |
||||
|
window[key] = func |
||||
|
}) |
||||
|
|
||||
|
$(document).ready(function () { |
||||
|
window.InitViewTAs() |
||||
|
window.onReadyNotasVides() |
||||
|
}) |
@ -0,0 +1,7 @@ |
|||||
|
/* |
||||
|
Pasta apps... |
||||
|
|
||||
|
- pensada para possuir módulos (entry_points) independentes |
||||
|
que se reflitam estruturalmente os apps do backend. |
||||
|
|
||||
|
*/ |
@ -0,0 +1 @@ |
|||||
|
import './scss/painel.scss' |
@ -0,0 +1,43 @@ |
|||||
|
|
||||
|
.painel-principal { |
||||
|
background: #1c1b1b; |
||||
|
font-family: Verdana; |
||||
|
font-size: x-large; |
||||
|
.text-title { |
||||
|
color: #4fa64d; |
||||
|
margin: 0.5rem; |
||||
|
font-weight: bold; |
||||
|
} |
||||
|
.text-subtitle { |
||||
|
color: #459170; |
||||
|
font-weight: bold; |
||||
|
} |
||||
|
.data-hora { |
||||
|
font-size: 180%; |
||||
|
} |
||||
|
|
||||
|
.text-value { |
||||
|
color: white; |
||||
|
} |
||||
|
|
||||
|
.logo-painel { |
||||
|
max-width: 100%; |
||||
|
} |
||||
|
.painels { |
||||
|
flex-wrap: wrap; |
||||
|
} |
||||
|
.painel{ |
||||
|
margin-top: 1rem; |
||||
|
table { |
||||
|
width: 100%; |
||||
|
} |
||||
|
h2 { |
||||
|
margin-bottom: 0.5rem; |
||||
|
} |
||||
|
#votacao, #oradores_list { |
||||
|
text-align: left; |
||||
|
display: inline-block; |
||||
|
margin-bottom: 1rem; |
||||
|
} |
||||
|
} |
||||
|
} |
@ -0,0 +1,115 @@ |
|||||
|
import './scss/parlamentar.scss' |
||||
|
import Vue from 'vue' |
||||
|
import { FormSelectPlugin } from 'bootstrap-vue' |
||||
|
import axios from 'axios' |
||||
|
|
||||
|
axios.defaults.xsrfCookieName = 'csrftoken' |
||||
|
axios.defaults.xsrfHeaderName = 'X-CSRFToken' |
||||
|
|
||||
|
Vue.use(FormSelectPlugin) |
||||
|
|
||||
|
const v = new Vue({ // eslint-disable-line
|
||||
|
delimiters: ['[[', ']]'], |
||||
|
el: '#app2', |
||||
|
data () { |
||||
|
return { |
||||
|
nome_pesquisa: '', |
||||
|
is_pesquisa: false, |
||||
|
legislatura_selecionada: '', |
||||
|
legislaturas: [], |
||||
|
parlamentares: [], |
||||
|
visible_parlamentares: [], |
||||
|
size_parlamentares: 0, |
||||
|
filter_ativo: false, |
||||
|
filter_titular: '' |
||||
|
} |
||||
|
}, |
||||
|
|
||||
|
watch: { |
||||
|
nome_pesquisa: function (val) { |
||||
|
this.debouncepesquisaParlamentar() |
||||
|
} |
||||
|
}, |
||||
|
|
||||
|
created () { |
||||
|
this.debouncepesquisaParlamentar = _.debounce(this.pesquisaParlamentar, 500) |
||||
|
}, |
||||
|
|
||||
|
methods: { |
||||
|
getParlamentares (event) { |
||||
|
if (this.legislatura_selecionada || this.legislatura_selecionada.toString() === '0') { |
||||
|
axios.get('/api/parlamentares/legislatura/' + this.legislatura_selecionada + '/parlamentares/?get_all=true') |
||||
|
.then(response => { |
||||
|
this.parlamentares = response.data |
||||
|
this.visible_parlamentares = this.parlamentares |
||||
|
this.size_parlamentares = this.visible_parlamentares.length |
||||
|
this.checkTitularAtivo() |
||||
|
}) |
||||
|
.catch(error => { |
||||
|
console.error('Ocorreu um erro ao obter os dados de parlamentares:' + error) |
||||
|
}) |
||||
|
} |
||||
|
}, |
||||
|
|
||||
|
pesquisaParlamentar (event) { |
||||
|
axios.get('/api/parlamentares/parlamentar/search_parlamentares/', { |
||||
|
params: { nome_parlamentar: this.nome_pesquisa } |
||||
|
}) |
||||
|
.then(response => { |
||||
|
this.parlamentares = response.data |
||||
|
this.visible_parlamentares = this.parlamentares |
||||
|
this.size_parlamentares = this.visible_parlamentares.length |
||||
|
}) |
||||
|
.catch(error => { |
||||
|
console.error('Erro ao procurar parlamentar:' + error) |
||||
|
}) |
||||
|
}, |
||||
|
|
||||
|
checkTitularAtivo (event) { |
||||
|
this.visible_parlamentares = this.parlamentares |
||||
|
if (this.filter_ativo) { |
||||
|
this.visible_parlamentares = this.visible_parlamentares.filter((v) => v.ativo) |
||||
|
} |
||||
|
if (this.filter_titular) { |
||||
|
this.visible_parlamentares = this.visible_parlamentares.filter((v) => v.titular === 'Sim') |
||||
|
} |
||||
|
this.size_parlamentares = this.visible_parlamentares.length |
||||
|
}, |
||||
|
|
||||
|
pesquisaChange (event) { |
||||
|
this.is_pesquisa = !this.is_pesquisa |
||||
|
this.filter_ativo = false |
||||
|
if (this.is_pesquisa) { |
||||
|
this.parlamentares = [] |
||||
|
} else { |
||||
|
this.getParlamentares() |
||||
|
} |
||||
|
} |
||||
|
}, |
||||
|
|
||||
|
mounted () { |
||||
|
axios.get('/api/parlamentares/legislatura/?get_all=true') |
||||
|
.then(response => { |
||||
|
this.legislaturas = response.data |
||||
|
|
||||
|
var currentYear = new Date().getFullYear() |
||||
|
|
||||
|
var reducer = (acc, legislatura) => { |
||||
|
var anoInicio = new Date(legislatura.data_inicio + ' 00:00').getFullYear() |
||||
|
var anoFim = new Date(legislatura.data_fim + ' 00:00').getFullYear() |
||||
|
if (currentYear >= anoInicio && currentYear <= anoFim) { |
||||
|
acc = legislatura.id |
||||
|
} |
||||
|
return acc |
||||
|
} |
||||
|
|
||||
|
this.legislatura_selecionada = this.legislaturas.reduce(reducer, '') |
||||
|
}) |
||||
|
.then(response => { |
||||
|
this.getParlamentares() |
||||
|
}) |
||||
|
.catch(err => { |
||||
|
console.error('Ocorreu um erro ao obter os dados de legislação: ' + err) |
||||
|
}) |
||||
|
} |
||||
|
}) |
@ -0,0 +1,164 @@ |
|||||
|
|
||||
|
window.refreshDatePicker = function () { |
||||
|
$.datepicker.setDefaults($.datepicker.regional['pt-BR']) |
||||
|
$('.dateinput').datepicker() |
||||
|
|
||||
|
const dateinput = document.querySelectorAll('.dateinput') |
||||
|
_.each(dateinput, function (input, index) { |
||||
|
input.setAttribute('autocomplete', 'off') |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
window.getCookie = function (name) { |
||||
|
var cookieValue = null |
||||
|
if (document.cookie && document.cookie !== '') { |
||||
|
var cookies = document.cookie.split(';') |
||||
|
for (var i = 0; i < cookies.length; i++) { |
||||
|
var cookie = $.trim(cookies[i]) |
||||
|
if (cookie.substring(0, name.length + 1) === name + '=') { |
||||
|
cookieValue = decodeURIComponent(cookie.substring(name.length + 1)) |
||||
|
break |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
return cookieValue |
||||
|
} |
||||
|
|
||||
|
window.autorModal = function () { |
||||
|
$(function () { |
||||
|
var dialog = $('#modal_autor').dialog({ |
||||
|
autoOpen: false, |
||||
|
modal: true, |
||||
|
width: 500, |
||||
|
height: 340, |
||||
|
show: { |
||||
|
effect: 'blind', |
||||
|
duration: 500 |
||||
|
}, |
||||
|
hide: { |
||||
|
effect: 'explode', |
||||
|
duration: 500 |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
$('#button-id-limpar').click(function () { |
||||
|
$('#nome_autor').text('') |
||||
|
|
||||
|
function clean_if_exists (fieldname) { |
||||
|
if ($(fieldname).length > 0) { |
||||
|
$(fieldname).val('') |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
clean_if_exists('#id_autor') |
||||
|
clean_if_exists('#id_autoria__autor') |
||||
|
clean_if_exists('#id_autorianorma__autor') |
||||
|
}) |
||||
|
|
||||
|
$('#button-id-pesquisar').click(function () { |
||||
|
$('#q').val('') |
||||
|
$('#div-resultado') |
||||
|
.children() |
||||
|
.remove() |
||||
|
$('#modal_autor').dialog('open') |
||||
|
$('#selecionar').attr('hidden', 'hidden') |
||||
|
}) |
||||
|
|
||||
|
$('#pesquisar').click(function () { |
||||
|
var name_in_query = $('#q').val() |
||||
|
// var q_0 = "q_0=nome__icontains"
|
||||
|
// var q_1 = name_in_query
|
||||
|
// query = q_1
|
||||
|
|
||||
|
$.get('/api/autor?q=' + name_in_query, function (data) { |
||||
|
$('#div-resultado') |
||||
|
.children() |
||||
|
.remove() |
||||
|
if (data.pagination.total_entries === 0) { |
||||
|
$('#selecionar').attr('hidden', 'hidden') |
||||
|
$('#div-resultado').html( |
||||
|
"<span class='alert'><strong>Nenhum resultado</strong></span>" |
||||
|
) |
||||
|
return |
||||
|
} |
||||
|
|
||||
|
var select = $( |
||||
|
'<select id="resultados" style="min-width: 90%; max-width:90%;" size="5"/>' |
||||
|
) |
||||
|
|
||||
|
data.results.forEach(function (item) { |
||||
|
select.append( |
||||
|
$('<option>') |
||||
|
.attr('value', item.value) |
||||
|
.text(item.text) |
||||
|
) |
||||
|
}) |
||||
|
|
||||
|
$('#div-resultado') |
||||
|
.append('<br/>') |
||||
|
.append(select) |
||||
|
$('#selecionar').removeAttr('hidden', 'hidden') |
||||
|
|
||||
|
if (data.pagination.total_pages > 1) { |
||||
|
$('#div-resultado').prepend( |
||||
|
'<span><br/>Mostrando 10 primeiros autores relativos a sua busca.<br/></span>' |
||||
|
) |
||||
|
} |
||||
|
|
||||
|
$('#selecionar').click(function () { |
||||
|
const res = $('#resultados option:selected') |
||||
|
const id = res.val() |
||||
|
const nome = res.text() |
||||
|
|
||||
|
$('#nome_autor').text(nome) |
||||
|
|
||||
|
// MateriaLegislativa pesquisa Autor via a tabela Autoria
|
||||
|
if ($('#id_autoria__autor').length) { |
||||
|
$('#id_autoria__autor').val(id) |
||||
|
} |
||||
|
// Protocolo pesquisa a própria tabela de Autor
|
||||
|
if ($('#id_autor').length) { |
||||
|
$('#id_autor').val(id) |
||||
|
} |
||||
|
// MateriaLegislativa pesquisa Autor via a tabela AutoriaNorma
|
||||
|
if ($('#id_autorianorma__autor').length) { |
||||
|
$('#id_autorianorma__autor').val(id) |
||||
|
} |
||||
|
|
||||
|
dialog.dialog('close') |
||||
|
}) |
||||
|
}) |
||||
|
}) |
||||
|
}) |
||||
|
|
||||
|
/* function get_nome_autor(fieldname) { |
||||
|
if ($(fieldname).length > 0) { // se campo existir
|
||||
|
if ($(fieldname).val() != "") { // e não for vazio
|
||||
|
var id = $(fieldname).val(); |
||||
|
$.get("/proposicao/get-nome-autor?id=" + id, function(data, status){ |
||||
|
$("#nome_autor").text(data.nome); |
||||
|
}); |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
get_nome_autor("#id_autor"); |
||||
|
get_nome_autor("#id_autoria__autor"); */ |
||||
|
} |
||||
|
|
||||
|
window.refreshMask = function () { |
||||
|
$('.telefone').mask('(99) 9999-9999', { placeholder: '(__) ____ -____' }) |
||||
|
$('.cpf').mask('000.000.000-00', { placeholder: '___.___.___-__' }) |
||||
|
$('.cep').mask('00000-000', { placeholder: '_____-___' }) |
||||
|
$('.rg').mask('0.000.000', { placeholder: '_.___.___' }) |
||||
|
$('.titulo_eleitor').mask('0000.0000.0000.0000', { |
||||
|
placeholder: '____.____.____.____' |
||||
|
}) |
||||
|
$('.dateinput').mask('00/00/0000', { placeholder: '__/__/____' }) |
||||
|
$('.hora, input[name=hora_inicio], input[name=hora_fim], input[name=hora]').mask('00:00', { |
||||
|
placeholder: 'hh:mm' |
||||
|
}) |
||||
|
$('.hora_hms').mask('00:00:00', { placeholder: 'hh:mm:ss' }) |
||||
|
$('.timeinput').mask('00:00:00', { placeholder: 'hh:mm:ss' }) |
||||
|
$('.cronometro').mask('00:00:00', { placeholder: 'hh:mm:ss' }) |
||||
|
} |
After Width: | Height: | Size: 329 B |
@ -0,0 +1,9 @@ |
|||||
|
div.jcrop-image.size-warning .jcrop-hline, |
||||
|
div.jcrop-image.size-warning .jcrop-vline { |
||||
|
border: 1px solid red; |
||||
|
background: none; |
||||
|
} |
||||
|
body.change-form .jcrop-holder + .help, |
||||
|
body.change-form .allow-fullsize + .help { clear: left; } |
||||
|
body.change-form .jcrop-holder { float:left; } |
||||
|
div.allow-fullsize { padding: 5px 0 0 10px; } |
@ -0,0 +1,167 @@ |
|||||
|
/* jquery.Jcrop.css v0.9.12 - MIT License */ |
||||
|
/* |
||||
|
The outer-most container in a typical Jcrop instance |
||||
|
If you are having difficulty with formatting related to styles |
||||
|
on a parent element, place any fixes here or in a like selector |
||||
|
|
||||
|
You can also style this element if you want to add a border, etc |
||||
|
A better method for styling can be seen below with .jcrop-light |
||||
|
(Add a class to the holder and style elements for that extended class) |
||||
|
*/ |
||||
|
.jcrop-holder { |
||||
|
direction: ltr; |
||||
|
text-align: left; |
||||
|
/* IE10 touch compatibility */ |
||||
|
-ms-touch-action: none; |
||||
|
} |
||||
|
/* Selection Border */ |
||||
|
.jcrop-vline, |
||||
|
.jcrop-hline { |
||||
|
background: #ffffff url("Jcrop.gif"); |
||||
|
font-size: 0; |
||||
|
position: absolute; |
||||
|
} |
||||
|
.jcrop-vline { |
||||
|
height: 100%; |
||||
|
width: 1px !important; |
||||
|
} |
||||
|
.jcrop-vline.right { |
||||
|
right: 0; |
||||
|
} |
||||
|
.jcrop-hline { |
||||
|
height: 1px !important; |
||||
|
width: 100%; |
||||
|
} |
||||
|
.jcrop-hline.bottom { |
||||
|
bottom: 0; |
||||
|
} |
||||
|
/* Invisible click targets */ |
||||
|
.jcrop-tracker { |
||||
|
height: 100%; |
||||
|
width: 100%; |
||||
|
/* "turn off" link highlight */ |
||||
|
-webkit-tap-highlight-color: transparent; |
||||
|
/* disable callout, image save panel */ |
||||
|
-webkit-touch-callout: none; |
||||
|
/* disable cut copy paste */ |
||||
|
-webkit-user-select: none; |
||||
|
} |
||||
|
/* Selection Handles */ |
||||
|
.jcrop-handle { |
||||
|
background-color: #333333; |
||||
|
border: 1px #eeeeee solid; |
||||
|
width: 7px; |
||||
|
height: 7px; |
||||
|
font-size: 1px; |
||||
|
} |
||||
|
.jcrop-handle.ord-n { |
||||
|
left: 50%; |
||||
|
margin-left: -4px; |
||||
|
margin-top: -4px; |
||||
|
top: 0; |
||||
|
} |
||||
|
.jcrop-handle.ord-s { |
||||
|
bottom: 0; |
||||
|
left: 50%; |
||||
|
margin-bottom: -4px; |
||||
|
margin-left: -4px; |
||||
|
} |
||||
|
.jcrop-handle.ord-e { |
||||
|
margin-right: -4px; |
||||
|
margin-top: -4px; |
||||
|
right: 0; |
||||
|
top: 50%; |
||||
|
} |
||||
|
.jcrop-handle.ord-w { |
||||
|
left: 0; |
||||
|
margin-left: -4px; |
||||
|
margin-top: -4px; |
||||
|
top: 50%; |
||||
|
} |
||||
|
.jcrop-handle.ord-nw { |
||||
|
left: 0; |
||||
|
margin-left: -4px; |
||||
|
margin-top: -4px; |
||||
|
top: 0; |
||||
|
} |
||||
|
.jcrop-handle.ord-ne { |
||||
|
margin-right: -4px; |
||||
|
margin-top: -4px; |
||||
|
right: 0; |
||||
|
top: 0; |
||||
|
} |
||||
|
.jcrop-handle.ord-se { |
||||
|
bottom: 0; |
||||
|
margin-bottom: -4px; |
||||
|
margin-right: -4px; |
||||
|
right: 0; |
||||
|
} |
||||
|
.jcrop-handle.ord-sw { |
||||
|
bottom: 0; |
||||
|
left: 0; |
||||
|
margin-bottom: -4px; |
||||
|
margin-left: -4px; |
||||
|
} |
||||
|
/* Dragbars */ |
||||
|
.jcrop-dragbar.ord-n, |
||||
|
.jcrop-dragbar.ord-s { |
||||
|
height: 7px; |
||||
|
width: 100%; |
||||
|
} |
||||
|
.jcrop-dragbar.ord-e, |
||||
|
.jcrop-dragbar.ord-w { |
||||
|
height: 100%; |
||||
|
width: 7px; |
||||
|
} |
||||
|
.jcrop-dragbar.ord-n { |
||||
|
margin-top: -4px; |
||||
|
} |
||||
|
.jcrop-dragbar.ord-s { |
||||
|
bottom: 0; |
||||
|
margin-bottom: -4px; |
||||
|
} |
||||
|
.jcrop-dragbar.ord-e { |
||||
|
margin-right: -4px; |
||||
|
right: 0; |
||||
|
} |
||||
|
.jcrop-dragbar.ord-w { |
||||
|
margin-left: -4px; |
||||
|
} |
||||
|
/* The "jcrop-light" class/extension */ |
||||
|
.jcrop-light .jcrop-vline, |
||||
|
.jcrop-light .jcrop-hline { |
||||
|
background: #ffffff; |
||||
|
filter: alpha(opacity=70) !important; |
||||
|
opacity: .70!important; |
||||
|
} |
||||
|
.jcrop-light .jcrop-handle { |
||||
|
-moz-border-radius: 3px; |
||||
|
-webkit-border-radius: 3px; |
||||
|
background-color: #000000; |
||||
|
border-color: #ffffff; |
||||
|
border-radius: 3px; |
||||
|
} |
||||
|
/* The "jcrop-dark" class/extension */ |
||||
|
.jcrop-dark .jcrop-vline, |
||||
|
.jcrop-dark .jcrop-hline { |
||||
|
background: #000000; |
||||
|
filter: alpha(opacity=70) !important; |
||||
|
opacity: 0.7 !important; |
||||
|
} |
||||
|
.jcrop-dark .jcrop-handle { |
||||
|
-moz-border-radius: 3px; |
||||
|
-webkit-border-radius: 3px; |
||||
|
background-color: #ffffff; |
||||
|
border-color: #000000; |
||||
|
border-radius: 3px; |
||||
|
} |
||||
|
/* Simple macro to turn off the antlines */ |
||||
|
.solid-line .jcrop-vline, |
||||
|
.solid-line .jcrop-hline { |
||||
|
background: #ffffff; |
||||
|
} |
||||
|
/* Fix for twitter bootstrap et al. */ |
||||
|
.jcrop-holder img, |
||||
|
img.jcrop-preview { |
||||
|
max-width: none; |
||||
|
} |
@ -0,0 +1,29 @@ |
|||||
|
/* jquery.Jcrop.min.css v0.9.12 (build:20130521) */ |
||||
|
.jcrop-holder{-ms-touch-action:none;direction:ltr;text-align:left;} |
||||
|
.jcrop-vline,.jcrop-hline{background:#FFF url(Jcrop.gif);font-size:0;position:absolute;} |
||||
|
.jcrop-vline{height:100%;width:1px!important;} |
||||
|
.jcrop-vline.right{right:0;} |
||||
|
.jcrop-hline{height:1px!important;width:100%;} |
||||
|
.jcrop-hline.bottom{bottom:0;} |
||||
|
.jcrop-tracker{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;height:100%;width:100%;} |
||||
|
.jcrop-handle{background-color:#333;border:1px #EEE solid;font-size:1px;height:7px;width:7px;} |
||||
|
.jcrop-handle.ord-n{left:50%;margin-left:-4px;margin-top:-4px;top:0;} |
||||
|
.jcrop-handle.ord-s{bottom:0;left:50%;margin-bottom:-4px;margin-left:-4px;} |
||||
|
.jcrop-handle.ord-e{margin-right:-4px;margin-top:-4px;right:0;top:50%;} |
||||
|
.jcrop-handle.ord-w{left:0;margin-left:-4px;margin-top:-4px;top:50%;} |
||||
|
.jcrop-handle.ord-nw{left:0;margin-left:-4px;margin-top:-4px;top:0;} |
||||
|
.jcrop-handle.ord-ne{margin-right:-4px;margin-top:-4px;right:0;top:0;} |
||||
|
.jcrop-handle.ord-se{bottom:0;margin-bottom:-4px;margin-right:-4px;right:0;} |
||||
|
.jcrop-handle.ord-sw{bottom:0;left:0;margin-bottom:-4px;margin-left:-4px;} |
||||
|
.jcrop-dragbar.ord-n,.jcrop-dragbar.ord-s{height:7px;width:100%;} |
||||
|
.jcrop-dragbar.ord-e,.jcrop-dragbar.ord-w{height:100%;width:7px;} |
||||
|
.jcrop-dragbar.ord-n{margin-top:-4px;} |
||||
|
.jcrop-dragbar.ord-s{bottom:0;margin-bottom:-4px;} |
||||
|
.jcrop-dragbar.ord-e{margin-right:-4px;right:0;} |
||||
|
.jcrop-dragbar.ord-w{margin-left:-4px;} |
||||
|
.jcrop-light .jcrop-vline,.jcrop-light .jcrop-hline{background:#FFF;filter:alpha(opacity=70)!important;opacity:.70!important;} |
||||
|
.jcrop-light .jcrop-handle{-moz-border-radius:3px;-webkit-border-radius:3px;background-color:#000;border-color:#FFF;border-radius:3px;} |
||||
|
.jcrop-dark .jcrop-vline,.jcrop-dark .jcrop-hline{background:#000;filter:alpha(opacity=70)!important;opacity:.7!important;} |
||||
|
.jcrop-dark .jcrop-handle{-moz-border-radius:3px;-webkit-border-radius:3px;background-color:#FFF;border-color:#000;border-radius:3px;} |
||||
|
.solid-line .jcrop-vline,.solid-line .jcrop-hline{background:#FFF;} |
||||
|
.jcrop-holder img,img.jcrop-preview{max-width:none;} |
@ -0,0 +1,202 @@ |
|||||
|
/* eslint-disable */ |
||||
|
var image_cropping = (function ($) { |
||||
|
var jcrop = {} |
||||
|
function init() { |
||||
|
$('input.image-ratio').each(function() { |
||||
|
var $this = $(this), |
||||
|
// find the image field corresponding to this cropping value
|
||||
|
// by stripping the last part of our id and appending the image field name
|
||||
|
field = $this.attr('name').replace($this.data('my-name'), $this.data('image-field')), |
||||
|
|
||||
|
// there should only be one file field we're referencing but in special cases
|
||||
|
// there can be several. Deal with it gracefully.
|
||||
|
$image_input = $('input.crop-thumb[data-field-name=' + field + ']:first') |
||||
|
|
||||
|
// skip this image if it's empty and hide the whole field, within admin and by itself
|
||||
|
if (!$image_input.length || $image_input.data('thumbnail-url') === undefined) { |
||||
|
$this.hide().parents('div.form-row:first').hide() |
||||
|
return |
||||
|
} |
||||
|
// check if the image field should be hidden
|
||||
|
if ($image_input.data('hide-field')) { |
||||
|
$image_input.hide().parents('div.form-row:first').hide() |
||||
|
} |
||||
|
|
||||
|
var image_id = $this.attr('id') + '-image', |
||||
|
org_width = $image_input.data('org-width'), |
||||
|
org_height = $image_input.data('org-height'), |
||||
|
min_width = $this.data('min-width'), |
||||
|
min_height = $this.data('min-height') |
||||
|
|
||||
|
var is_image_portrait = (org_height > org_width) |
||||
|
var is_select_portrait = (min_height > min_width) |
||||
|
|
||||
|
if ($this.data('adapt-rotation') === true) { |
||||
|
if (is_image_portrait != is_select_portrait) { |
||||
|
// cropping height/width need to be switched, picture is in portrait mode
|
||||
|
var x = min_width |
||||
|
min_width = min_height |
||||
|
min_height = x |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
var $image = $('<img>', { |
||||
|
'id': image_id, |
||||
|
'src': $image_input.data('thumbnail-url') |
||||
|
}) |
||||
|
|
||||
|
var options = { |
||||
|
minSize: [5, 5], |
||||
|
keySupport: false, |
||||
|
trueSize: [org_width, org_height], |
||||
|
onSelect: update_selection($this), |
||||
|
addClass: ($this.data('size-warning') && ((org_width < min_width) || (org_height < min_height))) ? 'size-warning jcrop-image': 'jcrop-image' |
||||
|
} |
||||
|
if ($this.data('ratio')) { |
||||
|
options['aspectRatio'] = $this.data('ratio') |
||||
|
} |
||||
|
if ($this.data('box_max_width')) { |
||||
|
options['boxWidth'] = $this.data('box_max_width') |
||||
|
} |
||||
|
if ($this.data('box_max_height')) { |
||||
|
options['boxHeight'] = $this.data('box_max_height') |
||||
|
} |
||||
|
|
||||
|
var cropping_disabled = false |
||||
|
if($this.val()[0] == "-"){ |
||||
|
cropping_disabled = true |
||||
|
$this.val($this.val().substr(1)) |
||||
|
} |
||||
|
|
||||
|
// is the image bigger than the minimal cropping values?
|
||||
|
// otherwise lock cropping area on full image
|
||||
|
var initial |
||||
|
if ($this.val()) { |
||||
|
initial = initial_cropping($this.val()) |
||||
|
} else { |
||||
|
|
||||
|
initial = max_cropping(min_width, min_height, org_width, org_height) |
||||
|
|
||||
|
// set cropfield to initial value
|
||||
|
$this.val(initial.join(',')) |
||||
|
} |
||||
|
|
||||
|
$.extend(options, {setSelect: initial}) |
||||
|
|
||||
|
// hide the input field, show image to crop instead
|
||||
|
$this.hide().after($image) |
||||
|
|
||||
|
$('#' + image_id).Jcrop(options, function(){jcrop[image_id]=this;}) |
||||
|
|
||||
|
if ($this.data('allow-fullsize') === true) { |
||||
|
if(cropping_disabled){ |
||||
|
jcrop[image_id].release() |
||||
|
$this.val('-'+$this.val()) |
||||
|
} |
||||
|
var label = 'allow-fullsize-'+image_id |
||||
|
var checked = cropping_disabled ? '' : ' checked="checked"' |
||||
|
var fullsize = $('<div class="field-box allow-fullsize">' + |
||||
|
'<input type="checkbox" id="'+label+'" name="'+label+'"'+checked+'></div>') |
||||
|
|
||||
|
if ($this.parent().find('.help').length) { |
||||
|
fullsize.insertBefore($this.parent().find('.help')) |
||||
|
} else { |
||||
|
fullsize.appendTo($this.parent()) |
||||
|
} |
||||
|
|
||||
|
$('#'+label).click(function(){ |
||||
|
if (cropping_disabled === true){ |
||||
|
$this.val($this.val().substr(1)) |
||||
|
jcrop[image_id].setSelect($this.val().split(',')) |
||||
|
cropping_disabled = false |
||||
|
} else { |
||||
|
$this.val('-'+$this.val()) |
||||
|
jcrop[image_id].release() |
||||
|
cropping_disabled = true |
||||
|
} |
||||
|
}) |
||||
|
$this.parent().find('.jcrop-tracker').mousedown(function(){ |
||||
|
if (cropping_disabled){ |
||||
|
$('#'+label).attr('checked','checked') |
||||
|
cropping_disabled = false |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
|
||||
|
function max_cropping (width, height, image_width, image_height) { |
||||
|
var ratio = width/height |
||||
|
var offset |
||||
|
|
||||
|
if (image_width < image_height * ratio) { |
||||
|
// width fits fully, height needs to be cropped
|
||||
|
offset = Math.round((image_height-(image_width/ratio))/2) |
||||
|
return [0, offset, image_width, image_height - offset] |
||||
|
} |
||||
|
// height fits fully, width needs to be cropped
|
||||
|
offset = Math.round((image_width-(image_height * ratio))/2) |
||||
|
return [offset, 0, image_width - offset, image_height] |
||||
|
} |
||||
|
|
||||
|
function initial_cropping (val) { |
||||
|
if (val === '') { return; } |
||||
|
var s = val.split(',') |
||||
|
return [ |
||||
|
parseInt(s[0], 10), |
||||
|
parseInt(s[1], 10), |
||||
|
parseInt(s[2], 10), |
||||
|
parseInt(s[3], 10) |
||||
|
] |
||||
|
} |
||||
|
|
||||
|
function _update_selection (sel, $crop_field) { |
||||
|
if ($crop_field.data('size-warning')) { |
||||
|
crop_indication(sel, $crop_field) |
||||
|
} |
||||
|
$crop_field.val(new Array( |
||||
|
Math.round(sel.x), |
||||
|
Math.round(sel.y), |
||||
|
Math.round(sel.x2), |
||||
|
Math.round(sel.y2) |
||||
|
).join(',')) |
||||
|
} |
||||
|
|
||||
|
function update_selection ($crop_field) { |
||||
|
return function(sel) { _update_selection(sel, $crop_field); } |
||||
|
} |
||||
|
|
||||
|
function crop_indication (sel, $crop_field) { |
||||
|
// indicate if cropped area gets smaller than the specified minimal cropping
|
||||
|
var $jcrop_holder = $crop_field.siblings('.jcrop-holder') |
||||
|
var min_width = $crop_field.data("min-width") |
||||
|
var min_height = $crop_field.data("min-height") |
||||
|
if ((sel.w < min_width) || (sel.h < min_height)) { |
||||
|
$jcrop_holder.addClass('size-warning') |
||||
|
} else { |
||||
|
$jcrop_holder.removeClass('size-warning') |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
return { |
||||
|
init: init, |
||||
|
jcrop: jcrop |
||||
|
} |
||||
|
|
||||
|
})(jQuery) |
||||
|
window.image_cropping = image_cropping |
||||
|
jQuery(function() { |
||||
|
/*var image_cropping_jquery_url = jQuery('.image-ratio:first').data('jquery-url') |
||||
|
if (image_cropping_jquery_url == "None") { |
||||
|
// JQUERY_URL is set to `none`. We therefore use the existing version of
|
||||
|
// jQuery and leave it otherwise untouched.
|
||||
|
jQ = jQuery |
||||
|
} else { |
||||
|
// JQUERY_URL is specified. Image Cropping's jQuery is included in no conflict mode,
|
||||
|
jQ = jQuery.noConflict(true) |
||||
|
} |
||||
|
jQ(function() {image_cropping.init();});*/ |
||||
|
$(function() { |
||||
|
image_cropping.init() |
||||
|
}) |
||||
|
}) |
@ -0,0 +1,6 @@ |
|||||
|
/* eslint-disable */ |
||||
|
import './css/jquery.Jcrop.min.css' |
||||
|
import './css/image_cropping.css' |
||||
|
|
||||
|
import './js/jquery.Jcrop.min' |
||||
|
import './image_cropping' |
@ -0,0 +1,23 @@ |
|||||
|
/* eslint-disable */ |
||||
|
/** |
||||
|
* jquery.Jcrop.min.js v0.9.12 (build:20130202) |
||||
|
* jQuery Image Cropping Plugin - released under MIT License |
||||
|
* Copyright (c) 2008-2013 Tapmodo Interactive LLC |
||||
|
* https://github.com/tapmodo/Jcrop
|
||||
|
*/ |
||||
|
(function(a){a.Jcrop=function(b,c){function i(a){return Math.round(a)+"px"}function j(a){return d.baseClass+"-"+a}function k(){return a.fx.step.hasOwnProperty("backgroundColor")}function l(b){var c=a(b).offset();return[c.left,c.top]}function m(a){return[a.pageX-e[0],a.pageY-e[1]]}function n(b){typeof b!="object"&&(b={}),d=a.extend(d,b),a.each(["onChange","onSelect","onRelease","onDblClick"],function(a,b){typeof d[b]!="function"&&(d[b]=function(){})})}function o(a,b,c){e=l(D),bc.setCursor(a==="move"?a:a+"-resize");if(a==="move")return bc.activateHandlers(q(b),v,c);var d=_.getFixed(),f=r(a),g=_.getCorner(r(f));_.setPressed(_.getCorner(f)),_.setCurrent(g),bc.activateHandlers(p(a,d),v,c)}function p(a,b){return function(c){if(!d.aspectRatio)switch(a){case"e":c[1]=b.y2;break;case"w":c[1]=b.y2;break;case"n":c[0]=b.x2;break;case"s":c[0]=b.x2}else switch(a){case"e":c[1]=b.y+1;break;case"w":c[1]=b.y+1;break;case"n":c[0]=b.x+1;break;case"s":c[0]=b.x+1}_.setCurrent(c),bb.update()}}function q(a){var b=a;return bd.watchKeys |
||||
|
(),function(a){_.moveOffset([a[0]-b[0],a[1]-b[1]]),b=a,bb.update()}}function r(a){switch(a){case"n":return"sw";case"s":return"nw";case"e":return"nw";case"w":return"ne";case"ne":return"sw";case"nw":return"se";case"se":return"nw";case"sw":return"ne"}}function s(a){return function(b){return d.disabled?!1:a==="move"&&!d.allowMove?!1:(e=l(D),W=!0,o(a,m(b)),b.stopPropagation(),b.preventDefault(),!1)}}function t(a,b,c){var d=a.width(),e=a.height();d>b&&b>0&&(d=b,e=b/a.width()*a.height()),e>c&&c>0&&(e=c,d=c/a.height()*a.width()),T=a.width()/d,U=a.height()/e,a.width(d).height(e)}function u(a){return{x:a.x*T,y:a.y*U,x2:a.x2*T,y2:a.y2*U,w:a.w*T,h:a.h*U}}function v(a){var b=_.getFixed();b.w>d.minSelect[0]&&b.h>d.minSelect[1]?(bb.enableHandles(),bb.done()):bb.release(),bc.setCursor(d.allowSelect?"crosshair":"default")}function w(a){if(d.disabled)return!1;if(!d.allowSelect)return!1;W=!0,e=l(D),bb.disableHandles(),bc.setCursor("crosshair");var b=m(a);return _.setPressed(b),bb.update(),bc.activateHandlers(x,v,a.type.substring |
||||
|
(0,5)==="touch"),bd.watchKeys(),a.stopPropagation(),a.preventDefault(),!1}function x(a){_.setCurrent(a),bb.update()}function y(){var b=a("<div></div>").addClass(j("tracker"));return g&&b.css({opacity:0,backgroundColor:"white"}),b}function be(a){G.removeClass().addClass(j("holder")).addClass(a)}function bf(a,b){function t(){window.setTimeout(u,l)}var c=a[0]/T,e=a[1]/U,f=a[2]/T,g=a[3]/U;if(X)return;var h=_.flipCoords(c,e,f,g),i=_.getFixed(),j=[i.x,i.y,i.x2,i.y2],k=j,l=d.animationDelay,m=h[0]-j[0],n=h[1]-j[1],o=h[2]-j[2],p=h[3]-j[3],q=0,r=d.swingSpeed;c=k[0],e=k[1],f=k[2],g=k[3],bb.animMode(!0);var s,u=function(){return function(){q+=(100-q)/r,k[0]=Math.round(c+q/100*m),k[1]=Math.round(e+q/100*n),k[2]=Math.round(f+q/100*o),k[3]=Math.round(g+q/100*p),q>=99.8&&(q=100),q<100?(bh(k),t()):(bb.done(),bb.animMode(!1),typeof b=="function"&&b.call(bs))}}();t()}function bg(a){bh([a[0]/T,a[1]/U,a[2]/T,a[3]/U]),d.onSelect.call(bs,u(_.getFixed())),bb.enableHandles()}function bh(a){_.setPressed([a[0],a[1]]),_.setCurrent([a[2], |
||||
|
a[3]]),bb.update()}function bi(){return u(_.getFixed())}function bj(){return _.getFixed()}function bk(a){n(a),br()}function bl(){d.disabled=!0,bb.disableHandles(),bb.setCursor("default"),bc.setCursor("default")}function bm(){d.disabled=!1,br()}function bn(){bb.done(),bc.activateHandlers(null,null)}function bo(){G.remove(),A.show(),A.css("visibility","visible"),a(b).removeData("Jcrop")}function bp(a,b){bb.release(),bl();var c=new Image;c.onload=function(){var e=c.width,f=c.height,g=d.boxWidth,h=d.boxHeight;D.width(e).height(f),D.attr("src",a),H.attr("src",a),t(D,g,h),E=D.width(),F=D.height(),H.width(E).height(F),M.width(E+L*2).height(F+L*2),G.width(E).height(F),ba.resize(E,F),bm(),typeof b=="function"&&b.call(bs)},c.src=a}function bq(a,b,c){var e=b||d.bgColor;d.bgFade&&k()&&d.fadeTime&&!c?a.animate({backgroundColor:e},{queue:!1,duration:d.fadeTime}):a.css("backgroundColor",e)}function br(a){d.allowResize?a?bb.enableOnly():bb.enableHandles():bb.disableHandles(),bc.setCursor(d.allowSelect?"crosshair":"default"),bb |
||||
|
.setCursor(d.allowMove?"move":"default"),d.hasOwnProperty("trueSize")&&(T=d.trueSize[0]/E,U=d.trueSize[1]/F),d.hasOwnProperty("setSelect")&&(bg(d.setSelect),bb.done(),delete d.setSelect),ba.refresh(),d.bgColor!=N&&(bq(d.shade?ba.getShades():G,d.shade?d.shadeColor||d.bgColor:d.bgColor),N=d.bgColor),O!=d.bgOpacity&&(O=d.bgOpacity,d.shade?ba.refresh():bb.setBgOpacity(O)),P=d.maxSize[0]||0,Q=d.maxSize[1]||0,R=d.minSize[0]||0,S=d.minSize[1]||0,d.hasOwnProperty("outerImage")&&(D.attr("src",d.outerImage),delete d.outerImage),bb.refresh()}var d=a.extend({},a.Jcrop.defaults),e,f=navigator.userAgent.toLowerCase(),g=/msie/.test(f),h=/msie [1-6]\./.test(f);typeof b!="object"&&(b=a(b)[0]),typeof c!="object"&&(c={}),n(c);var z={border:"none",visibility:"visible",margin:0,padding:0,position:"absolute",top:0,left:0},A=a(b),B=!0;if(b.tagName=="IMG"){if(A[0].width!=0&&A[0].height!=0)A.width(A[0].width),A.height(A[0].height);else{var C=new Image;C.src=A[0].src,A.width(C.width),A.height(C.height)}var D=A.clone().removeAttr("id"). |
||||
|
css(z).show();D.width(A.width()),D.height(A.height()),A.after(D).hide()}else D=A.css(z).show(),B=!1,d.shade===null&&(d.shade=!0);t(D,d.boxWidth,d.boxHeight);var E=D.width(),F=D.height(),G=a("<div />").width(E).height(F).addClass(j("holder")).css({position:"relative",backgroundColor:d.bgColor}).insertAfter(A).append(D);d.addClass&&G.addClass(d.addClass);var H=a("<div />"),I=a("<div />").width("100%").height("100%").css({zIndex:310,position:"absolute",overflow:"hidden"}),J=a("<div />").width("100%").height("100%").css("zIndex",320),K=a("<div />").css({position:"absolute",zIndex:600}).dblclick(function(){var a=_.getFixed();d.onDblClick.call(bs,a)}).insertBefore(D).append(I,J);B&&(H=a("<img />").attr("src",D.attr("src")).css(z).width(E).height(F),I.append(H)),h&&K.css({overflowY:"hidden"});var L=d.boundary,M=y().width(E+L*2).height(F+L*2).css({position:"absolute",top:i(-L),left:i(-L),zIndex:290}).mousedown(w),N=d.bgColor,O=d.bgOpacity,P,Q,R,S,T,U,V=!0,W,X,Y;e=l(D);var Z=function(){function a(){var a={},b=["touchstart" |
||||
|
,"touchmove","touchend"],c=document.createElement("div"),d;try{for(d=0;d<b.length;d++){var e=b[d];e="on"+e;var f=e in c;f||(c.setAttribute(e,"return;"),f=typeof c[e]=="function"),a[b[d]]=f}return a.touchstart&&a.touchend&&a.touchmove}catch(g){return!1}}function b(){return d.touchSupport===!0||d.touchSupport===!1?d.touchSupport:a()}return{createDragger:function(a){return function(b){return d.disabled?!1:a==="move"&&!d.allowMove?!1:(e=l(D),W=!0,o(a,m(Z.cfilter(b)),!0),b.stopPropagation(),b.preventDefault(),!1)}},newSelection:function(a){return w(Z.cfilter(a))},cfilter:function(a){return a.pageX=a.originalEvent.changedTouches[0].pageX,a.pageY=a.originalEvent.changedTouches[0].pageY,a},isSupported:a,support:b()}}(),_=function(){function h(d){d=n(d),c=a=d[0],e=b=d[1]}function i(a){a=n(a),f=a[0]-c,g=a[1]-e,c=a[0],e=a[1]}function j(){return[f,g]}function k(d){var f=d[0],g=d[1];0>a+f&&(f-=f+a),0>b+g&&(g-=g+b),F<e+g&&(g+=F-(e+g)),E<c+f&&(f+=E-(c+f)),a+=f,c+=f,b+=g,e+=g}function l(a){var b=m();switch(a){case"ne":return[ |
||||
|
b.x2,b.y];case"nw":return[b.x,b.y];case"se":return[b.x2,b.y2];case"sw":return[b.x,b.y2]}}function m(){if(!d.aspectRatio)return p();var f=d.aspectRatio,g=d.minSize[0]/T,h=d.maxSize[0]/T,i=d.maxSize[1]/U,j=c-a,k=e-b,l=Math.abs(j),m=Math.abs(k),n=l/m,r,s,t,u;return h===0&&(h=E*10),i===0&&(i=F*10),n<f?(s=e,t=m*f,r=j<0?a-t:t+a,r<0?(r=0,u=Math.abs((r-a)/f),s=k<0?b-u:u+b):r>E&&(r=E,u=Math.abs((r-a)/f),s=k<0?b-u:u+b)):(r=c,u=l/f,s=k<0?b-u:b+u,s<0?(s=0,t=Math.abs((s-b)*f),r=j<0?a-t:t+a):s>F&&(s=F,t=Math.abs(s-b)*f,r=j<0?a-t:t+a)),r>a?(r-a<g?r=a+g:r-a>h&&(r=a+h),s>b?s=b+(r-a)/f:s=b-(r-a)/f):r<a&&(a-r<g?r=a-g:a-r>h&&(r=a-h),s>b?s=b+(a-r)/f:s=b-(a-r)/f),r<0?(a-=r,r=0):r>E&&(a-=r-E,r=E),s<0?(b-=s,s=0):s>F&&(b-=s-F,s=F),q(o(a,b,r,s))}function n(a){return a[0]<0&&(a[0]=0),a[1]<0&&(a[1]=0),a[0]>E&&(a[0]=E),a[1]>F&&(a[1]=F),[Math.round(a[0]),Math.round(a[1])]}function o(a,b,c,d){var e=a,f=c,g=b,h=d;return c<a&&(e=c,f=a),d<b&&(g=d,h=b),[e,g,f,h]}function p(){var d=c-a,f=e-b,g;return P&&Math.abs(d)>P&&(c=d>0?a+P:a-P),Q&&Math.abs |
||||
|
(f)>Q&&(e=f>0?b+Q:b-Q),S/U&&Math.abs(f)<S/U&&(e=f>0?b+S/U:b-S/U),R/T&&Math.abs(d)<R/T&&(c=d>0?a+R/T:a-R/T),a<0&&(c-=a,a-=a),b<0&&(e-=b,b-=b),c<0&&(a-=c,c-=c),e<0&&(b-=e,e-=e),c>E&&(g=c-E,a-=g,c-=g),e>F&&(g=e-F,b-=g,e-=g),a>E&&(g=a-F,e-=g,b-=g),b>F&&(g=b-F,e-=g,b-=g),q(o(a,b,c,e))}function q(a){return{x:a[0],y:a[1],x2:a[2],y2:a[3],w:a[2]-a[0],h:a[3]-a[1]}}var a=0,b=0,c=0,e=0,f,g;return{flipCoords:o,setPressed:h,setCurrent:i,getOffset:j,moveOffset:k,getCorner:l,getFixed:m}}(),ba=function(){function f(a,b){e.left.css({height:i(b)}),e.right.css({height:i(b)})}function g(){return h(_.getFixed())}function h(a){e.top.css({left:i(a.x),width:i(a.w),height:i(a.y)}),e.bottom.css({top:i(a.y2),left:i(a.x),width:i(a.w),height:i(F-a.y2)}),e.right.css({left:i(a.x2),width:i(E-a.x2)}),e.left.css({width:i(a.x)})}function j(){return a("<div />").css({position:"absolute",backgroundColor:d.shadeColor||d.bgColor}).appendTo(c)}function k(){b||(b=!0,c.insertBefore(D),g(),bb.setBgOpacity(1,0,1),H.hide(),l(d.shadeColor||d.bgColor,1),bb. |
||||
|
isAwake()?n(d.bgOpacity,1):n(1,1))}function l(a,b){bq(p(),a,b)}function m(){b&&(c.remove(),H.show(),b=!1,bb.isAwake()?bb.setBgOpacity(d.bgOpacity,1,1):(bb.setBgOpacity(1,1,1),bb.disableHandles()),bq(G,0,1))}function n(a,e){b&&(d.bgFade&&!e?c.animate({opacity:1-a},{queue:!1,duration:d.fadeTime}):c.css({opacity:1-a}))}function o(){d.shade?k():m(),bb.isAwake()&&n(d.bgOpacity)}function p(){return c.children()}var b=!1,c=a("<div />").css({position:"absolute",zIndex:240,opacity:0}),e={top:j(),left:j().height(F),right:j().height(F),bottom:j()};return{update:g,updateRaw:h,getShades:p,setBgColor:l,enable:k,disable:m,resize:f,refresh:o,opacity:n}}(),bb=function(){function k(b){var c=a("<div />").css({position:"absolute",opacity:d.borderOpacity}).addClass(j(b));return I.append(c),c}function l(b,c){var d=a("<div />").mousedown(s(b)).css({cursor:b+"-resize",position:"absolute",zIndex:c}).addClass("ord-"+b);return Z.support&&d.bind("touchstart.jcrop",Z.createDragger(b)),J.append(d),d}function m(a){var b=d.handleSize,e=l(a,c++ |
||||
|
).css({opacity:d.handleOpacity}).addClass(j("handle"));return b&&e.width(b).height(b),e}function n(a){return l(a,c++).addClass("jcrop-dragbar")}function o(a){var b;for(b=0;b<a.length;b++)g[a[b]]=n(a[b])}function p(a){var b,c;for(c=0;c<a.length;c++){switch(a[c]){case"n":b="hline";break;case"s":b="hline bottom";break;case"e":b="vline right";break;case"w":b="vline"}e[a[c]]=k(b)}}function q(a){var b;for(b=0;b<a.length;b++)f[a[b]]=m(a[b])}function r(a,b){d.shade||H.css({top:i(-b),left:i(-a)}),K.css({top:i(b),left:i(a)})}function t(a,b){K.width(Math.round(a)).height(Math.round(b))}function v(){var a=_.getFixed();_.setPressed([a.x,a.y]),_.setCurrent([a.x2,a.y2]),w()}function w(a){if(b)return x(a)}function x(a){var c=_.getFixed();t(c.w,c.h),r(c.x,c.y),d.shade&&ba.updateRaw(c),b||A(),a?d.onSelect.call(bs,u(c)):d.onChange.call(bs,u(c))}function z(a,c,e){if(!b&&!c)return;d.bgFade&&!e?D.animate({opacity:a},{queue:!1,duration:d.fadeTime}):D.css("opacity",a)}function A(){K.show(),d.shade?ba.opacity(O):z(O,!0),b=!0}function B |
||||
|
(){F(),K.hide(),d.shade?ba.opacity(1):z(1),b=!1,d.onRelease.call(bs)}function C(){h&&J.show()}function E(){h=!0;if(d.allowResize)return J.show(),!0}function F(){h=!1,J.hide()}function G(a){a?(X=!0,F()):(X=!1,E())}function L(){G(!1),v()}var b,c=370,e={},f={},g={},h=!1;d.dragEdges&&a.isArray(d.createDragbars)&&o(d.createDragbars),a.isArray(d.createHandles)&&q(d.createHandles),d.drawBorders&&a.isArray(d.createBorders)&&p(d.createBorders),a(document).bind("touchstart.jcrop-ios",function(b){a(b.currentTarget).hasClass("jcrop-tracker")&&b.stopPropagation()});var M=y().mousedown(s("move")).css({cursor:"move",position:"absolute",zIndex:360});return Z.support&&M.bind("touchstart.jcrop",Z.createDragger("move")),I.append(M),F(),{updateVisible:w,update:x,release:B,refresh:v,isAwake:function(){return b},setCursor:function(a){M.css("cursor",a)},enableHandles:E,enableOnly:function(){h=!0},showHandles:C,disableHandles:F,animMode:G,setBgOpacity:z,done:L}}(),bc=function(){function f(b){M.css({zIndex:450}),b?a(document).bind("touchmove.jcrop" |
||||
|
,k).bind("touchend.jcrop",l):e&&a(document).bind("mousemove.jcrop",h).bind("mouseup.jcrop",i)}function g(){M.css({zIndex:290}),a(document).unbind(".jcrop")}function h(a){return b(m(a)),!1}function i(a){return a.preventDefault(),a.stopPropagation(),W&&(W=!1,c(m(a)),bb.isAwake()&&d.onSelect.call(bs,u(_.getFixed())),g(),b=function(){},c=function(){}),!1}function j(a,d,e){return W=!0,b=a,c=d,f(e),!1}function k(a){return b(m(Z.cfilter(a))),!1}function l(a){return i(Z.cfilter(a))}function n(a){M.css("cursor",a)}var b=function(){},c=function(){},e=d.trackDocument;return e||M.mousemove(h).mouseup(i).mouseout(i),D.before(M),{activateHandlers:j,setCursor:n}}(),bd=function(){function e(){d.keySupport&&(b.show(),b.focus())}function f(a){b.hide()}function g(a,b,c){d.allowMove&&(_.moveOffset([b,c]),bb.updateVisible(!0)),a.preventDefault(),a.stopPropagation()}function i(a){if(a.ctrlKey||a.metaKey)return!0;Y=a.shiftKey?!0:!1;var b=Y?10:1;switch(a.keyCode){case 37:g(a,-b,0);break;case 39:g(a,b,0);break;case 38:g(a,0,-b);break; |
||||
|
case 40:g(a,0,b);break;case 27:d.allowSelect&&bb.release();break;case 9:return!0}return!1}var b=a('<input type="radio" />').css({position:"fixed",left:"-120px",width:"12px"}).addClass("jcrop-keymgr"),c=a("<div />").css({position:"absolute",overflow:"hidden"}).append(b);return d.keySupport&&(b.keydown(i).blur(f),h||!d.fixedSupport?(b.css({position:"absolute",left:"-20px"}),c.append(b).insertBefore(D)):b.insertBefore(D)),{watchKeys:e}}();Z.support&&M.bind("touchstart.jcrop",Z.newSelection),J.hide(),br(!0);var bs={setImage:bp,animateTo:bf,setSelect:bg,setOptions:bk,tellSelect:bi,tellScaled:bj,setClass:be,disable:bl,enable:bm,cancel:bn,release:bb.release,destroy:bo,focus:bd.watchKeys,getBounds:function(){return[E*T,F*U]},getWidgetSize:function(){return[E,F]},getScaleFactor:function(){return[T,U]},getOptions:function(){return d},ui:{holder:G,selection:K}};return g&&G.bind("selectstart",function(){return!1}),A.data("Jcrop",bs),bs},a.fn.Jcrop=function(b,c){var d;return this.each(function(){if(a(this).data("Jcrop")){if( |
||||
|
b==="api")return a(this).data("Jcrop");a(this).data("Jcrop").setOptions(b)}else this.tagName=="IMG"?a.Jcrop.Loader(this,function(){a(this).css({display:"block",visibility:"hidden"}),d=a.Jcrop(this,b),a.isFunction(c)&&c.call(d)}):(a(this).css({display:"block",visibility:"hidden"}),d=a.Jcrop(this,b),a.isFunction(c)&&c.call(d))}),this},a.Jcrop.Loader=function(b,c,d){function g(){f.complete?(e.unbind(".jcloader"),a.isFunction(c)&&c.call(f)):window.setTimeout(g,50)}var e=a(b),f=e[0];e.bind("load.jcloader",g).bind("error.jcloader",function(b){e.unbind(".jcloader"),a.isFunction(d)&&d.call(f)}),f.complete&&a.isFunction(c)&&(e.unbind(".jcloader"),c.call(f))},a.Jcrop.defaults={allowSelect:!0,allowMove:!0,allowResize:!0,trackDocument:!0,baseClass:"jcrop",addClass:null,bgColor:"black",bgOpacity:.6,bgFade:!1,borderOpacity:.4,handleOpacity:.5,handleSize:null,aspectRatio:0,keySupport:!0,createHandles:["n","s","e","w","nw","ne","se","sw"],createDragbars:["n","s","e","w"],createBorders:["n","s","e","w"],drawBorders:!0,dragEdges |
||||
|
:!0,fixedSupport:!0,touchSupport:null,shade:null,boxWidth:0,boxHeight:0,boundary:2,fadeTime:400,animationDelay:20,swingSpeed:3,minSelect:[0,0],maxSize:[0,0],minSize:[0,0],onChange:function(){},onSelect:function(){},onDblClick:function(){},onRelease:function(){}}})(jQuery); |
@ -0,0 +1,716 @@ |
|||||
|
/* eslint-disable */ |
||||
|
/*! |
||||
|
* jQuery Color Animations v2.0pre |
||||
|
* http://jquery.org/
|
||||
|
* |
||||
|
* Copyright 2011 John Resig |
||||
|
* Dual licensed under the MIT or GPL Version 2 licenses. |
||||
|
* http://jquery.org/license
|
||||
|
*/ |
||||
|
|
||||
|
(function (jQuery, undefined) { |
||||
|
var stepHooks = 'backgroundColor borderBottomColor borderLeftColor borderRightColor borderTopColor color outlineColor'.split(' ') |
||||
|
|
||||
|
// plusequals test for += 100 -= 100
|
||||
|
|
||||
|
var rplusequals = /^([\-+])=\s*(\d+\.?\d*)/ |
||||
|
|
||||
|
// a set of RE's that can match strings and generate color tuples.
|
||||
|
|
||||
|
var stringParsers = [{ |
||||
|
re: /rgba?\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/, |
||||
|
parse: function (execResult) { |
||||
|
return [ |
||||
|
execResult[ 1 ], |
||||
|
execResult[ 2 ], |
||||
|
execResult[ 3 ], |
||||
|
execResult[ 4 ] |
||||
|
] |
||||
|
} |
||||
|
}, { |
||||
|
re: /rgba?\(\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/, |
||||
|
parse: function (execResult) { |
||||
|
return [ |
||||
|
2.55 * execResult[1], |
||||
|
2.55 * execResult[2], |
||||
|
2.55 * execResult[3], |
||||
|
execResult[ 4 ] |
||||
|
] |
||||
|
} |
||||
|
}, { |
||||
|
re: /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/, |
||||
|
parse: function (execResult) { |
||||
|
return [ |
||||
|
parseInt(execResult[ 1 ], 16), |
||||
|
parseInt(execResult[ 2 ], 16), |
||||
|
parseInt(execResult[ 3 ], 16) |
||||
|
] |
||||
|
} |
||||
|
}, { |
||||
|
re: /#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/, |
||||
|
parse: function (execResult) { |
||||
|
return [ |
||||
|
parseInt(execResult[ 1 ] + execResult[ 1 ], 16), |
||||
|
parseInt(execResult[ 2 ] + execResult[ 2 ], 16), |
||||
|
parseInt(execResult[ 3 ] + execResult[ 3 ], 16) |
||||
|
] |
||||
|
} |
||||
|
}, { |
||||
|
re: /hsla?\(\s*(\d+(?:\.\d+)?)\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d+(?:\.\d+)?)\s*)?\)/, |
||||
|
space: 'hsla', |
||||
|
parse: function (execResult) { |
||||
|
return [ |
||||
|
execResult[1], |
||||
|
execResult[2] / 100, |
||||
|
execResult[3] / 100, |
||||
|
execResult[4] |
||||
|
] |
||||
|
} |
||||
|
}] |
||||
|
|
||||
|
// jQuery.Color( )
|
||||
|
|
||||
|
var color = jQuery.Color = function (color, green, blue, alpha) { |
||||
|
return new jQuery.Color.fn.parse(color, green, blue, alpha) |
||||
|
} |
||||
|
|
||||
|
var spaces = { |
||||
|
rgba: { |
||||
|
cache: '_rgba', |
||||
|
props: { |
||||
|
red: { |
||||
|
idx: 0, |
||||
|
type: 'byte', |
||||
|
empty: true |
||||
|
}, |
||||
|
green: { |
||||
|
idx: 1, |
||||
|
type: 'byte', |
||||
|
empty: true |
||||
|
}, |
||||
|
blue: { |
||||
|
idx: 2, |
||||
|
type: 'byte', |
||||
|
empty: true |
||||
|
}, |
||||
|
alpha: { |
||||
|
idx: 3, |
||||
|
type: 'percent', |
||||
|
def: 1 |
||||
|
} |
||||
|
} |
||||
|
}, |
||||
|
hsla: { |
||||
|
cache: '_hsla', |
||||
|
props: { |
||||
|
hue: { |
||||
|
idx: 0, |
||||
|
type: 'degrees', |
||||
|
empty: true |
||||
|
}, |
||||
|
saturation: { |
||||
|
idx: 1, |
||||
|
type: 'percent', |
||||
|
empty: true |
||||
|
}, |
||||
|
lightness: { |
||||
|
idx: 2, |
||||
|
type: 'percent', |
||||
|
empty: true |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
var propTypes = { |
||||
|
'byte': { |
||||
|
floor: true, |
||||
|
min: 0, |
||||
|
max: 255 |
||||
|
}, |
||||
|
'percent': { |
||||
|
min: 0, |
||||
|
max: 1 |
||||
|
}, |
||||
|
'degrees': { |
||||
|
mod: 360, |
||||
|
floor: true |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
var rgbaspace = spaces.rgba.props |
||||
|
|
||||
|
var support = color.support = {} |
||||
|
|
||||
|
// colors = jQuery.Color.names
|
||||
|
|
||||
|
var colors |
||||
|
|
||||
|
// local aliases of functions called often
|
||||
|
|
||||
|
var each = jQuery.each |
||||
|
|
||||
|
spaces.hsla.props.alpha = rgbaspace.alpha |
||||
|
|
||||
|
function clamp (value, prop, alwaysAllowEmpty) { |
||||
|
var type = propTypes[ prop.type ] || {} |
||||
|
|
||||
|
var allowEmpty = prop.empty || alwaysAllowEmpty |
||||
|
|
||||
|
if (allowEmpty && value == null) { |
||||
|
return null |
||||
|
} |
||||
|
if (prop.def && value == null) { |
||||
|
return prop.def |
||||
|
} |
||||
|
if (type.floor) { |
||||
|
value = ~~value |
||||
|
} else { |
||||
|
value = parseFloat(value) |
||||
|
} |
||||
|
if (value == null || isNaN(value)) { |
||||
|
return prop.def |
||||
|
} |
||||
|
if (type.mod) { |
||||
|
value = value % type.mod |
||||
|
// -10 -> 350
|
||||
|
return value < 0 ? type.mod + value : value |
||||
|
} |
||||
|
|
||||
|
// for now all property types without mod have min and max
|
||||
|
return type.min > value ? type.min : type.max < value ? type.max : value |
||||
|
} |
||||
|
|
||||
|
function stringParse (string) { |
||||
|
var inst = color() |
||||
|
|
||||
|
var rgba = inst._rgba = [] |
||||
|
|
||||
|
string = string.toLowerCase() |
||||
|
|
||||
|
each(stringParsers, function (i, parser) { |
||||
|
var match = parser.re.exec(string) |
||||
|
|
||||
|
var values = match && parser.parse(match) |
||||
|
|
||||
|
var parsed |
||||
|
|
||||
|
var spaceName = parser.space || 'rgba' |
||||
|
|
||||
|
var cache = spaces[ spaceName ].cache |
||||
|
|
||||
|
if (values) { |
||||
|
parsed = inst[ spaceName ](values) |
||||
|
|
||||
|
// if this was an rgba parse the assignment might happen twice
|
||||
|
// oh well....
|
||||
|
inst[ cache ] = parsed[ cache ] |
||||
|
rgba = inst._rgba = parsed._rgba |
||||
|
|
||||
|
// exit each( stringParsers ) here because we matched
|
||||
|
return false |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
// Found a stringParser that handled it
|
||||
|
if (rgba.length !== 0) { |
||||
|
// if this came from a parsed string, force "transparent" when alpha is 0
|
||||
|
// chrome, (and maybe others) return "transparent" as rgba(0,0,0,0)
|
||||
|
if (Math.max.apply(Math, rgba) === 0) { |
||||
|
jQuery.extend(rgba, colors.transparent) |
||||
|
} |
||||
|
return inst |
||||
|
} |
||||
|
|
||||
|
// named colors / default - filter back through parse function
|
||||
|
if (string = colors[ string ]) { |
||||
|
return string |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
color.fn = color.prototype = { |
||||
|
constructor: color, |
||||
|
parse: function (red, green, blue, alpha) { |
||||
|
if (red === undefined) { |
||||
|
this._rgba = [ null, null, null, null ] |
||||
|
return this |
||||
|
} |
||||
|
if (red instanceof jQuery || red.nodeType) { |
||||
|
red = red instanceof jQuery ? red.css(green) : jQuery(red).css(green) |
||||
|
green = undefined |
||||
|
} |
||||
|
|
||||
|
var inst = this |
||||
|
|
||||
|
var type = jQuery.type(red) |
||||
|
|
||||
|
var rgba = this._rgba = [] |
||||
|
|
||||
|
var source |
||||
|
|
||||
|
// more than 1 argument specified - assume ( red, green, blue, alpha )
|
||||
|
if (green !== undefined) { |
||||
|
red = [ red, green, blue, alpha ] |
||||
|
type = 'array' |
||||
|
} |
||||
|
|
||||
|
if (type === 'string') { |
||||
|
return this.parse(stringParse(red) || colors._default) |
||||
|
} |
||||
|
|
||||
|
if (type === 'array') { |
||||
|
each(rgbaspace, function (key, prop) { |
||||
|
rgba[ prop.idx ] = clamp(red[ prop.idx ], prop) |
||||
|
}) |
||||
|
return this |
||||
|
} |
||||
|
|
||||
|
if (type === 'object') { |
||||
|
if (red instanceof color) { |
||||
|
each(spaces, function (spaceName, space) { |
||||
|
if (red[ space.cache ]) { |
||||
|
inst[ space.cache ] = red[ space.cache ].slice() |
||||
|
} |
||||
|
}) |
||||
|
} else { |
||||
|
each(spaces, function (spaceName, space) { |
||||
|
each(space.props, function (key, prop) { |
||||
|
var cache = space.cache |
||||
|
|
||||
|
// if the cache doesn't exist, and we know how to convert
|
||||
|
if (!inst[ cache ] && space.to) { |
||||
|
// if the value was null, we don't need to copy it
|
||||
|
// if the key was alpha, we don't need to copy it either
|
||||
|
if (red[ key ] == null || key === 'alpha') { |
||||
|
return |
||||
|
} |
||||
|
inst[ cache ] = space.to(inst._rgba) |
||||
|
} |
||||
|
|
||||
|
// this is the only case where we allow nulls for ALL properties.
|
||||
|
// call clamp with alwaysAllowEmpty
|
||||
|
inst[ cache ][ prop.idx ] = clamp(red[ key ], prop, true) |
||||
|
}) |
||||
|
}) |
||||
|
} |
||||
|
return this |
||||
|
} |
||||
|
}, |
||||
|
is: function (compare) { |
||||
|
var is = color(compare) |
||||
|
|
||||
|
var same = true |
||||
|
|
||||
|
var myself = this |
||||
|
|
||||
|
each(spaces, function (_, space) { |
||||
|
var isCache = is[ space.cache ] |
||||
|
|
||||
|
var localCache |
||||
|
if (isCache) { |
||||
|
localCache = myself[ space.cache ] || space.to && space.to(myself._rgba) || [] |
||||
|
each(space.props, function (_, prop) { |
||||
|
if (isCache[ prop.idx ] != null) { |
||||
|
same = (isCache[ prop.idx ] === localCache[ prop.idx ]) |
||||
|
return same |
||||
|
} |
||||
|
}) |
||||
|
} |
||||
|
return same |
||||
|
}) |
||||
|
return same |
||||
|
}, |
||||
|
_space: function () { |
||||
|
var used = [] |
||||
|
|
||||
|
var inst = this |
||||
|
each(spaces, function (spaceName, space) { |
||||
|
if (inst[ space.cache ]) { |
||||
|
used.push(spaceName) |
||||
|
} |
||||
|
}) |
||||
|
return used.pop() |
||||
|
}, |
||||
|
transition: function (other, distance) { |
||||
|
var end = color(other) |
||||
|
|
||||
|
var spaceName = end._space() |
||||
|
|
||||
|
var space = spaces[ spaceName ] |
||||
|
|
||||
|
var start = this[ space.cache ] || space.to(this._rgba) |
||||
|
|
||||
|
var result = start.slice() |
||||
|
|
||||
|
end = end[ space.cache ] |
||||
|
each(space.props, function (key, prop) { |
||||
|
var index = prop.idx |
||||
|
|
||||
|
var startValue = start[ index ] |
||||
|
|
||||
|
var endValue = end[ index ] |
||||
|
|
||||
|
var type = propTypes[ prop.type ] || {} |
||||
|
|
||||
|
// if null, don't override start value
|
||||
|
if (endValue === null) { |
||||
|
return |
||||
|
} |
||||
|
// if null - use end
|
||||
|
if (startValue === null) { |
||||
|
result[ index ] = endValue |
||||
|
} else { |
||||
|
if (type.mod) { |
||||
|
if (endValue - startValue > type.mod / 2) { |
||||
|
startValue += type.mod |
||||
|
} else if (startValue - endValue > type.mod / 2) { |
||||
|
startValue -= type.mod |
||||
|
} |
||||
|
} |
||||
|
result[ prop.idx ] = clamp((endValue - startValue) * distance + startValue, prop) |
||||
|
} |
||||
|
}) |
||||
|
return this[ spaceName ](result) |
||||
|
}, |
||||
|
blend: function (opaque) { |
||||
|
// if we are already opaque - return ourself
|
||||
|
if (this._rgba[ 3 ] === 1) { |
||||
|
return this |
||||
|
} |
||||
|
|
||||
|
var rgb = this._rgba.slice() |
||||
|
|
||||
|
var a = rgb.pop() |
||||
|
|
||||
|
var blend = color(opaque)._rgba |
||||
|
|
||||
|
return color(jQuery.map(rgb, function (v, i) { |
||||
|
return (1 - a) * blend[ i ] + a * v |
||||
|
})) |
||||
|
}, |
||||
|
toRgbaString: function () { |
||||
|
var prefix = 'rgba(' |
||||
|
|
||||
|
var rgba = jQuery.map(this._rgba, function (v, i) { |
||||
|
return v == null ? (i > 2 ? 1 : 0) : v |
||||
|
}) |
||||
|
|
||||
|
if (rgba[ 3 ] === 1) { |
||||
|
rgba.pop() |
||||
|
prefix = 'rgb(' |
||||
|
} |
||||
|
|
||||
|
return prefix + rgba.join(',') + ')' |
||||
|
}, |
||||
|
toHslaString: function () { |
||||
|
var prefix = 'hsla(' |
||||
|
|
||||
|
var hsla = jQuery.map(this.hsla(), function (v, i) { |
||||
|
if (v == null) { |
||||
|
v = i > 2 ? 1 : 0 |
||||
|
} |
||||
|
|
||||
|
// catch 1 and 2
|
||||
|
if (i && i < 3) { |
||||
|
v = Math.round(v * 100) + '%' |
||||
|
} |
||||
|
return v |
||||
|
}) |
||||
|
|
||||
|
if (hsla[ 3 ] === 1) { |
||||
|
hsla.pop() |
||||
|
prefix = 'hsl(' |
||||
|
} |
||||
|
return prefix + hsla.join(',') + ')' |
||||
|
}, |
||||
|
toHexString: function (includeAlpha) { |
||||
|
var rgba = this._rgba.slice() |
||||
|
|
||||
|
var alpha = rgba.pop() |
||||
|
|
||||
|
if (includeAlpha) { |
||||
|
rgba.push(~~(alpha * 255)) |
||||
|
} |
||||
|
|
||||
|
return '#' + jQuery.map(rgba, function (v, i) { |
||||
|
// default to 0 when nulls exist
|
||||
|
v = (v || 0).toString(16) |
||||
|
return v.length === 1 ? '0' + v : v |
||||
|
}).join('') |
||||
|
}, |
||||
|
toString: function () { |
||||
|
return this._rgba[ 3 ] === 0 ? 'transparent' : this.toRgbaString() |
||||
|
} |
||||
|
} |
||||
|
color.fn.parse.prototype = color.fn |
||||
|
|
||||
|
// hsla conversions adapted from:
|
||||
|
// http://www.google.com/codesearch/p#OAMlx_jo-ck/src/third_party/WebKit/Source/WebCore/inspector/front-end/Color.js&d=7&l=193
|
||||
|
|
||||
|
function hue2rgb (p, q, h) { |
||||
|
h = (h + 1) % 1 |
||||
|
if (h * 6 < 1) { |
||||
|
return p + (q - p) * 6 * h |
||||
|
} |
||||
|
if (h * 2 < 1) { |
||||
|
return q |
||||
|
} |
||||
|
if (h * 3 < 2) { |
||||
|
return p + (q - p) * ((2 / 3) - h) * 6 |
||||
|
} |
||||
|
return p |
||||
|
} |
||||
|
|
||||
|
spaces.hsla.to = function (rgba) { |
||||
|
if (rgba[ 0 ] == null || rgba[ 1 ] == null || rgba[ 2 ] == null) { |
||||
|
return [ null, null, null, rgba[ 3 ] ] |
||||
|
} |
||||
|
var r = rgba[ 0 ] / 255 |
||||
|
|
||||
|
var g = rgba[ 1 ] / 255 |
||||
|
|
||||
|
var b = rgba[ 2 ] / 255 |
||||
|
|
||||
|
var a = rgba[ 3 ] |
||||
|
|
||||
|
var max = Math.max(r, g, b) |
||||
|
|
||||
|
var min = Math.min(r, g, b) |
||||
|
|
||||
|
var diff = max - min |
||||
|
|
||||
|
var add = max + min |
||||
|
|
||||
|
var l = add * 0.5 |
||||
|
|
||||
|
var h; var s |
||||
|
|
||||
|
if (min === max) { |
||||
|
h = 0 |
||||
|
} else if (r === max) { |
||||
|
h = (60 * (g - b) / diff) + 360 |
||||
|
} else if (g === max) { |
||||
|
h = (60 * (b - r) / diff) + 120 |
||||
|
} else { |
||||
|
h = (60 * (r - g) / diff) + 240 |
||||
|
} |
||||
|
|
||||
|
if (l === 0 || l === 1) { |
||||
|
s = l |
||||
|
} else if (l <= 0.5) { |
||||
|
s = diff / add |
||||
|
} else { |
||||
|
s = diff / (2 - add) |
||||
|
} |
||||
|
return [ Math.round(h) % 360, s, l, a == null ? 1 : a ] |
||||
|
} |
||||
|
|
||||
|
spaces.hsla.from = function (hsla) { |
||||
|
if (hsla[ 0 ] == null || hsla[ 1 ] == null || hsla[ 2 ] == null) { |
||||
|
return [ null, null, null, hsla[ 3 ] ] |
||||
|
} |
||||
|
var h = hsla[ 0 ] / 360 |
||||
|
|
||||
|
var s = hsla[ 1 ] |
||||
|
|
||||
|
var l = hsla[ 2 ] |
||||
|
|
||||
|
var a = hsla[ 3 ] |
||||
|
|
||||
|
var q = l <= 0.5 ? l * (1 + s) : l + s - l * s |
||||
|
|
||||
|
var p = 2 * l - q |
||||
|
|
||||
|
var r; var g; var b |
||||
|
|
||||
|
return [ |
||||
|
Math.round(hue2rgb(p, q, h + (1 / 3)) * 255), |
||||
|
Math.round(hue2rgb(p, q, h) * 255), |
||||
|
Math.round(hue2rgb(p, q, h - (1 / 3)) * 255), |
||||
|
a |
||||
|
] |
||||
|
} |
||||
|
|
||||
|
each(spaces, function (spaceName, space) { |
||||
|
var props = space.props |
||||
|
|
||||
|
var cache = space.cache |
||||
|
|
||||
|
var to = space.to |
||||
|
|
||||
|
var from = space.from |
||||
|
|
||||
|
// makes rgba() and hsla()
|
||||
|
color.fn[ spaceName ] = function (value) { |
||||
|
// generate a cache for this space if it doesn't exist
|
||||
|
if (to && !this[ cache ]) { |
||||
|
this[ cache ] = to(this._rgba) |
||||
|
} |
||||
|
if (value === undefined) { |
||||
|
return this[ cache ].slice() |
||||
|
} |
||||
|
|
||||
|
var type = jQuery.type(value) |
||||
|
|
||||
|
var arr = (type === 'array' || type === 'object') ? value : arguments |
||||
|
|
||||
|
var local = this[ cache ].slice() |
||||
|
|
||||
|
var ret |
||||
|
|
||||
|
each(props, function (key, prop) { |
||||
|
var val = arr[ type === 'object' ? key : prop.idx ] |
||||
|
if (val == null) { |
||||
|
val = local[ prop.idx ] |
||||
|
} |
||||
|
local[ prop.idx ] = clamp(val, prop) |
||||
|
}) |
||||
|
|
||||
|
if (from) { |
||||
|
ret = color(from(local)) |
||||
|
ret[ cache ] = local |
||||
|
return ret |
||||
|
} else { |
||||
|
return color(local) |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
// makes red() green() blue() alpha() hue() saturation() lightness()
|
||||
|
each(props, function (key, prop) { |
||||
|
// alpha is included in more than one space
|
||||
|
if (color.fn[ key ]) { |
||||
|
return |
||||
|
} |
||||
|
color.fn[ key ] = function (value) { |
||||
|
var vtype = jQuery.type(value) |
||||
|
|
||||
|
var fn = (key === 'alpha' ? (this._hsla ? 'hsla' : 'rgba') : spaceName) |
||||
|
|
||||
|
var local = this[ fn ]() |
||||
|
|
||||
|
var cur = local[ prop.idx ] |
||||
|
|
||||
|
var match |
||||
|
|
||||
|
if (vtype === 'undefined') { |
||||
|
return cur |
||||
|
} |
||||
|
|
||||
|
if (vtype === 'function') { |
||||
|
value = value.call(this, cur) |
||||
|
vtype = jQuery.type(value) |
||||
|
} |
||||
|
if (value == null && prop.empty) { |
||||
|
return this |
||||
|
} |
||||
|
if (vtype === 'string') { |
||||
|
match = rplusequals.exec(value) |
||||
|
if (match) { |
||||
|
value = cur + parseFloat(match[ 2 ]) * (match[ 1 ] === '+' ? 1 : -1) |
||||
|
} |
||||
|
} |
||||
|
local[ prop.idx ] = value |
||||
|
return this[ fn ](local) |
||||
|
} |
||||
|
}) |
||||
|
}) |
||||
|
|
||||
|
// add .fx.step functions
|
||||
|
each(stepHooks, function (i, hook) { |
||||
|
jQuery.cssHooks[ hook ] = { |
||||
|
set: function (elem, value) { |
||||
|
var parsed, backgroundColor, curElem |
||||
|
|
||||
|
if (jQuery.type(value) !== 'string' || (parsed = stringParse(value))) { |
||||
|
value = color(parsed || value) |
||||
|
if (!support.rgba && value._rgba[ 3 ] !== 1) { |
||||
|
curElem = hook === 'backgroundColor' ? elem.parentNode : elem |
||||
|
do { |
||||
|
backgroundColor = jQuery.curCSS(curElem, 'backgroundColor') |
||||
|
} while ( |
||||
|
(backgroundColor === '' || backgroundColor === 'transparent') && |
||||
|
(curElem = curElem.parentNode) && |
||||
|
curElem.style |
||||
|
) |
||||
|
|
||||
|
value = value.blend(backgroundColor && backgroundColor !== 'transparent' |
||||
|
? backgroundColor |
||||
|
: '_default') |
||||
|
} |
||||
|
|
||||
|
value = value.toRgbaString() |
||||
|
} |
||||
|
elem.style[ hook ] = value |
||||
|
} |
||||
|
} |
||||
|
jQuery.fx.step[ hook ] = function (fx) { |
||||
|
if (!fx.colorInit) { |
||||
|
fx.start = color(fx.elem, hook) |
||||
|
fx.end = color(fx.end) |
||||
|
fx.colorInit = true |
||||
|
} |
||||
|
jQuery.cssHooks[ hook ].set(fx.elem, fx.start.transition(fx.end, fx.pos)) |
||||
|
} |
||||
|
}) |
||||
|
|
||||
|
// detect rgba support
|
||||
|
jQuery(function () { |
||||
|
var div = document.createElement('div') |
||||
|
|
||||
|
var div_style = div.style |
||||
|
|
||||
|
div_style.cssText = 'background-color:rgba(1,1,1,.5)' |
||||
|
support.rgba = div_style.backgroundColor.indexOf('rgba') > -1 |
||||
|
}) |
||||
|
|
||||
|
// Some named colors to work with
|
||||
|
// From Interface by Stefan Petre
|
||||
|
// http://interface.eyecon.ro/
|
||||
|
colors = jQuery.Color.names = { |
||||
|
aqua: '#00ffff', |
||||
|
azure: '#f0ffff', |
||||
|
beige: '#f5f5dc', |
||||
|
black: '#000000', |
||||
|
blue: '#0000ff', |
||||
|
brown: '#a52a2a', |
||||
|
cyan: '#00ffff', |
||||
|
darkblue: '#00008b', |
||||
|
darkcyan: '#008b8b', |
||||
|
darkgrey: '#a9a9a9', |
||||
|
darkgreen: '#006400', |
||||
|
darkkhaki: '#bdb76b', |
||||
|
darkmagenta: '#8b008b', |
||||
|
darkolivegreen: '#556b2f', |
||||
|
darkorange: '#ff8c00', |
||||
|
darkorchid: '#9932cc', |
||||
|
darkred: '#8b0000', |
||||
|
darksalmon: '#e9967a', |
||||
|
darkviolet: '#9400d3', |
||||
|
fuchsia: '#ff00ff', |
||||
|
gold: '#ffd700', |
||||
|
green: '#008000', |
||||
|
indigo: '#4b0082', |
||||
|
khaki: '#f0e68c', |
||||
|
lightblue: '#add8e6', |
||||
|
lightcyan: '#e0ffff', |
||||
|
lightgreen: '#90ee90', |
||||
|
lightgrey: '#d3d3d3', |
||||
|
lightpink: '#ffb6c1', |
||||
|
lightyellow: '#ffffe0', |
||||
|
lime: '#00ff00', |
||||
|
magenta: '#ff00ff', |
||||
|
maroon: '#800000', |
||||
|
navy: '#000080', |
||||
|
olive: '#808000', |
||||
|
orange: '#ffa500', |
||||
|
pink: '#ffc0cb', |
||||
|
purple: '#800080', |
||||
|
violet: '#800080', |
||||
|
red: '#ff0000', |
||||
|
silver: '#c0c0c0', |
||||
|
white: '#ffffff', |
||||
|
yellow: '#ffff00', |
||||
|
transparent: [ null, null, null, 0 ], |
||||
|
_default: '#ffffff' |
||||
|
} |
||||
|
})(jQuery) |
@ -0,0 +1,296 @@ |
|||||
|
/* eslint-disable */ |
||||
|
/*! |
||||
|
* jQuery-runner - v2.3.3 - 2014-08-06 |
||||
|
* https://github.com/jylauril/jquery-runner/
|
||||
|
* Copyright (c) 2014 Jyrki Laurila <https://github.com/jylauril>
|
||||
|
*/ |
||||
|
(function() { |
||||
|
var Runner, formatTime, meta, pad, runners, uid, _$, _requestAnimationFrame, _uid |
||||
|
|
||||
|
meta = { |
||||
|
version: "2.3.3", |
||||
|
name: "jQuery-runner" |
||||
|
} |
||||
|
|
||||
|
_$ = $ |
||||
|
|
||||
|
if (!(_$ && _$.fn)) { |
||||
|
throw new Error('[' + meta.name + '] jQuery or jQuery-like library is required for this plugin to work') |
||||
|
} |
||||
|
|
||||
|
runners = {} |
||||
|
|
||||
|
pad = function(num) { |
||||
|
return (num < 10 ? '0' : '') + num |
||||
|
} |
||||
|
|
||||
|
_uid = 1 |
||||
|
|
||||
|
uid = function() { |
||||
|
return 'runner' + _uid++ |
||||
|
} |
||||
|
|
||||
|
_requestAnimationFrame = (function(win, raf) { |
||||
|
return win['r' + raf] || win['webkitR' + raf] || win['mozR' + raf] || win['msR' + raf] || function(fn) { |
||||
|
return setTimeout(fn, 30) |
||||
|
} |
||||
|
})(this, 'equestAnimationFrame') |
||||
|
|
||||
|
formatTime = function(time, settings) { |
||||
|
var i, len, ms, output, prefix, separator, step, steps, value, _i, _len |
||||
|
settings = settings || {} |
||||
|
steps = [3600000, 60000, 1000, 10] |
||||
|
separator = ['', ':', ':', '.'] |
||||
|
prefix = '' |
||||
|
output = '' |
||||
|
ms = settings.milliseconds |
||||
|
len = steps.length |
||||
|
value = 0 |
||||
|
if (time < 0) { |
||||
|
time = Math.abs(time) |
||||
|
prefix = '-' |
||||
|
} |
||||
|
for (i = _i = 0, _len = steps.length; _i < _len; i = ++_i) { |
||||
|
step = steps[i] |
||||
|
value = 0 |
||||
|
if (time >= step) { |
||||
|
value = Math.floor(time / step) |
||||
|
time -= value * step |
||||
|
} |
||||
|
if ((value || i > 1 || output) && (i !== len - 1 || ms)) { |
||||
|
output += (output ? separator[i] : '') + pad(value) |
||||
|
} |
||||
|
} |
||||
|
return prefix + output |
||||
|
} |
||||
|
|
||||
|
Runner = (function() { |
||||
|
function Runner(items, options, start) { |
||||
|
var id |
||||
|
if (!(this instanceof Runner)) { |
||||
|
return new Runner(items, options, start) |
||||
|
} |
||||
|
this.items = items |
||||
|
id = this.id = uid() |
||||
|
this.settings = _$.extend({}, this.settings, options) |
||||
|
runners[id] = this |
||||
|
items.each(function(index, element) { |
||||
|
_$(element).data('runner', id) |
||||
|
}) |
||||
|
this.value(this.settings.startAt) |
||||
|
if (start || this.settings.autostart) { |
||||
|
this.start() |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.running = false |
||||
|
|
||||
|
Runner.prototype.updating = false |
||||
|
|
||||
|
Runner.prototype.finished = false |
||||
|
|
||||
|
Runner.prototype.interval = null |
||||
|
|
||||
|
Runner.prototype.total = 0 |
||||
|
|
||||
|
Runner.prototype.lastTime = 0 |
||||
|
|
||||
|
Runner.prototype.startTime = 0 |
||||
|
|
||||
|
Runner.prototype.lastLap = 0 |
||||
|
|
||||
|
Runner.prototype.lapTime = 0 |
||||
|
|
||||
|
Runner.prototype.settings = { |
||||
|
autostart: false, |
||||
|
countdown: false, |
||||
|
stopAt: null, |
||||
|
startAt: 0, |
||||
|
milliseconds: true, |
||||
|
format: null |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.value = function(value) { |
||||
|
this.items.each((function(_this) { |
||||
|
return function(item, element) { |
||||
|
var action |
||||
|
item = _$(element) |
||||
|
action = item.is('input') ? 'val' : 'text' |
||||
|
item[action](_this.format(value)) |
||||
|
} |
||||
|
})(this)) |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.format = function(value) { |
||||
|
var format |
||||
|
format = this.settings.format |
||||
|
format = _$.isFunction(format) ? format : formatTime |
||||
|
return format(value, this.settings) |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.update = function() { |
||||
|
var countdown, delta, settings, stopAt, time |
||||
|
if (!this.updating) { |
||||
|
this.updating = true |
||||
|
settings = this.settings |
||||
|
time = _$.now() |
||||
|
stopAt = settings.stopAt |
||||
|
countdown = settings.countdown |
||||
|
delta = time - this.lastTime |
||||
|
this.lastTime = time |
||||
|
if (countdown) { |
||||
|
this.total -= delta |
||||
|
} else { |
||||
|
this.total += delta |
||||
|
} |
||||
|
if (stopAt !== null && ((countdown && this.total <= stopAt) || (!countdown && this.total >= stopAt))) { |
||||
|
this.total = stopAt |
||||
|
this.finished = true |
||||
|
this.stop() |
||||
|
this.fire('runnerFinish') |
||||
|
} |
||||
|
this.value(this.total) |
||||
|
this.updating = false |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.fire = function(event) { |
||||
|
this.items.trigger(event, this.info()) |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.start = function() { |
||||
|
var step |
||||
|
if (!this.running) { |
||||
|
this.running = true |
||||
|
if (!this.startTime || this.finished) { |
||||
|
this.reset() |
||||
|
} |
||||
|
this.lastTime = _$.now() |
||||
|
step = (function(_this) { |
||||
|
return function() { |
||||
|
if (_this.running) { |
||||
|
_this.update() |
||||
|
_requestAnimationFrame(step) |
||||
|
} |
||||
|
} |
||||
|
})(this) |
||||
|
_requestAnimationFrame(step) |
||||
|
this.fire('runnerStart') |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.stop = function() { |
||||
|
if (this.running) { |
||||
|
this.running = false |
||||
|
this.update() |
||||
|
this.fire('runnerStop') |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.toggle = function() { |
||||
|
if (this.running) { |
||||
|
this.stop() |
||||
|
} else { |
||||
|
this.start() |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.lap = function() { |
||||
|
var lap, last |
||||
|
last = this.lastTime |
||||
|
lap = last - this.lapTime |
||||
|
if (this.settings.countdown) { |
||||
|
lap = -lap |
||||
|
} |
||||
|
if (this.running || lap) { |
||||
|
this.lastLap = lap |
||||
|
this.lapTime = last |
||||
|
} |
||||
|
last = this.format(this.lastLap) |
||||
|
this.fire('runnerLap') |
||||
|
return last |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.reset = function(stop) { |
||||
|
var nowTime |
||||
|
if (stop) { |
||||
|
this.stop() |
||||
|
} |
||||
|
nowTime = _$.now() |
||||
|
if (typeof this.settings.startAt === 'number' && !this.settings.countdown) { |
||||
|
nowTime -= this.settings.startAt |
||||
|
} |
||||
|
this.startTime = this.lapTime = this.lastTime = nowTime |
||||
|
this.total = this.settings.startAt |
||||
|
this.value(this.total) |
||||
|
this.finished = false |
||||
|
this.fire('runnerReset') |
||||
|
} |
||||
|
|
||||
|
Runner.prototype.info = function() { |
||||
|
var lap |
||||
|
lap = this.lastLap || 0 |
||||
|
return { |
||||
|
running: this.running, |
||||
|
finished: this.finished, |
||||
|
time: this.total, |
||||
|
formattedTime: this.format(this.total), |
||||
|
startTime: this.startTime, |
||||
|
lapTime: lap, |
||||
|
formattedLapTime: this.format(lap), |
||||
|
settings: this.settings |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
return Runner |
||||
|
|
||||
|
})() |
||||
|
|
||||
|
_$.fn.runner = function(method, options, start) { |
||||
|
var id, runner |
||||
|
if (!method) { |
||||
|
method = 'init' |
||||
|
} |
||||
|
if (typeof method === 'object') { |
||||
|
start = options |
||||
|
options = method |
||||
|
method = 'init' |
||||
|
} |
||||
|
id = this.data('runner') |
||||
|
runner = id ? runners[id] : false |
||||
|
switch (method) { |
||||
|
case 'init': |
||||
|
new Runner(this, options, start) |
||||
|
break |
||||
|
case 'info': |
||||
|
if (runner) { |
||||
|
return runner.info() |
||||
|
} |
||||
|
break |
||||
|
case 'reset': |
||||
|
if (runner) { |
||||
|
runner.reset(options) |
||||
|
} |
||||
|
break |
||||
|
case 'lap': |
||||
|
if (runner) { |
||||
|
return runner.lap() |
||||
|
} |
||||
|
break |
||||
|
case 'start': |
||||
|
case 'stop': |
||||
|
case 'toggle': |
||||
|
if (runner) { |
||||
|
return runner[method]() |
||||
|
} |
||||
|
break |
||||
|
case 'version': |
||||
|
return meta.version |
||||
|
default: |
||||
|
_$.error('[' + meta.name + '] Method ' + method + ' does not exist') |
||||
|
} |
||||
|
return this |
||||
|
} |
||||
|
|
||||
|
_$.fn.runner.format = formatTime |
||||
|
}).call(window) |
@ -0,0 +1,42 @@ |
|||||
|
|
||||
|
import tinymce from 'tinymce/tinymce' |
||||
|
import './langs/pt_BR.js' |
||||
|
|
||||
|
import 'tinymce/themes/silver' |
||||
|
import 'tinymce/icons/default' |
||||
|
|
||||
|
import 'tinymce/plugins/table' |
||||
|
import 'tinymce/plugins/lists' |
||||
|
import 'tinymce/plugins/code' |
||||
|
import 'tinymce/plugins/visualblocks' |
||||
|
|
||||
|
import 'tinymce/skins/ui/oxide/skin.css' |
||||
|
|
||||
|
window.tinymce = tinymce |
||||
|
|
||||
|
window.removeTinymce = function () { |
||||
|
while (window.tinymce.editors.length > 0) { |
||||
|
window.tinymce.remove(window.tinymce.editors[0]) |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
window.initTextRichEditor = function (elements, readonly = false) { |
||||
|
window.removeTinymce() |
||||
|
const configTinymce = { |
||||
|
selector: elements === null || elements === undefined ? 'textarea' : elements, |
||||
|
forced_root_block: '', |
||||
|
min_height: 200, |
||||
|
language: 'pt_BR', |
||||
|
branding: false, |
||||
|
content_css: 'default', |
||||
|
plugins: ['lists table code visualblocks'], |
||||
|
menubar: 'edit view format table tools', |
||||
|
toolbar: 'undo redo | styleselect | bold italic | alignleft aligncenter alignright alignjustify | bullist numlist outdent indent' |
||||
|
} |
||||
|
if (readonly) { |
||||
|
configTinymce.readonly = 1 |
||||
|
configTinymce.menubar = false |
||||
|
configTinymce.toolbar = false |
||||
|
} |
||||
|
window.tinymce.init(configTinymce) |
||||
|
} |
@ -0,0 +1,262 @@ |
|||||
|
/* eslint-disable */ |
||||
|
tinymce.addI18n('pt_BR', { |
||||
|
'Redo': 'Refazer', |
||||
|
'Undo': 'Desfazer', |
||||
|
'Cut': 'Recortar', |
||||
|
'Copy': 'Copiar', |
||||
|
'Paste': 'Colar', |
||||
|
'Select all': 'Selecionar tudo', |
||||
|
'New document': 'Novo documento', |
||||
|
'Ok': 'Ok', |
||||
|
'Cancel': 'Cancelar', |
||||
|
'Visual aids': 'Ajuda visual', |
||||
|
'Bold': 'Negrito', |
||||
|
'Italic': 'It\u00e1lico', |
||||
|
'Underline': 'Sublinhar', |
||||
|
'Strikethrough': 'Riscar', |
||||
|
'Superscript': 'Sobrescrito', |
||||
|
'Subscript': 'Subscrever', |
||||
|
'Clear formatting': 'Limpar formata\u00e7\u00e3o', |
||||
|
'Align left': 'Alinhar \u00e0 esquerda', |
||||
|
'Align center': 'Centralizar', |
||||
|
'Align right': 'Alinhar \u00e0 direita', |
||||
|
'Justify': 'Justificar', |
||||
|
'Bullet list': 'Lista n\u00e3o ordenada', |
||||
|
'Numbered list': 'Lista ordenada', |
||||
|
'Decrease indent': 'Diminuir recuo', |
||||
|
'Increase indent': 'Aumentar recuo', |
||||
|
'Close': 'Fechar', |
||||
|
'Formats': 'Formatos', |
||||
|
'Your browser doesn\'t support direct access to the clipboard. Please use the Ctrl+X/C/V keyboard shortcuts instead.': 'Seu navegador n\u00e3o suporta acesso direto \u00e0 \u00e1rea de transfer\u00eancia. Por favor use os atalhos Ctrl+X - C - V do teclado', |
||||
|
'Headers': 'Cabe\u00e7alhos', |
||||
|
'Header 1': 'Cabe\u00e7alho 1', |
||||
|
'Header 2': 'Cabe\u00e7alho 2', |
||||
|
'Header 3': 'Cabe\u00e7alho 3', |
||||
|
'Header 4': 'Cabe\u00e7alho 4', |
||||
|
'Header 5': 'Cabe\u00e7alho 5', |
||||
|
'Header 6': 'Cabe\u00e7alho 6', |
||||
|
'Headings': 'Cabe\u00e7alhos', |
||||
|
'Heading 1': 'Cabe\u00e7alho 1', |
||||
|
'Heading 2': 'Cabe\u00e7alho 2', |
||||
|
'Heading 3': 'Cabe\u00e7alho 3', |
||||
|
'Heading 4': 'Cabe\u00e7alho 4', |
||||
|
'Heading 5': 'Cabe\u00e7alho 5', |
||||
|
'Heading 6': 'Cabe\u00e7alho 6', |
||||
|
'Preformatted': 'Preformatado', |
||||
|
'Div': 'Container', |
||||
|
'Pre': 'Pre', |
||||
|
'Code': 'C\u00f3digo', |
||||
|
'Paragraph': 'Par\u00e1grafo', |
||||
|
'Blockquote': 'Aspas', |
||||
|
'Inline': 'Em linha', |
||||
|
'Blocks': 'Blocos', |
||||
|
'Paste is now in plain text mode. Contents will now be pasted as plain text until you toggle this option off.': 'O comando colar est\u00e1 agora em modo texto plano. O conte\u00fado ser\u00e1 colado como texto plano at\u00e9 voc\u00ea desligar esta op\u00e7\u00e3o.', |
||||
|
'Font Family': 'Fonte', |
||||
|
'Font Sizes': 'Tamanho', |
||||
|
'Class': 'Classe', |
||||
|
'Browse for an image': 'Procure uma imagem', |
||||
|
'OR': 'OU', |
||||
|
'Drop an image here': 'Arraste uma imagem aqui', |
||||
|
'Upload': 'Carregar', |
||||
|
'Block': 'Bloco', |
||||
|
'Align': 'Alinhamento', |
||||
|
'Default': 'Padr\u00e3o', |
||||
|
'Circle': 'C\u00edrculo', |
||||
|
'Disc': 'Disco', |
||||
|
'Square': 'Quadrado', |
||||
|
'Lower Alpha': 'a. b. c. ...', |
||||
|
'Lower Greek': '\u03b1. \u03b2. \u03b3. ...', |
||||
|
'Lower Roman': 'i. ii. iii. ...', |
||||
|
'Upper Alpha': 'A. B. C. ...', |
||||
|
'Upper Roman': 'I. II. III. ...', |
||||
|
'Anchor': '\u00c2ncora', |
||||
|
'Name': 'Nome', |
||||
|
'Id': 'Id', |
||||
|
'Id should start with a letter, followed only by letters, numbers, dashes, dots, colons or underscores.': 'Id deve come\u00e7ar com uma letra, seguido apenas por letras, n\u00fameros, tra\u00e7os, pontos, dois pontos ou sublinhados.', |
||||
|
'You have unsaved changes are you sure you want to navigate away?': 'Voc\u00ea tem mudan\u00e7as n\u00e3o salvas. Voc\u00ea tem certeza que deseja sair?', |
||||
|
'Restore last draft': 'Restaurar \u00faltimo rascunho', |
||||
|
'Special character': 'Caracteres especiais', |
||||
|
'Source code': 'C\u00f3digo fonte', |
||||
|
'Insert/Edit code sample': 'Inserir/Editar c\u00f3digo de exemplo', |
||||
|
'Language': 'Idioma', |
||||
|
'Code sample': 'Exemplo de c\u00f3digo', |
||||
|
'Color': 'Cor', |
||||
|
'R': 'R', |
||||
|
'G': 'G', |
||||
|
'B': 'B', |
||||
|
'Left to right': 'Da esquerda para a direita', |
||||
|
'Right to left': 'Da direita para a esquerda', |
||||
|
'Emoticons': 'Emoticons', |
||||
|
'Document properties': 'Propriedades do documento', |
||||
|
'Title': 'T\u00edtulo', |
||||
|
'Keywords': 'Palavras-chave', |
||||
|
'Description': 'Descri\u00e7\u00e3o', |
||||
|
'Robots': 'Rob\u00f4s', |
||||
|
'Author': 'Autor', |
||||
|
'Encoding': 'Codifica\u00e7\u00e3o', |
||||
|
'Fullscreen': 'Tela cheia', |
||||
|
'Action': 'A\u00e7\u00e3o', |
||||
|
'Shortcut': 'Atalho', |
||||
|
'Help': 'Ajuda', |
||||
|
'Address': 'Endere\u00e7o', |
||||
|
'Focus to menubar': 'Foco no menu', |
||||
|
'Focus to toolbar': 'Foco na barra de ferramentas', |
||||
|
'Focus to element path': 'Foco no caminho do elemento', |
||||
|
'Focus to contextual toolbar': 'Foco na barra de ferramentas contextual', |
||||
|
'Insert link (if link plugin activated)': 'Inserir link (se o plugin de link estiver ativado)', |
||||
|
'Save (if save plugin activated)': 'Salvar (se o plugin de salvar estiver ativado)', |
||||
|
'Find (if searchreplace plugin activated)': 'Procurar (se o plugin de procurar e substituir estiver ativado)', |
||||
|
'Plugins installed ({0}):': 'Plugins instalados ({0}):', |
||||
|
'Premium plugins:': 'Plugins premium:', |
||||
|
'Learn more...': 'Saiba mais...', |
||||
|
'You are using {0}': 'Voc\u00ea est\u00e1 usando {0}', |
||||
|
'Plugins': 'Plugins', |
||||
|
'Handy Shortcuts': 'Atalhos \u00fateis', |
||||
|
'Horizontal line': 'Linha horizontal', |
||||
|
'Insert/edit image': 'Inserir/editar imagem', |
||||
|
'Image description': 'Inserir descri\u00e7\u00e3o', |
||||
|
'Source': 'Endere\u00e7o da imagem', |
||||
|
'Dimensions': 'Dimens\u00f5es', |
||||
|
'Constrain proportions': 'Manter propor\u00e7\u00f5es', |
||||
|
'General': 'Geral', |
||||
|
'Advanced': 'Avan\u00e7ado', |
||||
|
'Style': 'Estilo', |
||||
|
'Vertical space': 'Espa\u00e7amento vertical', |
||||
|
'Horizontal space': 'Espa\u00e7amento horizontal', |
||||
|
'Border': 'Borda', |
||||
|
'Insert image': 'Inserir imagem', |
||||
|
'Image': 'Imagem', |
||||
|
'Image list': 'Lista de Imagens', |
||||
|
'Rotate counterclockwise': 'Girar em sentido hor\u00e1rio', |
||||
|
'Rotate clockwise': 'Girar em sentido anti-hor\u00e1rio', |
||||
|
'Flip vertically': 'Virar verticalmente', |
||||
|
'Flip horizontally': 'Virar horizontalmente', |
||||
|
'Edit image': 'Editar imagem', |
||||
|
'Image options': 'Op\u00e7\u00f5es de Imagem', |
||||
|
'Zoom in': 'Aumentar zoom', |
||||
|
'Zoom out': 'Diminuir zoom', |
||||
|
'Crop': 'Cortar', |
||||
|
'Resize': 'Redimensionar', |
||||
|
'Orientation': 'Orienta\u00e7\u00e3o', |
||||
|
'Brightness': 'Brilho', |
||||
|
'Sharpen': 'Aumentar nitidez', |
||||
|
'Contrast': 'Contraste', |
||||
|
'Color levels': 'N\u00edveis de cor', |
||||
|
'Gamma': 'Gama', |
||||
|
'Invert': 'Inverter', |
||||
|
'Apply': 'Aplicar', |
||||
|
'Back': 'Voltar', |
||||
|
'Insert date/time': 'Inserir data/hora', |
||||
|
'Date/time': 'data/hora', |
||||
|
'Insert link': 'Inserir link', |
||||
|
'Insert/edit link': 'Inserir/editar link', |
||||
|
'Text to display': 'Texto para mostrar', |
||||
|
'Url': 'Url', |
||||
|
'Target': 'Alvo', |
||||
|
'None': 'Nenhum', |
||||
|
'New window': 'Nova janela', |
||||
|
'Remove link': 'Remover link', |
||||
|
'Anchors': '\u00c2ncoras', |
||||
|
'Link': 'Link', |
||||
|
'Paste or type a link': 'Cole ou digite um Link', |
||||
|
'The URL you entered seems to be an email address. Do you want to add the required mailto: prefix?': 'The URL you entered seems to be an email address. Do you want to add the required mailto: prefix?', |
||||
|
'The URL you entered seems to be an external link. Do you want to add the required http:// prefix?': 'A URL que voc\u00ea informou parece ser um link externo. Deseja incluir o prefixo http://?', |
||||
|
'Link list': 'Lista de Links', |
||||
|
'Insert video': 'Inserir v\u00eddeo', |
||||
|
'Insert/edit video': 'Inserir/editar v\u00eddeo', |
||||
|
'Insert/edit media': 'Inserir/editar imagem', |
||||
|
'Alternative source': 'Fonte alternativa', |
||||
|
'Poster': 'Autor', |
||||
|
'Paste your embed code below:': 'Insira o c\u00f3digo de incorpora\u00e7\u00e3o abaixo:', |
||||
|
'Embed': 'Incorporar', |
||||
|
'Media': 'imagem', |
||||
|
'Nonbreaking space': 'Espa\u00e7o n\u00e3o separ\u00e1vel', |
||||
|
'Page break': 'Quebra de p\u00e1gina', |
||||
|
'Paste as text': 'Colar como texto', |
||||
|
'Preview': 'Pr\u00e9-visualizar', |
||||
|
'Print': 'Imprimir', |
||||
|
'Save': 'Salvar', |
||||
|
'Find': 'Localizar', |
||||
|
'Replace with': 'Substituir por', |
||||
|
'Replace': 'Substituir', |
||||
|
'Replace all': 'Substituir tudo', |
||||
|
'Prev': 'Anterior', |
||||
|
'Next': 'Pr\u00f3ximo', |
||||
|
'Find and replace': 'Localizar e substituir', |
||||
|
'Could not find the specified string.': 'N\u00e3o foi poss\u00edvel encontrar o termo especificado', |
||||
|
'Match case': 'Diferenciar mai\u00fasculas e min\u00fasculas', |
||||
|
'Whole words': 'Palavras inteiras', |
||||
|
'Spellcheck': 'Corretor ortogr\u00e1fico', |
||||
|
'Ignore': 'Ignorar', |
||||
|
'Ignore all': 'Ignorar tudo', |
||||
|
'Finish': 'Finalizar', |
||||
|
'Add to Dictionary': 'Adicionar ao Dicion\u00e1rio', |
||||
|
'Insert table': 'Inserir tabela', |
||||
|
'Table properties': 'Propriedades da tabela', |
||||
|
'Delete table': 'Excluir tabela', |
||||
|
'Cell': 'C\u00e9lula', |
||||
|
'Row': 'Linha', |
||||
|
'Column': 'Coluna', |
||||
|
'Cell properties': 'Propriedades da c\u00e9lula', |
||||
|
'Merge cells': 'Agrupar c\u00e9lulas', |
||||
|
'Split cell': 'Dividir c\u00e9lula', |
||||
|
'Insert row before': 'Inserir linha antes', |
||||
|
'Insert row after': 'Inserir linha depois', |
||||
|
'Delete row': 'Excluir linha', |
||||
|
'Row properties': 'Propriedades da linha', |
||||
|
'Cut row': 'Recortar linha', |
||||
|
'Copy row': 'Copiar linha', |
||||
|
'Paste row before': 'Colar linha antes', |
||||
|
'Paste row after': 'Colar linha depois', |
||||
|
'Insert column before': 'Inserir coluna antes', |
||||
|
'Insert column after': 'Inserir coluna depois', |
||||
|
'Delete column': 'Excluir coluna', |
||||
|
'Cols': 'Colunas', |
||||
|
'Rows': 'Linhas', |
||||
|
'Width': 'Largura', |
||||
|
'Height': 'Altura', |
||||
|
'Cell spacing': 'Espa\u00e7amento da c\u00e9lula', |
||||
|
'Cell padding': 'Espa\u00e7amento interno da c\u00e9lula', |
||||
|
'Caption': 'Legenda', |
||||
|
'Left': 'Esquerdo', |
||||
|
'Center': 'Centro', |
||||
|
'Right': 'Direita', |
||||
|
'Cell type': 'Tipo de c\u00e9lula', |
||||
|
'Scope': 'Escopo', |
||||
|
'Alignment': 'Alinhamento', |
||||
|
'H Align': 'Alinhamento H', |
||||
|
'V Align': 'Alinhamento V', |
||||
|
'Top': 'Superior', |
||||
|
'Middle': 'Meio', |
||||
|
'Bottom': 'Inferior', |
||||
|
'Header cell': 'C\u00e9lula cabe\u00e7alho', |
||||
|
'Row group': 'Agrupar linha', |
||||
|
'Column group': 'Agrupar coluna', |
||||
|
'Row type': 'Tipo de linha', |
||||
|
'Header': 'Cabe\u00e7alho', |
||||
|
'Body': 'Corpo', |
||||
|
'Footer': 'Rodap\u00e9', |
||||
|
'Border color': 'Cor da borda', |
||||
|
'Insert template': 'Inserir modelo', |
||||
|
'Templates': 'Modelos', |
||||
|
'Template': 'Modelo', |
||||
|
'Text color': 'Cor do texto', |
||||
|
'Background color': 'Cor do fundo', |
||||
|
'Custom...': 'Personalizado...', |
||||
|
'Custom color': 'Cor personalizada', |
||||
|
'No color': 'Nenhuma cor', |
||||
|
'Table of Contents': '\u00edndice de Conte\u00fado', |
||||
|
'Show blocks': 'Mostrar blocos', |
||||
|
'Show invisible characters': 'Exibir caracteres invis\u00edveis', |
||||
|
'Words: {0}': 'Palavras: {0}', |
||||
|
'{0} words': '{0} palavras', |
||||
|
'File': 'Arquivo', |
||||
|
'Edit': 'Editar', |
||||
|
'Insert': 'Inserir', |
||||
|
'View': 'Visualizar', |
||||
|
'Format': 'Formatar', |
||||
|
'Table': 'Tabela', |
||||
|
'Tools': 'Ferramentas', |
||||
|
'Powered by {0}': 'Distribu\u00eddo por {0}', |
||||
|
'Rich Text Area. Press ALT-F9 for menu. Press ALT-F10 for toolbar. Press ALT-0 for help': '\u00c1rea de texto formatado. Pressione ALT-F9 para exibir o menu, ALT-F10 para exibir a barra de ferramentas ou ALT-0 para exibir a ajuda' |
||||
|
}) |
@ -0,0 +1,40 @@ |
|||||
|
// app - global
|
||||
|
// é uma app fundamental para o layout do sapl tradicional.
|
||||
|
// é importada pelo backend em seus templates
|
||||
|
|
||||
|
import '@fortawesome/fontawesome-free/css/all.css' |
||||
|
|
||||
|
import 'bootstrap' |
||||
|
|
||||
|
import 'webpack-jquery-ui/dialog' |
||||
|
import 'webpack-jquery-ui/sortable' |
||||
|
import 'webpack-jquery-ui/datepicker' |
||||
|
import 'webpack-jquery-ui/autocomplete' |
||||
|
import 'jquery-ui/ui/i18n/datepicker-pt-BR' |
||||
|
|
||||
|
import 'jquery-ui-themes/themes/cupertino/jquery-ui.min.css' |
||||
|
|
||||
|
import 'jquery-mask-plugin' |
||||
|
|
||||
|
import './scss/app.scss' |
||||
|
|
||||
|
import './js/tinymce' |
||||
|
import './js/image_cropping' |
||||
|
import './js/functions' |
||||
|
|
||||
|
import * as moment from 'moment' |
||||
|
import 'moment/locale/pt-br' |
||||
|
|
||||
|
// eslint-disable-next-line
|
||||
|
require('imports-loader?window.jQuery=jquery!./js/jquery.runner.js') |
||||
|
|
||||
|
window.$ = $ |
||||
|
window.jQuery = $ |
||||
|
|
||||
|
window.moment = moment |
||||
|
|
||||
|
window.autorModal() |
||||
|
window.refreshMask() |
||||
|
window.refreshDatePicker() |
||||
|
|
||||
|
window.initTextRichEditor('#texto-rico') |
@ -0,0 +1,49 @@ |
|||||
|
|
||||
|
$blue: #02baf2 !default; |
||||
|
$red: #f84545 !default; |
||||
|
|
||||
|
@import "~bootstrap/scss/functions"; |
||||
|
@import "~bootstrap/scss/variables"; |
||||
|
@import "~bootstrap/scss/mixins"; |
||||
|
@import "~bootstrap/scss/reboot"; |
||||
|
@import "~bootstrap/scss/type"; |
||||
|
@import "~bootstrap/scss/images"; |
||||
|
@import "~bootstrap/scss/code"; |
||||
|
@import "~bootstrap/scss/grid"; |
||||
|
@import "~bootstrap/scss/tables"; |
||||
|
@import "~bootstrap/scss/forms"; |
||||
|
@import "~bootstrap/scss/buttons"; |
||||
|
@import "~bootstrap/scss/transitions"; |
||||
|
@import "~bootstrap/scss/dropdown"; |
||||
|
@import "~bootstrap/scss/button-group"; |
||||
|
@import "~bootstrap/scss/input-group"; |
||||
|
@import "~bootstrap/scss/custom-forms"; |
||||
|
@import "~bootstrap/scss/nav"; |
||||
|
@import "~bootstrap/scss/navbar"; |
||||
|
@import "~bootstrap/scss/card"; |
||||
|
@import "~bootstrap/scss/breadcrumb"; |
||||
|
@import "~bootstrap/scss/pagination"; |
||||
|
@import "~bootstrap/scss/badge"; |
||||
|
@import "~bootstrap/scss/jumbotron"; |
||||
|
@import "~bootstrap/scss/alert"; |
||||
|
@import "~bootstrap/scss/progress"; |
||||
|
@import "~bootstrap/scss/media"; |
||||
|
@import "~bootstrap/scss/list-group"; |
||||
|
@import "~bootstrap/scss/close"; |
||||
|
@import "~bootstrap/scss/toasts"; |
||||
|
@import "~bootstrap/scss/modal"; |
||||
|
@import "~bootstrap/scss/tooltip"; |
||||
|
@import "~bootstrap/scss/popover"; |
||||
|
@import "~bootstrap/scss/carousel"; |
||||
|
@import "~bootstrap/scss/spinners"; |
||||
|
@import "~bootstrap/scss/utilities"; |
||||
|
@import "~bootstrap/scss/print"; |
||||
|
|
||||
|
@each $color, $value in $theme-colors { |
||||
|
.btn-outline-#{$color} { |
||||
|
@include button-outline-variant($value); |
||||
|
border-color: #d6e1e5; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
|
@ -0,0 +1,4 @@ |
|||||
|
@import "header"; |
||||
|
|
||||
|
@import "libs/libs"; |
||||
|
@import "layouts/layouts"; |
@ -0,0 +1,25 @@ |
|||||
|
|
||||
|
body { |
||||
|
margin-bottom: 160px; |
||||
|
} |
||||
|
.footer { |
||||
|
background: #364347; |
||||
|
color: white; |
||||
|
text-align: center; |
||||
|
position: absolute; |
||||
|
width: 100%; |
||||
|
bottom: 0px; |
||||
|
p { |
||||
|
color: white; |
||||
|
margin-top: 10px; |
||||
|
} |
||||
|
.container { |
||||
|
padding-top: 25px; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
@media (max-width: 991px) { |
||||
|
.footer { |
||||
|
position: relative; |
||||
|
} |
||||
|
} |
@ -0,0 +1,190 @@ |
|||||
|
html { |
||||
|
position: relative; |
||||
|
min-height: 100%; |
||||
|
} |
||||
|
|
||||
|
h1, h2, h3, h4, h5, h6, form, dl, dt, dd, p, div, img, a { |
||||
|
margin: 0; |
||||
|
padding: 0; |
||||
|
} |
||||
|
h1, .h1 { |
||||
|
font-size: 30px; |
||||
|
} |
||||
|
h2, .h2 { |
||||
|
font-size: 24px; |
||||
|
} |
||||
|
h3, .h3 { |
||||
|
font-size: 20px; |
||||
|
} |
||||
|
h4, .h4 { |
||||
|
font-size: 16px; |
||||
|
} |
||||
|
h5, .h5 { |
||||
|
font-size: 14px; |
||||
|
} |
||||
|
h6, .h6 { |
||||
|
font-size: 12px; |
||||
|
} |
||||
|
|
||||
|
p { |
||||
|
margin: 0.25em 0; |
||||
|
&.control-label { |
||||
|
font-weight: bold; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
label { |
||||
|
margin-bottom: 0; |
||||
|
line-height: 1; |
||||
|
} |
||||
|
input[type=checkbox], input[type=radio] { |
||||
|
margin: 0 5px 0 0; |
||||
|
position: relative; |
||||
|
} |
||||
|
|
||||
|
fieldset { |
||||
|
fieldset { |
||||
|
font-size: 95%; |
||||
|
legend { |
||||
|
font-size: 18px; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
ul { |
||||
|
margin: 0; |
||||
|
} |
||||
|
.hidden { |
||||
|
display: none; |
||||
|
} |
||||
|
|
||||
|
.form-control-static { |
||||
|
padding: 0.2em 0; |
||||
|
padding-left: 12px; |
||||
|
background-color: #f7f7f7; |
||||
|
&:empty { |
||||
|
display: none; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
.legend { |
||||
|
display: block; |
||||
|
width: 100%; |
||||
|
padding: 0; |
||||
|
margin-bottom: 20px; |
||||
|
font-size: 21px; |
||||
|
line-height: inherit; |
||||
|
color: #333; |
||||
|
border: 0; |
||||
|
border-bottom: 1px solid #e5e5e5; |
||||
|
clear: both; |
||||
|
} |
||||
|
|
||||
|
.page-header { |
||||
|
margin: 20px 0px 10px; |
||||
|
} |
||||
|
|
||||
|
.caret { |
||||
|
&.top { |
||||
|
transform: rotate(180deg); |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
.lista-parlamentares .table td { |
||||
|
vertical-align: middle; |
||||
|
} |
||||
|
small { |
||||
|
color: #777; |
||||
|
} |
||||
|
|
||||
|
.container-tabaux { |
||||
|
.sidebar-tabaux { |
||||
|
background: #fafafa; |
||||
|
margin-top: -70px; |
||||
|
padding: 10px; |
||||
|
border: 1px solid #eee; |
||||
|
.navbar-right { |
||||
|
margin: 0; |
||||
|
} |
||||
|
.nav-pills > li + li { |
||||
|
margin-left: 0px; |
||||
|
} |
||||
|
li { |
||||
|
width: 100%; |
||||
|
} |
||||
|
span { |
||||
|
display: none; |
||||
|
} |
||||
|
.dropdown-menu { |
||||
|
padding: 0px; |
||||
|
right: 10px; |
||||
|
margin-top: -5px; |
||||
|
overflow: hidden; |
||||
|
a { |
||||
|
border: 0px; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
ul { |
||||
|
list-style: none; |
||||
|
padding: 0; |
||||
|
} |
||||
|
|
||||
|
.list { |
||||
|
font-family: "SourceSansProSemiBold", Helvetica, Arial, sans-serif; |
||||
|
font-size: 0px; |
||||
|
display: table; |
||||
|
width: 100%; |
||||
|
margin: 0; |
||||
|
|
||||
|
ul { |
||||
|
display: table; |
||||
|
width: 100%; |
||||
|
margin: 0; |
||||
|
} |
||||
|
|
||||
|
li { |
||||
|
width: calc(50%); |
||||
|
display: inline-block; |
||||
|
position: relative; |
||||
|
} |
||||
|
& > li { |
||||
|
width: 100%; |
||||
|
border-bottom: 1px solid #eee; |
||||
|
padding-bottom: 20px; |
||||
|
margin-bottom: 20px; |
||||
|
} |
||||
|
|
||||
|
.head_title { |
||||
|
color: #364347; |
||||
|
font-size: 1.7rem; |
||||
|
text-transform: none; |
||||
|
} |
||||
|
|
||||
|
a { |
||||
|
span { |
||||
|
display: none; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
.mce-branding.mce-label { |
||||
|
display: none; |
||||
|
} |
||||
|
|
||||
|
.dont-break-out { |
||||
|
overflow-wrap: break-word; |
||||
|
word-wrap: break-word; |
||||
|
word-break: break-word; |
||||
|
|
||||
|
/*-ms-hyphens: auto; |
||||
|
-moz-hyphens: auto; |
||||
|
-webkit-hyphens: auto; |
||||
|
hyphens: auto;*/ |
||||
|
} |
||||
|
|
||||
|
@media print { |
||||
|
a[href]:after { |
||||
|
content: none !important; |
||||
|
} |
||||
|
} |
@ -0,0 +1,188 @@ |
|||||
|
|
||||
|
.container-home { |
||||
|
position: relative; |
||||
|
padding: 2em 1.5em 1.5em 1.5em; |
||||
|
max-width: 1000px; |
||||
|
margin: 0 auto; |
||||
|
a:hover { |
||||
|
color: #444; |
||||
|
-webkit-transition: 0.3s ease-in; |
||||
|
-moz-transition: 0.3s ease-in; |
||||
|
-o-transition: 0.3s ease-in |
||||
|
} |
||||
|
|
||||
|
#homeIndex { |
||||
|
text-align: center; |
||||
|
} |
||||
|
|
||||
|
.homeBanner span { |
||||
|
color: white; |
||||
|
font-size: 32px; |
||||
|
font-weight: 600; |
||||
|
display: inline-block; |
||||
|
vertical-align: middle; |
||||
|
padding: 2px 45px 4px; |
||||
|
border: 2px solid; |
||||
|
} |
||||
|
|
||||
|
.homeBanner::after { |
||||
|
display: inline-block; |
||||
|
vertical-align: middle; |
||||
|
height: 100%; |
||||
|
} |
||||
|
|
||||
|
.homeBlock { |
||||
|
display: inline-block; |
||||
|
position: relative; |
||||
|
background-color: #F3F3F3; |
||||
|
width: 190px; |
||||
|
height: 260px; |
||||
|
margin: 3px; |
||||
|
text-align: center; |
||||
|
font-size: 0; |
||||
|
overflow: hidden; |
||||
|
} |
||||
|
|
||||
|
.homeBlock > a { |
||||
|
display: block; |
||||
|
position: absolute; |
||||
|
width: 100%; |
||||
|
height: 100%; |
||||
|
top: 0; |
||||
|
left: 0; |
||||
|
} |
||||
|
|
||||
|
.homeBlock::after { |
||||
|
content: ''; |
||||
|
display: inline-block; |
||||
|
vertical-align: middle; |
||||
|
height: 100%; |
||||
|
overflow: visible; |
||||
|
clear: none; |
||||
|
visibility: initial; |
||||
|
} |
||||
|
|
||||
|
.homeContent { |
||||
|
position: relative; |
||||
|
padding: 10px; |
||||
|
text-align: justify; |
||||
|
font-size: 14px; |
||||
|
color: #FFF; |
||||
|
opacity: 0; |
||||
|
transition: opacity 0.5s ease; |
||||
|
display: inline-block; |
||||
|
vertical-align: middle; |
||||
|
} |
||||
|
|
||||
|
.homeContent p { |
||||
|
display: block; |
||||
|
line-height: 13px; |
||||
|
font-size: 80%; |
||||
|
color: white; |
||||
|
} |
||||
|
|
||||
|
.homeIcon { |
||||
|
position: relative; |
||||
|
display: inline-block; |
||||
|
width: 105px; |
||||
|
height: 105px; |
||||
|
border-radius: 50%; |
||||
|
background: #364347; |
||||
|
z-index: 1; |
||||
|
} |
||||
|
|
||||
|
.homeIcon::before { |
||||
|
content: ''; |
||||
|
position: absolute; |
||||
|
width: 100%; |
||||
|
height: 100%; |
||||
|
border-radius: 50%; |
||||
|
background: #364347; |
||||
|
top: 0; |
||||
|
left: 0; |
||||
|
transform: scale(0.95); |
||||
|
transition: transform 0.6s ease; |
||||
|
} |
||||
|
|
||||
|
.homeIcon img { |
||||
|
position: absolute; |
||||
|
margin: auto; |
||||
|
top: 0; |
||||
|
bottom: 0; |
||||
|
right: 0; |
||||
|
left: 0; |
||||
|
transition: opacity 0.4s 0.4s ease; |
||||
|
} |
||||
|
|
||||
|
.homeFront { |
||||
|
position: absolute; |
||||
|
top: 46%; |
||||
|
width: 100%; |
||||
|
font-size: 0; |
||||
|
transform: translateY(-60%); |
||||
|
|
||||
|
} |
||||
|
|
||||
|
.homeFront h2 { |
||||
|
position: absolute; |
||||
|
margin-top: 18px; |
||||
|
font-size: 22px; |
||||
|
font-weight: 700; |
||||
|
color: #595959 !important; |
||||
|
width: 100%; |
||||
|
padding: 0 6%; |
||||
|
z-index: 0; |
||||
|
} |
||||
|
|
||||
|
.homeTitle { |
||||
|
display: block; |
||||
|
height: 32px; |
||||
|
text-align: center; |
||||
|
width: 100%; |
||||
|
opacity: 0; |
||||
|
transition: opacity 0.4s ease; |
||||
|
} |
||||
|
|
||||
|
.homeTitle::before { |
||||
|
content: ''; |
||||
|
display: inline-block; |
||||
|
vertical-align: middle; |
||||
|
height: 100%; |
||||
|
} |
||||
|
|
||||
|
.homeTitle h2 { |
||||
|
display: inline-block; |
||||
|
vertical-align: middle; |
||||
|
max-width: 110px; |
||||
|
font-size: 14px; |
||||
|
color: white !important; |
||||
|
line-height: 1em; |
||||
|
} |
||||
|
|
||||
|
.homeTitle img { |
||||
|
display: inline-block; |
||||
|
vertical-align: middle; |
||||
|
height: 30px; |
||||
|
margin-right: 5px; |
||||
|
} |
||||
|
|
||||
|
.homeBlock:hover .homeIcon::before { |
||||
|
transform: scale(3.6) translateY(7px); |
||||
|
} |
||||
|
|
||||
|
.homeBlock:hover .homeContent{ |
||||
|
opacity: 1; |
||||
|
transition-delay: 0.2s; |
||||
|
} |
||||
|
|
||||
|
.homeBlock:hover .homeIcon img { |
||||
|
opacity: 0; |
||||
|
transition-duration: 0.2s; |
||||
|
transition-delay: 0s; |
||||
|
} |
||||
|
|
||||
|
.homeBlock:hover .homeTitle { |
||||
|
opacity: 1; |
||||
|
} |
||||
|
|
||||
|
} |