$(function() { entry = Array(); category = Array(); category['list/'] = Array(); category['list/']['title'] = "ENTRY-施工実績-DEALER:HQ"; category['list/']['description'] = "コンテナハウス 2040JP"; category['list/']['type'] = "https://2040.jp"; category['list/']['pagenation'] = "0"; category['list/']['format'] = "Content_Format_001"; category['list/']['directory'] = "list/"; category['list/'] = Array(); category['list/']['title'] = "ENTRY-施工実績-DEALER:HOKKAIDO"; category['list/']['description'] = "コンテナハウス 2040北海道.jp"; category['list/']['type'] = "https://2040hokkaido.jp"; category['list/']['pagenation'] = "1"; category['list/']['format'] = "Content_Format_001"; category['list/']['directory'] = "list/"; category['list/'] = Array(); category['list/']['title'] = "ENTRY-施工実績-DEALER:TOHOKU"; category['list/']['description'] = "コンテナハウス 2040東北.jp"; category['list/']['type'] = "https://2040tohoku.jp"; category['list/']['pagenation'] = "2"; category['list/']['format'] = "Content_Format_001"; category['list/']['directory'] = "list/"; category['list/'] = Array(); category['list/']['title'] = "ENTRY-施工実績-DEALER:SHINSHU"; category['list/']['description'] = "コンテナハウス 2040信州.jp"; category['list/']['type'] = "https://2040shinshu.jp"; category['list/']['pagenation'] = "3"; category['list/']['format'] = "Content_Format_001"; category['list/']['directory'] = "list/"; category['list/'] = Array(); category['list/']['title'] = "ENTRY-施工実績-DEALER:SAITAMA"; category['list/']['description'] = "コンテナハウス 2040埼玉.jp"; category['list/']['type'] = "https://2040saitama.jp"; category['list/']['pagenation'] = "4"; category['list/']['format'] = "Content_Format_001"; category['list/']['directory'] = "list/"; category['list/'] = Array(); category['list/']['title'] = "ENTRY-施工実績-DEALER:YAMANASHI"; category['list/']['description'] = "コンテナハウス 2040山梨.jp"; category['list/']['type'] = "https://2040yamanashi.jp"; category['list/']['pagenation'] = "5"; category['list/']['format'] = "Content_Format_001"; category['list/']['directory'] = "list/"; category['list/'] = Array(); category['list/']['title'] = "ENTRY-施工実績-DEALER:WAKAYAMA"; category['list/']['description'] = "コンテナハウス 2040和歌山.jp"; category['list/']['type'] = "https://2040wakayama.jp"; category['list/']['pagenation'] = "6"; category['list/']['format'] = "Content_Format_001"; category['list/']['directory'] = "list/"; category['list/'] = Array(); category['list/']['title'] = "ENTRY-施工実績-DEALER:HYOGO"; category['list/']['description'] = "コンテナハウス 2040兵庫.jp"; category['list/']['type'] = "https://2040hyogo.jp"; category['list/']['pagenation'] = "7"; category['list/']['format'] = "Content_Format_001"; category['list/']['directory'] = "list/"; category['list/'] = Array(); category['list/']['title'] = "ENTRY-施工実績-DEALER:FUKUOKA"; category['list/']['description'] = "コンテナハウス 2040福岡.jp"; category['list/']['type'] = "https://2040fukuoka.jp"; category['list/']['pagenation'] = "8"; category['list/']['format'] = "Content_Format_001"; category['list/']['directory'] = "list/"; category['root'] = Array(); category['root']['title'] = "top"; category['root']['description'] = ""; category['root']['type'] = "page"; category['root']['pagenation'] = "0"; category['root']['format'] = "Part_Content_001"; category['root']['directory'] = "root"; category['list/'] = Array(); category['list/']['title'] = "GALLERY - 施工実績"; category['list/']['description'] = ""; category['list/']['type'] = "page"; category['list/']['pagenation'] = "10"; category['list/']['format'] = "Part_Content_040"; category['list/']['directory'] = "list/"; category['list/house/'] = Array(); category['list/house/']['title'] = "施工実績/TYPE:HOUSE"; category['list/house/']['description'] = ""; category['list/house/']['type'] = "page"; category['list/house/']['pagenation'] = "11"; category['list/house/']['format'] = "Part_Content_040"; category['list/house/']['directory'] = "list/house/"; category['list/store/'] = Array(); category['list/store/']['title'] = "施工実績/TYPE:STORE"; category['list/store/']['description'] = ""; category['list/store/']['type'] = "page"; category['list/store/']['pagenation'] = "12"; category['list/store/']['format'] = "Part_Content_040"; category['list/store/']['directory'] = "list/store/"; category['list/office/'] = Array(); category['list/office/']['title'] = "施工実績/TYPE:OFFICE"; category['list/office/']['description'] = ""; category['list/office/']['type'] = "page"; category['list/office/']['pagenation'] = "13"; category['list/office/']['format'] = "Part_Content_040"; category['list/office/']['directory'] = "list/office/"; category['list/accommodation/'] = Array(); category['list/accommodation/']['title'] = "施工実績/TYPE:ACCOMMODATION"; category['list/accommodation/']['description'] = ""; category['list/accommodation/']['type'] = "page"; category['list/accommodation/']['pagenation'] = "14"; category['list/accommodation/']['format'] = "Part_Content_040"; category['list/accommodation/']['directory'] = "list/accommodation/"; category['list/others/'] = Array(); category['list/others/']['title'] = "施工実績/TYPE:OTHERS"; category['list/others/']['description'] = ""; category['list/others/']['type'] = "page"; category['list/others/']['pagenation'] = "15"; category['list/others/']['format'] = "Part_Content_040"; category['list/others/']['directory'] = "list/others/"; category['list/hq/'] = Array(); category['list/hq/']['title'] = "施工実績/DEALER:HQ"; category['list/hq/']['description'] = ""; category['list/hq/']['type'] = "page"; category['list/hq/']['pagenation'] = "16"; category['list/hq/']['format'] = "Part_Content_040"; category['list/hq/']['directory'] = "list/hq/"; category['list/hokkaido/'] = Array(); category['list/hokkaido/']['title'] = "施工実績/DEALER:HOKKAIDO"; category['list/hokkaido/']['description'] = ""; category['list/hokkaido/']['type'] = "page"; category['list/hokkaido/']['pagenation'] = "17"; category['list/hokkaido/']['format'] = "Part_Content_040"; category['list/hokkaido/']['directory'] = "list/hokkaido/"; category['list/tohoku/'] = Array(); category['list/tohoku/']['title'] = "施工実績/DEALER:TOHOKU"; category['list/tohoku/']['description'] = ""; category['list/tohoku/']['type'] = "page"; category['list/tohoku/']['pagenation'] = "18"; category['list/tohoku/']['format'] = "Part_Content_040"; category['list/tohoku/']['directory'] = "list/tohoku/"; category['list/shinshu/'] = Array(); category['list/shinshu/']['title'] = "施工実績/DEALER:SHINSHU"; category['list/shinshu/']['description'] = ""; category['list/shinshu/']['type'] = "page"; category['list/shinshu/']['pagenation'] = "19"; category['list/shinshu/']['format'] = "Part_Content_040"; category['list/shinshu/']['directory'] = "list/shinshu/"; category['list/saitama/'] = Array(); category['list/saitama/']['title'] = "施工実績/DEALER:SAITAMA"; category['list/saitama/']['description'] = ""; category['list/saitama/']['type'] = "page"; category['list/saitama/']['pagenation'] = "20"; category['list/saitama/']['format'] = "Part_Content_040"; category['list/saitama/']['directory'] = "list/saitama/"; category['list/yamanashi/'] = Array(); category['list/yamanashi/']['title'] = "施工実績/DEALER:YAMANASHI"; category['list/yamanashi/']['description'] = ""; category['list/yamanashi/']['type'] = "page"; category['list/yamanashi/']['pagenation'] = "21"; category['list/yamanashi/']['format'] = "Part_Content_040"; category['list/yamanashi/']['directory'] = "list/yamanashi/"; category['list/wakayama/'] = Array(); category['list/wakayama/']['title'] = "施工実績/DEALER:WAKAYAMA"; category['list/wakayama/']['description'] = ""; category['list/wakayama/']['type'] = "page"; category['list/wakayama/']['pagenation'] = "22"; category['list/wakayama/']['format'] = "Part_Content_040"; category['list/wakayama/']['directory'] = "list/wakayama/"; category['list/hyogo/'] = Array(); category['list/hyogo/']['title'] = "施工実績/DEALER:HYOGO"; category['list/hyogo/']['description'] = ""; category['list/hyogo/']['type'] = "page"; category['list/hyogo/']['pagenation'] = "23"; category['list/hyogo/']['format'] = "Part_Content_040"; category['list/hyogo/']['directory'] = "list/hyogo/"; category['list/fukuoka/'] = Array(); category['list/fukuoka/']['title'] = "施工実績/DEALER:FUKUOKA"; category['list/fukuoka/']['description'] = ""; category['list/fukuoka/']['type'] = "page"; category['list/fukuoka/']['pagenation'] = "24"; category['list/fukuoka/']['format'] = "Part_Content_040"; category['list/fukuoka/']['directory'] = "list/fukuoka/"; function htmlEncode(value){ return $('
').text(value).html(); } function htmlDecode(value){ return $('
').html(value).text(); } var href = ""; var past_href = location.href; var past_directory = $("body").attr("data-directory"); var past_index_num = $("body").attr("data-index_num"); var past_archive_year_dir = $("body").attr("data-archive_year_dir"); var past_modal_content_type = ""; var memo_scroll = 0; var id = past_href.replace( "https://2040gallery.jp/", "" ).replace( "?mode=preview", "" ); var option = ""; navi_active(past_href); var hash = ""; if(past_href.indexOf( "#/" ) != -1){ hash_arr = past_href.split("#/"); past_href = hash_arr[0]; hash = hash_arr[1]; PJAX_hash( hash ); } function PJAX_pjax( href, option, target ) { hash = ""; if(href.indexOf( "#/" ) != -1){ hash_arr = href.split("#/"); href = hash_arr[0]; hash = hash_arr[1]; PJAX_hash( hash ); } var scroll_id = href.replace( "https://2040gallery.jp/", "" ).replace( "?mode=preview", "" ); if( scroll_id == "" ){ scroll_id = "root"; } PJAX_scroll_ground( scroll_id, option ); if( href && past_href != href && href.indexOf( "#" ) == -1 ){ scroll_action_flag = false; if( typeof scroll_action_limiter != "undefined" ){ clearTimeout( scroll_action_limiter ); } id = href.replace( "https://2040gallery.jp/", "" ).replace( "?mode=preview", "" ); if( typeof entry[id] != "undefined" ){ id = entry[id]; href = href.replace( id, entry[id] ); } past_href = href; console.log("──── pjax ────"); console.log("href: " + href); console.log("id: " + id); console.log("option: " + option); console.log("target: " + target); var data_directory = ""; if( typeof $("body").attr("data-directory") !== 'undefined' && $("body").attr("data-directory") !== false ){ var data_directory = String($("body").attr("data-directory")); } var data_archive_year_dir = ""; if( typeof $("body").attr("data-archive_year_dir") !== 'undefined' && $("body").attr("data-archive_year_dir") !== false ){ var data_archive_year_dir = String($("body").attr("data-archive_year_dir")); } var data_index_num = ""; if( typeof $("body").attr("data-index_num") !== 'undefined' && $("body").attr("data-index_num") !== false ){ var data_index_num = String($("body").attr("data-index_num")); } if( option != "by_scroll" && typeof category[scroll_id] != "undefined" && category[scroll_id]['type'] != "modal" && category[scroll_id]['directory'] == data_directory && data_archive_year_dir+data_index_num == "" ){ }else if( option != "by_onpop" && option != "by_scroll" && option != "by_load_more" ){ $("body").append('
'); $("body > div.loading").addClass("show"); } if( typeof pjax_request != "undefined" ){ pjax_request.abort(); } pjax_request = $.ajax({ url: "https://2040gallery.jp/js_pjax_json.php", data: "id=" + id + "&type=json" + "", dataType: "json", success: function(data, dataType){ var pagetitle = data.pagetitle; var meta_og_image = data.meta_og_image; var permalink = data.permalink; var page_format = data.page_format; var body_class = data.body_class; var path = data.path; var directory = data.directory; var directory_1 = data.directory_1; var directory_2 = data.directory_2; var directory_3 = data.directory_3; var directory_4 = data.directory_4; var file = data.file; var scroll = data.scroll; var page_type = data.page_type; var pagenation = data.pagenation; var index_num = data.index_num; var archive_year_dir = data.archive_year_dir; var index_parent_dir = data.index_parent_dir; var modal_content_type = data.modal_content_type; var modal_content_page_format = data.modal_content_page_format; var modal_content_entry_date = data.modal_content_entry_date; var modal_content_entry_title_jp = data.modal_content_entry_title_jp; var modal_content_entry_title_en = data.modal_content_entry_title_en; var modal_content_entry_description_jp = data.modal_content_entry_description_jp; var modal_content_entry_description_en = data.modal_content_entry_description_en; var modal_content_media = data.modal_content_media; if( option != "by_onpop" && // option != "by_forward" && option != "by_load_more" ){ console.log("push"); PJAX_pushState( href, pagetitle ); } document.title = pagetitle; var ga_title = pagetitle; if( option != "by_load_more" ){ $("body").attr("class",body_class); $("body").attr("data-file",file); if( modal_content_type == "" ){ $("body").attr("data-scroll",scroll); $("body").attr("data-directory",directory); $("body").attr("data-index_num",index_num); $("body").attr("data-archive_year_dir",archive_year_dir); } } console.log("modal_content_type: " + modal_content_type); console.log("past_directory: " + past_directory); console.log("directory: " + directory); console.log("pagenation: " + pagenation); console.log("page_type: " + page_type); console.log("index_num: " + index_num); console.log("archive_year_dir: " + archive_year_dir); console.log("index_parent_dir: " + index_parent_dir); console.log("scroll: " + scroll); navi_active(href); if( modal_content_type != "" ){ past_modal_content_type = modal_content_type; PJAX_ajaxload_modal( href, data, option, target ); }else{ if( option != "by_scroll" ){ if( option == "by_load_more" && target != "" ){ PJAX_ajaxload_loadmore( href, data, option, target ); }else if( past_directory != directory || past_index_num != index_num || past_archive_year_dir != archive_year_dir ){ past_index_num = index_num; past_directory = directory; past_archive_year_dir = archive_year_dir; scrollto(0); PJAX_ajaxload_directory( href, data, option, target ); }else if( past_directory == directory && scroll == "" ){ scroll_action_flag = true; if( past_modal_content_type == "" ){ scrollto(0); }else{ } PJAX_loading_remove(); }else{ scroll_action_flag = true; if( past_modal_content_type == "" ){ scroll_action_flag = false; var scrollto_val = 0; if( scroll != "" ){ // window_resize(); scrollto_val = $("#" + selectorEscape(scroll)).position().top + 10; } scrollto(scrollto_val); }else{ window_resize(); if( scroll != "" ){ // window_resize(); scrollto_val = $("#" + selectorEscape(scroll)).position().top + 10; scrollto(scrollto_val); } } PJAX_loading_remove(); } } past_modal_content_type = ""; } setTimeout( function(){ if( $("body #entry").css("z-index") == -1 ){ $("body #entry").empty(); } } , 2000); }, error: function(XMLHttpRequest, textStatus, errorThrown){ } }); }else{ if( option != "by_scroll" ){ var elm_id = id.replace( /\//g, '' ); if( $("#"+elm_id)[0] ){ var target= $("#"+elm_id); var scrollto_val = target.position().top + 10; scrollto(scrollto_val); }else{ // scrollto(0); } } PJAX_loading_remove(); } } function PJAX_loading_remove() { $("body > div.loading").removeClass("show"); setTimeout( function(){ $("body > div.loading").remove(); } , 1000); } function PJAX_scroll_ground( scroll_id, option ) { // window_resize(); if( option != "by_scroll" && typeof category[scroll_id] != "undefined" && category[scroll_id]['type'] != "modal" && category[scroll_id]['directory'] == $("body").attr("data-directory") ){ if( past_modal_content_type == "" ){ // console.log("ground: " + scroll_id); var scrollto_val = 0; if( category[scroll_id]['type'] == "ground" && $("#" + selectorEscape(scroll_id))[0] ){ scrollto_val = $("#" + selectorEscape(scroll_id)).position().top + 10; } scrollto(scrollto_val); }else{ $("body").removeClass("entry modal"); } PJAX_loading_remove(); } } function PJAX_ajaxload_modal( href, data, option, target ) { $("#entry").empty(); if( typeof ajax_request != "undefined" ){ ajax_request.abort(); } ajax_request = $.ajax({ url: href, dataType: "html", success: function(data, dataType){ var get_elm = $('#entry > *', $('
').prepend(data)); $("#entry").append(get_elm); $("#entry > div.inner").addClass("pending"); setTimeout( function(){ $("#entry > div.inner").removeClass("pending"); window_resize(); } , 100); // var container_id = $("body #container > div#base > article").attr("id"); // if( container_id == "root" ){ // container_id = ""; // } // var return_href = "https://2040gallery.jp/" + container_id; // $("#entry a.pjax.close").attr("href",return_href); // $("#entry a.pjax.return").attr("href",return_href); img_load(); window_resize(); PJAX_loading_remove(); }, error: function(XMLHttpRequest, textStatus, errorThrown){ } }); } function PJAX_ajaxload_directory( href, data, option, target ) { $("body > #wrapper > #container > div.static_elm").fadeOut(1000, function() { $(this).remove(); }); $("html").addClass("moving"); var scroll = data.scroll; if( typeof ajax_request != "undefined" ){ ajax_request.abort(); } ajax_request = $.ajax({ url: href, dataType: "html", success: function(ajax_data, dataType){ console.log($('#wrapper.logged_in', $('
').prepend(ajax_data))); if( $('#wrapper.logged_in', $('
').prepend(ajax_data))[0] ){ $("#wrapper").addClass("logged_in"); }else{ $("#wrapper").removeClass("logged_in"); } var get_article_elm = $('#container > div#base > article', $('
').prepend(ajax_data)); $("#container > div#base > article").addClass("leave"); $("#container > div#base").append(get_article_elm); // var get_navi_elm = $('#navi', $('
').prepend(ajax_data)); // $("#navi").empty(); // $("#navi").prepend(get_navi_elm); $("#container > div#base > article").addClass("ajax"); setTimeout( function(){ $("#container > div#base > article.leave").remove(); setTimeout( function(){ $("html").removeClass("moving"); scroll_trigger(); } , 500); load_iframe(); // FB.XFBML.parse(); window_resize(); PJAX_loading_remove(); var scrollto_val = 0; if( scroll != "" ){ scrollto_val = $("#" + selectorEscape(scroll)).position().top; } scrollto(scrollto_val); img_load(); } , 10); img_load(); scroll_action_flag = true; }, error: function(XMLHttpRequest, textStatus, errorThrown){ } }); } function PJAX_ajaxload_loadmore( href, data, option, target ) { var scroll = data.scroll; if( typeof ajax_request != "undefined" ){ ajax_request.abort(); } ajax_request = $.ajax({ url: href, dataType: "html", success: function(data, dataType){ target.children("li.load_more").remove(); var get_elm = $('div.index > ul > *', $('
').prepend(data)); target.append(get_elm); img_load(); window_resize(); PJAX_loading_remove(); if( ! $("body.modal")[0] && ! $("body.entry")[0] ){ scroll_action_flag = true; } var target_index = target.closest(".index"); // thm_random_fade_start( target_index ); }, error: function(XMLHttpRequest, textStatus, errorThrown){ } }); } function scrollto(val){ scroll_action_flag = false; $('html, body').stop().animate({ scrollTop: val }, 1000, "easeOutQuint",function(){ scroll_action_flag = true; }); } function PJAX_pushState( href, title ) { if ( window.history.pushState ) { window.history.pushState( title, null, href ); } else { } } window.onpopstate = function(event){ if (event.state) { } else { } var href = location.href; if ( window.history.pushState ) { PJAX_pjax( href, "by_onpop", "" ); } else { var href = "https://2040gallery.jp/#!/" + href.replace( /^.\//, '' ); window.location = href; } } $(document).on("click", "a.pjax:not(.deactive)", function(){ var href = $(this).attr("href"); if ( window.history.pushState ) { PJAX_pjax( href, "", "" ); } else { var href = href.replace( "https://2040gallery.jp/", "" ); var href = "https://2040gallery.jp/#!/" + href.replace( /^.\//, '' ); var past_href = location.href; window.location = href; } return false; }); $(document).on("click", "div.index > ul > li.load_more > a.pjax_load_more", function(){ var href = $(this).attr("href"); var target = $(this).closest("ul"); if ( window.history.pushState ) { var parent = $(this).parent(); parent.addClass("loading"); parent.append('
loading
'); PJAX_pjax( href, "by_load_more", target ); } return false; }); $(window).hashchange( function(){ var hash = location.hash; if( hash.indexOf( "#!/" ) != -1 ){ var href = hash.replace( /^#!\//, '' ); if( href == "" ){ var href = "https://2040gallery.jp/"; } PJAX_pjax( href, "", "" ); }else if(hash.indexOf( "#/" ) != -1){ hash_arr = hash.split("#/"); hash = hash_arr[1]; PJAX_hash( hash ); } }) $(window).bind('load', function() { var hash = location.hash; if( hash.indexOf( "#!/" ) != -1 ){ var href = hash.replace( /^#!\//, '' ); if ( window.history.pushState ) { window.location = href; }else{ PJAX_pjax( href, "", "" ); } } }); function scroll_trigger() { if( $("html:not(.moving) .scroll_trigger:not(.action)")[0] ){ $(".scroll_trigger:not(.action)").each(function(i){ var target = $(this); var position = target.offset().top; var move_y = +(position - scroll_val); var in_position = position + window_height/1000; var window_bottom_position = $(window).scrollTop() + $(window).height(); if(in_position < window_bottom_position){ target.addClass('action'); if( target.find(".auto_fade")[0] ){ var target_elm = target.find(".auto_fade"); setTimeout(function(){ elm_fade( target_elm, 150 ); },100); } if( target.find(".textillate_wrapper")[0] ){ var target_textillate = target.find(".textillate_wrapper"); setTimeout(function(){ textillate( target_textillate, 600 ); },100); } if( target.find("iframe.pending")[0] ){ var target_iframe = target.find("iframe.pending"); setTimeout(function(){ target_iframe.removeClass("pending") target_iframe.attr("src",target_iframe.attr("data-src")); },100); } // if( target.find("video[autoplay]")[0] ){ // var target_video = target.find("video[autoplay]"); // target_video.each(function(i){ // var player = $(this).get(0); // player.play(); // }); // } } }); } } function textillate(wrapper,speed) { if( wrapper.find("span")[0] ){ wrapper.addClass("textillate"); wrapper.find("span").each(function(i){ // $(this).delay(speed*i).queue(function() { // $(this).addClass("show"); // }); $(this).delay(speed*i).queue(function() { $(this).textillate({ in: { effect: 'fadeIn', delay: 50 } }).dequeue(); }); }); } } function elm_fade( targets, delay ){ var target_num = targets.length; $(targets[0]).addClass("show"); targets.splice(0,1); if (target_num > 0) { setTimeout(function(){ elm_fade( targets, delay ); },delay); } else { return false; } } function thm_random_fade_start( target_index ){ var target_thms = target_index.find("ul > li.thm:not(.show)"); thm_random_fade( target_thms, 200 ); } function thm_random_fade( targets, delay ){ var target_num = targets.length; var random_i = Math.floor(Math.random()*target_num); $(targets[random_i]).addClass("show"); targets.splice(random_i,1); if (target_num > 0) { setTimeout(function(){ thm_random_fade( targets, delay ); },delay); } else { return false; } } function scroll_off(){ var scroll_event = 'onwheel' in document ? 'wheel' : 'onmousewheel' in document ? 'mousewheel' : 'DOMMouseScroll'; $(document).on(scroll_event,function(e){e.preventDefault();}); $(document).on('touchmove.noScroll', function(e) {e.preventDefault();}); } function scroll_on(){ var scroll_event = 'onwheel' in document ? 'wheel' : 'onmousewheel' in document ? 'mousewheel' : 'DOMMouseScroll'; $(document).off(scroll_event); $(document).off('.noScroll'); } if( id == "" ){ // scroll_off(); }else{ // scroll_on(); } var document_height = $(document).height(); var content_height = get_total_height($("#container > div#base > *")); var entry_height = get_total_height($("#entry > div.inner > *")); if( $("html.touch_device")[0] ){ if( window.innerHeight > window.innerWidth ){ var window_height = $(window).height(); }else{ var window_height = $(window).height(); } }else{ var window_height = window.innerHeight ? window.innerHeight: $(window).height(); } var window_width = $(window).width(); var window_ratio = window_height / window_width; var scroll_val = $(window).scrollTop(); var scroll_action_flag = true; if( $("body #container > div#base article.ground")[0] ){ scroll_action_flag = false; } if( $("body.modal")[0] ){ scroll_action_flag = false; } if( $("body.entry")[0] ){ scroll_action_flag = false; } function base_scroll() { scroll_trigger(); scroll_val = $(window).scrollTop(); // console.log(scroll_val+window_height+"|"+content_height); if( scroll_val+window_height > content_height - 100 ){ $("html").addClass("scrolled") $("html").addClass("scrollend") }else if( scroll_val < Math.round(window_height/100) ){ $("html").removeClass("scrolled") $("html").removeClass("scrollend") }else if( scroll_val >= Math.round(window_height/100) && scroll_val+window_height < content_height - 100 ){ $("html").addClass("scrolled") $("html").removeClass("scrollend") }else{ $("html").addClass("scrolled") $("html").addClass("scrollend") } if( $("article#root > article#top div.slide")[0] ){ if( scroll_val < window_height*1.5 ){ $("article#root > article#top div.slide > ul.carousel li.cell > a > div.img").css({ "transform": "matrix(1, 0, 0, 1, 0, "+ (scroll_val/4) +")" }); $("article#root > article#top div#top_navi").css({ "transform": "matrix(1, 0, 0, 1, 0, "+ (scroll_val/4) +")" }); } } if( $("body.root")[0] ){ if( scroll_val < window_height ){ $("body.root div#navi > nav").removeClass("show"); }else{ $("body.root div#navi > nav").addClass("show"); } } if( $("img.parallax")[0] ){ var window_center_y = window_height/2 + scroll_val; $("img.parallax").each(function(){ var target = $(this); var wrapper = $(this).closest(".parallax_base"); var speed_adjust = 1; if( target.attr("data-speed_adjust") != undefined ){ speed_adjust = target.attr("data-speed_adjust"); } if( target.height() <= wrapper.height() ){ target.css({"height": "120%" }); } var wrapper_y = wrapper.offset().top; var wrapper_center_y = wrapper_y + wrapper.height()/2; var distance = window_center_y - wrapper_center_y; var parallax_height = wrapper.height(); var img_height = target.height(); var val = img_height-parallax_height; var move_y = Math.round((val/window_height)*distance)*speed_adjust; target.css({"transform": "matrix(1, 0, 0, 1, 0, "+ move_y +")"}); }); } if( scroll_action_flag === true && $("body #container > div#base article.ground")[0] ){ scroll_action_flag = false; if( typeof scroll_action_limiter != "undefined" ){ clearTimeout( scroll_action_limiter ); } scroll_action_limiter = setTimeout( function(){ $("body #container > div#base article.ground").each(function(){ if( $(this).attr("id") != null ){ var ground_id = $(this).attr("id"); if( typeof category[ground_id] != "undefined" ){ var ground_offset = $("#" + selectorEscape( ground_id )).position().top; var ground_height = $("#" + selectorEscape( ground_id )).height(); if( scroll_val >= ground_offset && scroll_val <= ground_offset + ground_height ){ // console.log("ground_id::"+ground_id); // console.log(id); // console.log(ground_id); var href = "https://2040gallery.jp/" + ground_id; // console.log("do"); PJAX_pjax( href, "by_scroll", "" ); }else if( scroll_val < $("body #container > div#base article.ground").first().position().top ){ if( $("body").attr("data-scroll") != "" ){ var scroll_split = $("body").attr("data-scroll").split('/'); var ground_directory = $("body").attr("data-scroll").replace( scroll_split[scroll_split.length-1], "" ); var href = "https://2040gallery.jp/" + ground_directory; // console.log("top::"+href); // console.log("why"); PJAX_pjax( href, "by_scroll", "" ); } } } } }); // console.log("true"); scroll_action_flag = true; } , 1000); } } function entry_scroll() { scroll_val = $("#entry > div.inner").scrollTop(); if( $("#entry > div.inner > article")[0] ){ scroll_val = $("#entry > div.inner").scrollTop(); // console.log(scroll_val+window_height+"|"+ Number(entry_height - 100)); if( scroll_val+window_height > entry_height - 100 ){ $("html").addClass("scrolled") $("html").addClass("scrollend") }else if( scroll_val < Math.round(window_height/100) ){ $("html").removeClass("scrolled") $("html").removeClass("scrollend") }else if( scroll_val >= Math.round(window_height/100) && scroll_val+window_height < entry_height - 100 ){ $("html").addClass("scrolled") $("html").removeClass("scrollend") }else{ $("html").addClass("scrolled") $("html").addClass("scrollend") } } } function window_resize() { document_height = $(document).height(); content_height = get_total_height($("#container > div#base > *")); entry_height = get_total_height($("#entry > div.inner > *")); if( $("html.touch_device")[0] ){ if( window.innerHeight > window.innerWidth ){ window_height = $(window).height(); }else{ window_height = $(window).height(); } }else{ window_height = window.innerHeight ? window.innerHeight: $(window).height(); } window_width = $(window).width(); window_ratio = window_height / window_width; if( window_ratio > 1 ){ $("html").removeClass("horizontal"); $("html").addClass("portrait"); }else{ $("html").removeClass("portrait"); $("html").addClass("horizontal"); } if( window_ratio < 0.6 ){ $("html").addClass("panorama"); }else{ $("html").removeClass("panorama"); } if( $("article#root > article#top")[0] ){ $("article#root > article#top").css({"height": window_height}); } if( $("body #container > div#base > article#root > article#top > div.inner > div.slide > ul")[0] ){ var wrapper_ratio = $("body #container > div#base > article#root > article#top > div.inner > div.slide > ul").height() / $("body #container > div#base > article#root > article#top > div.inner > div.slide > ul").width(); $("body #container > div#base > article#root > article#top > div.inner > div.slide > ul li.cell").each(function(){ var target_li = $(this); var target_img = $(this).find("div.img > img"); target_img.imagesLoaded(function(){ target_img.addClass("loaded"); var img_ratio = target_img.height() / target_img.width(); target_li.removeClass("horizontal vertical"); if( wrapper_ratio < img_ratio ){ target_li.addClass("vertical"); }else{ target_li.addClass("horizontal"); } }); }); } base_scroll(); entry_scroll_bind(); entry_scroll(); } var scroll_flug = true; $(window).on("scroll.main",function(){ setTimeout(function(){ scroll_flug = true; }, 10); if(scroll_flug){ scroll_flug = false; base_scroll(); } }); function entry_scroll_bind(){ if( $("#entry > div.inner > article")[0] ){ $("html").removeClass("scrolled"); $("html").removeClass("scrollend"); $("#entry > div.inner").on("scroll.main",function(){ entry_scroll(); // if(scroll_flug){ // scroll_flug = false; // base_scroll(); // setTimeout(function(){ // scroll_flug = true; // return scroll_flug; // }, 50); // } }); } } entry_scroll_bind(); $(window).bind("resize", window_resize); function selectorEscape(val){ return val.replace(/\//g, '\\/'); } function video_stop(){ $("article#top > div.inner > div.video > ul > li.video_1.part").removeClass("active"); setTimeout(function(){ $("article#top > div.inner > div.video > ul > li.video_1.part > div").empty(); $("article#top > div.inner > div.video > ul > li.video_2.part").removeClass("active"); setTimeout(function(){ $("article#top > div.inner > div.video > ul > li.video_2.part > div").empty(); },1000); },1000); } function video_play(){ if( $("body.root")[0] ){ setTimeout(function(){ $("article#top > div.inner > div.video > ul > li.video_1.part").addClass("active"); create_video( $("article#top > div.inner > div.video > ul > li.video_1.part > div") , "https://2040gallery.jp/elements/video_01" , "video_01" ); setTimeout(function(){ $("article#top > div.inner > div.video > ul > li.video_2.part").addClass("active"); create_video( $("article#top > div.inner > div.video > ul > li.video_2.part > div") , "https://2040gallery.jp/elements/video_02" , "video_02" ); setTimeout(function(){ $("article#top > div.inner > div.video > ul > li.part > div > img").fadeIn(1000); },1000); },500); },4000); } // if( $("body.root")[0] ){ // setTimeout(function(){ // $("article#top > div.inner > div.video > ul > li.video_1.part").addClass("active"); // create_video( $("article#top > div.inner > div.video > ul > li.video_1.part > div") , "http://test:1111@leafbrand.co.jp/elements/video_01" , "video_01" ); // setTimeout(function(){ // $("article#top > div.inner > div.video > ul > li.video_2.part").addClass("active"); // create_video( $("article#top > div.inner > div.video > ul > li.video_2.part > div") , "http://test:1111@leafbrand.co.jp/elements/video_02" , "video_02" ); // setTimeout(function(){ // $("article#top > div.inner > div.video > ul > li.part > div > img").fadeIn(1000); // },1000); // },500); // },4000); // } } function create_video(target, video_file, target_id) { if( $("html.touch_device.iOS")[0] ) { var width = target.outerWidth(); var height = target.outerHeight(); target.append(''); setTimeout(function(){ target.parent().addClass("play"); var video = document.createElement('video'); video.style.display = 'none'; document.body.appendChild(video); var canvas = document.getElementById('video_canvas_'+target_id); $(canvas).css({"display": "block"}); var ctx = canvas.getContext("2d"); var ctime = 0; var lastTime; video.addEventListener('canplay',function(){ lastTime = Date.now(); setInterval(function(){ var curTime = Date.now(); var diff = Date.now() - lastTime; lastTime = curTime; ctime += diff/1000; video.currentTime = ctime; ctx.drawImage(video, 0, 0, width, height); if(video.duration <= video.currentTime){ ctime = 0; } }, 1000/30); },false); video.src = video_file +'.mp4?24042721'; video.load(); },1000); }else{ target.append(''); setTimeout(function(){ target.parent().addClass("play"); target.find("video").each(function(){ if( ! $(this).hasClass("play") ){ $(this).addClass("play"); $(this).get(0).play(); } }); },1000); } } function load_iframe(){ $("iframe.preload:not('.loaded')").each(function(){ $(this).load(function(){ $(this).addClass("loaded"); }); }); } load_iframe(); var start_limit = 4000; $("html").data("preloaded", 0); function preload(){ var img = [], img_arr = $("img.preload"), // ローディング対象の画像を指定 img_arr_lngth = img_arr.size(); var img_arr_lngth_total = img_arr_lngth; if( img_arr_lngth_total > 0 ){ img_arr.each(function(indx){ img[indx] = new Image(); img[indx].onload = function(){ img_arr_lngth = img_arr_lngth - 1; var progress = Math.round((1-img_arr_lngth/img_arr_lngth_total)*100); $("div.progress").stop().animate({"width": progress + "%"},1000); if( 0 >= img_arr_lngth ){ // img_load(); window_resize(); $("html").data("preloaded", 1); $("div.progress").stop().animate({"width": "100%"},1500,"easeOutQuad",function(){ setTimeout(function(){ $("div.progress").addClass("out"); var timer = getPast(); console.log(timer); $("#header").addClass("start"); if( timer > start_limit ){ preload_finish(); }else{ setTimeout(function(){ console.log(getPast()); preload_finish(); },start_limit-timer); } },200); }); } }; img[indx].src = $(this).attr('src'); }); }else{ $("html").data("preloaded", 1); $("div#progress").stop().animate({"width": "100%"},1500,"easeOutQuad",function(){ setTimeout(function(){ $("div.progress").addClass("out"); setTimeout(function(){ $("div#preloader").fadeOut(1000, function() { $(this).remove(); window_resize(); }); },2000); },200); }); } } function preload_finish(){ window_resize(); $("div#preloader").fadeOut(200, function() { $(this).remove(); $("html").addClass("start"); window.FB.XFBML.parse(); }); } function img_load(){ $("img.preload:not('.loaded')").each(function(){ $(this).imagesLoaded(function(){ $(this).addClass("loaded"); }); }); } var watch_target = document.getElementById('base'); var article_id = ""; function watch_reflesh(){ var observer = new MutationObserver(function() { article_id = $("body #container > div#base > article:not(.leave)").attr("id"); if( article_id == "login/" && $("#login_complete")[0] ){ var href = "https://2040gallery.jp/accounts/"; PJAX_pjax( href, "", "" ); } }); observer.observe(watch_target, { childList: true, subtree: true }); } $("body #header > header > h1 > a > img").imagesLoaded(function(){ if( $("#preloader")[0] ){ $("div#preloader > div.bg").addClass("show"); preload(); getPast(); setTimeout(function(){ $("#header > header > h1 > div.area > div.circle").addClass("show"); },1000); } }); $(window).bind('load', function() { if( $("#preloader")[0] ){ img_load(); // window_resize(); if( $("body #container > div#base article.ground")[0] ){ var target = $("#" + selectorEscape($("body").attr("data-scroll"))); if( target[0] ){ var val = target.position().top; scrollto(val); }else{ scroll_action_flag = true; } } watch_reflesh(); } }); function rnd(n){ return Math.floor(Math.random()*(n+1)); } function get_total_height(elms) { var total_height = 0; elms.each(function(i){ var height = $(this).outerHeight(true); total_height += height; }); return total_height; } function PJAX_hash( hash ) { if( $("[data-scrollto='"+hash+"']")[0] ){ var val = $("[data-scrollto='"+hash+"']").first().position().top - 120; scrollto(val); } } function navi_active(href){ if( href == "https://2040gallery.jp/" || href == "https://2040gallery.jp/list/" ){ $("div#navi > nav > div.navi > div.input_select > select").each(function(i){ $(this).val(""); $(this).removeClass("active"); }); }else if( $("div#navi > nav > div.navi > div.input_select > select > option[value='"+href+"']")[0] ){ var target = $("div#navi > nav > div.navi > div.input_select > select > option[value='"+href+"']").parent("select"); var id = target.attr("id"); console.log(id); console.log(href); $("div#navi > nav > div.navi > div.input_select > select").each(function(i){ if( $(this).attr("id") == id ){ $(this).val(href); $(this).addClass("active"); }else{ $(this).val(""); $(this).removeClass("active"); } }); } } $(document).on("change", "div#navi > nav > div.navi > div.input_select > select", function(e) { var href = $(this).val(); console.log(href); PJAX_pjax( href, "", "" ); return false; }); var getPast = (function() { var lastDate = NaN; return function() { var now = Date.now(); var past = now - lastDate; lastDate = now; return past; }; })(); });