Beispiel #1
0
    function imgLoaded(img, isBroken) {
        // don't proceed if BLANK image, or image is already loaded
        if (img.src === BLANK || $.inArray(img, loaded) !== -1) {
            return;
        }

        // store element in loaded images array
        loaded.push(img);

        // keep track of broken and properly loaded images
        if (isBroken) {
            broken.push(img);
        } else {
            proper.push(img);
        }

        // cache image and its state for future calls
        $.data(img, 'imagesLoaded', {
            isBroken: isBroken,
            src: img.src
        });

        // trigger deferred progress method if present
        if (hasNotify) {
            deferred.notifyWith($(img), [isBroken, $images, $(proper), $(broken)]);
        }

        // call doneLoading and clean listeners if all images are loaded
        if ($images.length === loaded.length) {
            setTimeout(doneLoading);
            $images.unbind('.imagesLoaded', imgLoadedHandler);
        }
    }
Beispiel #2
0
module.exports = function(btn, parent, callback){
  $(btn).addClass('wgt_scrollToTop')
    .data('scrollToTopCallback', callback);

  if(!parent){
    parent = btn;
  }
  $(parent).addClass('wgt_parent_scrollToTop top-arrived');
};
Beispiel #3
0
    changeParams: function(params) {
        var self = this;

        $('#waterFall').html('');
        $('#waterfall-message').remove();
        $('#waterfall-loading').remove();

        self.waterfall.option(params);
        self.afterLoad();
    },
Beispiel #4
0
$('body').on('click', '.wgt_scrollToTop', function(){
  var btn = $(this);
  var toTopBtnsParent = $(this).closest('.wgt_parent_scrollToTop');

  isScrolling = true;
  scrollTo(null, null, function(){
    isScrolling = false;
    toTopBtnsParent.addClass('top-arrived');
    safeCall(btn.data('scrollToTopCallback'));
  });
});
Beispiel #5
0
    function doneLoading() {
        var $proper = $(proper),
            $broken = $(broken);

        if (deferred) {
            if (broken.length) {
                deferred.reject($images, $proper, $broken);
            } else {
                deferred.resolve($images);
            }
        }

        if ($.isFunction(callback)) {
            callback.call($this, $images, $proper, $broken);
        }
    }
Beispiel #6
0
// 图片预览
function showResult() {

    feature = picCrop.getHiphotoFeature();
    var cropInfo = picCrop.getcropInfo();
    var ratioX = 240 / cropInfo.width;
    var ratioY = 160 / cropInfo.height;
    var cropResult = $('<img src="' + originalInfo.picUrl + '"  alt="" />');
    $('.poster-wrap').html(cropResult);
    $('.poster-wrap img').css({
        width: originalInfo.width * ratioX,
        height: originalInfo.height * ratioY,
        marginLeft: '-' + Math.round(ratioX * cropInfo.x1) + 'px',
        marginTop: '-' + Math.round(ratioY * cropInfo.y1) + 'px'
    });
    cropDialog.hide();
}
Beispiel #7
0
 afterLoad: function() {
     // 瀑布流加载后回调函数
     $('#waterFall').on('click', '.waterFall_item ', function() {
         nsLog({
             type: 8997
         });
     });
 }
Beispiel #8
0
$(window).on('scroll', function(){
  if (!isScrolling) {
    var toTopBtnsParent = $('.wgt_parent_scrollToTop');

    if (scrollHost.scrollTop > 800) {
      toTopBtnsParent.removeClass('top-arrived');
    } else {
      toTopBtnsParent.addClass('top-arrived');
    }
  }
});
Beispiel #9
0
    prepareParams: function() {
        var tagIds = [],
            postParams = {},
            limit = limitNum,
            contentLength = isFromLemma ? 38 : 40,
            currentTagId = $('#current_tag_id').val();
            
        $('#category .selected').each(function() {
            var tagId = $(this).attr('data-value') || 0;
            tagIds.push(tagId);
        });

        postParams = {
            limit: limit,
            timeout: 3000,
            filterTags: jsonStringify(tagIds),
            tagId: currentTagId,
            fromLemma: isFromLemma,
            contentLength: contentLength
        };

        return postParams;
    },
Beispiel #10
0
 setTimeout(function () {
     $('.crop-container').html('');
     picCrop = new PicCrop({
         container: '.crop-container',
         picUrl: picInfo.picUrl,
         boxWidth: 450,
         boxHeight: 300,
         cropWidth: 240,
         cropHeight: 160,
         selectArr: [0, 0, picInfo.width, picInfo.height],
         originalWidth: picInfo.width,
         originalHeight: picInfo.height
     });
     cropDialog.find('.crop-btn').on('click', showResult);
 }, 1000);
Beispiel #11
0
 * @example    // 典型的调用示例。
    var createWaterFall = require('wiki-tag:widget/waterfall/createWaterFall.js');

    createWaterFall.prepareParams();          // 生成瀑布流初始化数据
    createWaterFall.initWaterFall(params);    // 初始化并启动瀑布流
    createWaterFall.changeParams(params);     // 重置瀑布流
 */

