littleshop/LittleShop/wwwroot/lib/handsontable/languages/ko-KR.js
sysadmin 76efba55bd feat: Phase 2.5 - Variant Collections Spreadsheet Editor
Replaces JSON textarea with professional Excel-like spreadsheet interface for managing product variant properties.

Features:
- Handsontable 14.6.1 spreadsheet component
- Property presets (Size, Color, Material, Storage, Custom)
- Inline cell editing with Tab/Enter navigation
- Context menu for add/remove rows and columns
- Keyboard shortcuts (Ctrl+D delete, Ctrl+Enter save, Ctrl+Z undo)
- Mobile touch gestures (swipe to delete rows)
- Automatic JSON serialization on form submit
- Form validation before saving
- Comprehensive user guide documentation

Files Changed:
- LittleShop/package.json: NPM package management setup
- LittleShop/wwwroot/js/variant-editor.js: 400-line spreadsheet editor module
- LittleShop/wwwroot/lib/handsontable/: Handsontable library (Community Edition)
- LittleShop/wwwroot/lib/hammerjs/: Hammer.js touch gesture library
- LittleShop/Areas/Admin/Views/VariantCollections/Edit.cshtml: Spreadsheet UI integration
- VARIANT_COLLECTIONS_USER_GUIDE.md: Complete user guide (18+ pages)

Technical Details:
- Excel-like editing experience (no more manual JSON editing)
- Mobile-first responsive design
- Browser compatibility: Chrome 90+, Firefox 88+, Edge 90+, Safari 14+
- Touch-optimized for mobile administration
- Automatic data validation and error handling
2025-11-13 19:40:06 +00:00

161 lines
6.6 KiB
JavaScript

