@sygnas/scroll-amount
Advanced tools
Comparing version 2.0.0 to 2.0.2
@@ -62,9 +62,7 @@ (function () { | ||
this.targets = document.querySelectorAll(target); // this.state = []; // data属性に書き出す内容 | ||
// this.observers = []; | ||
this.targets = document.querySelectorAll(target); // 一番上にスクロールした | ||
this.isTop = false; // 一番上にスクロールした | ||
this.isTop = false; // 一番下にスクロールした | ||
this.isBottom = false; // 一番下にスクロールした | ||
// 最後の状態 | ||
this.isBottom = false; // 最後の状態 | ||
@@ -145,11 +143,11 @@ this.lastState = ''; | ||
if (this.isTop) { | ||
if (this.isTop && this.opt.onTop) { | ||
this.opt.onTop(); | ||
} else { | ||
} else if (this.opt.onNotTop) { | ||
this.opt.onNotTop(); | ||
} | ||
if (this.isBottom) { | ||
if (this.isBottom && this.opt.onBottom) { | ||
this.opt.onBottom(); | ||
} else { | ||
} else if (this.opt.onNotBottom) { | ||
this.opt.onNotBottom(); | ||
@@ -173,2 +171,2 @@ } | ||
})(); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"bundle.js","sources":["../dist/index.es.js","src/demo.ts"],"sourcesContent":["/**\n * Add scrolling state(top / not-top / bottom / not-bottom)\n *\n * @author   Hiroshi Fukuda <info.sygnas@gmail.com>\n * @license  MIT\n */\n///////////////////////////////////////\n// 状態を付与するためのdata属性\nvar ATTR_NAME = \"data-scroll-amount\";\n// 状態の名前\nvar ATTR_TOP = \"top\";\nvar ATTR_BOTTOM = \"bottom\";\nvar ATTR_NOT_TOP = \"not-top\";\nvar ATTR_NOT_BOTTOM = \"not-bottom\";\nvar ATTR_POSITION = \"data-position\";\n// 監視用エレメントのデフォルトstyle\nvar COMMON_STYLE = {\n    position: \"absolute\",\n    left: \"0\",\n};\n// IntersectionObserverの設定\nvar OBSERVER_OPT = {\n    root: null,\n    rootMargin: \"0px\",\n    threshold: 0,\n};\n///////////////////////////////////////\nvar SygScrollAmount = /** @class */ (function () {\n    // private observers: IntersectionObserver[];\n    /**\n     * コンストラクタ\n     * @param target string 状態を付与する対象エレメントのセレクタ文字列\n     */\n    function SygScrollAmount(target, options) {\n        if (options === void 0) { options = {}; }\n        var defaults = {\n            // 最上部のオフセット\n            offsetTop: \"70px\",\n            // 最下部のオフセット\n            offsetBottom: \"70px\",\n            // 最上部にスクロールした時に実行\n            onTop: function () { },\n            // 最上部から離れた時に実行\n            onNotTop: function () { },\n            // 最下部にスクロールした時に実行\n            onBottom: function () { },\n            // 最下部から離れた時に実行\n            onNotBottom: function () { },\n        };\n        // 与えられた設定を適用\n        this.opt = Object.assign(defaults, options);\n        // 状態付与の対象\n        this.targets = document.querySelectorAll(target);\n        // this.state = []; // data属性に書き出す内容\n        // this.observers = [];\n        this.isTop = false; // 一番上にスクロールした\n        this.isBottom = false; // 一番下にスクロールした\n        // 最後の状態\n        this.lastState = '';\n        this.start();\n    }\n    /**\n     * 監視用エレメント作成して監視開始\n     */\n    SygScrollAmount.prototype.createObserveElement = function (position) {\n        var element = document.createElement(\"div\");\n        Object.assign(element.style, COMMON_STYLE);\n        element.style.height = this.opt.offsetTop;\n        element.setAttribute(ATTR_POSITION, position);\n        if (position === \"top\") {\n            element.style.top = \"0\";\n        }\n        else {\n            element.style.bottom = \"0\";\n        }\n        // ページ最下部に追加\n        document.body.appendChild(element);\n        return element;\n    };\n    /**\n     * スクロール検知処理を開始\n     */\n    SygScrollAmount.prototype.start = function () {\n        // <body> に position 設定\n        document.body.style.position = \"relative\";\n        // IntersectionObserverを作成して監視開始\n        var observer = new IntersectionObserver(this.observerCallback.bind(this), OBSERVER_OPT);\n        // 監視用エレメント作成\n        observer.observe(this.createObserveElement(\"top\"));\n        observer.observe(this.createObserveElement(\"bottom\"));\n    };\n    /**\n     * スクロール処理\n     * IntersectionObserver に反応した <div> が top/bottom どちらかで判定する\n     */\n    SygScrollAmount.prototype.observerCallback = function (entries) {\n        var _this = this;\n        entries.forEach(function (entry) {\n            var position = entry.target.getAttribute(ATTR_POSITION);\n            if (position === \"top\") {\n                _this.isTop = entry.isIntersecting;\n            }\n            else {\n                _this.isBottom = entry.isIntersecting;\n            }\n        });\n        // 属性を付与\n        this.setAttribute();\n    };\n    /**\n     * 属性を付与\n     */\n    SygScrollAmount.prototype.setAttribute = function () {\n        var state = [\n            this.isTop ? ATTR_TOP : ATTR_NOT_TOP,\n            this.isBottom ? ATTR_BOTTOM : ATTR_NOT_BOTTOM,\n        ].join(' ');\n        // 結果を data属性に反映する\n        // 前回と同じなら反映しない\n        if (state !== this.lastState) {\n            this.lastState = state;\n            this.targets.forEach(function (target) {\n                target.setAttribute(ATTR_NAME, state);\n            });\n            // オプション関数を実行\n            if (this.isTop) {\n                this.opt.onTop();\n            }\n            else {\n                this.opt.onNotTop();\n            }\n            if (this.isBottom) {\n                this.opt.onBottom();\n            }\n            else {\n                this.opt.onNotBottom();\n            }\n        }\n    };\n    return SygScrollAmount;\n}());\n\nexport { SygScrollAmount as default };\n","\nimport ScrollAmount from '../../dist/index.es.js';\n\nconst target1 = new ScrollAmount('.js-scroll-amount', {\n    onTop() {\n        console.log(\"top\");\n    },\n    onBottom() {\n        console.log(\"bottom\");\n    }\n});\n\n"],"names":["ATTR_NAME","ATTR_TOP","ATTR_BOTTOM","ATTR_NOT_TOP","ATTR_NOT_BOTTOM","ATTR_POSITION","COMMON_STYLE","position","left","OBSERVER_OPT","root","rootMargin","threshold","SygScrollAmount","target","options","defaults","offsetTop","offsetBottom","onTop","onNotTop","onBottom","onNotBottom","opt","Object","assign","targets","document","querySelectorAll","isTop","isBottom","lastState","start","prototype","createObserveElement","element","createElement","style","height","setAttribute","top","bottom","body","appendChild","observer","IntersectionObserver","observerCallback","bind","observe","entries","_this","forEach","entry","getAttribute","isIntersecting","state","join","ScrollAmount"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"bundle.js","sources":["../dist/index.es.js","src/demo.ts"],"sourcesContent":["/**\n * Add scrolling state(top / not-top / bottom / not-bottom)\n *\n * @author   Hiroshi Fukuda <info.sygnas@gmail.com>\n * @license  MIT\n */\n///////////////////////////////////////\n// 状態を付与するためのdata属性\nvar ATTR_NAME = \"data-scroll-amount\";\n// 状態の名前\nvar ATTR_TOP = \"top\";\nvar ATTR_BOTTOM = \"bottom\";\nvar ATTR_NOT_TOP = \"not-top\";\nvar ATTR_NOT_BOTTOM = \"not-bottom\";\nvar ATTR_POSITION = \"data-position\";\n// 監視用エレメントのデフォルトstyle\nvar COMMON_STYLE = {\n    position: \"absolute\",\n    left: \"0\",\n};\n// IntersectionObserverの設定\nvar OBSERVER_OPT = {\n    root: null,\n    rootMargin: \"0px\",\n    threshold: 0,\n};\n///////////////////////////////////////\nvar SygScrollAmount = /** @class */ (function () {\n    // private observers: IntersectionObserver[];\n    /**\n     * コンストラクタ\n     * @param target string 状態を付与する対象エレメントのセレクタ文字列\n     */\n    function SygScrollAmount(target, options) {\n        if (options === void 0) { options = {}; }\n        var defaults = {\n            // 最上部のオフセット\n            offsetTop: \"70px\",\n            // 最下部のオフセット\n            offsetBottom: \"70px\",\n            // 最上部にスクロールした時に実行\n            onTop: function () { },\n            // 最上部から離れた時に実行\n            onNotTop: function () { },\n            // 最下部にスクロールした時に実行\n            onBottom: function () { },\n            // 最下部から離れた時に実行\n            onNotBottom: function () { },\n        };\n        // 与えられた設定を適用\n        this.opt = Object.assign(defaults, options);\n        // 状態付与の対象\n        this.targets = document.querySelectorAll(target);\n        // 一番上にスクロールした\n        this.isTop = false;\n        // 一番下にスクロールした\n        this.isBottom = false;\n        // 最後の状態\n        this.lastState = '';\n        this.start();\n    }\n    /**\n     * 監視用エレメント作成して監視開始\n     */\n    SygScrollAmount.prototype.createObserveElement = function (position) {\n        var element = document.createElement(\"div\");\n        Object.assign(element.style, COMMON_STYLE);\n        element.style.height = this.opt.offsetTop;\n        element.setAttribute(ATTR_POSITION, position);\n        if (position === \"top\") {\n            element.style.top = \"0\";\n        }\n        else {\n            element.style.bottom = \"0\";\n        }\n        // ページ最下部に追加\n        document.body.appendChild(element);\n        return element;\n    };\n    /**\n     * スクロール検知処理を開始\n     */\n    SygScrollAmount.prototype.start = function () {\n        // <body> に position 設定\n        document.body.style.position = \"relative\";\n        // IntersectionObserverを作成して監視開始\n        var observer = new IntersectionObserver(this.observerCallback.bind(this), OBSERVER_OPT);\n        // 監視用エレメント作成\n        observer.observe(this.createObserveElement(\"top\"));\n        observer.observe(this.createObserveElement(\"bottom\"));\n    };\n    /**\n     * スクロール処理\n     * IntersectionObserver に反応した <div> が top/bottom どちらかで判定する\n     */\n    SygScrollAmount.prototype.observerCallback = function (entries) {\n        var _this = this;\n        entries.forEach(function (entry) {\n            var position = entry.target.getAttribute(ATTR_POSITION);\n            if (position === \"top\") {\n                _this.isTop = entry.isIntersecting;\n            }\n            else {\n                _this.isBottom = entry.isIntersecting;\n            }\n        });\n        // 属性を付与\n        this.setAttribute();\n    };\n    /**\n     * 属性を付与\n     */\n    SygScrollAmount.prototype.setAttribute = function () {\n        var state = [\n            this.isTop ? ATTR_TOP : ATTR_NOT_TOP,\n            this.isBottom ? ATTR_BOTTOM : ATTR_NOT_BOTTOM,\n        ].join(' ');\n        // 結果を data属性に反映する\n        // 前回と同じなら反映しない\n        if (state !== this.lastState) {\n            this.lastState = state;\n            this.targets.forEach(function (target) {\n                target.setAttribute(ATTR_NAME, state);\n            });\n            // オプション関数を実行\n            if (this.isTop && this.opt.onTop) {\n                this.opt.onTop();\n            }\n            else if (this.opt.onNotTop) {\n                this.opt.onNotTop();\n            }\n            if (this.isBottom && this.opt.onBottom) {\n                this.opt.onBottom();\n            }\n            else if (this.opt.onNotBottom) {\n                this.opt.onNotBottom();\n            }\n        }\n    };\n    return SygScrollAmount;\n}());\n\nexport { SygScrollAmount as default };\n","\nimport ScrollAmount from '../../dist/index.es.js';\n\nconst target1 = new ScrollAmount('.js-scroll-amount', {\n    onTop() {\n        console.log(\"top\");\n    },\n    onBottom() {\n        console.log(\"bottom\");\n    }\n});\n\n"],"names":["ATTR_NAME","ATTR_TOP","ATTR_BOTTOM","ATTR_NOT_TOP","ATTR_NOT_BOTTOM","ATTR_POSITION","COMMON_STYLE","position","left","OBSERVER_OPT","root","rootMargin","threshold","SygScrollAmount","target","options","defaults","offsetTop","offsetBottom","onTop","onNotTop","onBottom","onNotBottom","opt","Object","assign","targets","document","querySelectorAll","isTop","isBottom","lastState","start","prototype","createObserveElement","element","createElement","style","height","setAttribute","top","bottom","body","appendChild","observer","IntersectionObserver","observerCallback","bind","observe","entries","_this","forEach","entry","getAttribute","isIntersecting","state","join","ScrollAmount"],"mappings":"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"} |
@@ -54,6 +54,6 @@ /** | ||
this.targets = document.querySelectorAll(target); | ||
// this.state = []; // data属性に書き出す内容 | ||
// this.observers = []; | ||
this.isTop = false; // 一番上にスクロールした | ||
this.isBottom = false; // 一番下にスクロールした | ||
// 一番上にスクロールした | ||
this.isTop = false; | ||
// 一番下にスクロールした | ||
this.isBottom = false; | ||
// 最後の状態 | ||
@@ -127,12 +127,12 @@ this.lastState = ''; | ||
// オプション関数を実行 | ||
if (this.isTop) { | ||
if (this.isTop && this.opt.onTop) { | ||
this.opt.onTop(); | ||
} | ||
else { | ||
else if (this.opt.onNotTop) { | ||
this.opt.onNotTop(); | ||
} | ||
if (this.isBottom) { | ||
if (this.isBottom && this.opt.onBottom) { | ||
this.opt.onBottom(); | ||
} | ||
else { | ||
else if (this.opt.onNotBottom) { | ||
this.opt.onNotBottom(); | ||
@@ -139,0 +139,0 @@ } |
@@ -56,6 +56,6 @@ 'use strict'; | ||
this.targets = document.querySelectorAll(target); | ||
// this.state = []; // data属性に書き出す内容 | ||
// this.observers = []; | ||
this.isTop = false; // 一番上にスクロールした | ||
this.isBottom = false; // 一番下にスクロールした | ||
// 一番上にスクロールした | ||
this.isTop = false; | ||
// 一番下にスクロールした | ||
this.isBottom = false; | ||
// 最後の状態 | ||
@@ -129,12 +129,12 @@ this.lastState = ''; | ||
// オプション関数を実行 | ||
if (this.isTop) { | ||
if (this.isTop && this.opt.onTop) { | ||
this.opt.onTop(); | ||
} | ||
else { | ||
else if (this.opt.onNotTop) { | ||
this.opt.onNotTop(); | ||
} | ||
if (this.isBottom) { | ||
if (this.isBottom && this.opt.onBottom) { | ||
this.opt.onBottom(); | ||
} | ||
else { | ||
else if (this.opt.onNotBottom) { | ||
this.opt.onNotBottom(); | ||
@@ -141,0 +141,0 @@ } |
@@ -57,6 +57,6 @@ var sygScrollAmount = (function () { | ||
this.targets = document.querySelectorAll(target); | ||
// this.state = []; // data属性に書き出す内容 | ||
// this.observers = []; | ||
this.isTop = false; // 一番上にスクロールした | ||
this.isBottom = false; // 一番下にスクロールした | ||
// 一番上にスクロールした | ||
this.isTop = false; | ||
// 一番下にスクロールした | ||
this.isBottom = false; | ||
// 最後の状態 | ||
@@ -130,12 +130,12 @@ this.lastState = ''; | ||
// オプション関数を実行 | ||
if (this.isTop) { | ||
if (this.isTop && this.opt.onTop) { | ||
this.opt.onTop(); | ||
} | ||
else { | ||
else if (this.opt.onNotTop) { | ||
this.opt.onNotTop(); | ||
} | ||
if (this.isBottom) { | ||
if (this.isBottom && this.opt.onBottom) { | ||
this.opt.onBottom(); | ||
} | ||
else { | ||
else if (this.opt.onNotBottom) { | ||
this.opt.onNotBottom(); | ||
@@ -151,2 +151,2 @@ } | ||
})(); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"scroll-amount.js","sources":["../src/index.ts"],"sourcesContent":["/**\n * Add scrolling state(top / not-top / bottom / not-bottom)\n *\n * @author   Hiroshi Fukuda <info.sygnas@gmail.com>\n * @license  MIT\n */\n\nimport { TOption, TOptionArg } from \"./TOption\";\n\ntype TTopOrBottom = \"top\" | \"bottom\";\n\n///////////////////////////////////////\n\n\n// 状態を付与するためのdata属性\nconst ATTR_NAME: string = \"data-scroll-amount\";\n\n// 状態の名前\nconst ATTR_TOP: string = \"top\";\nconst ATTR_BOTTOM: string = \"bottom\";\nconst ATTR_NOT_TOP: string = \"not-top\";\nconst ATTR_NOT_BOTTOM: string = \"not-bottom\";\nconst ATTR_POSITION: string = \"data-position\";\n\n// 監視用エレメントのデフォルトstyle\nconst COMMON_STYLE: object = {\n  position: \"absolute\",\n  left: \"0\",\n};\n\n// IntersectionObserverの設定\nconst OBSERVER_OPT: object = {\n  root: null,\n  rootMargin: \"0px\",\n  threshold: 0,\n};\n\n///////////////////////////////////////\nclass SygScrollAmount {\n  private opt: TOption;\n  private targets;\n  private isTop: boolean;\n  private isBottom: boolean;\n  private lastState: string;\n  // private observers: IntersectionObserver[];\n\n  /**\n   * コンストラクタ\n   * @param target string 状態を付与する対象エレメントのセレクタ文字列\n   */\n  constructor(target: string, options: TOptionArg = {}) {\n    const defaults: TOption = {\n      // 最上部のオフセット\n      offsetTop: \"70px\",\n      // 最下部のオフセット\n      offsetBottom: \"70px\",\n      // 最上部にスクロールした時に実行\n      onTop() {},\n      // 最上部から離れた時に実行\n      onNotTop() {},\n      // 最下部にスクロールした時に実行\n      onBottom() {},\n      // 最下部から離れた時に実行\n      onNotBottom() {},\n    };\n\n    // 与えられた設定を適用\n    this.opt = Object.assign(defaults, options);\n    // 状態付与の対象\n    this.targets = document.querySelectorAll<HTMLElement>(target);\n    // this.state = []; // data属性に書き出す内容\n    // this.observers = [];\n    this.isTop = false; // 一番上にスクロールした\n    this.isBottom = false; // 一番下にスクロールした\n    // 最後の状態\n    this.lastState = '';\n\n    this.start();\n  }\n\n  /**\n   * 監視用エレメント作成して監視開始\n   */\n  createObserveElement(position: TTopOrBottom): HTMLDivElement {\n    const element: HTMLDivElement = document.createElement(\"div\");\n\n    Object.assign(element.style, COMMON_STYLE);\n    element.style.height = this.opt.offsetTop;\n    element.setAttribute(ATTR_POSITION, position);\n\n    if (position === \"top\") {\n      element.style.top = \"0\";\n    } else {\n      element.style.bottom = \"0\";\n    }\n    // ページ最下部に追加\n    document.body.appendChild(element);\n    return element;\n  }\n\n  /**\n   * スクロール検知処理を開始\n   */\n  private start() {\n    // <body> に position 設定\n    document.body.style.position = \"relative\";\n\n    // IntersectionObserverを作成して監視開始\n    const observer: IntersectionObserver = new IntersectionObserver(\n      this.observerCallback.bind(this),\n      OBSERVER_OPT\n    );\n\n    // 監視用エレメント作成\n    observer.observe(this.createObserveElement(\"top\"));\n    observer.observe(this.createObserveElement(\"bottom\"));\n  }\n\n  /**\n   * スクロール処理\n   * IntersectionObserver に反応した <div> が top/bottom どちらかで判定する\n   */\n  private observerCallback(\n    entries: IntersectionObserverEntry[]\n  ) {\n\n    entries.forEach((entry) => {\n      const position: TTopOrBottom = entry.target.getAttribute(\n        ATTR_POSITION\n      ) as TTopOrBottom;\n\n      if (position === \"top\") {\n        this.isTop = entry.isIntersecting;\n      } else {\n        this.isBottom = entry.isIntersecting;\n      }\n    });\n\n    // 属性を付与\n    this.setAttribute();\n  }\n\n  /**\n   * 属性を付与\n   */\n  private setAttribute(): void {\n    const state: string = [\n      this.isTop ? ATTR_TOP : ATTR_NOT_TOP,\n      this.isBottom ? ATTR_BOTTOM : ATTR_NOT_BOTTOM,\n    ].join(' ');\n\n    // 結果を data属性に反映する\n    // 前回と同じなら反映しない\n    if (state !== this.lastState) {\n      this.lastState= state;\n\n      this.targets.forEach((target: HTMLElement) => {\n        target.setAttribute(ATTR_NAME, state);\n      });\n\n      // オプション関数を実行\n      if(this.isTop){\n        this.opt.onTop();\n      }else{\n        this.opt.onNotTop();\n      }\n\n      if(this.isBottom){\n        this.opt.onBottom();\n      }else{\n        this.opt.onNotBottom();\n      }\n    }\n  }\n}\n\n\nexport default SygScrollAmount;\n"],"names":[],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"scroll-amount.js","sources":["../src/index.ts"],"sourcesContent":["/**\n * Add scrolling state(top / not-top / bottom / not-bottom)\n *\n * @author   Hiroshi Fukuda <info.sygnas@gmail.com>\n * @license  MIT\n */\n\nimport { TOption, TTopOrBottom } from \"./types\";\n\n\n///////////////////////////////////////\n\n\n// 状態を付与するためのdata属性\nconst ATTR_NAME: string = \"data-scroll-amount\";\n\n// 状態の名前\nconst ATTR_TOP: string = \"top\";\nconst ATTR_BOTTOM: string = \"bottom\";\nconst ATTR_NOT_TOP: string = \"not-top\";\nconst ATTR_NOT_BOTTOM: string = \"not-bottom\";\nconst ATTR_POSITION: string = \"data-position\";\n\n// 監視用エレメントのデフォルトstyle\nconst COMMON_STYLE: object = {\n  position: \"absolute\",\n  left: \"0\",\n};\n\n// IntersectionObserverの設定\nconst OBSERVER_OPT: IntersectionObserverInit = {\n  root: null,\n  rootMargin: \"0px\",\n  threshold: 0,\n};\n\n///////////////////////////////////////\nclass SygScrollAmount {\n  private opt: TOption;\n  private targets;\n  private isTop: boolean;\n  private isBottom: boolean;\n  private lastState: string;\n  // private observers: IntersectionObserver[];\n\n  /**\n   * コンストラクタ\n   * @param target string 状態を付与する対象エレメントのセレクタ文字列\n   */\n  constructor(target: string, options: TOption = {}) {\n    const defaults: TOption = {\n      // 最上部のオフセット\n      offsetTop: \"70px\",\n      // 最下部のオフセット\n      offsetBottom: \"70px\",\n      // 最上部にスクロールした時に実行\n      onTop() {},\n      // 最上部から離れた時に実行\n      onNotTop() {},\n      // 最下部にスクロールした時に実行\n      onBottom() {},\n      // 最下部から離れた時に実行\n      onNotBottom() {},\n    };\n\n    // 与えられた設定を適用\n    this.opt = Object.assign(defaults, options);\n    // 状態付与の対象\n    this.targets = document.querySelectorAll<HTMLElement>(target);\n    // 一番上にスクロールした\n    this.isTop = false;\n    // 一番下にスクロールした\n    this.isBottom = false;\n    // 最後の状態\n    this.lastState = '';\n\n    this.start();\n  }\n\n  /**\n   * 監視用エレメント作成して監視開始\n   */\n  createObserveElement(position: TTopOrBottom): HTMLDivElement {\n    const element: HTMLDivElement = document.createElement(\"div\");\n\n    Object.assign(element.style, COMMON_STYLE);\n    element.style.height = this.opt.offsetTop as string;\n    element.setAttribute(ATTR_POSITION, position);\n\n    if (position === \"top\") {\n      element.style.top = \"0\";\n    } else {\n      element.style.bottom = \"0\";\n    }\n    // ページ最下部に追加\n    document.body.appendChild(element);\n    return element;\n  }\n\n  /**\n   * スクロール検知処理を開始\n   */\n  private start() {\n    // <body> に position 設定\n    document.body.style.position = \"relative\";\n\n    // IntersectionObserverを作成して監視開始\n    const observer: IntersectionObserver = new IntersectionObserver(\n      this.observerCallback.bind(this),\n      OBSERVER_OPT\n    );\n\n    // 監視用エレメント作成\n    observer.observe(this.createObserveElement(\"top\"));\n    observer.observe(this.createObserveElement(\"bottom\"));\n  }\n\n  /**\n   * スクロール処理\n   * IntersectionObserver に反応した <div> が top/bottom どちらかで判定する\n   */\n  private observerCallback( entries: IntersectionObserverEntry[]): void {\n\n    entries.forEach((entry) => {\n      const position: TTopOrBottom = entry.target.getAttribute(\n        ATTR_POSITION\n      ) as TTopOrBottom;\n\n      if (position === \"top\") {\n        this.isTop = entry.isIntersecting;\n      } else {\n        this.isBottom = entry.isIntersecting;\n      }\n    });\n\n    // 属性を付与\n    this.setAttribute();\n  }\n\n  /**\n   * 属性を付与\n   */\n  private setAttribute(): void {\n    const state: string = [\n      this.isTop ? ATTR_TOP : ATTR_NOT_TOP,\n      this.isBottom ? ATTR_BOTTOM : ATTR_NOT_BOTTOM,\n    ].join(' ');\n\n    // 結果を data属性に反映する\n    // 前回と同じなら反映しない\n    if (state !== this.lastState) {\n      this.lastState= state;\n\n      this.targets.forEach((target: HTMLElement) => {\n        target.setAttribute(ATTR_NAME, state);\n      });\n\n      // オプション関数を実行\n      if(this.isTop && this.opt.onTop){\n        this.opt.onTop();\n      }else if(this.opt.onNotTop){\n        this.opt.onNotTop();\n      }\n\n      if(this.isBottom && this.opt.onBottom){\n        this.opt.onBottom();\n      }else if(this.opt.onNotBottom){\n        this.opt.onNotBottom();\n      }\n    }\n  }\n}\n\n\nexport default SygScrollAmount;\n"],"names":[],"mappings":"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"} |
@@ -7,2 +7,2 @@ var sygScrollAmount=function(){"use strict"; | ||
* @license MIT | ||
*/var t="data-position",o={position:"absolute",left:"0"},e={root:null,rootMargin:"0px",threshold:0};return function(){function s(t,o){void 0===o&&(o={});this.opt=Object.assign({offsetTop:"70px",offsetBottom:"70px",onTop:function(){},onNotTop:function(){},onBottom:function(){},onNotBottom:function(){}},o),this.targets=document.querySelectorAll(t),this.isTop=!1,this.isBottom=!1,this.lastState="",this.start()}return s.prototype.createObserveElement=function(e){var s=document.createElement("div");return Object.assign(s.style,o),s.style.height=this.opt.offsetTop,s.setAttribute(t,e),"top"===e?s.style.top="0":s.style.bottom="0",document.body.appendChild(s),s},s.prototype.start=function(){document.body.style.position="relative";var t=new IntersectionObserver(this.observerCallback.bind(this),e);t.observe(this.createObserveElement("top")),t.observe(this.createObserveElement("bottom"))},s.prototype.observerCallback=function(o){var e=this;o.forEach((function(o){"top"===o.target.getAttribute(t)?e.isTop=o.isIntersecting:e.isBottom=o.isIntersecting})),this.setAttribute()},s.prototype.setAttribute=function(){var t=[this.isTop?"top":"not-top",this.isBottom?"bottom":"not-bottom"].join(" ");t!==this.lastState&&(this.lastState=t,this.targets.forEach((function(o){o.setAttribute("data-scroll-amount",t)})),this.isTop?this.opt.onTop():this.opt.onNotTop(),this.isBottom?this.opt.onBottom():this.opt.onNotBottom())},s}()}(); | ||
*/var t="data-position",o={position:"absolute",left:"0"},e={root:null,rootMargin:"0px",threshold:0};return function(){function s(t,o){void 0===o&&(o={});this.opt=Object.assign({offsetTop:"70px",offsetBottom:"70px",onTop:function(){},onNotTop:function(){},onBottom:function(){},onNotBottom:function(){}},o),this.targets=document.querySelectorAll(t),this.isTop=!1,this.isBottom=!1,this.lastState="",this.start()}return s.prototype.createObserveElement=function(e){var s=document.createElement("div");return Object.assign(s.style,o),s.style.height=this.opt.offsetTop,s.setAttribute(t,e),"top"===e?s.style.top="0":s.style.bottom="0",document.body.appendChild(s),s},s.prototype.start=function(){document.body.style.position="relative";var t=new IntersectionObserver(this.observerCallback.bind(this),e);t.observe(this.createObserveElement("top")),t.observe(this.createObserveElement("bottom"))},s.prototype.observerCallback=function(o){var e=this;o.forEach((function(o){"top"===o.target.getAttribute(t)?e.isTop=o.isIntersecting:e.isBottom=o.isIntersecting})),this.setAttribute()},s.prototype.setAttribute=function(){var t=[this.isTop?"top":"not-top",this.isBottom?"bottom":"not-bottom"].join(" ");t!==this.lastState&&(this.lastState=t,this.targets.forEach((function(o){o.setAttribute("data-scroll-amount",t)})),this.isTop&&this.opt.onTop?this.opt.onTop():this.opt.onNotTop&&this.opt.onNotTop(),this.isBottom&&this.opt.onBottom?this.opt.onBottom():this.opt.onNotBottom&&this.opt.onNotBottom())},s}()}(); |
{ | ||
"name": "@sygnas/scroll-amount", | ||
"version": "2.0.0", | ||
"version": "2.0.2", | ||
"description": "Add scrolling state(top / not-top / bottom / not-bottom)", | ||
@@ -18,5 +18,4 @@ "main": "dist/index.js", | ||
"watch": "rollup -w -c rollup.config.js", | ||
"delete": "rm -rf dist && rm -rf types", | ||
"build": "npm run delete && rollup -c rollup.config.js", | ||
"types": "tsc -d --outDir types --noEmit false", | ||
"build": "rm -rf dist && rollup -c rollup.config.js", | ||
"types": "rm -rf types && tsc -d --outDir types --noEmit false --emitDeclarationOnly true", | ||
"demo": "rollup -c rollup.demo.config.js", | ||
@@ -23,0 +22,0 @@ "production": "npm run build && npm run types", |
@@ -8,5 +8,4 @@ /** | ||
import { TOption, TOptionArg } from "./TOption"; | ||
import { TOption, TTopOrBottom } from "./types"; | ||
type TTopOrBottom = "top" | "bottom"; | ||
@@ -33,3 +32,3 @@ /////////////////////////////////////// | ||
// IntersectionObserverの設定 | ||
const OBSERVER_OPT: object = { | ||
const OBSERVER_OPT: IntersectionObserverInit = { | ||
root: null, | ||
@@ -53,3 +52,3 @@ rootMargin: "0px", | ||
*/ | ||
constructor(target: string, options: TOptionArg = {}) { | ||
constructor(target: string, options: TOption = {}) { | ||
const defaults: TOption = { | ||
@@ -74,6 +73,6 @@ // 最上部のオフセット | ||
this.targets = document.querySelectorAll<HTMLElement>(target); | ||
// this.state = []; // data属性に書き出す内容 | ||
// this.observers = []; | ||
this.isTop = false; // 一番上にスクロールした | ||
this.isBottom = false; // 一番下にスクロールした | ||
// 一番上にスクロールした | ||
this.isTop = false; | ||
// 一番下にスクロールした | ||
this.isBottom = false; | ||
// 最後の状態 | ||
@@ -92,3 +91,3 @@ this.lastState = ''; | ||
Object.assign(element.style, COMMON_STYLE); | ||
element.style.height = this.opt.offsetTop; | ||
element.style.height = this.opt.offsetTop as string; | ||
element.setAttribute(ATTR_POSITION, position); | ||
@@ -128,5 +127,3 @@ | ||
*/ | ||
private observerCallback( | ||
entries: IntersectionObserverEntry[] | ||
) { | ||
private observerCallback( entries: IntersectionObserverEntry[]): void { | ||
@@ -168,11 +165,11 @@ entries.forEach((entry) => { | ||
// オプション関数を実行 | ||
if(this.isTop){ | ||
if(this.isTop && this.opt.onTop){ | ||
this.opt.onTop(); | ||
}else{ | ||
}else if(this.opt.onNotTop){ | ||
this.opt.onNotTop(); | ||
} | ||
if(this.isBottom){ | ||
if(this.isBottom && this.opt.onBottom){ | ||
this.opt.onBottom(); | ||
}else{ | ||
}else if(this.opt.onNotBottom){ | ||
this.opt.onNotBottom(); | ||
@@ -179,0 +176,0 @@ } |
@@ -49,3 +49,3 @@ { | ||
// "declarationMap": true, | ||
"emitDeclarationOnly": true, | ||
// "emitDeclarationOnly": true, | ||
// "sourceMap": true, | ||
@@ -52,0 +52,0 @@ // "outFile": "./", |
@@ -7,4 +7,3 @@ /** | ||
*/ | ||
import { TOptionArg } from "./TOption"; | ||
declare type TTopOrBottom = "top" | "bottom"; | ||
import { TOption, TTopOrBottom } from "./types"; | ||
declare class SygScrollAmount { | ||
@@ -20,3 +19,3 @@ private opt; | ||
*/ | ||
constructor(target: string, options?: TOptionArg); | ||
constructor(target: string, options?: TOption); | ||
/** | ||
@@ -23,0 +22,0 @@ * 監視用エレメント作成して監視開始 |
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
0
89459
20
1149