HEX
Server: Apache
System: Linux WWW 6.1.0-40-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.153-1 (2025-09-20) x86_64
User: web11 (1011)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/intranet.kauko.lt/wp-content/plugins/js_composer/assets/lib/vc/vc_chart/jquery.vc_chart.js
/* =========================================================
 * jquery.vc_chart.js v1.0
 * =========================================================
 * Copyright 2013 Wpbakery
 *
 * Jquery chart plugin for the WPBakery Page Builder.
 * ========================================================= */
( function ( $ ) {
	'use strict';

	/**
	 * Pie chart animated.
	 * @param element - DOM element
	 * @param options - settings object.
	 * @constructor
	 */
	function VcChart ( element, options ) {
		this.el = element;
		this.$el = $( this.el );
		this.options = $.extend({
			color: '#f7f7f7',
			units: '',
			label_selector: '.vc_pie_chart_value',
			back_selector: '.vc_pie_chart_back',
			responsive: true
		}, options );
		this.init();
	}

	VcChart.prototype = {
		constructor: VcChart,
		_progress_v: 0,
		animated: false,
		init: function () {
			this.color = this.options.color;
			this.value = this.$el.data( 'pie-value' ) / 100;
			this.label_value = this.$el.data( 'pie-label-value' ) || this.$el.data( 'pie-value' );
			this.$wrapper = $( '.vc_pie_wrapper', this.$el );
			this.$label = $( this.options.label_selector, this.$el );
			this.$back = $( this.options.back_selector, this.$el );
			this.$canvas = this.$el.find( 'canvas' );
			this.draw();
			this.setWayPoint();
			if ( true === this.options.responsive ) {
				this.setResponsive();
			}
		},
		setResponsive: function () {
			var that = this;
			$( window ).on( 'resize', function () {
				if ( !that.$el || !that.$el.is( ':visible' ) ) {
					// We are detached, lets skip everything
					return;
				}
				if ( true === that.animated ) {
					that.circle.stop();
				}
				that.draw( true );
			});
		},
		draw: function ( redraw ) {
			var w = this.$el.addClass( 'vc_ready' ).width(),
				border_w = 5,
				radius;
			if ( !w ) {
				w = this.$el.parents( ':visible' ).first().width() - 2;
			}
			w = w / 100 * 80;
			radius = w / 2 - border_w - 1;
			this.$wrapper.css({ 'width': w + 'px' });
			this.$label.css({ 'width': w, 'height': w, 'line-height': w + 'px' });
			this.$back.css({ 'width': w, 'height': w });
			this.$canvas.attr({ 'width': w + 'px', 'height': w + 'px' });
			this.$el.addClass( 'vc_ready' );

			this.circle = new ProgressCircle({
				canvas: this.$canvas.get( 0 ),
				minRadius: radius,
				arcWidth: border_w
			});
			if ( true === redraw && true === this.animated ) {
				this._progress_v = this.value;
				this.circle.addEntry({
					fillColor: this.color,
					progressListener: $.proxy( this.setProgress, this )
				}).start();
			}
		},
		setProgress: function () {
			var labelValue = this.label_value ? this.stripHtmlTags( this.label_value.toString() ) : '';
			var units = this.options.units ? this.stripHtmlTags( this.options.units ) : '';

			if ( this._progress_v >= this.value ) {
				this.circle.stop();
				this.$label.text( labelValue + units );
				return this._progress_v;
			}
			this._progress_v += 0.005;
			var label_value = this._progress_v / this.value * this.label_value;
			var val = Math.round( label_value ) + units;
			this.$label.text( val );
			return this._progress_v;
		},
		animate: function () {
			if ( true !== this.animated ) {
				this.animated = true;
				this.circle.addEntry({
					fillColor: this.color,
					progressListener: $.proxy( this.setProgress, this )
				}).start( 5 );
			}
		},
		setWayPoint: function () {
			if ( 'undefined' !== typeof ( $.fn.vcwaypoint ) ) {
				this.$el.vcwaypoint( $.proxy( this.animate, this ), { offset: '85%' });
			} else {
				this.animate();
			}
		},
		stripHtmlTags: function ( string ) {
			return string.replace( /(<([^>]+)>)/ig, '' );
		}
	};
	/**
	 * jQuery plugin
	 * @param option - object with settings
	 * @return {*}
	 */
	$.fn.vcChat = function ( option, value ) {
		return this.each( function () {
			var $this = $( this ),
				data = $this.data( 'vc_chart' ),
				options = 'object' === typeof ( option ) ? option : {
					color: $this.data( 'pie-color' ),
					units: $this.data( 'pie-units' )
				};
			if ( 'undefined' === typeof ( option ) ) {
				$this.data( 'vc_chart', ( data = new VcChart( this, options ) ) );
			}
			if ( 'string' === typeof ( option ) ) {
				data[ option ]( value );
			}
		});
	};
	/**
	 * Allows users to rewrite function inside theme.
	 */
	if ( 'function' !== typeof ( window.vc_pieChart ) ) {
		window.vc_pieChart = function () {
			$( '.vc_pie_chart:visible' ).vcChat();
		};
	}
	$( document ).ready( function () {
		if ( !window.vc_iframe ) {
			vc_pieChart();
		}
	});
})( window.jQuery );