var $ = require('wiki-common:widget/lib/jquery/jquery.js'),
    jsonStringify = require('wiki-common:widget/util/string.js').jsonStringify,
    scrollTo = require('wiki-common:widget/util/scrollTo.js'),
    JSmart = require('wiki-common:widget/lib/jsmart/jsmart.js'),
    waterFall = require('wiki-tag:widget/util/waterfall/waterfall.js'),
    nsLog = require('wiki-common:widget/component/nslog/nslog.js');

var fromLemma = $('#fromLemma').val();
var isFromLemma = (fromLemma === '1');
var page = $('#page').val();
var isPage = (page === '1');
var limitNum = $('#limit').val();
var top = $("#category").position().top;
var img1 = '';
var img2 = '';
var src = isPage ? img1 : img2;
var createWaterFall = {
    waterfall: null,
    prepareParams: function() {
        var tagIds = [],
            postParams = {},
            limit = limitNum,
            contentLength = isFromLemma ? 38 : 40,
Beispiel #12
0
module.exports = function(host, callback) {

    'use strict';

    // blank image data-uri bypasses webkit log warning (thx doug jones)
    var BLANK = '';

    var $this = $(host),
        deferred = $.isFunction($.Deferred) ? $.Deferred() : 0,
        hasNotify = $.isFunction(deferred.notify),
        $images = $this.find('img').add($this.filter('img')),
        loaded = [],
        proper = [],
        broken = [];

    // Register deferred callbacks
    if ($.isPlainObject(callback)) {
        $.each(callback, function(key, value) {
            if (key === 'callback') {
                callback = value;
            } else if (deferred) {
                deferred[key](value);
            }
        });
    }

    function doneLoading() {
        var $proper = $(proper),
            $broken = $(broken);

        if (deferred) {
            if (broken.length) {
                deferred.reject($images, $proper, $broken);
            } else {
                deferred.resolve($images);
            }
        }

        if ($.isFunction(callback)) {
            callback.call($this, $images, $proper, $broken);
        }
    }

    function imgLoadedHandler(event) {
        imgLoaded(event.target, event.type === 'error');
    }

    function imgLoaded(img, isBroken) {
        // don't proceed if BLANK image, or image is already loaded
        if (img.src === BLANK || $.inArray(img, loaded) !== -1) {
            return;
        }

        // store element in loaded images array
        loaded.push(img);

        // keep track of broken and properly loaded images
        if (isBroken) {
            broken.push(img);
        } else {
            proper.push(img);
        }

        // cache image and its state for future calls
        $.data(img, 'imagesLoaded', {
            isBroken: isBroken,
            src: img.src
        });

        // trigger deferred progress method if present
        if (hasNotify) {
            deferred.notifyWith($(img), [isBroken, $images, $(proper), $(broken)]);
        }

        // call doneLoading and clean listeners if all images are loaded
        if ($images.length === loaded.length) {
            setTimeout(doneLoading);
            $images.unbind('.imagesLoaded', imgLoadedHandler);
        }
    }

    // if no images, trigger immediately
    if (!$images.length) {
        doneLoading();
    } else {
        $images.bind('load.imagesLoaded error.imagesLoaded', imgLoadedHandler)
            .each(function(i, el) {
                var src = el.src,

                    // find out if this image has been already checked for status
                    // if it was, and src has not changed, call imgLoaded on it
                    cached = $.data(el, 'imagesLoaded');
                if (cached && cached.src === src) {
                    imgLoaded(el, cached.isBroken);
                    return;
                }

                // if complete is true and browser supports natural sizes, try
                // to check for image status manually
                if (el.complete && el.naturalWidth !== undefined) {
                    imgLoaded(el, el.naturalWidth === 0 || el.naturalHeight === 0);
                    return;
                }

                // cached images don't fire load sometimes, so we reset src, but only when
                // dealing with IE, or image is complete (loaded) and failed manual check
                // webkit hack from http://groups.google.com/group/jquery-dev/browse_thread/thread/eee6ab7b2da50e1f
                if (el.readyState || el.complete) {
                    el.src = BLANK;
                    el.src = src;
                }
            });
    }

    return deferred ? deferred.promise($this) : $this;

};
Beispiel #13
0
    var scrollToTop = require('wiki-common:widget/util/scrollToTop.js');

    scrollToTop('#someBtnId', function(){    // 注册“返回页首”按钮
      console.log('已返回页首');
    });
 */

var $ = require('wiki-common:widget/lib/jquery/jquery.js'),
  scrollTo = require('wiki-common:widget/util/scrollTo.js'),
  browser = require('wiki-common:widget/util/browser.js'),
  safeCall = require('wiki-common:widget/util/safeCall.js');

var scrollHost = (browser.ie() || browser.firefox()) ? document.documentElement : document.body,
  isScrolling = false;

$(window).on('scroll', function(){
  if (!isScrolling) {
    var toTopBtnsParent = $('.wgt_parent_scrollToTop');

    if (scrollHost.scrollTop > 800) {
      toTopBtnsParent.removeClass('top-arrived');
    } else {
      toTopBtnsParent.addClass('top-arrived');
    }
  }
});

$('body').on('click', '.wgt_scrollToTop', function(){
  var btn = $(this);
  var toTopBtnsParent = $(this).closest('.wgt_parent_scrollToTop');
Beispiel #14
0
 $('#category .selected').each(function() {
     var tagId = $(this).attr('data-value') || 0;
     tagIds.push(tagId);
 });
Beispiel #15
0
/**
 * @file import
 */
var $ = require('wiki-common:widget/lib/jquery/jquery.js');
var Dialog = require('wiki-common:widget/ui/dialog/dialog.js');
var lemmaImport = require('wiki-tag:widget/mis/lemmaImport.js');


// 词条批量、分步操作
var $importArea = $('#importArea');

lemmaImport.init({
    host: $('.result'),
    span: 500,
    url: '/api/tagtask/submitmanagerlemma',
    extAjaxData: {
        taskId: window.tplData.taskId,
        type: 'add',
        tk: window.tplData.tk
    }
});

$('#add').on('click', function () {
    var lemmaIds = $.trim($importArea.val()).split('\n');
    lemmaImport.reset({
        lemmas: lemmaIds,
        extAjaxData: {
            type: 'add'
        }
    });
    Dialog.confirm({
Beispiel #16
0
/**
 * @file create
 */
var $ = require('wiki-common:widget/lib/jquery/jquery.js');
require('wiki-tag:widget/datePicker/js/jquery-ui.js')($);
require('wiki-tag:widget/datePicker/js/jquery-ui-timepicker.js')($);

var Dialog = require('wiki-common:widget/ui/dialog/dialog.js');
var PicUploader = require('wiki-common:widget/component/picUploader/picUploader.js');
var PicCrop = require('wiki-common:widget/component/picUploader/picCropper.js');

//  开始、结束时间
$('.startTime').datetimepicker({
    timeFormat: 'hh:mm:ss'
});
$('.endTime').datetimepicker({
    timeFormat: 'hh:mm:ss'
});


// 上传图片
var feature = null;
var picCrop = null;
var originalInfo = null;
var defaultPicInfo = window.tplData.defaultPicInfo;
var cropDialog = $('.crop-dialog');

var picUploader = new PicUploader({
    uploadBtn: '#poster-edit',
    previewWidth: 240,
    previewHeight: 160,
Beispiel #17
0
$('.submitBtn').on('click', function () {
    var action = $(this).attr('data-action');
    var taskName = $('.taskName').val();
    var startTime = $('.startTime').val();
    var endTime = $('.endTime').val();
    var groupType = $('.limit input:checked').val();
    var tags = [];
    var desc = $('textarea[name="description"]').val();
    var tagInput = $('.tagName input');

    for (var i = 0; i < tagInput.length; i++) {
        tags.push(tagInput.eq(i).val());
    }
    if (!taskName) {
        Dialog.alert({
            icon: 'ERROR',
            mainMsg: '请输入任务名称'
        });
        return;
    }
    if (!groupType) {
        Dialog.alert({
            icon: 'ERROR',
            mainMsg: '请选择参与资格'
        });
        return;
    }
    if (!desc) {
        Dialog.alert({
            icon: 'ERROR',
            mainMsg: '请填写任务介绍'
        });
        return;
    }

    var params = {
        name: taskName,
        startTime: startTime ? startTime : 0,
        endTime: endTime ? endTime : 0,
        groupType: groupType,
        tags: tags,
        description: desc
    };
    if (feature) {
        var uploadImgInfo = $.extend({
            'crop': feature.split(';')[0].split('=')[1],
            'eWH': feature.split(';')[1].split('=')[1]
        }, originalInfo);
        params.uploadImgInfo = uploadImgInfo;
        params.image = defaultPicInfo;
    } else {
        params.image = defaultPicInfo;
    }


    if (window.tplData.taskId) {
        params.taskId = window.tplData.taskId;
    }
    $.ajax({
        type: 'POST',
        url: '/api/tagtask/' + action,
        data: params,

        success: function () {
            Dialog.alert({
                mainMsg: '操作成功',
                onConfirm: function () {
                    window.location.reload();
                }
            });
        },
        error: function () {
            Dialog.alert({
                icon: 'Error',
                mainMsg: '系统错误,请稍候重试'
            });
        }
    });
});
Beispiel #18
0
$('.tagName span').on('click', function () {
    var newInput = $('<li><span>标签' + addNum + '</span><input type="text" name="tags"></li>');
    $('.input-wrap').append(newInput);
    addNum++;
});