From d0bc77eac612169ff12f855835e4d459ce26655f Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 14 Oct 2024 09:10:12 +0000 Subject: [PATCH 1/8] Bump nanasess/mdb2 from 2.5.0 to 2.5.1 Bumps [nanasess/mdb2](https://github.com/nanasess/MDB2) from 2.5.0 to 2.5.1. - [Release notes](https://github.com/nanasess/MDB2/releases) - [Commits](https://github.com/nanasess/MDB2/compare/2.5.0...2.5.1) --- updated-dependencies: - dependency-name: nanasess/mdb2 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] --- composer.lock | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/composer.lock b/composer.lock index 077480dc11..ceabf8b90a 100644 --- a/composer.lock +++ b/composer.lock @@ -72,16 +72,16 @@ }, { "name": "nanasess/mdb2", - "version": "2.5.0", + "version": "2.5.1", "source": { "type": "git", "url": "https://github.com/nanasess/MDB2.git", - "reference": "4f079c71ca0422d8c1ccafa66e4aaaf4ef5dc725" + "reference": "7bec1c13bf4c2c1cabf42d1d7fadcc344c0fb24a" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/nanasess/MDB2/zipball/4f079c71ca0422d8c1ccafa66e4aaaf4ef5dc725", - "reference": "4f079c71ca0422d8c1ccafa66e4aaaf4ef5dc725", + "url": "https://api.github.com/repos/nanasess/MDB2/zipball/7bec1c13bf4c2c1cabf42d1d7fadcc344c0fb24a", + "reference": "7bec1c13bf4c2c1cabf42d1d7fadcc344c0fb24a", "shasum": "" }, "require": { @@ -117,9 +117,9 @@ "orm" ], "support": { - "source": "https://github.com/nanasess/MDB2/tree/2.5.0" + "source": "https://github.com/nanasess/MDB2/tree/2.5.1" }, - "time": "2022-04-11T06:56:18+00:00" + "time": "2024-10-08T03:05:24+00:00" }, { "name": "nanasess/php8-compat", From 9603021679e8509c5ddc3a1ac2020da9f9d7bcb0 Mon Sep 17 00:00:00 2001 From: Kentaro Ohkouchi Date: Thu, 17 Oct 2024 22:38:06 +0900 Subject: [PATCH 2/8] Add php:8.4-rc --- .github/actions/dockerbuild/action.yml | 3 +-- .github/workflows/dockerbuild-and-push.yml | 5 ++--- .github/workflows/dockerbuild.yml | 2 +- .github/workflows/e2e-tests.yml | 4 ++-- .github/workflows/unit-tests.yml | 2 +- 5 files changed, 7 insertions(+), 9 deletions(-) diff --git a/.github/actions/dockerbuild/action.yml b/.github/actions/dockerbuild/action.yml index 8bec828e97..e24efe6863 100644 --- a/.github/actions/dockerbuild/action.yml +++ b/.github/actions/dockerbuild/action.yml @@ -22,8 +22,7 @@ runs: run: | echo "IMAGE_NAME=${GITHUB_REPOSITORY,,}-php" >> ${GITHUB_ENV} - - if: ${{ inputs.php-version >= 7.4 }} - shell: 'bash' + - shell: 'bash' run: | echo "GD_OPTIONS=--with-freetype --with-jpeg" >> ${GITHUB_ENV} echo "EXT_INSTALL_ARGS=gd zip mysqli pgsql opcache" >> ${GITHUB_ENV} diff --git a/.github/workflows/dockerbuild-and-push.yml b/.github/workflows/dockerbuild-and-push.yml index d7e293aaac..125683f27b 100644 --- a/.github/workflows/dockerbuild-and-push.yml +++ b/.github/workflows/dockerbuild-and-push.yml @@ -21,15 +21,14 @@ jobs: strategy: fail-fast: false matrix: - php: [ '7.4', '8.0', '8.1', '8.2', '8.3' ] + php: [ '7.4', '8.0', '8.1', '8.2', '8.3', '8.4-rc' ] steps: - name: downcase REPO run: | echo "IMAGE_NAME=${GITHUB_REPOSITORY,,}-php" >> ${GITHUB_ENV} - - if: ${{ matrix.php >= 7.4 }} - run: | + - run: | echo "GD_OPTIONS=--with-freetype --with-jpeg" >> ${GITHUB_ENV} echo "EXT_INSTALL_ARGS=gd zip mysqli pgsql opcache" >> ${GITHUB_ENV} echo "APCU=apcu" >> ${GITHUB_ENV} diff --git a/.github/workflows/dockerbuild.yml b/.github/workflows/dockerbuild.yml index 26c6b554c5..d2d4ec2a42 100644 --- a/.github/workflows/dockerbuild.yml +++ b/.github/workflows/dockerbuild.yml @@ -19,7 +19,7 @@ jobs: strategy: fail-fast: false matrix: - php: [ '7.4', '8.0', '8.1', '8.2', '8.3' ] + php: [ '7.4', '8.0', '8.1', '8.2', '8.3', '8.4-rc' ] steps: - name: Checkout diff --git a/.github/workflows/e2e-tests.yml b/.github/workflows/e2e-tests.yml index 5e5dcd305c..3c9cb1f6fe 100644 --- a/.github/workflows/e2e-tests.yml +++ b/.github/workflows/e2e-tests.yml @@ -30,7 +30,7 @@ jobs: - 'test/front_login' - 'test/front_guest' - 'test/admin' - php: [ '7.4', '8.0', '8.1', '8.2', '8.3' ] + php: [ '7.4', '8.0', '8.1', '8.2', '8.3', '8.4-rc' ] db: [ mysql, pgsql ] steps: - name: Checkout @@ -123,7 +123,7 @@ jobs: fail-fast: false matrix: db: [ 'pgsql', 'mysql' ] - php: [ '7.4', '8.0', '8.1', '8.2', '8.3' ] + php: [ '7.4', '8.0', '8.1', '8.2', '8.3', '8.4-rc' ] include: - db: mysql dbport: '3306' diff --git a/.github/workflows/unit-tests.yml b/.github/workflows/unit-tests.yml index 14ef5dfc4f..e41c0520e9 100644 --- a/.github/workflows/unit-tests.yml +++ b/.github/workflows/unit-tests.yml @@ -24,7 +24,7 @@ jobs: fail-fast: false matrix: operating-system: [ ubuntu-22.04 ] - php: [ '7.4', '8.0', '8.1', '8.2', '8.3' ] + php: [ '7.4', '8.0', '8.1', '8.2', '8.3', '8.4-rc' ] db: [ mysql, pgsql ] steps: From 7bb29419052466da56d430d38e07ad9fd1c611be Mon Sep 17 00:00:00 2001 From: Kentaro Ohkouchi Date: Thu, 17 Oct 2024 23:44:48 +0900 Subject: [PATCH 3/8] =?UTF-8?q?PHP8.4=E3=81=A7=20`Argument=20#1=20($mode)?= =?UTF-8?q?=20must=20be=20a=20single=20character`=20=E3=81=A8=E3=81=AA?= =?UTF-8?q?=E3=82=8B=E3=81=9F=E3=82=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- html/install/templates/step4.tpl | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/html/install/templates/step4.tpl b/html/install/templates/step4.tpl index 53e2c6c624..933b39ccef 100644 --- a/html/install/templates/step4.tpl +++ b/html/install/templates/step4.tpl @@ -30,7 +30,7 @@ - " /> + @@ -48,7 +48,7 @@
  • EC-CUBEバージョン:
  • PHP情報:
  • DB情報:
  • -
  • OS情報:
  • +
  • OS情報:
  • From 3900242e7f7629b4b02cd56b7a373aad32f1840a Mon Sep 17 00:00:00 2001 From: Kentaro Ohkouchi Date: Thu, 17 Oct 2024 23:46:36 +0900 Subject: [PATCH 4/8] =?UTF-8?q?PHP8.4.0+=E3=81=A7=20MobileDetect=203.74.x?= =?UTF-8?q?=20=E3=81=8C=20E=5FDEPRECATED=20=E3=82=92=E7=99=BA=E7=94=9F?= =?UTF-8?q?=E3=81=95=E3=81=9B=E3=82=8B=E3=81=9F=E3=82=81=E5=88=86=E5=B2=90?= =?UTF-8?q?=E3=81=99=E3=82=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit MobileDetect 4.8.x は PHP7.4.x に対応していないため、3.74.x を利用する --- tests/class/fixtures/server/common.php | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/tests/class/fixtures/server/common.php b/tests/class/fixtures/server/common.php index ca9ccba031..db9a949582 100644 --- a/tests/class/fixtures/server/common.php +++ b/tests/class/fixtures/server/common.php @@ -4,7 +4,12 @@ require __DIR__.'/../../../require.php'; -error_reporting(-1); +if (PHP_VERSION_ID >= 80400) { + // XXX PHP8.4.0+で MobileDetect 3.74.x が E_DEPRECATED を発生させるため + error_reporting(E_ALL & ~E_DEPRECATED); +} else { + error_reporting(E_ALL); +} ini_set('display_errors', '1'); header_remove('X-Powered-By'); From e511f15a489ba5109c82e68f8031fa6e338d81f7 Mon Sep 17 00:00:00 2001 From: Kentaro Ohkouchi Date: Fri, 18 Oct 2024 00:24:46 +0900 Subject: [PATCH 5/8] =?UTF-8?q?Fixes=20#1019=20PR=20=E3=81=AE=E5=A0=B4?= =?UTF-8?q?=E5=90=88=E3=81=AF=20`TAG=3D${DOCKER=5FMETADATA=5FOUTPUT=5FVERS?= =?UTF-8?q?ION}`=20=E3=82=92=E8=A8=AD=E5=AE=9A=E3=81=99=E3=82=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/e2e-tests.yml | 12 ++++++++++-- .github/workflows/phpstan.yml | 6 +++++- .github/workflows/unit-tests.yml | 6 +++++- 3 files changed, 20 insertions(+), 4 deletions(-) diff --git a/.github/workflows/e2e-tests.yml b/.github/workflows/e2e-tests.yml index 3c9cb1f6fe..1a114efb30 100644 --- a/.github/workflows/e2e-tests.yml +++ b/.github/workflows/e2e-tests.yml @@ -60,7 +60,11 @@ jobs: echo "COMPOSE_FILE=docker-compose.yml:docker-compose.${DB}.yml:docker-compose.dev.yml" >> $GITHUB_ENV echo "IMAGE_NAME=${OWNER,,}/ec-cube2-php" >> $GITHUB_ENV if [ $EVENT_NAME = "pull_request" ]; then - echo "TAG=${PHP}-apache-${BASE_REF}" >> $GITHUB_ENV + if [ -n $DOCKER_METADATA_OUTPUT_VERSION ]; then + echo "TAG=${DOCKER_METADATA_OUTPUT_VERSION}" >> $GITHUB_ENV + else + echo "TAG=${PHP}-apache-${BASE_REF}" >> $GITHUB_ENV + fi else echo "TAG=${PHP}-apache-${REF_NAME}" >> $GITHUB_ENV fi @@ -158,7 +162,11 @@ jobs: echo "COMPOSE_FILE=docker-compose.yml:docker-compose.${DB}.yml:docker-compose.dev.yml" >> $GITHUB_ENV echo "IMAGE_NAME=${OWNER,,}/ec-cube2-php" >> $GITHUB_ENV if [ $EVENT_NAME = "pull_request" ]; then - echo "TAG=${PHP}-apache-${BASE_REF}" >> $GITHUB_ENV + if [ -n $DOCKER_METADATA_OUTPUT_VERSION ]; then + echo "TAG=${DOCKER_METADATA_OUTPUT_VERSION}" >> $GITHUB_ENV + else + echo "TAG=${PHP}-apache-${BASE_REF}" >> $GITHUB_ENV + fi else echo "TAG=${PHP}-apache-${REF_NAME}" >> $GITHUB_ENV fi diff --git a/.github/workflows/phpstan.yml b/.github/workflows/phpstan.yml index 96d47fdb71..0858b04b40 100644 --- a/.github/workflows/phpstan.yml +++ b/.github/workflows/phpstan.yml @@ -39,7 +39,11 @@ jobs: echo "COMPOSE_FILE=docker-compose.yml:docker-compose.pgsql.yml:docker-compose.dev.yml" >> $GITHUB_ENV echo "IMAGE_NAME=${OWNER,,}/ec-cube2-php" >> $GITHUB_ENV if [ $EVENT_NAME = "pull_request" ]; then - echo "TAG=8.3-apache-${BASE_REF}" >> $GITHUB_ENV + if [ -n $DOCKER_METADATA_OUTPUT_VERSION ]; then + echo "TAG=${DOCKER_METADATA_OUTPUT_VERSION}" >> $GITHUB_ENV + else + echo "TAG=8.3-apache-${BASE_REF}" >> $GITHUB_ENV + fi else echo "TAG=8.3-apache-${REF_NAME}" >> $GITHUB_ENV fi diff --git a/.github/workflows/unit-tests.yml b/.github/workflows/unit-tests.yml index e41c0520e9..89b0a2a465 100644 --- a/.github/workflows/unit-tests.yml +++ b/.github/workflows/unit-tests.yml @@ -53,7 +53,11 @@ jobs: echo "COMPOSE_FILE=docker-compose.yml:docker-compose.${DB}.yml:docker-compose.dev.yml" >> $GITHUB_ENV echo "IMAGE_NAME=${OWNER,,}/ec-cube2-php" >> $GITHUB_ENV if [ $EVENT_NAME = "pull_request" ]; then - echo "TAG=${PHP}-apache-${BASE_REF}" >> $GITHUB_ENV + if [ -n $DOCKER_METADATA_OUTPUT_VERSION ]; then + echo "TAG=${DOCKER_METADATA_OUTPUT_VERSION}" >> $GITHUB_ENV + else + echo "TAG=${PHP}-apache-${BASE_REF}" >> $GITHUB_ENV + fi else echo "TAG=${PHP}-apache-${REF_NAME}" >> $GITHUB_ENV fi From 04c904fe18035fa69c4de984873e244b4969fb9e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E3=81=AE=E3=81=B6?= Date: Tue, 22 Oct 2024 10:28:20 +0900 Subject: [PATCH 6/8] =?UTF-8?q?webpack=E3=81=AE=E8=BB=BD=E9=87=8F=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- data/eccube.js | 617 +- html/js/eccube.js | 2 +- html/js/eccube.js.LICENSE.txt | 20 +- html/js/eccube.js.map | 2 +- package-lock.json | 9893 +++++++++++++++++++++++++++++ package.json | 25 +- webpack.config.js | 21 +- yarn.lock | 10753 ++++++++++++++++++-------------- 8 files changed, 16464 insertions(+), 4869 deletions(-) create mode 100644 package-lock.json diff --git a/data/eccube.js b/data/eccube.js index 0a5ab31f8d..26d88bfd95 100644 --- a/data/eccube.js +++ b/data/eccube.js @@ -1,46 +1,42 @@ -const $ = require( "jquery" ); - -global.$ = global.jQuery = $; -require( "jquery-migrate" ); +import $ from "jquery"; +import "jquery-migrate"; /* 警告を無効にする */ -$( () => { - $.migrateMute = true; -} ); -require( "jquery-colorbox" ); -require( "jquery-colorbox/example2/colorbox.css" ); -require( "jquery-easing" ); +$.migrateMute = true; -require( "slick-carousel" ); -require( "slick-carousel/slick/slick.css" ); -require( "slick-carousel/slick/slick-theme.css" ); +import "jquery-colorbox"; +import "jquery-colorbox/example2/colorbox.css"; +import "jquery-easing"; -/* -* This file is part of EC-CUBE -* -* Copyright(c) EC-CUBE CO.,LTD. All Rights Reserved. -* -* http://www.ec-cube.co.jp/ -* -* This program is free software; you can redistribute it and/or -* modify it under the terms of the GNU General Public License -* as published by the Free Software Foundation; either version 2 -* of the License, or (at your option) any later version. -* -* This program is distributed in the hope that it will be useful, -* but WITHOUT ANY WARRANTY; without even the implied warranty of -* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -* GNU General Public License for more details. -* -* You should have received a copy of the GNU General Public License -* along with this program; if not, write to the Free Software -* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -*/ - -( function( window, undefined ) { +import "slick-carousel"; +import "slick-carousel/slick/slick.css"; +import "slick-carousel/slick/slick-theme.css"; +/* + * This file is part of EC-CUBE + * + * Copyright(c) EC-CUBE CO.,LTD. All Rights Reserved. + * + * http://www.ec-cube.co.jp/ + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + */ + +(function (window, undefined) { // 名前空間の重複を防ぐ - if ( window.eccube === undefined ) { + if (window.eccube === undefined) { window.eccube = {}; } @@ -56,41 +52,36 @@ require( "slick-carousel/slick/slick-theme.css" ); directories: "no", status: "no", focus: true, - formTarget: "" - } + formTarget: "", + }, }; - eccube.openWindow = function( URL, name, width, height, option ) { + eccube.openWindow = function (URL, name, width, height, option) { let features = `width=${width},height=${height}`; - if ( option === undefined ) { + if (option === undefined) { option = eccube.defaults.windowFeatures; } else { - option = $.extend( eccube.defaults.windowFeatures, option ); - } - features = `${features},scrollbars=${option.scrollbars - },resizable=${option.resizable - },toolbar=${option.toolbar - },location=${option.location - },directories=${option.directories - },status=${option.status}`; - if ( option.hasOwnProperty( "menubar" ) ) { + option = $.extend(eccube.defaults.windowFeatures, option); + } + features = `${features},scrollbars=${option.scrollbars},resizable=${option.resizable},toolbar=${option.toolbar},location=${option.location},directories=${option.directories},status=${option.status}`; + if (option.hasOwnProperty("menubar")) { features = `${features},menubar=${option.menubar}`; } - const WIN = window.open( URL, name, features ); - if ( option.formTarget !== "" ) { - document.forms[ option.formTarget ].target = name; + const WIN = window.open(URL, name, features); + if (option.formTarget !== "") { + document.forms[option.formTarget].target = name; } - if ( option.focus ) { + if (option.focus) { WIN.focus(); } }; // 親ウィンドウの存在確認. - eccube.isOpener = function() { + eccube.isOpener = function () { const ua = navigator.userAgent; - if ( window.opener ) { - if ( ua.indexOf( "MSIE 4" ) !== -1 && ua.indexOf( "Win" ) !== -1 ) { - if ( window.opener.hasOwnProperty( "closed" ) ) { + if (window.opener) { + if (ua.indexOf("MSIE 4") !== -1 && ua.indexOf("Win") !== -1) { + if (window.opener.hasOwnProperty("closed")) { return !window.opener.closed; } return false; @@ -101,66 +92,82 @@ require( "slick-carousel/slick/slick-theme.css" ); }; // 郵便番号入力呼び出し. - eccube.getAddress = function( php_url, tagname1, tagname2, input1, input2 ) { - const zip1 = document.form1[ tagname1 ].value; - const zip2 = document.form1[ tagname2 ].value; + eccube.getAddress = function (php_url, tagname1, tagname2, input1, input2) { + const zip1 = document.form1[tagname1].value; + const zip2 = document.form1[tagname2].value; - if ( zip1.length === 3 && zip2.length === 4 ) { + if (zip1.length === 3 && zip2.length === 4) { $.get( php_url, { - zip1, zip2, input1, input2 + zip1, + zip2, + input1, + input2, }, - ( data ) => { - const arrData = data.split( "|" ); - if ( arrData.length > 1 ) { - eccube.putAddress( input1, input2, arrData[ 0 ], arrData[ 1 ], arrData[ 2 ] ); + (data) => { + const arrData = data.split("|"); + if (arrData.length > 1) { + eccube.putAddress( + input1, + input2, + arrData[0], + arrData[1], + arrData[2] + ); } else { - window.alert( data ); + window.alert(data); } - }, + } ); } else { - window.alert( "郵便番号を正しく入力して下さい。" ); + window.alert("郵便番号を正しく入力して下さい。"); } }; // 郵便番号から検索した住所を渡す. - eccube.putAddress = function( input1, input2, state, city, town ) { - if ( state !== "" ) { - + eccube.putAddress = function (input1, input2, state, city, town) { + if (state !== "") { // 項目に値を入力する. - document.form1[ input1 ].selectedIndex = state; - document.form1[ input2 ].value = city + town; + document.form1[input1].selectedIndex = state; + document.form1[input2].value = city + town; } }; - eccube.setFocus = function( name ) { - if ( document.form1.hasOwnProperty( name ) ) { - document.form1[ name ].focus(); + eccube.setFocus = function (name) { + if (document.form1.hasOwnProperty(name)) { + document.form1[name].focus(); } }; // モードとキーを指定してSUBMITを行う。 - eccube.setModeAndSubmit = function( mode, keyname, keyid ) { - switch ( mode ) { + eccube.setModeAndSubmit = function (mode, keyname, keyid) { + switch (mode) { case "delete_category": - if ( !window.confirm( "選択したカテゴリとカテゴリ内の全てのカテゴリを削除します" ) ) { + if ( + !window.confirm( + "選択したカテゴリとカテゴリ内の全てのカテゴリを削除します" + ) + ) { return; } break; case "delete": - if ( !window.confirm( "一度削除したデータは、元に戻せません。\n削除しても宜しいですか?" ) ) { + if ( + !window.confirm( + "一度削除したデータは、元に戻せません。\n削除しても宜しいですか?" + ) + ) { return; } break; case "confirm": - if ( !window.confirm( "登録しても宜しいですか" ) ) { + if (!window.confirm("登録しても宜しいですか")) { return; } break; case "delete_all": - if ( !window.confirm( "検索結果を全て削除しても宜しいですか" ) ) { + if (!window.confirm("検索結果を全て削除しても宜しいですか")) { return; } break; @@ -168,32 +175,41 @@ require( "slick-carousel/slick/slick-theme.css" ); break; } document.form1.mode.value = mode; - if ( keyname !== undefined && keyname !== "" && keyid !== undefined && keyid !== "" ) { - document.form1[ keyname ].value = keyid; + if ( + keyname !== undefined && + keyname !== "" && + keyid !== undefined && + keyid !== "" + ) { + document.form1[keyname].value = keyid; } document.form1.submit(); }; - eccube.fnFormModeSubmit = function( form, mode, keyname, keyid ) { - switch ( mode ) { + eccube.fnFormModeSubmit = function (form, mode, keyname, keyid) { + switch (mode) { case "delete": - if ( !window.confirm( "一度削除したデータは、元に戻せません。\n削除しても宜しいですか?" ) ) { + if ( + !window.confirm( + "一度削除したデータは、元に戻せません。\n削除しても宜しいですか?" + ) + ) { return; } break; case "cartDelete": - if ( !window.confirm( "カゴから商品を削除しても宜しいでしょうか?" ) ) { + if (!window.confirm("カゴから商品を削除しても宜しいでしょうか?")) { return; } mode = "delete"; break; case "confirm": - if ( !window.confirm( "登録しても宜しいですか" ) ) { + if (!window.confirm("登録しても宜しいですか")) { return; } break; case "regist": - if ( !window.confirm( "登録しても宜しいですか" ) ) { + if (!window.confirm("登録しても宜しいですか")) { return; } break; @@ -201,88 +217,93 @@ require( "slick-carousel/slick/slick-theme.css" ); break; } const values = { mode }; - if ( keyname !== undefined && keyname !== "" && keyid !== undefined && keyid !== "" ) { - values[ keyname ] = keyid; - } - eccube.submitForm( values, form ); + if ( + keyname !== undefined && + keyname !== "" && + keyid !== undefined && + keyid !== "" + ) { + values[keyname] = keyid; + } + eccube.submitForm(values, form); }; - eccube.setValueAndSubmit = function( form, key, val, msg ) { + eccube.setValueAndSubmit = function (form, key, val, msg) { let ret; - if ( msg !== undefined ) { - ret = window.confirm( msg ); + if (msg !== undefined) { + ret = window.confirm(msg); } else { ret = true; } - if ( ret ) { + if (ret) { const values = {}; - values[ key ] = val; - eccube.submitForm( values, form ); + values[key] = val; + eccube.submitForm(values, form); } return false; }; - eccube.setValue = function( key, val, form ) { - const formElement = eccube.getFormElement( form ); - formElement.find( `*[name=${key}]` ).val( val ); + eccube.setValue = function (key, val, form) { + const formElement = eccube.getFormElement(form); + formElement.find(`*[name=${key}]`).val(val); }; - eccube.changeAction = function( url, form ) { - const formElement = eccube.getFormElement( form ); - formElement.attr( "action", url ); + eccube.changeAction = function (url, form) { + const formElement = eccube.getFormElement(form); + formElement.attr("action", url); }; // ページナビで使用する。 - eccube.movePage = function( pageno, mode, form ) { + eccube.movePage = function (pageno, mode, form) { const values = { pageno }; - if ( mode !== undefined ) { + if (mode !== undefined) { values.mode = mode; } - eccube.submitForm( values, form ); + eccube.submitForm(values, form); }; /** - * フォームを送信する. - * - * @param values - * @param form - */ - eccube.submitForm = function( values, form ) { - const formElement = eccube.getFormElement( form ); - if ( values !== undefined && typeof values === "object" ) { - $.each( values, ( index, value ) => { - eccube.setValue( index, value, formElement ); - } ); + * フォームを送信する. + * + * @param values + * @param form + */ + eccube.submitForm = function (values, form) { + const formElement = eccube.getFormElement(form); + if (values !== undefined && typeof values === "object") { + $.each(values, (index, value) => { + eccube.setValue(index, value, formElement); + }); } formElement.submit(); }; /** - * フォームを特定してエレメントを返す. - * - * @param form - * @returns {*} - */ - eccube.getFormElement = function( form ) { + * フォームを特定してエレメントを返す. + * + * @param form + * @returns {*} + */ + eccube.getFormElement = function (form) { let formElement; - if ( form !== undefined && typeof form === "string" && form !== "" ) { - formElement = $( `form#${form}` ); - } else if ( form !== undefined && typeof form === "object" ) { + if (form !== undefined && typeof form === "string" && form !== "") { + formElement = $(`form#${form}`); + } else if (form !== undefined && typeof form === "object") { formElement = form; } else { - formElement = $( `form#${eccube.defaults.formId}` ); + formElement = $(`form#${eccube.defaults.formId}`); } return formElement; }; // ポイント入力制限。 - eccube.togglePointForm = function() { - if ( document.form1.point_check ) { - const list = [ "use_point" ]; + eccube.togglePointForm = function () { + if (document.form1.point_check) { + const list = ["use_point"]; let color; let flag; - if ( !document.form1.point_check[ 0 ].checked ) { + if (!document.form1.point_check[0].checked) { color = "#dddddd"; flag = true; } else { @@ -291,25 +312,29 @@ require( "slick-carousel/slick/slick-theme.css" ); } const len = list.length; - for ( let i = 0; i < len; i++ ) { - if ( document.form1[ list[ i ] ] ) { - const current_color = document.form1[ list[ i ] ].style.backgroundColor; - if ( color !== "#dddddd" && ( current_color === "#ffe8e8" || current_color === "rgb(255, 232, 232)" ) ) { + for (let i = 0; i < len; i++) { + if (document.form1[list[i]]) { + const current_color = document.form1[list[i]].style.backgroundColor; + if ( + color !== "#dddddd" && + (current_color === "#ffe8e8" || + current_color === "rgb(255, 232, 232)") + ) { continue; } - document.form1[ list[ i ] ].disabled = flag; - document.form1[ list[ i ] ].style.backgroundColor = color; + document.form1[list[i]].disabled = flag; + document.form1[list[i]].style.backgroundColor = color; } } } }; // 別のお届け先入力制限。 - eccube.toggleDeliveryForm = function() { - if ( !document.form1 ) { + eccube.toggleDeliveryForm = function () { + if (!document.form1) { return; } - if ( document.form1.deliv_check ) { + if (document.form1.deliv_check) { const list = [ "shipping_name01", "shipping_name02", @@ -328,13 +353,13 @@ require( "slick-carousel/slick/slick-theme.css" ); "shipping_zipcode", "shipping_fax01", "shipping_fax02", - "shipping_fax03" + "shipping_fax03", ]; - if ( !document.form1.deliv_check.checked ) { - eccube.changeDisabled( list, "#dddddd" ); + if (!document.form1.deliv_check.checked) { + eccube.changeDisabled(list, "#dddddd"); } else { - eccube.changeDisabled( list, "" ); + eccube.changeDisabled(list, ""); } } }; @@ -342,67 +367,66 @@ require( "slick-carousel/slick/slick-theme.css" ); // 最初に設定されていた色を保存しておく。 eccube.savedColor = []; - eccube.changeDisabled = function( list, color ) { + eccube.changeDisabled = function (list, color) { const len = list.length; - for ( let i = 0; i < len; i++ ) { - if ( document.form1[ list[ i ] ] ) { - if ( color === "" ) { - + for (let i = 0; i < len; i++) { + if (document.form1[list[i]]) { + if (color === "") { // 有効にする。 - document.form1[ list[ i ] ].removeAttribute( "disabled" ); - document.form1[ list[ i ] ].style.backgroundColor = eccube.savedColor[ list[ i ] ]; + document.form1[list[i]].removeAttribute("disabled"); + document.form1[list[i]].style.backgroundColor = + eccube.savedColor[list[i]]; } else { - // 無効にする。 - document.form1[ list[ i ] ].setAttribute( "disabled", "disabled" ); - eccube.savedColor[ list[ i ] ] = document.form1[ list[ i ] ].style.backgroundColor; - document.form1[ list[ i ] ].style.backgroundColor = color;// "#f0f0f0"; + document.form1[list[i]].setAttribute("disabled", "disabled"); + eccube.savedColor[list[i]] = + document.form1[list[i]].style.backgroundColor; + document.form1[list[i]].style.backgroundColor = color; // "#f0f0f0"; } } } }; // ログイン時の入力チェック - eccube.checkLoginFormInputted = function( form, emailKey, passKey ) { - const formElement = $( `form#${form}` ); + eccube.checkLoginFormInputted = function (form, emailKey, passKey) { + const formElement = $(`form#${form}`); const checkItems = []; - if ( typeof emailKey === "undefined" ) { - checkItems[ 0 ] = "login_email"; + if (typeof emailKey === "undefined") { + checkItems[0] = "login_email"; } else { - checkItems[ 0 ] = emailKey; + checkItems[0] = emailKey; } - if ( typeof passKey === "undefined" ) { - checkItems[ 1 ] = "login_pass"; + if (typeof passKey === "undefined") { + checkItems[1] = "login_pass"; } else { - checkItems[ 1 ] = passKey; + checkItems[1] = passKey; } const max = checkItems.length; let errorFlag = false; // 必須項目のチェック - for ( let cnt = 0; cnt < max; cnt++ ) { - if ( formElement.find( `input[name=${checkItems[ cnt ]}]` ).val() === "" ) { + for (let cnt = 0; cnt < max; cnt++) { + if (formElement.find(`input[name=${checkItems[cnt]}]`).val() === "") { errorFlag = true; break; } } // 必須項目が入力されていない場合 - if ( errorFlag === true ) { - window.alert( "メールアドレス/パスワードを入力して下さい。" ); + if (errorFlag === true) { + window.alert("メールアドレス/パスワードを入力して下さい。"); return false; } return true; }; // 親ウィンドウのページを変更する. - eccube.changeParentUrl = function( url ) { - + eccube.changeParentUrl = function (url) { // 親ウィンドウの存在確認 - if ( eccube.isOpener() ) { + if (eccube.isOpener()) { window.opener.location.href = url; } else { window.close(); @@ -413,96 +437,110 @@ require( "slick-carousel/slick/slick-theme.css" ); // 引数1:フォーム名称 // 引数2:文字数カウント対象 // 引数3:カウント結果格納対象 - eccube.countChars = function( form, sch, cnt ) { - const formElement = $( `form#${form}` ); - formElement.find( `input[name=${cnt}]` ).val( formElement.find( `*[name=${sch}]` ).val().length ); + eccube.countChars = function (form, sch, cnt) { + const formElement = $(`form#${form}`); + formElement + .find(`input[name=${cnt}]`) + .val(formElement.find(`*[name=${sch}]`).val().length); }; // テキストエリアのサイズを変更する. - eccube.toggleRows = function( buttonSelector, textAreaSelector, max, min ) { - if ( $( textAreaSelector ).attr( "rows" ) <= min ) { - $( textAreaSelector ).attr( "rows", max ); - $( buttonSelector ).text( "縮小" ); + eccube.toggleRows = function (buttonSelector, textAreaSelector, max, min) { + if ($(textAreaSelector).attr("rows") <= min) { + $(textAreaSelector).attr("rows", max); + $(buttonSelector).text("縮小"); } else { - $( textAreaSelector ).attr( "rows", min ); - $( buttonSelector ).text( "拡大" ); + $(textAreaSelector).attr("rows", min); + $(buttonSelector).text("拡大"); } }; /** - * 規格2のプルダウンを設定する. - */ - eccube.setClassCategories = function( $form, product_id, $sele1, $sele2, selected_id2 ) { - if ( $sele1 && $sele1.length ) { + * 規格2のプルダウンを設定する. + */ + eccube.setClassCategories = function ( + $form, + product_id, + $sele1, + $sele2, + selected_id2 + ) { + if ($sele1 && $sele1.length) { const classcat_id1 = $sele1.val() ? $sele1.val() : ""; - if ( $sele2 && $sele2.length ) { - + if ($sele2 && $sele2.length) { // 規格2の選択肢をクリア $sele2.children().remove(); let classcat2; // 商品一覧時 - if ( eccube.hasOwnProperty( "productsClassCategories" ) ) { - classcat2 = eccube.productsClassCategories[ product_id ][ classcat_id1 ]; + if (eccube.hasOwnProperty("productsClassCategories")) { + classcat2 = eccube.productsClassCategories[product_id][classcat_id1]; } else { - // 詳細表示時 - classcat2 = eccube.classCategories[ classcat_id1 ]; + classcat2 = eccube.classCategories[classcat_id1]; } // 規格2の要素を設定 - for ( const key in classcat2 ) { - if ( classcat2.hasOwnProperty( key ) ) { - const id = classcat2[ key ].classcategory_id2; - const { name } = classcat2[ key ]; - const option = $( "