Вызов снипета в типе файла javascript

Добрый день, создаю файл с расширением js через Modx, в нем хочу прописать вызов снипета Migx (например) как это можно реализовать, при вызове любого снипета Modx ругается на неверный синтаксис.
BRUSHED.slider = function(){
	$.supersized({

		slides 					:  	[			// Slideshow Images
											
	[[getImageList? 
    &tvname=`slider`
    &tpl=`@CODE: {image : '[[+image]]', title : '<div class="slide-content">[[+title]]</div>', thumb : '', url : ''},`
    &tplLast=`@CODE: {image : '[[+image]]', title : '<div class="slide-content">[[+title]]</div>', thumb : '', url : ''}`]]

									],
									
		// Theme Options			   
		progress_bar			:	0,			// Timer for each slide							
		mouse_scrub				:	0
		
	});

}
Подскажите в каком направлении копать ) просто не хочеться писать большой скрипт в тело документа
Alexsandr
21 апреля 2017, 04:41
modx.pro
1 852
0

Комментарии: 12

Володя
21 апреля 2017, 07:51
0
при вызове любого снипета Modx ругается на неверный синтаксис.
Вы создали ресурс, задали ему тип javascript, в область контента поместили данный код. Кто ругается? Где?
    Alexsandr
    21 апреля 2017, 08:02
    0
    Вот смотрите создал ресурс с расширением le Navigation
    ================================================== */
    var mobileMenuClone = $('#menu').clone().attr('id', 'navigation-mobile');

    BRUSHED.mobileNav = function(){
    var windowWidth = $(window).width();

    if( windowWidth <= 979 ) {
    if( $('#mobile-nav').length > 0 ) {
    mobileMenuClone.insertAfter('#menu');
    $('#navigation-mobile #menu-nav').attr('id', 'menu-nav-mobile');
    }
    } else {
    $('#navigation-mobile').css('display', 'none');
    if ($('#mobile-nav').hasClass('open')) {
    $('#mobile-nav').removeClass('open');
    }
    }
    }

    BRUSHED.listenerMenu = function(){
    $('#mobile-nav').on('click', function(e){
    $(this).toggleClass('open');

    if ($('#mobile-nav').hasClass('open')) {
    $('#navigation-mobile').slideDown(500, 'easeOutExpo');
    } else {
    $('#navigation-mobile').slideUp(500, 'easeOutExpo');
    }
    e.preventDefault();
    });

    $('#menu-nav-mobile a').on('click', function(){
    $('#mobile-nav').removeClass('open');
    $('#navigation-mobile').slideUp(350, 'easeOutExpo');
    });
    }

    /* ==================================================
    Slider Options
    ================================================== */

    BRUSHED.slider = function(){
    $.supersized({
    // Functionality
    slideshow: 1, // Slideshow on/off
    autoplay: 1, // Slideshow starts playing automatically
    start_slide: 1, // Start slide (0 is random)
    stop_loop: 0, // Pauses slideshow on last slide
    random: 0, // Randomize slide order (Ignores start slide)
    slide_interval: 12000, // Length between transitions
    transition: 1, // 0-None, 1-Fade, 2-Slide Top, 3-Slide Right, 4-Slide Bottom, 5-Slide Left, 6-Carousel Right, 7-Carousel Left
    transition_speed: 300, // Speed of transition
    new_window: 1, // Image links open in new window/tab
    pause_hover: 0, // Pause slideshow on hover
    keyboard_nav: 1, // Keyboard navigation on/off
    performance: 1, // 0-Normal, 1-Hybrid speed/quality, 2-Optimizes image quality, 3-Optimizes transition speed // (Only works for Firefox/IE, not Webkit)
    image_protect: 1, // Disables image dragging and right click with Javascript

    // Size & Position
    min_width: 0, // Min width allowed (in pixels)
    min_height: 0, // Min height allowed (in pixels)
    vertical_center: 1, // Vertically center background
    horizontal_center: 1, // Horizontally center background
    fit_always: 0, // Image will never exceed browser width or height (Ignores min. dimensions)
    fit_portrait: 1, // Portrait images will not exceed browser height
    fit_landscape: 0, // Landscape images will not exceed browser width

    // Components
    slide_links: 'blank', // Individual links for each slide (Options: false, 'num', 'name', 'blank')
    thumb_links: 0, // Individual thumb links for each slide
    thumbnail_navigation: 0, // Thumbnail navigation
    slides: [ // Slideshow Images
    {image: '_include/img/slider-images/image01.jpg', title: 'Brushed', thumb: '', url: ''},
    {image: '_include/img/slider-images/image02.jpg', title: 'Brushed', thumb: '', url: ''},
    {image: '_include/img/slider-images/image03.jpg', title: 'Brushed', thumb: '', url: ''},
    {image: '_include/img/slider-images/image04.jpg', title: 'Brushed', thumb: '', url: ''}
    ],

    // Theme Options
    progress_bar: 0, // Timer for each slide
    mouse_scrub: 0

    });

    }

    /* ==================================================
    Navigation Fix
    ================================================== */

    BRUSHED.nav = function(){
    $('.sticky-nav').waypoint('sticky');
    }

    /* ==================================================
    Filter Works
    ================================================== */

    BRUSHED.filter = function (){
    if($('#projects').length > 0){
    var $container = $('#projects');

    $container.isotope({
    // options
    animationEngine: 'best-available',
    itemSelector: '.item-thumbs',
    layoutMode: 'fitRows'
    });


    // filter items when filter link is clicked
    var $optionSets = $('#options .option-set'),
    $optionLinks = $optionSets.find('a');

    $optionLinks.click(function(){
    var $this = $(this);
    // don't proceed if already selected
    if ( $this.hasClass('selected') ) {
    return false;
    }
    var $optionSet = $this.parents('.option-set');
    $optionSet.find('.selected').removeClass('selected');
    $this.addClass('selected');

    // make option object dynamically, i.e. { filter: '.my-filter-class' }
    var options = {},
    key = $optionSet.attr('data-option-key'),
    value = $this.attr('data-option-value');
    // parse 'false' as false boolean
    value = value === 'false'? false: value;
    options[ key ] = value;
    if ( key === 'layoutMode' && typeof changeLayoutMode === 'function' ) {
    // changes in layout modes need extra logic
    changeLayoutMode( $this, options )
    } else {
    // otherwise, apply new options
    $container.isotope( options );
    }

    return false;
    });
    }
    }

    /* ==================================================
    FancyBox
    ================================================== */

    BRUSHED.fancyBox = function(){
    if($('.fancybox').length > 0 || $('.fancybox-media').length > 0 || $('.fancybox-various').length > 0){

    $(".fancybox").fancybox({
    padding: 0,
    beforeShow: function () {
    this.title = $(this.element).attr('title');
    this.title = '' + this.title + '' + '' + $(this.element).parent().find('img').attr('alt') + '';
    },
    helpers: {
    title: { type: 'inside' },
    }
    });

    $('.fancybox-media').fancybox({
    openEffect: 'none',
    closeEffect: 'none',
    helpers: {
    media: {}
    }
    });
    }
    }

    /* ==================================================
    Contact Form
    ================================================== */

    BRUSHED.contactForm = function(){
    $("#contact-submit").on('click',function() {
    $contact_form = $('#contact-form');

    var fields = $contact_form.serialize();

    $.ajax({
    type: «POST»,
    url: "_include/php/contact.php",
    data: fields,
    dataType: 'json',
    success: function(response) {

    if(response.status){
    $('#contact-form input').val('');
    $('#contact-form textarea').val('');
    }

    $('#response').empty().html(response.html);
    }
    });
    return false;
    });
    }

    /* ==================================================
    Twitter Feed
    ================================================== */

    BRUSHED.tweetFeed = function(){
    var valueTop = -64;

    $("#ticker").tweet({
    username: «Bluxart»,
    page: 1,
    avatar_size: 0,
    count: 10,
    template: "{text}{time}",
    filter: function(t){ return! /^@\w+/.test(t.tweet_raw_text); },
    loading_text: «loading ...»
    }).bind(«loaded», function() {
    var ul = $(this).find(".tweet_list");
    var ticker = function() {
    setTimeout(function() {
    ul.find('li:first').animate( {marginTop: valueTop + 'px'}, 500, 'linear', function() {
    $(this).detach().appendTo(ul).removeAttr('style');
    });
    ticker();
    }, 5000);
    };
    ticker();
    });

    }

    /* ==================================================
    Menu Highlight
    ================================================== */

    BRUSHED.menu = function(){
    $('#menu-nav, #menu-nav-mobile').onePageNav({
    currentClass: 'current',
    changeHash: false,
    scrollSpeed: 750,
    scrollOffset: 30,
    scrollThreshold: 0.5,
    easing: 'easeOutExpo',
    filter: ':not(.external)'
    });
    }

    /* ==================================================
    Next Section
    ================================================== */

    BRUSHED.goSection = function(){
    $('#nextsection').on('click', function(){
    $target = $($(this).attr('href')).offset().top-30;

    $('body, html').animate({scrollTop: $target}, 750, 'easeOutExpo');
    return false;
    });
    }

    /* ==================================================
    GoUp
    ================================================== */

    BRUSHED.goUp = function(){
    $('#goUp').on('click', function(){
    $target = $($(this).attr('href')).offset().top-30;

    $('body, html').animate({scrollTop: $target}, 750, 'easeOutExpo');
    return false;
    });
    }

    /* ==================================================
    Scroll to Top
    ================================================== */

    BRUSHED.scrollToTop = function(){
    var windowWidth = $(window).width(),
    didScroll = false;

    var $arrow = $('#back-to-top');

    $arrow.click(function(e) {
    $('body,html').animate({ scrollTop: «0» }, 750, 'easeOutExpo' );
    e.preventDefault();
    })

    $(window).scroll(function() {
    didScroll = true;
    });

    setInterval(function() {
    if( didScroll ) {
    didScroll = false;

    if( $(window).scrollTop() > 1000 ) {
    $arrow.css('display', 'block');
    } else {
    $arrow.css('display', 'none');
    }
    }
    }, 250);
    }

    /* ==================================================
    Thumbs / Social Effects
    ================================================== */

    BRUSHED.utils = function(){

    $('.item-thumbs').bind('touchstart', function(){
    $(".active").removeClass(«active»);
    $(this).addClass('active');
    });

    $('.image-wrap').bind('touchstart', function(){
    $(".active").removeClass(«active»);
    $(this).addClass('active');
    });

    $('#social ul li').bind('touchstart', function(){
    $(".active").removeClass(«active»);
    $(this).addClass('active');
    });

    }

    /* ==================================================
    Accordion
    ================================================== */

    BRUSHED.accordion = function(){
    var accordion_trigger = $('.accordion-heading.accordionize');

    accordion_trigger.delegate('.accordion-toggle','click', function(event){
    if($(this).hasClass('active')){
    $(this).removeClass('active');
    $(this).addClass('inactive');
    }
    else{
    accordion_trigger.find('.active').addClass('inactive');
    accordion_trigger.find('.active').removeClass('active');
    $(this).removeClass('inactive');
    $(this).addClass('active');
    }
    event.preventDefault();
    });
    }

    /* ==================================================
    Toggle
    ================================================== */

    BRUSHED.toggle = function(){
    var accordion_trigger_toggle = $('.accordion-heading.togglize');

    accordion_trigger_toggle.delegate('.accordion-toggle','click', function(event){
    if($(this).hasClass('active')){
    $(this).removeClass('active');
    $(this).addClass('inactive');
    }
    else{
    $(this).removeClass('inactive');
    $(this).addClass('active');
    }
    event.preventDefault();
    });
    }

    /* ==================================================
    Tooltip
    ================================================== */

    BRUSHED.toolTip = function(){
    $('a[data-toggle=tooltip]').tooltip();
    }

    /* ==================================================
    Init
    ================================================== */

    BRUSHED.slider();

    $(document).ready(function(){
    Modernizr.load([
    {
    test: Modernizr.placeholder,
    nope: '_include/js/placeholder.js',
    complete: function() {
    if (!Modernizr.placeholder) {
    Placeholders.init({
    live: true,
    hideOnFocus: false,
    className: «yourClass»,
    textColor: "#999"
    });
    }
    }
    }
    ]);

    // Preload the page with jPreLoader
    $('body').jpreLoader({
    splashID: "#jSplash",
    showSplash: true,
    showPercentage: true,
    autoClose: true,
    splashFunction: function() {
    $('#circle').delay(250).animate({'opacity': 1}, 500, 'linear');
    }
    });

    BRUSHED.nav();
    BRUSHED.mobileNav();
    BRUSHED.listenerMenu();
    BRUSHED.menu();
    BRUSHED.goSection();
    BRUSHED.goUp();
    BRUSHED.filter();
    BRUSHED.fancyBox();
    BRUSHED.contactForm();
    BRUSHED.tweetFeed();
    BRUSHED.scrollToTop();
    BRUSHED.utils();
    BRUSHED.accordion();
    BRUSHED.toggle();
    BRUSHED.toolTip();
    });

    $(window).resize(function(){
    BRUSHED.mobileNav();
    });

    });

    Но вот если я добавлю вызов migx (там я создал слайды)
    slides 					:  	[		
    	[[getImageList? 
        &tvname=`slider`
        &tpl=`@CODE: {image : '[[+image]]', title : '<div class="slide-content">[[+title]]</div>', thumb : '', url : ''},`
        &tplLast=`@CODE: {image : '[[+image]]', title : '<div class="slide-content">[[+title]]</div>', thumb : '', url : ''}`]]
    								],

    то вот ошибка (скрин 2)

    не могу понять когда создаю например карту сайта все работает а вот как можно сделать вызов снипета
    первая ошибка ругается на символ expected in indentifier and instead saw '&'
      Володя
      21 апреля 2017, 08:13
      +1
      то вот ошибка (скрин 2)

      да эт редактор вам подсвечивает неверный синтаксис, но ему то откуда знать что вы сниппет тут решили вставить. Не обращайте внимания и все.
        Alexsandr
        21 апреля 2017, 08:17
        0
        Но тогда вызов снипета не срабатывает
          Володя
          21 апреля 2017, 08:22
          0
          Но тогда вызов снипета не срабатывает

          да уж чудеса чудесные…
          проверьте прежде свой вызов сниппета, уберите все и оставьте только его… будет чего?
            Alexsandr
            21 апреля 2017, 08:34
            0
            Пустой файлик вызов снипета не срабатывает в типе файла javascript, мне интересно как реализовать вызов снипета в таком типе файла
              Володя
              21 апреля 2017, 08:37
              0
              Пустой файлик вызов снипета не срабатывает в типе файла javascript
              то если сменить тип ресурса на другой, все ок? бред помоему…
                Антон
                Антон
                21 апреля 2017, 08:39
                0
                Вы хотите на фронтенде у клиента вызвать сниппет?
                  Alexsandr
                  21 апреля 2017, 08:42
                  0
                  Смотрите: я хочу создать динамический файл javascript в котором вызываються снипеты, затем подключить его уже на страницу. Просто не могу понять как это реализовать
                    Павел Романов
                    21 апреля 2017, 11:02
                    +1
                    1. Попробуйте загнать шаблоны в чанки, и не использовать @CODE:
                    slides : [
                    [[getImageList? 
                    &tvname=`slider`
                    &tpl=`chunk1`
                    &tplLast=`chunk2`
                    ]]
                    ],
                    2. Если используется Fenom на страницах, в чанки добавьте пробелы после скобок:
                    { image : '[[+image]]', title : '<div class="slide-content">[[+title]]</div>', thumb : '', url : '' },
                    и
                    { image : '[[+image]]', title : '<div class="slide-content">[[+title]]</div>', thumb : '', url : '' }
                      Alexsandr
                      21 апреля 2017, 11:04
                      0
                      спасибо что то я про чанки не догадался сразу))
    Авторизуйтесь или зарегистрируйтесь, чтобы оставлять комментарии.
    12