(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory(require("handsontable"));
else if(typeof define === 'function' && define.amd)
define(["handsontable"], factory);
else {
var a = typeof exports === 'object' ? factory(require("handsontable")) : factory(root["Handsontable"]);
for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
}
})(typeof self !== 'undefined' ? self : this, (__WEBPACK_EXTERNAL_MODULE__2__) => {
return /******/ (() => { // webpackBootstrap
/******/ var __webpack_modules__ = ([
/* 0 */,
/* 1 */
/***/ ((module) => {
function _interopRequireDefault(e) {
return e && e.__esModule ? e : {
"default": e
};
}
module.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports["default"] = module.exports;
/***/ }),
/* 2 */
/***/ ((module) => {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE__2__;
/***/ })
/******/ ]);
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
var __webpack_exports__ = {};
// This entry need to be wrapped in an IIFE because it need to be in strict mode.
(() => {
"use strict";
var exports = __webpack_exports__;
var _interopRequireDefault = __webpack_require__(1);
exports.__esModule = true;
var _handsontable = _interopRequireDefault(__webpack_require__(2));
/**
* @preserve
* Authors: Hwang, Gun-gu
* Last updated: Aug 20, 2018
*
* Description: Definition file for Korean - Korea language-country.
*/
const C = _handsontable.default.languages.dictionaryKeys;
const dictionary = {
languageCode: 'ko-KR',
[C.CONTEXTMENU_ITEMS_ROW_ABOVE]: '위쪽에 행 삽입',
[C.CONTEXTMENU_ITEMS_ROW_BELOW]: '아래쪽에 행 삽입',
[C.CONTEXTMENU_ITEMS_INSERT_LEFT]: '왼쪽에 열 삽입',
[C.CONTEXTMENU_ITEMS_INSERT_RIGHT]: '오른쪽에 열 삽입',
[C.CONTEXTMENU_ITEMS_REMOVE_ROW]: ['행 삭제', '여러 행 삭제'],
[C.CONTEXTMENU_ITEMS_REMOVE_COLUMN]: ['열 삭제', '여러 열 삭제'],
[C.CONTEXTMENU_ITEMS_UNDO]: '되돌리기',
[C.CONTEXTMENU_ITEMS_REDO]: '다시하기',
[C.CONTEXTMENU_ITEMS_READ_ONLY]: '읽기 전용',
[C.CONTEXTMENU_ITEMS_CLEAR_COLUMN]: '열 지우기',
[C.CONTEXTMENU_ITEMS_ALIGNMENT]: '정렬',
[C.CONTEXTMENU_ITEMS_ALIGNMENT_LEFT]: '왼쪽',
[C.CONTEXTMENU_ITEMS_ALIGNMENT_CENTER]: '중앙',
[C.CONTEXTMENU_ITEMS_ALIGNMENT_RIGHT]: '오른쪽',
[C.CONTEXTMENU_ITEMS_ALIGNMENT_JUSTIFY]: '자동',
[C.CONTEXTMENU_ITEMS_ALIGNMENT_TOP]: '위쪽',
[C.CONTEXTMENU_ITEMS_ALIGNMENT_MIDDLE]: '가운데',
[C.CONTEXTMENU_ITEMS_ALIGNMENT_BOTTOM]: '아래쪽',
[C.CONTEXTMENU_ITEMS_FREEZE_COLUMN]: '열 고정',
[C.CONTEXTMENU_ITEMS_UNFREEZE_COLUMN]: '열 고정 해제',
[C.CONTEXTMENU_ITEMS_BORDERS]: '테두리',
[C.CONTEXTMENU_ITEMS_BORDERS_TOP]: '위쪽',
[C.CONTEXTMENU_ITEMS_BORDERS_RIGHT]: '오른쪽',
[C.CONTEXTMENU_ITEMS_BORDERS_BOTTOM]: '아래쪽',
[C.CONTEXTMENU_ITEMS_BORDERS_LEFT]: '왼쪽',
[C.CONTEXTMENU_ITEMS_REMOVE_BORDERS]: '테두리 지우기',
[C.CONTEXTMENU_ITEMS_ADD_COMMENT]: '댓글 달기',
[C.CONTEXTMENU_ITEMS_EDIT_COMMENT]: '댓글 편집',
[C.CONTEXTMENU_ITEMS_REMOVE_COMMENT]: '댓글 삭제',
[C.CONTEXTMENU_ITEMS_READ_ONLY_COMMENT]: '읽기 전용 댓글',
[C.CONTEXTMENU_ITEMS_MERGE_CELLS]: '셀 병합',
[C.CONTEXTMENU_ITEMS_UNMERGE_CELLS]: '셀 병합 해제',
[C.CONTEXTMENU_ITEMS_COPY]: '복사',
[C.CONTEXTMENU_ITEMS_CUT]: '잘라내기',
[C.CONTEXTMENU_ITEMS_NESTED_ROWS_INSERT_CHILD]: '자녀 행 추가',
[C.CONTEXTMENU_ITEMS_NESTED_ROWS_DETACH_CHILD]: '부모행에서 제거',
[C.CONTEXTMENU_ITEMS_HIDE_COLUMN]: ['열 숨기기', '여러 열 숨기기'],
[C.CONTEXTMENU_ITEMS_SHOW_COLUMN]: ['열 숨기기 해제', '여러 열 숨기기 해제'],
[C.CONTEXTMENU_ITEMS_HIDE_ROW]: ['행 숨기기', '여러 행 숨기기'],
[C.CONTEXTMENU_ITEMS_SHOW_ROW]: ['행 숨기기 해제', '여러 행 숨기기 해제'],
[C.FILTERS_CONDITIONS_NONE]: '조건없음',
[C.FILTERS_CONDITIONS_EMPTY]: '비어있음',
[C.FILTERS_CONDITIONS_NOT_EMPTY]: '비어있지 않음',
[C.FILTERS_CONDITIONS_EQUAL]: '같',
[C.FILTERS_CONDITIONS_NOT_EQUAL]: '같지 않음',
[C.FILTERS_CONDITIONS_BEGINS_WITH]: '시작 문자',
[C.FILTERS_CONDITIONS_ENDS_WITH]: '끝 문자',
[C.FILTERS_CONDITIONS_CONTAINS]: '포함',
[C.FILTERS_CONDITIONS_NOT_CONTAIN]: '포함하지 않음',
[C.FILTERS_CONDITIONS_GREATER_THAN]: '보다 큼',
[C.FILTERS_CONDITIONS_GREATER_THAN_OR_EQUAL]: '크거나 같음',
[C.FILTERS_CONDITIONS_LESS_THAN]: '보다 작',
[C.FILTERS_CONDITIONS_LESS_THAN_OR_EQUAL]: '작거나 같음',
[C.FILTERS_CONDITIONS_BETWEEN]: '사이',
[C.FILTERS_CONDITIONS_NOT_BETWEEN]: '사이 제외',
[C.FILTERS_CONDITIONS_AFTER]: '다음',
[C.FILTERS_CONDITIONS_BEFORE]: '전',
[C.FILTERS_CONDITIONS_TODAY]: '오늘',
[C.FILTERS_CONDITIONS_TOMORROW]: '내일',
[C.FILTERS_CONDITIONS_YESTERDAY]: '어제',
[C.FILTERS_VALUES_BLANK_CELLS]: '공란',
[C.FILTERS_DIVS_FILTER_BY_CONDITION]: '조건부 필터',
[C.FILTERS_DIVS_FILTER_BY_VALUE]: '값 필터',
[C.FILTERS_LABELS_CONJUNCTION]: '그리고',
[C.FILTERS_LABELS_DISJUNCTION]: '또는',
[C.FILTERS_BUTTONS_SELECT_ALL]: '전체선택',
[C.FILTERS_BUTTONS_CLEAR]: '지우기',
[C.FILTERS_BUTTONS_OK]: '확인',
[C.FILTERS_BUTTONS_CANCEL]: '취소',
[C.FILTERS_BUTTONS_PLACEHOLDER_SEARCH]: '찾기',
[C.FILTERS_BUTTONS_PLACEHOLDER_VALUE]: '값',
[C.FILTERS_BUTTONS_PLACEHOLDER_SECOND_VALUE]: '두번째 값'
};
_handsontable.default.languages.registerLanguageDictionary(dictionary);
var _default = exports["default"] = dictionary;
})();
__webpack_exports__ = __webpack_exports__.___;
/******/ return __webpack_exports__;
/******/ })()
;
});