diff --git a/_locales/am/messages.json b/_locales/am/messages.json index 12ca161..728b40d 100644 --- a/_locales/am/messages.json +++ b/_locales/am/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/ar/messages.json b/_locales/ar/messages.json index 1ee8d40..3bfb587 100644 --- a/_locales/ar/messages.json +++ b/_locales/ar/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "يمنع الوصول" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "إلغاء" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "إخفاء في وضع ملء الشاشة" }, - "next": { - "message": "التالي" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "أخرى" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "السابق" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "إعادة تعيين" @@ -41,4 +47,4 @@ "time": { "message": "الوقت" } -} +} \ No newline at end of file diff --git a/_locales/bg/messages.json b/_locales/bg/messages.json index 12ca161..728b40d 100644 --- a/_locales/bg/messages.json +++ b/_locales/bg/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/bn/messages.json b/_locales/bn/messages.json index 12ca161..728b40d 100644 --- a/_locales/bn/messages.json +++ b/_locales/bn/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/ca/messages.json b/_locales/ca/messages.json index 12ca161..728b40d 100644 --- a/_locales/ca/messages.json +++ b/_locales/ca/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/cs/messages.json b/_locales/cs/messages.json index 12ca161..728b40d 100644 --- a/_locales/cs/messages.json +++ b/_locales/cs/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/da/messages.json b/_locales/da/messages.json index 12ca161..728b40d 100644 --- a/_locales/da/messages.json +++ b/_locales/da/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/de/messages.json b/_locales/de/messages.json index b66e7e5..3f15372 100644 --- a/_locales/de/messages.json +++ b/_locales/de/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Nächster" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Vorheriger" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/el/messages.json b/_locales/el/messages.json index 12ca161..728b40d 100644 --- a/_locales/el/messages.json +++ b/_locales/el/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/en/messages.json b/_locales/en/messages.json index 12ca161..728b40d 100644 --- a/_locales/en/messages.json +++ b/_locales/en/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/es/messages.json b/_locales/es/messages.json index 12ca161..728b40d 100644 --- a/_locales/es/messages.json +++ b/_locales/es/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/et/messages.json b/_locales/et/messages.json index 12ca161..728b40d 100644 --- a/_locales/et/messages.json +++ b/_locales/et/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/fa/messages.json b/_locales/fa/messages.json index 12ca161..728b40d 100644 --- a/_locales/fa/messages.json +++ b/_locales/fa/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/fi/messages.json b/_locales/fi/messages.json index 12ca161..728b40d 100644 --- a/_locales/fi/messages.json +++ b/_locales/fi/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/fil/messages.json b/_locales/fil/messages.json index 12ca161..728b40d 100644 --- a/_locales/fil/messages.json +++ b/_locales/fil/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/fr/messages.json b/_locales/fr/messages.json index 12ca161..728b40d 100644 --- a/_locales/fr/messages.json +++ b/_locales/fr/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/gu/messages.json b/_locales/gu/messages.json index 12ca161..728b40d 100644 --- a/_locales/gu/messages.json +++ b/_locales/gu/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/he/messages.json b/_locales/he/messages.json index eb7746e..833d1d0 100644 --- a/_locales/he/messages.json +++ b/_locales/he/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "הגישה נדחתה" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "ביטול" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "הסתרה במסך מלא" }, - "next": { - "message": "הבא" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "אחר" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "הקודם" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "איפוס" @@ -41,4 +47,4 @@ "time": { "message": "זמן" } -} +} \ No newline at end of file diff --git a/_locales/hi/messages.json b/_locales/hi/messages.json index 12ca161..728b40d 100644 --- a/_locales/hi/messages.json +++ b/_locales/hi/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/hr/messages.json b/_locales/hr/messages.json index 12ca161..728b40d 100644 --- a/_locales/hr/messages.json +++ b/_locales/hr/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/hu/messages.json b/_locales/hu/messages.json index 12ca161..728b40d 100644 --- a/_locales/hu/messages.json +++ b/_locales/hu/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/id/messages.json b/_locales/id/messages.json index 12ca161..728b40d 100644 --- a/_locales/id/messages.json +++ b/_locales/id/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/it/messages.json b/_locales/it/messages.json index 12ca161..728b40d 100644 --- a/_locales/it/messages.json +++ b/_locales/it/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/ja/messages.json b/_locales/ja/messages.json index 12ca161..728b40d 100644 --- a/_locales/ja/messages.json +++ b/_locales/ja/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/kn/messages.json b/_locales/kn/messages.json index 12ca161..728b40d 100644 --- a/_locales/kn/messages.json +++ b/_locales/kn/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/ko/messages.json b/_locales/ko/messages.json index 12ca161..728b40d 100644 --- a/_locales/ko/messages.json +++ b/_locales/ko/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/lt/messages.json b/_locales/lt/messages.json index 12ca161..728b40d 100644 --- a/_locales/lt/messages.json +++ b/_locales/lt/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/lv/messages.json b/_locales/lv/messages.json index 12ca161..728b40d 100644 --- a/_locales/lv/messages.json +++ b/_locales/lv/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/ml/messages.json b/_locales/ml/messages.json index 12ca161..728b40d 100644 --- a/_locales/ml/messages.json +++ b/_locales/ml/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/mr/messages.json b/_locales/mr/messages.json index 12ca161..728b40d 100644 --- a/_locales/mr/messages.json +++ b/_locales/mr/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/ms/messages.json b/_locales/ms/messages.json index 12ca161..728b40d 100644 --- a/_locales/ms/messages.json +++ b/_locales/ms/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/nl/messages.json b/_locales/nl/messages.json index 12ca161..728b40d 100644 --- a/_locales/nl/messages.json +++ b/_locales/nl/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/no/messages.json b/_locales/no/messages.json index 12ca161..728b40d 100644 --- a/_locales/no/messages.json +++ b/_locales/no/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/pl/messages.json b/_locales/pl/messages.json index 12ca161..728b40d 100644 --- a/_locales/pl/messages.json +++ b/_locales/pl/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/pt_BR/messages.json b/_locales/pt_BR/messages.json index 12ca161..728b40d 100644 --- a/_locales/pt_BR/messages.json +++ b/_locales/pt_BR/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/pt_PT/messages.json b/_locales/pt_PT/messages.json index 12ca161..728b40d 100644 --- a/_locales/pt_PT/messages.json +++ b/_locales/pt_PT/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/ro/messages.json b/_locales/ro/messages.json index 12ca161..728b40d 100644 --- a/_locales/ro/messages.json +++ b/_locales/ro/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/ru/messages.json b/_locales/ru/messages.json index 31f02a6..d8cf6b4 100644 --- a/_locales/ru/messages.json +++ b/_locales/ru/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Следующий" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Предыдущий" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/sk/messages.json b/_locales/sk/messages.json index 12ca161..728b40d 100644 --- a/_locales/sk/messages.json +++ b/_locales/sk/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/sl/messages.json b/_locales/sl/messages.json index 12ca161..728b40d 100644 --- a/_locales/sl/messages.json +++ b/_locales/sl/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/sr/messages.json b/_locales/sr/messages.json index 12ca161..728b40d 100644 --- a/_locales/sr/messages.json +++ b/_locales/sr/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/sv/messages.json b/_locales/sv/messages.json index 12ca161..728b40d 100644 --- a/_locales/sv/messages.json +++ b/_locales/sv/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/sw/messages.json b/_locales/sw/messages.json index 12ca161..728b40d 100644 --- a/_locales/sw/messages.json +++ b/_locales/sw/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/ta/messages.json b/_locales/ta/messages.json index 12ca161..728b40d 100644 --- a/_locales/ta/messages.json +++ b/_locales/ta/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/te/messages.json b/_locales/te/messages.json index 12ca161..728b40d 100644 --- a/_locales/te/messages.json +++ b/_locales/te/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/th/messages.json b/_locales/th/messages.json index 12ca161..728b40d 100644 --- a/_locales/th/messages.json +++ b/_locales/th/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/tr/messages.json b/_locales/tr/messages.json index 12ca161..728b40d 100644 --- a/_locales/tr/messages.json +++ b/_locales/tr/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/uk/messages.json b/_locales/uk/messages.json index 12ca161..728b40d 100644 --- a/_locales/uk/messages.json +++ b/_locales/uk/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/vi/messages.json b/_locales/vi/messages.json index 12ca161..728b40d 100644 --- a/_locales/vi/messages.json +++ b/_locales/vi/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/zh_CN/messages.json b/_locales/zh_CN/messages.json index 12ca161..728b40d 100644 --- a/_locales/zh_CN/messages.json +++ b/_locales/zh_CN/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/_locales/zh_TW/messages.json b/_locales/zh_TW/messages.json index 12ca161..728b40d 100644 --- a/_locales/zh_TW/messages.json +++ b/_locales/zh_TW/messages.json @@ -2,6 +2,12 @@ "accessIsDenied": { "message": "Access is denied" }, + "appearance": { + "message": "Appearance" + }, + "backgroundColor": { + "message": "Background color" + }, "cancel": { "message": "Cancel" }, @@ -20,14 +26,14 @@ "hideInFullscreen": { "message": "Hide in fullscreen" }, - "next": { - "message": "Next" + "nextFrame": { + "message": "Next frame" }, - "other": { - "message": "Other" + "opacity": { + "message": "Opacity" }, - "prev": { - "message": "Prev" + "previousFrame": { + "message": "Previous frame" }, "reset": { "message": "Reset" diff --git a/content-script.js b/content-script.js index a5ee411..0c55f64 100644 --- a/content-script.js +++ b/content-script.js @@ -664,6 +664,14 @@ window.addEventListener('DOMContentLoaded', function() { hide_in_fullscreen = items.hide_in_fullscreen; } + if (items.hasOwnProperty('opacity')) { + ui.info_panel.style.opacity = items.opacity; + } + + if (items.hasOwnProperty('background_color')) { + ui.info_panel.style.backgroundColor = items.background_color; + } + setInterval(searchVideos, 2500); setInterval(calcPositions, 1000); setInterval(checkMouse, 100); @@ -690,6 +698,10 @@ chrome.storage.onChanged.addListener(function(changes) { moveUserInterface(); } else if (key === 'hide_in_fullscreen') { hide_in_fullscreen = value; + } else if (key === 'opacity') { + ui.info_panel.style.opacity = value; + } else if (key === 'background_color') { + ui.info_panel.style.backgroundColor = value; } if (key === location.hostname) { diff --git a/manifest.json b/manifest.json index d3f58da..7fe5bfd 100644 --- a/manifest.json +++ b/manifest.json @@ -2,7 +2,7 @@ "manifest_version": 2, "name": "Frame By Frame", "description": "__MSG_description__", - "version": "1.7.0", + "version": "2.0.0", "default_locale": "en", @@ -28,11 +28,9 @@ }], "browser_action": { - "default_popup": "popup/index.html" + "default_popup": "popup/popup.html" }, - "options_page": "popup/index.html", - "offline_enabled": true, "permissions": [ diff --git a/popup/index.html b/popup/index.html deleted file mode 100644 index 0f20170..0000000 --- a/popup/index.html +++ /dev/null @@ -1,37 +0,0 @@ - - - - - - Frame By Frame - - - - - - - - - - \ No newline at end of file diff --git a/popup/popup.css b/popup/popup.css new file mode 100644 index 0000000..b6bdb22 --- /dev/null +++ b/popup/popup.css @@ -0,0 +1,133 @@ +/*-------------------------------------------------------------- +>>> POPUP: +---------------------------------------------------------------- +# Body +# Made with love +--------------------------------------------------------------*/ + +/*-------------------------------------------------------------- +# BODY +--------------------------------------------------------------*/ + +body { + color: #565676; + background: #0e0e1b; + --satus-primary: #3d3d8f; + --satus-hover: rgba(255,255,255,.03); + --satus-header-background: #1c1c36; + --satus-header-text: #9595b2; + --satus-layers-background: #0e0e1b; + --satus-layers-text: #565676; + --satus-section-card-background: #161627; + --satus-section-card-text: #9595b2; + --satus-switch-background: rgba(255, 255, 255, .12); + --satus-modal-background: #202031; + --satus-modal-text: #9595b2; +} + +.satus-header { + font-weight: 600; + font-size: 15px; + justify-content: flex-start; +} + +.satus-header .satus-button { + width: 40px; + min-width: 40px; + height: 40px; + padding: 8px; + color: inherit; + border-radius: 50%; + margin: 0 8px 0 -8px; +} + +.satus-header .satus-button:hover { + cursor: pointer; + background: rgba(255, 255, 255, .04); +} + +.satus-header .satus-button>svg { + stroke: currentcolor; + stroke-linecap: round; + stroke-linejoin: round; + fill: none; +} + +.satus-switch--domain { + width: calc(100% - 16px); + height: 48px; + margin: 16px 8px 16px; + padding: 0 16px; + color: #494965; + border: 1px solid #22222f; + border-radius: 8px; + background-color: #14141f; +} + +.satus-switch--domain:hover { + background-color: #181825; + color: #565676; + border-color: #272735; +} + +.satus-span--error { + display: flex; + box-sizing: border-box; + width: calc(100% - 16px); + height: 48px; + margin: 16px 8px 16px; + padding: 0 16px; + color: rgba(255, 127, 127, .7); + border: 1px solid rgba(255, 0, 0, .15); + border-radius: 8px; + background: rgba(255, 0, 0, .1); + align-items: center; +} + +.satus-section--label { + font-size: 14px; + font-weight: 600; +} + + +/*-------------------------------------------------------------- +# MADE WITH LOVE +--------------------------------------------------------------*/ + +.made-with-love { + font-size: 13px; + position: absolute; + bottom: 16px; + left: 50%; + width: 100%; + height: auto; + min-height: auto; + padding: 0; + cursor: pointer; + transform: translateX(-50%); + text-align: center; + justify-content: center; + text-decoration: none; + color: #9595b2; + font-weight: 600; +} + +.satus-base[data-hide-made-with-love=true] .made-with-love { + display: none; +} + +.made-with-love svg { + position: relative; + top: 4px; + width: 16px; + height: 16px; + fill: #d62121; +} + +.satus.dark .made-with-love svg { + fill: #704343; +} + +.made-with-love span { + margin: 0 0 0 4px; +} \ No newline at end of file diff --git a/popup/popup.html b/popup/popup.html new file mode 100644 index 0000000..5983d8c --- /dev/null +++ b/popup/popup.html @@ -0,0 +1,22 @@ + + + + + + Frame By Frame + + + + + + + + + \ No newline at end of file diff --git a/popup/popup.js b/popup/popup.js new file mode 100644 index 0000000..595d66b --- /dev/null +++ b/popup/popup.js @@ -0,0 +1,182 @@ +/*-------------------------------------------------------------- +>>> POPUP: +---------------------------------------------------------------- +# Skeleton +# Initialization +--------------------------------------------------------------*/ + +/*-------------------------------------------------------------- +# SKELETON +--------------------------------------------------------------*/ + +var skeleton = { + component: 'base', + + header: { + component: 'header', + + back: { + component: 'button', + attr: { + 'hidden': 'true' + }, + on: { + click: 'layers.back' + }, + pluviam: true, + + svg: { + component: 'svg', + attr: { + 'viewBox': '0 0 24 24', + 'stroke-width': '1.5' + }, + + path: { + component: 'path', + attr: { + 'd': 'M14 18l-6-6 6-6' + } + } + } + }, + title: { + component: 'span', + text: 'Frame By Frame' + } + }, + layers: { + component: 'layers', + on: { + open: function () { + var skeleton = this.path[this.path.length - 1]; + + this.base.skeleton.header.back.rendered.hidden = this.path.length <= 1; + this.base.skeleton.header.title.rendered.innerText = satus.locale.get(skeleton.title) || 'Frame By Frame'; + } + }, + + toolbar: { + component: 'switch', + class: 'satus-switch--domain' + }, + section: { + component: 'section', + class: 'satus-section--card', + + appearance: { + component: 'button', + text: 'appearance', + on: { + click: { + component: 'section', + class: 'satus-section--card', + title: 'appearance', + + hide_in_fullscreen: { + component: 'switch', + text: 'hideInFullscreen' + }, + background_color: { + component: 'color-picker', + text: 'backgroundColor', + value: '#000' + }, + opacity: { + component: 'slider', + text: 'opacity', + value: .85, + step: .05, + storage: 'opacity' + } + } + } + }, + shortcuts: { + component: 'button', + text: 'shortcuts', + on: { + click: { + component: 'section', + class: 'satus-section--card', + title: 'shortcuts', + + next_shortcut: { + component: 'shortcut', + text: 'nextFrame', + value: { + keys: { + 37: { + key: 'ArrowRight' + } + } + } + }, + prev_shortcut: { + component: 'shortcut', + text: 'previousFrame', + value: { + keys: { + 39: { + key: 'ArrowLeft' + } + } + } + }, + hide_shortcut: { + component: 'shortcut', + text: 'hide', + value: { + keys: { + 72: { + key: 'h' + } + } + } + } + } + } + } + }, + + made_with_love: { + component: 'a', + class: 'made-with-love', + attr: { + target: '_blank', + href: 'https://chrome.google.com/webstore/detail/improve-youtube-open-sour/bnomihfieiccainjcjblhegjgglakjdd' + }, + properties: { + innerHTML: 'Made with by ImprovedTube' + } + } + } +}; + + +/*-------------------------------------------------------------- +# INITIALIZATION +--------------------------------------------------------------*/ + +satus.storage.import(function (items) { + satus.fetch('../_locales/' + (items.language || 'en') + '/messages.json', function (object) { + for (var key in object) { + satus.locale.strings[key] = object[key].message; + } + + chrome.tabs.query({active: true, currentWindow: true}, function(tabs) { + chrome.tabs.sendMessage(tabs[0].id, {}, function(response) { + skeleton.layers.toolbar.text = response || 'accessIsDenied'; + + if (!response) { + skeleton.layers.toolbar.component = 'span'; + skeleton.layers.toolbar.class = 'satus-span--error'; + } else { + skeleton.layers.toolbar.storage = 'domains/' + response; + } + + satus.render(skeleton); + }); + }); + }); +}); \ No newline at end of file diff --git a/popup/satus.css b/popup/satus.css new file mode 100644 index 0000000..65df412 --- /dev/null +++ b/popup/satus.css @@ -0,0 +1 @@ +html{--satus-theme-primary:#ff4158;--satus-header-background:#fff;--satus-switch-background:rgba(0,0,0,.08)}.satus-color-picker{font-size:inherit;position:relative;display:flex;box-sizing:border-box;margin:0;cursor:pointer;color:inherit;border:none;outline:0;background-color:var(--satus-theme-button);justify-content:space-between;-webkit-tap-highlight-color:transparent;align-items:center;-webkit-appearance:none}.satus-color-picker__value{width:24px;height:24px;border-radius:50%}.satus-modal--color-picker{position:relative}.satus-modal--color-picker .satus-modal__surface{display:flex;flex-direction:column;align-items:center}.satus-modal--color-picker canvas{width:256px;height:256px}.satus-color-picker__cursor{border-radius:50%;position:absolute;pointer-events:none;width:5px;border:1px solid #fff;height:5px;box-shadow:0 0 0 1px #000;transform:translate(-50%,-50%)}.satus-color-picker__slider .satus-slider__container{height:18px}.satus-color-picker__slider .satus-slider__track-container{top:calc(50% - 9px);height:18px}.satus-color-picker__slider .satus-slider__track-container::before{height:16px;opacity:1;background:linear-gradient(90deg,#fff,#000);border:1px solid #bfbfbf;border-radius:4px}.satus-color-picker__slider .satus-slider__track{background:0 0}.satus-color-picker__slider .satus-slider__thumb{background:#fff;top:0;border-radius:4px;height:18px;box-shadow:0 0 2px rgb(0,0,0,.2)}.satus-color-picker__slider .satus-slider__thumb:before{display:none}.satus-color-picker__actions{width:100%;justify-content:flex-end}.satus-main{color:var(--satus-main-text);background:var(--satus-main-background)}.satus-button{font:inherit;position:relative;overflow:hidden;height:48px;margin:0;padding:8px;color:var(--satus-button-text);border:none;background:var(--satus-button-background);appearance:none}.satus-button:hover{cursor:pointer;background-color:var(--satus-hover)}.satus-button>*{pointer-events:none}.satus-list{list-style:none;margin:0}.satus-list__item{display:flex;align-items:center;justify-content:space-between;height:48px}.satus-list__item>:last-child{text-align:right}.satus-section{display:flex;flex-wrap:wrap}.satus-section--align-start{justify-content:flex-start}.satus-section--align-end{justify-content:flex-end}.satus-header>.satus-section{align-items:center}.satus-section--card{flex-direction:column;width:calc(100% - 16px);max-width:900px;margin:8px auto;padding:8px 0;border:1px solid rgba(0,0,0,.1);border-radius:8px;background:var(--satus-section-card-background);color:var(--satus-section-card-text)}.satus-section--card>*{min-height:48px;padding:0 16px;text-align:left}.satus-section--card>.satus-button{display:flex;padding:0 16px;align-items:center}.satus-section--card>.satus-button>svg{width:20px;margin-right:8px;color:var(--satus-theme-primary)}.satus-section--label{font-size:17px;display:block;width:calc(100% - 16px);max-width:900px;margin:16px auto 8px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar:hover{width:8px}::-webkit-scrollbar-thumb{background:rgba(0,0,0,.3)}.satus-modal{position:absolute;z-index:100;top:0;left:0;display:flex;width:100%;height:100vh;justify-content:center;align-items:center}.satus-modal__scrim{position:absolute;top:0;left:0;width:100%;height:100%;animation:modalFadeIn 150ms linear forwards;opacity:0;background:rgba(0,0,0,.2);backdrop-filter:blur(8px)}.satus-modal__surface{font-size:14px;display:flex;overflow-y:auto;flex-direction:column;width:95%;min-width:240px;max-width:560px;max-height:80%;padding:8px 0;transform:scale(.8);animation:modalZoomIn 150ms linear forwards;animation-delay:20ms;opacity:0;color:var(--satus-modal-text);border-radius:6px;background-color:var(--satus-modal-background);box-shadow:inset 0 -1px 1px 1px rgb(0,0,0,.1),0 2px 6px rgb(0,0,0,.15)}.satus-modal--closing .satus-modal__scrim{animation:modalFadeOut 70ms linear forwards}.satus-modal--closing .satus-modal__surface{animation:modalZoomOut 70ms linear forwards}@keyframes modalFadeIn{from{opacity:0}to{opacity:1}}@keyframes modalFadeOut{from{opacity:1}to{opacity:0}}@keyframes modalZoomIn{from{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@keyframes modalZoomOut{from{transform:scale(1);opacity:1}to{transform:scale(.8);opacity:0}}.satus-switch{font:inherit;display:flex;transition:background-color 75ms;color:inherit;border:none;outline:0;background-color:transparent;justify-content:space-between;align-items:center}.satus-switch:hover{cursor:pointer;background-color:var(--satus-hover)}.satus-switch__thumb{width:38px;height:20px;transition:background-color 150ms;border-radius:20px;background-color:var(--satus-switch-background)}.satus-switch__thumb::before{display:block;width:16px;height:16px;margin:2px;content:'';transition:transform 150ms cubic-bezier(.4,0,.2,1);border-radius:50%;background-color:#fff;will-change:transform}.satus-switch[data-value=true] .satus-switch__thumb{background-color:var(--satus-primary)}.satus-switch[data-value=true] .satus-switch__thumb::before{transform:translateX(18px)}.satus-slider{position:relative;display:flex;flex-direction:column;box-sizing:border-box;width:100%;min-height:64px;padding:0 16px;-webkit-user-select:none;-moz-user-select:none;user-select:none;outline:0;align-items:flex-start;justify-content:center}.satus-slider:hover{cursor:pointer;background-color:rgba(0,0,0,.04)}.satus-slider__label{cursor:default}.satus-slider>input{position:absolute;z-index:1;top:0;left:0;box-sizing:border-box;width:100%;height:100%;margin:0;padding:0;opacity:0}.satus-slider__container{position:relative;width:100%;height:12px;margin:8px 0 0}.satus-slider__track-container{position:absolute;top:calc(50% - 1px);width:100%;height:2px;pointer-events:none}.satus-slider__track-container::before{position:absolute;top:0;left:0;width:100%;height:2px;content:'';opacity:.26;background-color:var(--satus-theme-primary)}.satus-slider__track{position:relative;width:0;height:100%;background-color:var(--satus-theme-primary);will-change:width}.satus-slider:not(.satus-slider--dragging) .satus-slider__track{transition:width .1s ease-out}.satus-slider__thumb{position:absolute;top:-5px;right:-12px;width:12px;height:12px;border-radius:50%;background-color:var(--satus-theme-primary);box-shadow:0 1px 5px rgba(0,0,0,.15)}.satus-slider .satus-slider__thumb::before{font-size:13px;position:absolute;top:-34px;left:50%;visibility:hidden;box-sizing:border-box;min-width:28px;padding:4px 4px;content:attr(data-value);transform:translateX(-50%);text-align:center;pointer-events:none;color:#fff;border-radius:4px;background:var(--satus-theme-tooltip)}.satus-slider:hover .satus-slider__thumb::before,.satus-slider>input:focus .satus-slider__container .satus-slider__thumb::before{visibility:visible}.satus-slider__ring{position:absolute;top:-11px;right:-18px;width:24px;height:24px;transition:.1s;transform:scale(0);opacity:0;border-radius:50%;background-color:var(--satus-theme-primary)}.satus-slider>input:focus+.satus-slider__container .satus-slider__ring{transform:scale(1);opacity:.25}.satus-shortcut{justify-content:space-between}.satus-shortcut__value{text-transform:uppercase;font-size:11px;opacity:.5}.satus-shortcut__actions{display:flex;justify-content:flex-end}.satus-shortcut__actions .satus-button{height:32px;background:rgba(0,0,0,.15);margin:8px 4px 0;border-radius:8px}.satus-shortcut__actions .satus-button:hover{background:rgba(0,0,0,.25)}.satus-shortcut__primary{display:flex;box-sizing:border-box;width:100%;height:68px;padding:16px;background:rgba(0,0,0,.16);align-items:center}.satus-shortcut__key{display:flex;box-sizing:border-box;min-width:32px;height:32px;padding:4px 8px;border-radius:4px;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.15),inset 0 -3px 0 rgba(0,0,0,.1);align-items:center;justify-content:center}.satus-shortcut__plus{position:relative;width:12px;height:12px;margin:8px}.satus-shortcut__plus::before{position:absolute;top:0;left:5px;width:2px;height:12px;content:'';background-color:#aaa}.satus-shortcut__plus::after{position:absolute;top:5px;left:0;width:12px;height:2px;content:'';background-color:#aaa}.satus-shortcut__mouse{position:relative;display:flex;width:28px;height:36px;border-radius:50%;border-top-left-radius:12px;border-top-right-radius:12px;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.15),inset 0 -3px 0 rgba(0,0,0,.1)}.satus-shortcut__mouse>div{position:absolute;top:0;left:13px;width:2px;height:11px;border-radius:2px;background:#ccc}.satus-shortcut__mouse::before{position:absolute;top:-4px;left:21px;width:2px;height:18px;content:'';background:#f96754}.satus-shortcut__mouse.false::after{position:absolute;top:-12px;left:17px;width:0;height:0;content:'';border-right:5px solid transparent;border-bottom:8px solid #f96754;border-left:5px solid transparent}.satus-shortcut__mouse.true::after{position:absolute;top:14px;left:17px;width:0;height:0;content:'';border-top:8px solid #f96754;border-right:5px solid transparent;border-left:5px solid transparent}.satus-section_shortcut{width:100%;margin:8px 0 0;justify-content:flex-end}.satus-button_shortcut{font-weight:500;overflow:hidden;height:28px;min-height:28px;margin-right:2px;padding:4px 8px;text-transform:uppercase;color:#f96754;border-radius:4px}.satus-base{display:flex;flex-direction:column;width:100%;height:100vh}.satus-text-field{position:relative;padding:0 16px;background-color:#333347;border-radius:8px;color:#c4c4d4;overflow:hidden;display:flex}.satus-text-field__pre{display:flex;position:relative;height:100%;margin:0;padding:0;overflow:hidden;align-items:center;flex:1}.satus-text-field__input{font:inherit;position:absolute;top:0;left:0;width:100%;min-width:0;max-width:none;height:100%;min-height:0;max-height:none;margin:0;padding:0;opacity:0;border:none;appearance:none;z-index:9}.satus-text-field__hidden-text{position:absolute;pointer-events:none;opacity:0}.satus-text-field__text{position:absolute;top:0;left:0;display:flex;height:100%;margin:0;align-items:center}.satus-text-field__cursor{position:absolute;top:6px;left:0;display:none;width:2px;height:25px;animation:blink 1s step-end 8;background:#fa0}.satus-text-field__selection{position:absolute;top:5px;left:0;display:none;width:0;height:25px;border:1px solid rgba(255,255,255,.2);border-radius:3px;background:rgba(255,255,255,.1)}.satus-text-field__input:focus+*+*+*+.satus-text-field__cursor,.satus-text-field__selection:not([disabled]){display:block}@keyframes blink{from,to{opacity:1}50%{opacity:0}}.satus-text-field__text>.group{color:#47ff47;background-color:rgb(71,255,71,.16)}.satus-text-field__text>.character-class{color:#ffc247;background-color:rgb(255,170,0,.16)}.satus-text-field__text>.quantifier{color:#47c2ff;background-color:rgb(71,194,255,.16)}.satus-text-field__text>.anchor{color:#47c2ff;background-color:rgb(71,194,255,.16)}.satus-text-field__text>.metasequence{color:#47ff47;background-color:rgb(71,255,71,.16)}.satus-text-field__text>.text{color:#c4c4d4;background-color:rgb(196,196,212,.16)}.satus-header{display:flex;box-sizing:border-box;height:56px;padding:0 16px;color:var(--satus-header-text);background:var(--satus-header-background);align-items:center;justify-content:space-between}.satus-layers{position:relative;overflow:hidden;color:var(--satus-layers-text);background:var(--satus-layers-background);flex:1}.satus-layer{position:absolute;top:0;left:0;display:flex;overflow-y:auto;width:100%;height:100%;flex-wrap:wrap;align-content:flex-start}.satus-input[type=text]{font:inherit;box-sizing:border-box;width:100%;margin:0;padding:0;padding:0 8px;color:inherit;border:none;outline:0;background:0 0;appearance:none}.satus-select{position:relative;display:flex;box-sizing:border-box;align-items:center}.satus-select select{font:inherit;position:absolute;top:0;left:0;width:100%;height:100%;margin:0;padding:0;padding:inherit;cursor:pointer;color:inherit;border:none;outline:0;background:0 0;appearance:none}.satus-select select:hover{cursor:pointer;background-color:rgba(0,0,0,.04)}.satus-section--card .satus-select select{text-align-last:right}.satus-pluviam{position:absolute;transform:scale(0);animation-name:pluviam;animation-duration:1s;opacity:.04;border-radius:50%;background:#000;animation-fill-mode:forwards}@keyframes pluviam{0%{transform:scale(0);opacity:.04}70%{transform:scale(.8);opacity:.04}100%{transform:scale(1);opacity:0}} \ No newline at end of file diff --git a/popup/satus.js b/popup/satus.js new file mode 100644 index 0000000..34bcb4e --- /dev/null +++ b/popup/satus.js @@ -0,0 +1 @@ +var satus={components:{},events:{},locale:{strings:{}},storage:{data:{}},append:function(M,N){(N||document.body).appendChild(M)},getAnimationDuration:function(M){return 1e3*Number(window.getComputedStyle(M).getPropertyValue("animation-duration").replace(/[^0-9.]/g,""))},attr:function(M,N){if(N)for(var I in N){var A;M.is_svg?M.setAttributeNS(null,I,N[I]):(A=N[I],"title"===I&&(A=satus.locale.get(A)),M.setAttribute(I,A))}},data:function(M,N){if(N)for(var I in N)M.dataset[I]=N[I]},properties:function(M,N){if(N)for(var I in N)M[I]=N[I]},camelize:function(M){for(var N="",I=0,A=M.length;IAlt")),!0===C.ctrlKey&&(N.push("Ctrl"),I.push("
Ctrl
")),!0===C.shiftKey&&(N.push("Shift"),I.push("
Shift
"))," "===C.key?(N.push("Space bar"),I.push("
Space bar
")):"string"==typeof C.key&&-1===["Shift","Control","Alt"].indexOf(C.key)&&("ArrowUp"===C.key?(N.push("↑"),I.push("
")):"ArrowRight"===C.key?(N.push("→"),I.push("
")):"ArrowDown"===C.key?(N.push("↓"),I.push("
")):"ArrowLeft"===C.key?(N.push("←"),I.push("
")):(A=C.key.toUpperCase(),N.push(A),I.push("
"+A+"
"))),C.wheel&&I.push('
'),c.innerText=N.join("+"),M&&0"))}return t.className="satus-shortcut__label",c.className="satus-shortcut__value",a(),c.dataset.value=c.innerText,N.addEventListener("click",function(){let N=document.createElement("div"),M=document.createElement("span"),I=document.createElement("div"),A=document.createElement("div"),D=document.createElement("div"),i=document.createElement("section"),g=document.createElement("div"),w=document.createElement("div"),j=document.createElement("div");function T(M){return M.preventDefault(),M.stopPropagation(),e=!1,clearTimeout(u),C={key:M.key,keyCode:M.keyCode,shiftKey:M.shiftKey,ctrlKey:M.ctrlKey,altKey:M.altKey},a(D),!1}function S(M){return M.stopPropagation(),!0===e&&(delete C.shiftKey,delete C.altKey,delete C.ctrlKey,delete C.keyCode,delete C.key),clearTimeout(u),u=setTimeout(function(){e=!0},300),C.wheel=M.deltaY,a(D),!1}function L(M){window.removeEventListener("keydown",T),window.removeEventListener("mousewheel",S),!0===M&&(c.innerText=c.dataset.value),N.classList.remove("satus-modal_open"),setTimeout(function(){N.remove()},Number(1e3*document.defaultView.getComputedStyle(N,"").getPropertyValue("animation-duration").replace(/[^0-9.]/g,"")))}N.className="satus-modal satus-modal_open",M.className="satus-shortcut-modal-label",I.className="satus-modal__scrim",A.className="satus-modal__surface satus-modal__surface_shortcut",D.className="satus-shortcut__canvas",i.className="satus-section satus-section--align-end satus-section_shortcut",g.className="satus-button satus-button_shortcut",w.className="satus-button satus-button_shortcut",j.className="satus-button satus-button_shortcut",M.innerText=t.innerText,a(D),window.addEventListener("keydown",T),window.addEventListener("mousewheel",S),I.addEventListener("click",L),g.addEventListener("click",function(){L(),a()}),w.addEventListener("click",L),j.addEventListener("click",function(){L(!1)}),i.appendChild(g),i.appendChild(w),i.appendChild(j),A.appendChild(M),A.appendChild(D),A.appendChild(i),N.appendChild(I),N.appendChild(A),document.body.appendChild(N)}),N.appendChild(t),N.appendChild(c),N},satus.components.shortcut=function(M){var N=document.createElement("button"),I=document.createElement("div");return N.className="satus-button",I.className="satus-shortcut__value",N.update=function(){var M=satus.storage.get(this.storage)||this.skeleton.value||{},N=[];if(M.shift&&N.push("Shift"),M.ctrl&&N.push("Ctrl"),M.alt&&N.push("Alt"),"object"==typeof M.keys)for(var I in M.keys){var A=M.keys[I].key||M.keys[I].code;32===I&&(A="space"),N.push(A)}this.valueElement.textContent=N.join(" + ")},N.render=function(){var M,N,I,A=this,D=this.primary.children;function i(M){var N=document.createElement("div");return N.className="satus-shortcut__"+M,A.primary.appendChild(N),N}for(M in satus.empty(this.primary),this.data.alt&&(i("key").textContent="Alt"),this.data.ctrl&&(D.length&&-1!==D[D.length-1].className.indexOf("key")&&i("plus"),i("key").textContent="Ctrl"),this.data.shift&&(D.length&&-1!==D[D.length-1].className.indexOf("key")&&i("plus"),i("key").textContent="Shift"),this.data.keys)D.length&&-1!==D[D.length-1].className.indexOf("key")&&i("plus"),i("key").textContent=this.data.keys[M].key.toUpperCase();this.data.wheel&&(D.length&&-1!==D[D.length-1].className.indexOf("key")&&i("plus"),N=i("mouse"),I=document.createElement("div"),N.appendChild(I),N.className+=" "+(0 by ImprovedTube', - onclick: function() { - window.open('https://chrome.google.com/webstore/detail/improve-youtube-open-sour/bnomihfieiccainjcjblhegjgglakjdd'); - } - } - } -}; - -satus.storage.import(function(items) { - satus.locale.import(function() { - satus.modules.updateStorageKeys(skeleton, function() { - chrome.tabs.query({active: true, currentWindow: true}, function(tabs) { - chrome.tabs.sendMessage(tabs[0].id, {}, function(response) { - skeleton.main.toolbar.enable.label = response || 'accessIsDenied'; - - if (!response) { - skeleton.main.toolbar.enable.style = { - opacity: .25, - pointerEvents: 'none' - }; - } else { - skeleton.main.toolbar.enable.storage_key = response; - } - - satus.render(skeleton); - }); - }); - }); - }); -}); \ No newline at end of file diff --git a/popup/styles.css b/popup/styles.css deleted file mode 100644 index e8c3b36..0000000 --- a/popup/styles.css +++ /dev/null @@ -1,230 +0,0 @@ -/*-------------------------------------------------------------- ->>> TABLE OF CONTENTS: ----------------------------------------------------------------- -# ---------------------------------------------------------------*/ - - -/*-------------------------------------------------------------- -# ---------------------------------------------------------------*/ - -body { - font-size: 14px; - display: flex; - overflow: hidden; - flex-direction: column; - width: 320px; - height: 532px; - margin: 0; - --satus-theme-header: #4b4abf; - --satus-theme-header-text: #fafafa; - --satus-theme-primary: #4b4abf; - --satus-theme-dialog: #191b1f; - --satus-theme-dialog-text: #b5b5b5; - --satus-theme-main: #121316; - --satus-theme-main-text: #bfbfbf; - --satus-theme-section: #191b1f; - --satus-theme-button: transparent; - --satus-theme-scrollbar: rgba(255, 255, 255, .2); - --satus-theme-scrollbar-focus: rgba(255, 255, 255, .4); - --satus-theme-tooltip: rgba(10, 10, 10, .7); - --satus-theme-ripple: rgba(255, 255, 255, .04); - --satus-theme-tabs-background: #17191c; - --satus-theme-tabs-border: #22252a; - --satus-theme-hover: rgba(255, 255, 255, .07); - --satus-theme-dialog-shadow: inset 0 -1px 1px 1px rgb(113, 123, 142, .1), 0 2px 6px rgb(101, 119, 154, .1); -} - -.satus-header { - font-size: 16px; - font-weight: 700; - letter-spacing: .125px; - align-items: center; -} - -.satus-section { - display: block; - width: calc(100% - 16px); - max-width: 900px; - margin: 8px auto; - padding: 8px 0; - border: 1px solid rgba(0, 0, 0, .1); - border-radius: 8px; -} - -.satus-main .satus-section.satus-section--toolbar { - padding: 0; - border: none; - background: none; - box-shadow: none; -} - -.satus-section--toolbar .satus-switch { - height: 48px; - border: 1px solid rgb(33, 37, 43, .5); - border-radius: 8px; - background: rgb(25, 27, 31, .2); -} - -.made-with-love { - font-size: 13px; - position: absolute; - bottom: 16px; - left: 50%; - width: 100%; - height: auto; - min-height: auto; - padding: 0; - cursor: pointer; - transform: translateX(-50%); - text-align: center; - justify-content: center; -} - -html[data-hide-made-with-love=true] .made-with-love { - display: none; -} - -.made-with-love svg { - position: relative; - top: 4px; - width: 16px; - height: 16px; - fill: #d62121; -} - -.satus.dark .made-with-love svg { - fill: #704343; -} - -.made-with-love span { - margin: 0 0 0 4px; -} - -.satus-main .satus-section--label { - font-size: 17px; - display: block; - width: calc(100% - 16px); - max-width: 900px; - margin: 16px auto 8px; -} - -@media (min-width: 321px) { - html { - display: flex; - justify-content: center; - } - body { - width: 100%; - max-width: 768px; - height: 100vh; - background: #050505; - } -} - -.video { - font: 700 18px monospace; - position: absolute; - top: calc(50% - 46px); - left: calc(50% - 81px); - display: flex; - overflow: hidden; - width: 160px; - height: 90px; - animation-name: hover; - animation-duration: 2s; - animation-iteration-count: infinite; - letter-spacing: 1px; - color: #404040; - border: 1px solid #808080; - border-radius: 8px; - background: #1a1a1a; - justify-content: center; - align-items: center; -} - -.cursor { - position: absolute; - bottom: calc(50% - 96px); - left: calc(50% - 120px); - width: 28px; - animation-name: move; - animation-duration: 2s; - animation-iteration-count: infinite; -} - -@keyframes move { - 0% { - transform: translate(0px, 0px); - opacity: 0; - } - 10% { - transform: translate(0px, 0px); - opacity: 1; - } - 90% { - transform: translate(160px, -56px); - opacity: 1; - } - 100% { - transform: translate(160px, -56px); - opacity: 0; - } -} - -@keyframes hover { - 0% { - color: #404040; - border: 1px solid #808080; - background: #1a1a1a; - } - 25% { - color: #404040; - border: 1px solid #808080; - background: #1a1a1a; - } - 100% { - color: #fff; - border: 1px solid #232323; - background: #3d6ef8; - } -} - -.heart { - position: absolute; - right: 40px; - bottom: 0; - display: block; - width: 24px; - height: 24px; - padding: 8px; - cursor: pointer; - transition: .2s; - opacity: .75; - fill: #ec033e; -} - -.heart:hover { - transform: scale(1.2); - opacity: 1; -} - -.github { - position: absolute; - right: 0; - bottom: 0; - display: block; - width: 20px; - height: 20px; - padding: 10px; - cursor: pointer; - transition: .2s; - opacity: .75; - fill: #e2e7f3; -} - -.github:hover { - transform: scale(1.2); - opacity: 1; -} \ No newline at end of file diff --git a/py/locale.py b/py/locale.py new file mode 100644 index 0000000..0f484d3 --- /dev/null +++ b/py/locale.py @@ -0,0 +1,128 @@ +#--------------------------------------------------------------- +# >>> TABLE OF CONTENTS: +#--------------------------------------------------------------- +# 1.0 Import modules +# 2.0 Lower camel case +# 3.0 Get list of files +# 4.0 Add item +# 5.0 Remove item +# 6.0 Decode +# 7.0 Initialization +#--------------------------------------------------------------- + +#--------------------------------------------------------------- +# 1.0 IMPORT MODULES +#--------------------------------------------------------------- + +import json +import os +import pathlib +import re + + +#--------------------------------------------------------------- +# 2.0 LOWER CAMEL CASE +#--------------------------------------------------------------- + +def lowerCamelCase(string): + string = re.sub(r"(-|_)+", " ", string).title().replace(" ", "") + + return string[0].lower() + string[1:] + + +#--------------------------------------------------------------- +# 3.0 GET LIST OF FILES +#--------------------------------------------------------------- + +def getListOfFiles(dirName): + allFiles = list() + + for entry in os.listdir(dirName): + fullPath = os.path.join(dirName, entry) + + if not os.path.isdir(fullPath): + allFiles.append(fullPath) + + for entry in os.listdir(dirName): + fullPath = os.path.join(dirName, entry) + + if os.path.isdir(fullPath): + allFiles = allFiles + getListOfFiles(fullPath) + + return allFiles + + +#--------------------------------------------------------------- +# 4.0 ADD ITEM +#--------------------------------------------------------------- + +def addItem(allFiles): + message = input("Enter your message: ") + + for keyFile in allFiles: + with open(keyFile, "r+") as json_file: + data = json.load(json_file) + + data[lowerCamelCase(message)] = { + "message": message + } + + json_file.seek(0) + json.dump(data, json_file, ensure_ascii=False, indent=4, sort_keys=True) + json_file.truncate() + + +#--------------------------------------------------------------- +# 5.0 REMOVE ITEM +#--------------------------------------------------------------- + +def removeItem(allFiles): + key = input("Enter your key (lowerCamelCase): ") + + for keyFile in allFiles: + with open(keyFile, "r+") as json_file: + data = json.load(json_file) + + if data[key]: + del data[key] + + json_file.seek(0) + json.dump(data, json_file, ensure_ascii=False, indent=4, sort_keys=True) + json_file.truncate() + + +#--------------------------------------------------------------- +# 6.0 DECODE +#--------------------------------------------------------------- + +def decodeCharacters(allFiles): + for keyFile in allFiles: + with open(keyFile, "r+") as json_file: + data = json.load(json_file) + + json_file.seek(0) + json.dump(data, json_file, ensure_ascii=False, indent=4, sort_keys=True) + json_file.truncate() + + +#--------------------------------------------------------------- +# 7.0 INITIALIZATION +#--------------------------------------------------------------- + +allFiles = getListOfFiles("../_locales/") + +operation = input(""" +-------------------------------- +Add item: 1 +Remove item: 2 +Decode: 3 +-------------------------------- + +Enter number: """) + +if operation == "1": + addItem(allFiles) +elif operation == "2" : + removeItem(allFiles) +elif operation == "3" : + decodeCharacters(allFiles) \ No newline at end of file diff --git a/satus.css b/satus.css deleted file mode 100644 index c5a9d8d..0000000 --- a/satus.css +++ /dev/null @@ -1,1091 +0,0 @@ -/*-------------------------------------------------------------- ->>> SATUS ----------------------------------------------------------------- -# Body -# Components - # Button - # Color picker - # Dialog - # Folder - # Header - # List - # Main - # Section - # Select - # Slider - # Switch - # Table - # Text - # Text field ---------------------------------------------------------------*/ - -/*-------------------------------------------------------------- -# BODY ---------------------------------------------------------------*/ - -body { - --satus-theme-primary: #f6b465; - --satus-theme-dialog: #f7f7f6; - --satus-theme-dialog-text: #777; - --satus-theme-header: #fff; - --satus-theme-header-text: #777; - --satus-theme-main: #f7f7f6; - --satus-theme-main-text: #777; - --satus-theme-section: #fff; - --satus-theme-button: transparent; - --satus-theme-scrollbar: rgba(0, 0, 0, .2); - --satus-theme-scrollbar-focus: rgba(0, 0, 0, .4); - --satus-theme-tooltip: rgba(0, 0, 0, .4); - --satus-theme-ripple: rgba(0, 0, 0, .04); -} - - -/*-------------------------------------------------------------- -# COMPONENTS ---------------------------------------------------------------*/ - -/*-------------------------------------------------------------- -# BUTTON ---------------------------------------------------------------*/ - -.satus-button { - font-size: inherit; - position: relative; - display: flex; - margin: 0; - cursor: pointer; - color: inherit; - border: none; - outline: none; - background-color: var(--satus-theme-button); - -webkit-tap-highlight-color: transparent; - align-items: center; - -webkit-appearance: none; -} - -.satus-button::before { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - content: ''; - opacity: 0; - background-color: var(--satus-theme-ripple); -} - -.satus-button:focus::before, -.satus-button:hover::before { - opacity: 1; -} - -.satus-button__icon { - width: 24px; - height: 24px; -} - -.satus-button svg { - width: 100%; - color: inherit; - fill: var(--satus-theme-primary); -} - -.satus-button__icon+.satus-button__label { - margin-left: 8px; -} - - -/*-------------------------------------------------------------- -# COLOR PICKER ---------------------------------------------------------------*/ - -.satus-color-picker { - font-size: inherit; - position: relative; - display: flex; - box-sizing: border-box; - margin: 0; - cursor: pointer; - color: inherit; - border: none; - outline: none; - background-color: var(--satus-theme-button); - justify-content: space-between; - -webkit-tap-highlight-color: transparent; - align-items: center; - -webkit-appearance: none; -} - -.satus-color-picker__value { - width: 24px; - height: 24px; - border-radius: 50%; -} - -.satus-dialog--color-picker .satus-scrollbar__content { - display: flex; - flex-direction: column; - align-items: center; -} - -.satus-dialog--color-picker .satus-button { - box-sizing: unset; - width: 24px; - height: 24px; - margin: 0 0 8px; - padding: 8px; - border-radius: 50%; -} - -.satus-dialog--color-picker .satus-button:hover { - background-color: var(--satus-theme-ripple); -} - -.satus-dialog--color-picker .satus-button::before { - content: unset; -} - -.satus-dialog--color-picker .satus-button svg { - fill: transparent; - stroke: var(--satus-theme-primary); -} - -.satus-dialog--color-picker canvas { - width: 200px; - height: 200px; - margin: 0 0 16px; -} - - -/*-------------------------------------------------------------- -# DIALOG ---------------------------------------------------------------*/ - -.satus-dialog { - position: absolute; - z-index: 100; - top: 0; - left: 0; - display: flex; - width: 100%; - height: 100vh; - justify-content: center; - align-items: center; -} - -.satus-dialog__scrim { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - animation: fadeIn 150ms linear forwards; - opacity: 0; - background: rgba(25, 25, 25, .2); - fill: var(--satus-theme-dialog-text); - backdrop-filter: blur(8px); -} - -.satus-dialog__surface { - font-size: 14px; - display: flex; - flex-direction: column; - width: 95%; - min-width: 240px; - max-width: 560px; - max-height: 80%; - padding: 8px 0; - transform: scale(.8); - animation: zoomIn 150ms linear forwards; - animation-delay: 20ms; - opacity: 0; - color: var(--satus-theme-dialog-text); - border-radius: 6px; - background-color: var(--satus-theme-dialog); - box-shadow: inset 0 -1px 1px 1px rgba(0, 0, 0, .1), 0 2px 6px rgba(0, 0, 0, .15); -} - -.satus-dialog--closing .satus-dialog__scrim { - animation: fadeOut 70ms linear forwards; -} - -.satus-dialog--closing .satus-dialog__surface { - animation: zoomOut 70ms linear forwards; -} - -@keyframes fadeIn { - from { - opacity: 0; - } - to { - opacity: 1; - } -} - -@keyframes fadeOut { - from { - opacity: 1; - } - to { - opacity: 0; - } -} - -@keyframes zoomIn { - from { - transform: scale(.8); - opacity: 0; - } - to { - transform: scale(1); - opacity: 1; - } -} - -@keyframes zoomOut { - from { - transform: scale(1); - opacity: 1; - } - to { - transform: scale(.8); - opacity: 0; - } -} - - -/*-------------------------------------------------------------- -# FOLDER ---------------------------------------------------------------*/ - -.satus-folder { - text-align: left; -} - - -/*-------------------------------------------------------------- -# HEADER ---------------------------------------------------------------*/ - -.satus-header { - position: relative; - z-index: 1; - display: flex; - box-sizing: border-box; - width: 100%; - min-height: 58px; - padding: 0 8px; - color: var(--satus-theme-header-text); - background-color: var(--satus-theme-header); - box-shadow: 0 0 3px rgba(0, 0, 0, .1); - fill: var(--satus-theme-header-text); -} - -.satus-header .satus-text--title { - font-size: 15px; - font-weight: 400; -} - - -/*-------------------------------------------------------------- -# LIST ---------------------------------------------------------------*/ - -.satus-list--compact, -.satus-list--compact li { - margin: 0; - padding: 0; - list-style: none; -} - - -/*-------------------------------------------------------------- -# MAIN ----------------------------------------------------------------- -# General -# Animations - # Opening - # Closing ---------------------------------------------------------------*/ - -/*-------------------------------------------------------------- -# General ---------------------------------------------------------------*/ - -.satus-main { - position: relative; - overflow: hidden; - width: 100%; - height: 100%; - color: var(--satus-theme-main-text); - background-color: var(--satus-theme-main); - fill: var(--satus-theme-main-text); -} - -.satus-main__container { - position: absolute; - top: 0; - left: 0; - overflow: auto; - box-sizing: border-box; - width: 100%; - height: 100%; - transition: 250ms; - background-color: var(--satus-theme-main); - will-change: transform; -} - - -/*-------------------------------------------------------------- -# Animations ---------------------------------------------------------------*/ - -.satus-main__container--fade-in-left { - animation: fadeInLeft 250ms; -} - -.satus-main__container--fade-in-right { - animation: fadeInRight 250ms; -} - -.satus-main__container--fade-out-left { - animation: fadeOutLeft 250ms; -} - -.satus-main__container--fade-out-right { - animation: fadeOutRight 250ms; -} - -@keyframes fadeInLeft { - from { - transform: translateX(-10%); - opacity: 0; - } - to { - transform: translateX(0%); - opacity: 1; - } -} - -@keyframes fadeInRight { - from { - transform: translateX(10%); - opacity: 0; - } - to { - transform: translateX(0%); - opacity: 1; - } -} - -@keyframes fadeOutLeft { - from { - transform: translateX(0%); - opacity: 1; - } - to { - transform: translateX(-10%); - opacity: 0; - } -} - -@keyframes fadeOutRight { - from { - transform: translateX(0%); - opacity: 1; - } - to { - transform: translateX(10%); - opacity: 0; - } -} - -.satus-scrollbar { - position: relative; - overflow: hidden; - width: 100%; - height: 100%; -} - -.satus-scrollbar__wrapper { - overflow-y: scroll; - width: 150%; - height: 100%; -} - -.satus-scrollbar__thumb { - position: absolute; - z-index: 999; - top: 0; - right: 0; - min-height: 32px; - padding: 0 2px; - transition: background-color 200ms, opacity 300ms; - opacity: 0; -} - -.satus-scrollbar__thumb::after { - display: block; - width: 3px; - height: 100%; - content: ''; - background-color: var(--satus-theme-scrollbar); -} - -.satus-scrollbar__thumb:hover::after { - background-color: var(--satus-theme-scrollbar-focus); -} - -.satus-scrollbar.active .satus-scrollbar__thumb, -.satus-scrollbar__thumb:hover { - transition: background-color 200ms, opacity 100ms; - opacity: 1; -} - - -/*-------------------------------------------------------------- -# SECTION ---------------------------------------------------------------*/ - -.satus-section { - display: inline-flex; - box-sizing: border-box; - background-color: var(--satus-theme-section); - align-items: center; - flex: 1; -} - - -/*-------------------------------------------------------------- -# SELECT ---------------------------------------------------------------*/ - -.satus-select { - justify-content: space-between; -} - -.satus-select__value { - font-size: 12px; - text-align: right; - opacity: .7; -} - -.satus-dialog--select-component .satus-dialog__surface { - position: absolute; - max-width: unset; - transform: unset; - animation: unset; - opacity: 1; -} - -.satus-dialog--select-component .satus-section { - top: 48px; - flex-direction: column; - transform: translateY(-16px); - animation: listIn 50ms linear forwards; - animation-delay: 20ms; - opacity: .5; -} - -.satus-dialog--select-component .satus-button { - width: 100%; - height: 48px; - padding: 0 16px; -} - -@keyframes listIn { - from { - transform: translateY(-16px); - opacity: .5; - } - to { - transform: translateY(0); - opacity: 1; - } -} - -.satus-shortcut { - position: relative; - display: flex; - box-sizing: border-box; - width: 100%; - height: 48px; - min-height: 48px; - padding: 0 16px; - cursor: pointer; - justify-content: space-between; - align-items: center; -} - -.satus-shortcut:hover { - background-color: var(--satus-theme-ripple); -} - -.satus-shortcut>.label { - margin: 0 0 4px 0; -} - -.satus-shortcut>.value { - font-size: 13px; - opacity: .5; -} - -.satus-shortcut-dialog-label { - font-size: 16px; - font-weight: 500; - box-sizing: border-box; - width: 100%; - margin: 4px 0 10px; - padding: 0 16px; -} - -.satus-shortcut__canvas { - display: flex; - box-sizing: border-box; - width: 100%; - height: 68px; - padding: 16px; - background: #dedede; - align-items: center; -} - -.satus-shortcut__key { - display: flex; - box-sizing: border-box; - min-width: 32px; - height: 32px; - padding: 4px 8px; - border-radius: 4px; - background: #fff; - box-shadow: 0 1px 3px rgba(0, 0, 0, .15), inset 0 -3px 0 rgba(0, 0, 0, .1); - align-items: center; - justify-content: center; -} - -.satus-shortcut__plus { - position: relative; - width: 12px; - height: 12px; - margin: 8px; -} - -.satus-shortcut__plus::before { - position: absolute; - top: 0; - left: 5px; - width: 2px; - height: 12px; - content: ''; - background-color: #aaa; -} - -.satus-shortcut__plus::after { - position: absolute; - top: 5px; - left: 0; - width: 12px; - height: 2px; - content: ''; - background-color: #aaa; -} - -.satus-shortcut__mouse { - position: relative; - display: flex; - width: 28px; - height: 36px; - border-radius: 50%; - border-top-left-radius: 12px; - border-top-right-radius: 12px; - background: #fff; - box-shadow: 0 1px 3px rgba(0, 0, 0, .15), inset 0 -3px 0 rgba(0, 0, 0, .1); -} - -.satus-shortcut__mouse>div { - position: absolute; - top: 0; - left: 13px; - width: 2px; - height: 11px; - border-radius: 2px; - background: #ccc; -} - -.satus-shortcut__mouse::before { - position: absolute; - top: -4px; - left: 21px; - width: 2px; - height: 18px; - content: ''; - background: #f96754; -} - -.satus-shortcut__mouse.false::after { - position: absolute; - top: -12px; - left: 17px; - width: 0; - height: 0; - content: ''; - border-right: 5px solid transparent; - border-bottom: 8px solid #f96754; - border-left: 5px solid transparent; -} - -.satus-shortcut__mouse.true::after { - position: absolute; - top: 14px; - left: 17px; - width: 0; - height: 0; - content: ''; - border-top: 8px solid #f96754; - border-right: 5px solid transparent; - border-left: 5px solid transparent; -} - -.satus-section_shortcut { - width: 100%; - margin: 8px 0 0; - justify-content: flex-end; -} - -.satus-button_shortcut { - font-weight: 500; - overflow: hidden; - height: 28px; - min-height: 28px; - margin-right: 2px; - padding: 4px 8px; - text-transform: uppercase; - color: #f96754; - border-radius: 4px; -} - - -/*-------------------------------------------------------------- -# SLIDER ---------------------------------------------------------------*/ - -.satus-slider { - position: relative; - display: flex; - flex-direction: column; - box-sizing: border-box; - width: 100%; - min-height: 64px; - padding: 0 16px; - -webkit-user-select: none; - -moz-user-select: none; - user-select: none; - outline: none; - align-items: flex-start; - justify-content: center; -} - -.satus-slider::before { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - content: ''; - opacity: 0; - background-color: var(--satus-theme-button); -} - -.satus-slider:hover::before { - opacity: 1; -} - - -/* LABEL */ - -.satus-slider__label { - cursor: default; -} - -.satus-slider__range { - position: absolute; - z-index: 1; - top: 0; - left: 0; - box-sizing: border-box; - width: 100%; - height: 100%; - margin: 0; - padding: 0; - opacity: 0; -} - - -/* TRACK */ - -.satus-slider__container { - position: relative; - width: 100%; - height: 12px; - margin: 8px 0 0; -} - -.satus-slider__track-container { - position: absolute; - top: calc(50% - 1px); - width: 100%; - height: 2px; - pointer-events: none; -} - -.satus-slider__track-container::before { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 2px; - content: ''; - opacity: .26; - background-color: var(--satus-theme-primary); -} - -.satus-slider__track { - position: relative; - width: 0; - height: 100%; - background-color: var(--satus-theme-primary); - will-change: width; -} - -.satus-slider:not(.satus-slider--dragging) .satus-slider__track { - transition: width 100ms ease-out; -} - -.satus-slider__thumb { - position: absolute; - top: -5px; - right: -12px; - width: 12px; - height: 12px; - border-radius: 50%; - background-color: var(--satus-theme-primary); - box-shadow: 0 1px 5px rgba(0, 0, 0, .15); -} - -.satus-slider .satus-slider__thumb::before { - font-size: 13px; - position: absolute; - top: -34px; - left: 50%; - visibility: hidden; - box-sizing: border-box; - min-width: 28px; - padding: 4px 4px; - content: attr(data-value); - transform: translateX(-50%); - text-align: center; - pointer-events: none; - color: #fff; - border-radius: 4px; - background: var(--satus-theme-tooltip); -} - -.satus-slider:hover .satus-slider__thumb::before, -.satus-slider__range:focus .satus-slider__container .satus-slider__thumb::before { - visibility: visible; -} - -.satus-slider__ring { - position: absolute; - top: -11px; - right: -18px; - width: 24px; - height: 24px; - transition: 100ms; - transform: scale(0); - opacity: 0; - border-radius: 50%; - background-color: var(--satus-theme-primary); -} - -.satus-slider__range:focus+.satus-slider__container .satus-slider__ring { - transform: scale(1); - opacity: .25; -} - - -/*-------------------------------------------------------------- -# SWITCH ---------------------------------------------------------------*/ - -.satus-switch { - position: relative; - display: flex; - box-sizing: border-box; - width: 100%; - height: 48px; - padding: 0 16px; - cursor: pointer; - -webkit-user-select: none; - -moz-user-select: none; - user-select: none; - background-color: transparent; - align-items: center; - justify-content: space-between; -} - -.satus-switch:hover { - background-color: var(--satus-theme-ripple); -} - -.satus-switch__input { - position: absolute; - z-index: 1; - top: 0; - left: 0; - width: 100%; - height: 100%; - margin: 0; - padding: 0; - opacity: 0; - outline: none; - -webkit-appearance: none; -} - - -/* LABEL */ - -.satus-switch__label { - padding: 0 16px 0 0; -} - - -/* TRACK*/ - -.satus-switch__track { - position: relative; - width: 32px; - min-width: 32px; - height: 18px; - border-radius: 18px; - background: #bdbdbd; -} - -.satus-switch__track::before { - position: absolute; - top: -7px; - left: -7px; - width: 32px; - height: 32px; - content: ''; - transition: left .1s cubic-bezier(.4, 0, .2, 1), transform 200ms, background-color 200ms; - transform: scale(0); - opacity: 0; - border-radius: 50%; - background-color: #000; - will-change: left, transform, background-color; -} - -.satus-switch__input:checked+.satus-switch__track::before { - left: 8px; - background-color: var(--satus-theme-primary, #54d2a3); -} - -.satus-switch__input:focus+.satus-switch__track::before { - transform: scale(1); - opacity: .08; -} - -.satus-switch__input:checked:focus+.satus-switch__track::before { - opacity: .25; -} - -.satus-switch__track::after { - position: absolute; - width: 14px; - height: 14px; - content: ''; - transition: transform .1s cubic-bezier(.4, 0, .2, 1); - transform: translate(2px, 2px); - border-radius: 50%; - background-color: #fff; - will-change: transform; -} - -.satus-switch__input:checked+.satus-switch__track { - background: var(--satus-theme-primary, #54d2a3); -} - -.satus-switch__input:checked+.satus-switch__track::after { - transform: translate(16px, 2px); -} - - -/*-------------------------------------------------------------- -# TABLE ---------------------------------------------------------------*/ - -.satus-table { - font-size: .875rem; - position: relative; - display: flex; - overflow: hidden; - flex-direction: column; - box-sizing: border-box; - border: 1px solid #ececec; - border-radius: 6px; -} - -.satus-table__head { - position: relative; - z-index: 1; - display: flex; - box-sizing: border-box; - width: 100%; - height: 44px; - padding: 0 8px; - background: #fff; - box-shadow: 0 2px 4px rgba(0, 0, 0, .1); -} - -.satus-table__head>div { - font-weight: 600; - display: inline-flex; - box-sizing: border-box; - padding: 0 8px 0 0; - opacity: .7; - flex-shrink: 0; - align-items: center; -} - -.satus-table__head>div:last-child { - padding: 0; -} - -.satus-table__head>div:hover { - cursor: pointer; - opacity: 1; -} - -.satus-table__head>div[data-sorting=false]:hover { - cursor: default; -} - -.satus-table__head>div>span { - position: relative; -} - -.satus-table__head>div[data-sorting=asc]>span::after { - position: absolute; - top: calc(50% - 2px); - right: -14px; - width: 0; - height: 0; - content: ''; - border-right: 4px solid transparent; - border-bottom: 5px solid currentColor; - border-left: 4px solid transparent; -} - -.satus-table__head>div[data-sorting=desc]>span::after { - position: absolute; - top: calc(50% - 2px); - right: -13px; - width: 0; - height: 0; - content: ''; - border-top: 5px solid currentColor; - border-right: 4px solid transparent; - border-left: 4px solid transparent; -} - -.satus-table__body { - overflow: hidden; - width: 100%; - height: calc(100% - 48px); - background: #fff; - flex: 1; -} - -.satus-table__row { - display: flex; - box-sizing: border-box; - padding: 0 8px; - border-bottom: 1px solid rgba(0, 0, 0, .1); -} - -.satus-table__row:nth-child(2n) { - background: rgba(0, 0, 0, .03); -} - -.satus-table__cell { - overflow: hidden; - box-sizing: border-box; - padding: 8px 8px 8px 0; - white-space: nowrap; - text-overflow: ellipsis; - word-wrap: break-word; - -webkit-hyphens: auto; - -moz-hyphens: auto; - hyphens: auto; - overflow-wrap: break-word; - flex-shrink: 0; -} - -.satus-table__cell:last-child { - padding-right: 0; -} - -.satus-table__cell input { - box-sizing: border-box; - width: 100%; - height: calc(100% - 10px); - margin: 5px 0; - padding: 1px 2px; - border: 1px solid #d2d2d2; - border-radius: 4px; - outline: none; -} - -.satus-table__paging>button { - min-width: 32px; - height: 32px; - padding: 0 8px; - cursor: pointer; - color: var(--satus-theme-on-surface, #555); - border: none; - background: transparent; -} - -.satus-table__paging>button.active { - color: #2979ff; -} - - -/*-------------------------------------------------------------- -# TEXT ---------------------------------------------------------------*/ - -.satus-text { - margin: 0; - color: inherit; - border: none; -} - - -/*-------------------------------------------------------------- -# TEXT FIELD ---------------------------------------------------------------*/ - -.satus-text-field { - font: inherit; - box-sizing: border-box; - width: 100%; - margin: 0; - padding: 0; - padding: 0 8px; - /* it overwrites padding above; remove one of them */ - color: inherit; - border: none; - outline: none; - background: unset; -} \ No newline at end of file diff --git a/satus.js b/satus.js deleted file mode 100644 index 458a589..0000000 --- a/satus.js +++ /dev/null @@ -1,2193 +0,0 @@ - -/*-------------------------------------------------------------- ->>> SATUS ----------------------------------------------------------------- -# Core - # Events - # Render - # Camelize - # Animation duration -# Modules - # Browser storage - # Localization - # Render - # Clone node styles - # Search - # Storage keys - # User -# Components - # Button - # Colop picker - # Dialog - # Folder - # Header - # List - # Main - # Scroll bar - # Section - # Select - # Shortcut - # Slider - # Switch - # Text - # Text field ---------------------------------------------------------------*/ - -var satus = {}; - - -/*-------------------------------------------------------------- -# EVENTS ---------------------------------------------------------------*/ - -satus.events = {}; - -satus.on = function(event, handler) { - if (!this.isset(this.events[event])) { - this.events[event] = []; - } - - this.events[event].push(handler); -}; - - -/*-------------------------------------------------------------- -# COMPONENTS ---------------------------------------------------------------*/ - -satus.components = {}; - - -/*-------------------------------------------------------------- -# MODULES ---------------------------------------------------------------*/ - -satus.modules = {}; - - -/*-------------------------------------------------------------- -# ISSET ---------------------------------------------------------------*/ - -satus.isset = function(variable) { - if (typeof variable === 'undefined' || variable === null) { - return false; - } - - return true; -}; - - -/*-------------------------------------------------------------- -# CAMELIZE ---------------------------------------------------------------*/ - -satus.camelize = function(string) { - return string.replace(/-[a-z]/g, function(match) { - return match[1].toUpperCase(); - }); -}; - - -/*-------------------------------------------------------------- -# ANIMATION DURATION ---------------------------------------------------------------*/ - -satus.getAnimationDuration = function(element) { - return Number(window.getComputedStyle(element).getPropertyValue('animation-duration').replace(/[^0-9.]/g, '')) * 1000; -}; - - -/*-------------------------------------------------------------- -# MODULES ---------------------------------------------------------------*/ - -/*-------------------------------------------------------------- -# BROWSER STORAGE ---------------------------------------------------------------*/ - -satus.storage = {}; - -satus.storage.get = function(name) { - var target = satus.storage; - - name = name.split('/').filter(function(value) { - return value != ''; - }); - - for (var i = 0, l = name.length; i < l; i++) { - if (satus.isset(target[name[i]])) { - target = target[name[i]]; - } else { - return undefined; - } - } - - return target; -}; - -satus.storage.set = function(name, value) { - var items = {}, - target = satus.storage; - - if (!satus.isset(name)) { - return false; - } - - name = name.split('/').filter(function(value) { - return value != ''; - }); - - for (var i = 0, l = name.length; i < l; i++) { - var item = name[i]; - - if (i < l - 1) { - - if (target[item]) { - target = target[item]; - } else { - target[item] = {}; - - target = target[item]; - } - } else { - target[item] = value; - } - } - - for (var key in satus.storage) { - if (typeof satus.storage[key] !== 'function') { - items[key] = satus.storage[key]; - } - } - - chrome.storage.local.set(items); -}; - -satus.storage.import = function(callback) { - chrome.storage.local.get(function(items) { - for (var key in items) { - satus.storage[key] = items[key]; - } - - if (callback) { - callback(items); - } - }); -}; - -satus.storage.clear = function() { - chrome.storage.local.clear(); - - for (var key in satus.storage) { - if (typeof satus.storage[key] !== 'function') { - delete satus.storage[key]; - } - } -}; - - -/*--------------------------------------------------------------- -# LOCALIZATION ----------------------------------------------------------------*/ - -satus.locale = { - messages: {} -}; - -satus.locale.getMessage = function(string) { - return this.messages[string] || string; -}; - -satus.locale.get = satus.locale.getMessage; - -satus.locale.import = function(language, callback) { - var xhr = new XMLHttpRequest(); - - if (typeof language === 'function') { - var callback = language; - } - - if (typeof language !== 'string') { - var language = chrome.i18n.getUILanguage(); - } - - xhr.onload = function() { - try { - var object = JSON.parse(this.responseText); - - for (var key in object) { - satus.locale.messages[key] = object[key].message; - } - - callback(language); - } catch (err) { - function listener(request) { - if (request !== null && typeof request === 'object') { - if (request.name === 'translation_response') { - var object = JSON.parse(request.value); - - chrome.runtime.onMessage.removeListener(listener); - - for (var key in object) { - satus.locale.messages[key] = object[key].message; - } - - callback(language); - } - } - } - - chrome.runtime.onMessage.addListener(listener); - - chrome.runtime.sendMessage({ - name: 'translation_request', - path: '../_locales/' + language + '/messages.json' - }); - } - }; - - xhr.onerror = function() { - if (language === 'en') { - callback(); - } else { - satus.locale.import('en', callback); - } - }; - - xhr.open('GET', '../_locales/' + language + '/messages.json', true); - xhr.send(); -}; - - -/*-------------------------------------------------------------- -# RENDER ---------------------------------------------------------------*/ - -satus.render = function(element, container, callback) { - function convert(object) { - if (object && object.type) { - var type = satus.camelize(object.type), - component = satus.components[type](object), - excluded_properties = ['type', 'label', 'class', 'title', 'storage']; - - function applyProperties(object, target) { - for (var key in object) { - if (satus.isset(object[key]) && typeof object[key] === 'object' && !object[key].type) { - if (typeof target[key] !== 'object') { - target[key] = {}; - } - - applyProperties(object[key], target[key]); - } else if (excluded_properties.indexOf(key) === -1) { - target[key] = object[key]; - } - } - } - - applyProperties(object, component); - - component.classList.add('satus-' + object.type); - - if (object.class) { - var class_list = object.class.split(' '); - - for (var i = 0, l = class_list.length; i < l; i++) { - component.classList.add(class_list[i]); - } - } - - if (object.before) { - var component_before = document.createElement('span'); - - component_before.innerHTML = object.before; - - for (var i = component_before.children.length - 1; i > -1; i--) { - component.insertBefore(component_before.children[i], component.firstChild); - } - } - - if (object.after) { - var component_after = document.createElement('span'); - - component_after.innerHTML = object.after; - - for (var i = component_after.children.length - 1; i > -1; i--) { - component.appendChild(component_after.children[i]); - } - } - - (container || document.body).appendChild(component); - - if (typeof component.onClickRender === 'object') { - component.addEventListener('click', function() { - satus.render(component.onClickRender); - }); - } - - if (satus.isset(satus.events.render)) { - for (var i = 0, l = satus.events.render.length; i < l; i++) { - satus.events.render[i](component, object); - } - } - - if (typeof component.onrender === 'function') { - component.onrender(object); - } - - if (callback) { - callback(); - } - } - } - - if (element.type) { - convert(element); - } else { - for (var key in element) { - convert(element[key]); - } - } -}; - - -/*-------------------------------------------------------------- -# CLONE NODE STYLES ---------------------------------------------------------------*/ - -satus.cloneNodeStyles = function(origin, target) { - target.style.cssText = window.getComputedStyle(origin, '').cssText; - - for (var i = 0, l = origin.children.length; i < l; i++) { - satus.cloneNodeStyles(origin.children[i], target.children[i]); - } -}; - - -/*-------------------------------------------------------------- -# SEARCH ---------------------------------------------------------------*/ - -satus.search = function(query, object, callback, categories) { - var threads = 0, - folder = '', - results = {}; - - function parse(items) { - threads++; - - for (var key in items) { - var item = items[key]; - - if (categories === true && item.type === 'folder' && folder !== item.label) { - folder = item.label; - } - - if (['switch', 'select', 'slider'].indexOf(item.type) !== -1 && key.indexOf(query) !== -1) { - if (categories === true) { - if (!results[folder]) { - results[folder] = {}; - } - - results[folder][key] = item; - } else { - results[key] = item; - } - } - - if (typeof item === 'object') { - parse(item); - } - } - - threads--; - - if (threads === 0) { - callback(results); - } - } - - parse(object); -}; - - -/*-------------------------------------------------------------- -# STORAGE KEYS ---------------------------------------------------------------*/ - -satus.modules.updateStorageKeys = function(object, callback) { - var threads = 0; - - function parse(items) { - threads++; - - for (var key in items) { - var item = items[key]; - - - if (item.type) { - item.storage_key = key; - } - - if (typeof item === 'object') { - parse(item); - } - } - - threads--; - - if (threads === 0) { - callback(); - } - } - - parse(object); -}; - - -/*-------------------------------------------------------------- -# USER ---------------------------------------------------------------*/ - -satus.modules.user = function() { - /*-------------------------------------------------------------- - 1.0 VARIABLES - --------------------------------------------------------------*/ - - var user_agent = navigator.userAgent, - random_cookie = 'ta{t`nX6cMXK,Wsc', - video = document.createElement('video'), - video_formats = { - ogg: 'video/ogg; codecs="theora"', - h264: 'video/mp4; codecs="avc1.42E01E"', - webm: 'video/webm; codecs="vp8, vorbis"', - vp9: 'video/webm; codecs="vp9"', - hls: 'application/x-mpegURL; codecs="avc1.42E01E"' - }, - audio = document.createElement('audio'), - audio_formats = { - mp3: 'audio/mpeg', - mp4: 'audio/mp4', - aif: 'audio/x-aiff' - }, - cvs = document.createElement('canvas'), - ctx = cvs.getContext('webgl'), - data = { - browser: { - audio: null, - cookies: null, - flash: null, - java: null, - languages: null, - name: null, - platform: null, - version: null, - video: null, - webgl: null - }, - os: { - name: null, - type: null - }, - device: { - connection: { - type: null, - speed: null - }, - cores: null, - gpu: null, - max_touch_points: null, - ram: null, - screen: null, - touch: null - } - }; - - - /*-------------------------------------------------------------- - 2.0 SOFTWARE - --------------------------------------------------------------*/ - - /*-------------------------------------------------------------- - 2.1.0 OS - --------------------------------------------------------------*/ - - /*-------------------------------------------------------------- - 2.1.1 NAME - --------------------------------------------------------------*/ - - if (navigator.appVersion.indexOf('Win') !== -1) { - if (navigator.appVersion.match(/(Windows 10.0|Windows NT 10.0)/)) { - data.os.name = 'Windows 10'; - } else if (navigator.appVersion.match(/(Windows 8.1|Windows NT 6.3)/)) { - data.os.name = 'Windows 8.1'; - } else if (navigator.appVersion.match(/(Windows 8|Windows NT 6.2)/)) { - data.os.name = 'Windows 8'; - } else if (navigator.appVersion.match(/(Windows 7|Windows NT 6.1)/)) { - data.os.name = 'Windows 7'; - } else if (navigator.appVersion.match(/(Windows NT 6.0)/)) { - data.os.name = 'Windows Vista'; - } else if (navigator.appVersion.match(/(Windows NT 5.1|Windows XP)/)) { - data.os.name = 'Windows XP'; - } else { - data.os.name = 'Windows'; - } - } else if (navigator.appVersion.indexOf('(iPhone|iPad|iPod)') !== -1) { - data.os.name = 'iOS'; - } else if (navigator.appVersion.indexOf('Mac') !== -1) { - data.os.name = 'macOS'; - } else if (navigator.appVersion.indexOf('Android') !== -1) { - data.os.name = 'Android'; - } else if (navigator.appVersion.indexOf('OpenBSD') !== -1) { - data.os.name = 'OpenBSD'; - } else if (navigator.appVersion.indexOf('SunOS') !== -1) { - data.os.name = 'SunOS'; - } else if (navigator.appVersion.indexOf('Linux') !== -1) { - data.os.name = 'Linux'; - } else if (navigator.appVersion.indexOf('X11') !== -1) { - data.os.name = 'UNIX'; - } - - /*-------------------------------------------------------------- - 2.1.2 TYPE - --------------------------------------------------------------*/ - - if (navigator.appVersion.match(/(Win64|x64|x86_64|WOW64)/)) { - data.os.type = '64-bit'; - } else { - data.os.type = '32-bit'; - } - - - /*-------------------------------------------------------------- - 2.2.0 BROWSER - --------------------------------------------------------------*/ - - /*-------------------------------------------------------------- - 2.2.1 NAME - --------------------------------------------------------------*/ - - if (user_agent.indexOf('Opera') !== -1) { - data.browser.name = 'Opera'; - } else if (user_agent.indexOf('Vivaldi') !== -1) { - data.browser.name = 'Vivaldi'; - } else if (user_agent.indexOf('Edge') !== -1) { - data.browser.name = 'Edge'; - } else if (user_agent.indexOf('Chrome') !== -1) { - data.browser.name = 'Chrome'; - } else if (user_agent.indexOf('Safari') !== -1) { - data.browser.name = 'Safari'; - } else if (user_agent.indexOf('Firefox') !== -1) { - data.browser.name = 'Firefox'; - } else if (user_agent.indexOf('MSIE') !== -1) { - data.browser.name = 'IE'; - } - - - /*-------------------------------------------------------------- - 2.2.2 VERSION - --------------------------------------------------------------*/ - - var browser_version = user_agent.match(new RegExp(data.browser.name + '/([0-9.]+)')); - - if (browser_version[1]) { - data.browser.version = browser_version[1]; - } - - - /*-------------------------------------------------------------- - 2.2.3 PLATFORM - --------------------------------------------------------------*/ - - data.browser.platform = navigator.platform || null; - - - /*-------------------------------------------------------------- - 2.2.4 LANGUAGES - --------------------------------------------------------------*/ - - data.browser.languages = navigator.languages || null; - - - /*-------------------------------------------------------------- - 2.2.5 COOKIES - --------------------------------------------------------------*/ - - if (document.cookie) { - document.cookie = random_cookie; - - if (document.cookie.indexOf(random_cookie) !== -1) { - data.browser.cookies = true; - } - } - - - /*-------------------------------------------------------------- - 2.2.6 FLASH - --------------------------------------------------------------*/ - - try { - if (new ActiveXObject('ShockwaveFlash.ShockwaveFlash')) { - data.browser.flash = true; - } - } catch (e) { - if (navigator.mimeTypes['application/x-shockwave-flash']) { - data.browser.flash = true; - } - } - - - /*-------------------------------------------------------------- - 2.2.7 JAVA - --------------------------------------------------------------*/ - - if (typeof navigator.javaEnabled === 'function' && navigator.javaEnabled()) { - data.browser.java = true; - } - - - /*-------------------------------------------------------------- - 2.2.8 VIDEO FORMATS - --------------------------------------------------------------*/ - - if (typeof video.canPlayType === 'function') { - data.browser.video = {}; - - for (var i in video_formats) { - var can_play_type = video.canPlayType(video_formats[i]); - - if (can_play_type === '') { - data.browser.video[i] = false; - } else { - data.browser.video[i] = can_play_type; - } - } - } - - - /*-------------------------------------------------------------- - 2.2.9 AUDIO FORMATS - --------------------------------------------------------------*/ - - if (typeof audio.canPlayType === 'function') { - data.browser.audio = {}; - - for (var i in audio_formats) { - var can_play_type = audio.canPlayType(audio_formats[i]); - - if (can_play_type == '') { - data.browser.audio[i] = false; - } else { - data.browser.audio[i] = can_play_type; - } - } - } - - - /*-------------------------------------------------------------- - 2.2.10 WEBGL - --------------------------------------------------------------*/ - - if (ctx && ctx instanceof WebGLRenderingContext) { - data.browser.webgl = true; - } - - - /*-------------------------------------------------------------- - 3.0 HARDWARE - --------------------------------------------------------------*/ - - /*-------------------------------------------------------------- - 3.1 SCREEN - --------------------------------------------------------------*/ - - if (screen) { - data.device.screen = screen.width + 'x' + screen.height; - } - - - /*-------------------------------------------------------------- - 3.2 RAM - --------------------------------------------------------------*/ - - if ('deviceMemory' in navigator) { - data.device.ram = navigator.deviceMemory + ' GB'; - } - - - /*-------------------------------------------------------------- - 3.3 GPU - --------------------------------------------------------------*/ - - if ( - ctx && - ctx instanceof WebGLRenderingContext && - 'getParameter' in ctx && - 'getExtension' in ctx - ) { - var info = ctx.getExtension('WEBGL_debug_renderer_info'); - - if (info) { - data.device.gpu = ctx.getParameter(info.UNMASKED_RENDERER_WEBGL); - } - } - - - /*-------------------------------------------------------------- - 3.4 CORES - --------------------------------------------------------------*/ - - if (navigator.hardwareConcurrency) { - data.device.cores = navigator.hardwareConcurrency; - } - - - /*-------------------------------------------------------------- - 3.5 TOUCH - --------------------------------------------------------------*/ - - if ( - window.hasOwnProperty('ontouchstart') || - window.DocumentTouch && document instanceof window.DocumentTouch || - navigator.maxTouchPoints > 0 || - window.navigator.msMaxTouchPoints > 0 - ) { - data.device.touch = true; - data.device.max_touch_points = navigator.maxTouchPoints; - } - - - /*-------------------------------------------------------------- - 3.6 CONNECTION - --------------------------------------------------------------*/ - - if (typeof navigator.connection === 'object') { - data.device.connection.type = navigator.connection.effectiveType || null; - - if (navigator.connection.downlink) { - data.device.connection.speed = navigator.connection.downlink + ' Mbps'; - } - } - - - /*-------------------------------------------------------------- - 4.0 CLEARING - --------------------------------------------------------------*/ - - video.remove(); - audio.remove(); - cvs.remove(); - - - return data; -}; -satus.on('render', function(component, data) { - if (data.perspective === true) { - component.style.willChange = 'transform'; - component.style.transformStyle = 'preserve-3d'; - component.style.transition = '.4s'; - - component.addEventListener('mousemove', function(event) { - var bounding = component.getBoundingClientRect(), - dx = event.clientX - bounding.left - bounding.width / 2, - dy = event.clientY - bounding.top - bounding.height / 2; - - this.style.transform = 'perspective(440px) rotateX(' + dy * -1 + 'deg) rotateY(' + dx + 'deg) translateZ(0)'; - }); - - component.addEventListener('mouseout', function(event) { - this.style.transform = 'perspective(440px) rotateX(0deg) rotateY(0deg) translateZ(0)'; - }); - } -}); - - -/*-------------------------------------------------------------- -# COMPONENTS ---------------------------------------------------------------*/ - -/*-------------------------------------------------------------- -# BUTTON ---------------------------------------------------------------*/ - -satus.components.button = function(element) { - var component = document.createElement('button'); - - if (satus.isset(element.icon)) { - var component_icon = document.createElement('span'); - - component_icon.className = 'satus-button__icon'; - component_icon.innerHTML = element.icon; - - component.appendChild(component_icon); - } - - if (satus.isset(element.label)) { - var component_label = document.createElement('span'); - - component_label.className = 'satus-button__label'; - component_label.innerText = satus.locale.getMessage(element.label); - - component.appendChild(component_label); - } - - return component; -}; - - -/*-------------------------------------------------------------- -# COLOR PICKER ---------------------------------------------------------------*/ - -satus.components.colorPicker = function(element) { - var component = document.createElement('div'), - component_value = document.createElement('div'); - - element.class = 'satus-button'; - component_value.className = 'satus-color-picker__value'; - component_value.style.backgroundColor = satus.storage.get(element.storage_key) || element.value || ''; - - if (satus.isset(element.label)) { - var component_label = document.createElement('span'); - - component_label.className = 'satus-button__label'; - component_label.innerText = satus.locale.getMessage(element.label); - - component.appendChild(component_label); - } - - component.addEventListener('click', function() { - var component = document.createElement('div'), - component_canvas = document.createElement('canvas'), - close = document.createElement('button'), - ctx = component_canvas.getContext('2d'), - image = new Image(), - dialog = satus.components.dialog({}); - - close.className = 'satus-button'; - close.innerHTML = ''; - close.onclick = function() { - dialog.querySelector('.satus-dialog__scrim').click(); - }; - - dialog.className = 'satus-dialog satus-dialog--color-picker'; - - component_canvas.width = 200; - component_canvas.height = 200; - - function select(event) { - var coordinates = component_canvas.getBoundingClientRect(), - x = event.clientX - coordinates.left, - y = event.clientY - coordinates.top, - color = ctx.getImageData(x, y, 1, 1).data; - - component_value.style.backgroundColor = 'rgb(' + color[0] + ',' + color[1] + ',' + color[2] + ')'; - - satus.storage.set(element.storage_key, component_value.style.backgroundColor); - } - - function mouseup(event) { - component_canvas.removeEventListener('mousemove', select); - window.removeEventListener('mouseup', mouseup); - } - - component_canvas.addEventListener('mousedown', function() { - select(event); - this.addEventListener('mousemove', select); - window.addEventListener('mouseup', mouseup); - }); - - image.onload = function() { - ctx.drawImage(image, 0, 0); - - image.remove(); - }; - - image.src = 'data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 270 270"><defs><radialGradient id="a"><stop offset="0%" stop-color="#fff"/><stop offset="100%" stop-color="#fff" stop-opacity="0"/></radialGradient></defs><g fill="none" stroke-width="133" class="IroWheelHue"><path stroke="hsl(240, 100%, 50%)" d="M201.477 136.74a66.5 66.5 0 00.023-1.74"/><path stroke="hsl(241, 100%, 50%)" d="M201.437 137.9a66.5 66.5 0 00.053-1.74"/><path stroke="hsl(242, 100%, 50%)" d="M201.376 139.06a66.5 66.5 0 00.083-1.74"/><path stroke="hsl(243, 100%, 50%)" d="M201.295 140.218a66.5 66.5 0 00.114-1.738"/><path stroke="hsl(244, 100%, 50%)" d="M201.194 141.374a66.5 66.5 0 00.144-1.735"/><path stroke="hsl(245, 100%, 50%)" d="M201.073 142.528a66.5 66.5 0 00.174-1.732"/><path stroke="hsl(246, 100%, 50%)" d="M200.931 143.68a66.5 66.5 0 00.205-1.729"/><path stroke="hsl(247, 100%, 50%)" d="M200.77 144.83a66.5 66.5 0 00.234-1.726"/><path stroke="hsl(248, 100%, 50%)" d="M200.588 145.976a66.5 66.5 0 00.265-1.721"/><path stroke="hsl(249, 100%, 50%)" d="M200.386 147.119a66.5 66.5 0 00.295-1.716"/><path stroke="hsl(250, 100%, 50%)" d="M200.165 148.258a66.5 66.5 0 00.325-1.71"/><path stroke="hsl(251, 100%, 50%)" d="M199.924 149.393a66.5 66.5 0 00.354-1.704"/><path stroke="hsl(252, 100%, 50%)" d="M199.663 150.524a66.5 66.5 0 00.384-1.698"/><path stroke="hsl(253, 100%, 50%)" d="M199.382 151.65a66.5 66.5 0 00.414-1.69"/><path stroke="hsl(254, 100%, 50%)" d="M199.081 152.771a66.5 66.5 0 00.444-1.683"/><path stroke="hsl(255, 100%, 50%)" d="M198.762 153.887a66.5 66.5 0 00.472-1.676"/><path stroke="hsl(256, 100%, 50%)" d="M198.422 154.997a66.5 66.5 0 00.502-1.667"/><path stroke="hsl(257, 100%, 50%)" d="M198.064 156.1a66.5 66.5 0 00.53-1.657"/><path stroke="hsl(258, 100%, 50%)" d="M197.686 157.198a66.5 66.5 0 00.56-1.648"/><path stroke="hsl(259, 100%, 50%)" d="M197.289 158.289a66.5 66.5 0 00.588-1.639"/><path stroke="hsl(260, 100%, 50%)" d="M196.873 159.372a66.5 66.5 0 00.617-1.628"/><path stroke="hsl(261, 100%, 50%)" d="M196.438 160.448a66.5 66.5 0 00.645-1.617"/><path stroke="hsl(262, 100%, 50%)" d="M195.984 161.517a66.5 66.5 0 00.674-1.606"/><path stroke="hsl(263, 100%, 50%)" d="M195.512 162.577a66.5 66.5 0 00.702-1.593"/><path stroke="hsl(264, 100%, 50%)" d="M195.022 163.629a66.5 66.5 0 00.729-1.581"/><path stroke="hsl(265, 100%, 50%)" d="M194.513 164.672a66.5 66.5 0 00.756-1.568"/><path stroke="hsl(266, 100%, 50%)" d="M193.986 165.706a66.5 66.5 0 00.784-1.554"/><path stroke="hsl(267, 100%, 50%)" d="M193.441 166.731a66.5 66.5 0 00.81-1.54"/><path stroke="hsl(268, 100%, 50%)" d="M192.879 167.746a66.5 66.5 0 00.837-1.526"/><path stroke="hsl(269, 100%, 50%)" d="M192.298 168.751a66.5 66.5 0 00.864-1.511"/><path stroke="hsl(270, 100%, 50%)" d="M191.7 169.746a66.5 66.5 0 00.89-1.496"/><path stroke="hsl(271, 100%, 50%)" d="M191.086 170.73a66.5 66.5 0 00.916-1.48"/><path stroke="hsl(272, 100%, 50%)" d="M190.453 171.704a66.5 66.5 0 00.942-1.464"/><path stroke="hsl(273, 100%, 50%)" d="M189.804 172.666a66.5 66.5 0 00.968-1.448"/><path stroke="hsl(274, 100%, 50%)" d="M189.139 173.617a66.5 66.5 0 00.992-1.43"/><path stroke="hsl(275, 100%, 50%)" d="M188.456 174.556a66.5 66.5 0 001.018-1.413"/><path stroke="hsl(276, 100%, 50%)" d="M187.758 175.483a66.5 66.5 0 001.042-1.395"/><path stroke="hsl(277, 100%, 50%)" d="M187.043 176.397a66.5 66.5 0 001.066-1.376"/><path stroke="hsl(278, 100%, 50%)" d="M186.313 177.3a66.5 66.5 0 001.09-1.359"/><path stroke="hsl(279, 100%, 50%)" d="M185.567 178.188a66.5 66.5 0 001.113-1.338"/><path stroke="hsl(280, 100%, 50%)" d="M184.806 179.064a66.5 66.5 0 001.136-1.319"/><path stroke="hsl(281, 100%, 50%)" d="M184.029 179.927a66.5 66.5 0 001.16-1.3"/><path stroke="hsl(282, 100%, 50%)" d="M183.237 180.776a66.5 66.5 0 001.182-1.279"/><path stroke="hsl(283, 100%, 50%)" d="M182.431 181.61a66.5 66.5 0 001.204-1.257"/><path stroke="hsl(284, 100%, 50%)" d="M181.61 182.431a66.5 66.5 0 001.226-1.236"/><path stroke="hsl(285, 100%, 50%)" d="M180.776 183.237a66.5 66.5 0 001.247-1.214"/><path stroke="hsl(286, 100%, 50%)" d="M179.927 184.029a66.5 66.5 0 001.268-1.193"/><path stroke="hsl(287, 100%, 50%)" d="M179.064 184.806a66.5 66.5 0 001.289-1.171"/><path stroke="hsl(288, 100%, 50%)" d="M178.188 185.567a66.5 66.5 0 001.31-1.148"/><path stroke="hsl(289, 100%, 50%)" d="M177.3 186.313a66.5 66.5 0 001.328-1.125"/><path stroke="hsl(290, 100%, 50%)" d="M176.397 187.043a66.5 66.5 0 001.348-1.101"/><path stroke="hsl(291, 100%, 50%)" d="M175.483 187.758a66.5 66.5 0 001.367-1.078"/><path stroke="hsl(292, 100%, 50%)" d="M174.556 188.456a66.5 66.5 0 001.385-1.053"/><path stroke="hsl(293, 100%, 50%)" d="M173.617 189.139a66.5 66.5 0 001.404-1.03"/><path stroke="hsl(294, 100%, 50%)" d="M172.666 189.804a66.5 66.5 0 001.422-1.004"/><path stroke="hsl(295, 100%, 50%)" d="M171.704 190.453a66.5 66.5 0 001.439-.98"/><path stroke="hsl(296, 100%, 50%)" d="M170.73 191.086a66.5 66.5 0 001.456-.955"/><path stroke="hsl(297, 100%, 50%)" d="M169.746 191.7a66.5 66.5 0 001.472-.928"/><path stroke="hsl(298, 100%, 50%)" d="M168.751 192.298a66.5 66.5 0 001.489-.903"/><path stroke="hsl(299, 100%, 50%)" d="M167.746 192.879a66.5 66.5 0 001.504-.877"/><path stroke="hsl(300, 100%, 50%)" d="M166.731 193.441a66.5 66.5 0 001.519-.85"/><path stroke="hsl(301, 100%, 50%)" d="M165.706 193.986a66.5 66.5 0 001.534-.824"/><path stroke="hsl(302, 100%, 50%)" d="M164.672 194.513a66.5 66.5 0 001.548-.797"/><path stroke="hsl(303, 100%, 50%)" d="M163.629 195.022a66.5 66.5 0 001.561-.77"/><path stroke="hsl(304, 100%, 50%)" d="M162.577 195.512a66.5 66.5 0 001.575-.742"/><path stroke="hsl(305, 100%, 50%)" d="M161.517 195.984a66.5 66.5 0 001.587-.715"/><path stroke="hsl(306, 100%, 50%)" d="M160.448 196.438a66.5 66.5 0 001.6-.687"/><path stroke="hsl(307, 100%, 50%)" d="M159.372 196.873a66.5 66.5 0 001.612-.66"/><path stroke="hsl(308, 100%, 50%)" d="M158.289 197.289a66.5 66.5 0 001.622-.631"/><path stroke="hsl(309, 100%, 50%)" d="M157.198 197.686a66.5 66.5 0 001.633-.603"/><path stroke="hsl(310, 100%, 50%)" d="M156.1 198.064a66.5 66.5 0 001.644-.574"/><path stroke="hsl(311, 100%, 50%)" d="M154.997 198.422a66.5 66.5 0 001.653-.545"/><path stroke="hsl(312, 100%, 50%)" d="M153.887 198.762a66.5 66.5 0 001.663-.517"/><path stroke="hsl(313, 100%, 50%)" d="M152.771 199.081a66.5 66.5 0 001.672-.487"/><path stroke="hsl(314, 100%, 50%)" d="M151.65 199.382a66.5 66.5 0 001.68-.458"/><path stroke="hsl(315, 100%, 50%)" d="M150.524 199.663a66.5 66.5 0 001.687-.429"/><path stroke="hsl(316, 100%, 50%)" d="M149.393 199.924a66.5 66.5 0 001.695-.4"/><path stroke="hsl(317, 100%, 50%)" d="M148.258 200.165a66.5 66.5 0 001.701-.37"/><path stroke="hsl(318, 100%, 50%)" d="M147.119 200.386a66.5 66.5 0 001.707-.34"/><path stroke="hsl(319, 100%, 50%)" d="M145.976 200.588a66.5 66.5 0 001.713-.31"/><path stroke="hsl(320, 100%, 50%)" d="M144.83 200.77a66.5 66.5 0 001.718-.28"/><path stroke="hsl(321, 100%, 50%)" d="M143.68 200.931a66.5 66.5 0 001.723-.25"/><path stroke="hsl(322, 100%, 50%)" d="M142.528 201.073a66.5 66.5 0 001.727-.22"/><path stroke="hsl(323, 100%, 50%)" d="M141.374 201.194a66.5 66.5 0 001.73-.19"/><path stroke="hsl(324, 100%, 50%)" d="M140.218 201.295a66.5 66.5 0 001.733-.16"/><path stroke="hsl(325, 100%, 50%)" d="M139.06 201.376a66.5 66.5 0 001.736-.13"/><path stroke="hsl(326, 100%, 50%)" d="M137.9 201.437a66.5 66.5 0 001.739-.099"/><path stroke="hsl(327, 100%, 50%)" d="M136.74 201.477a66.5 66.5 0 001.74-.068"/><path stroke="hsl(328, 100%, 50%)" d="M135.58 201.497a66.5 66.5 0 001.74-.038"/><path stroke="hsl(329, 100%, 50%)" d="M134.42 201.497a66.5 66.5 0 001.74-.007"/><path stroke="hsl(330, 100%, 50%)" d="M133.26 201.477a66.5 66.5 0 001.74.023"/><path stroke="hsl(331, 100%, 50%)" d="M132.1 201.437a66.5 66.5 0 001.74.053"/><path stroke="hsl(332, 100%, 50%)" d="M130.94 201.376a66.5 66.5 0 001.74.083"/><path stroke="hsl(333, 100%, 50%)" d="M129.782 201.295a66.5 66.5 0 001.738.114"/><path stroke="hsl(334, 100%, 50%)" d="M128.626 201.194a66.5 66.5 0 001.735.144"/><path stroke="hsl(335, 100%, 50%)" d="M127.472 201.073a66.5 66.5 0 001.732.174"/><path stroke="hsl(336, 100%, 50%)" d="M126.32 200.931a66.5 66.5 0 001.729.205"/><path stroke="hsl(337, 100%, 50%)" d="M125.17 200.77a66.5 66.5 0 001.726.234"/><path stroke="hsl(338, 100%, 50%)" d="M124.024 200.588a66.5 66.5 0 001.721.265"/><path stroke="hsl(339, 100%, 50%)" d="M122.881 200.386a66.5 66.5 0 001.716.295"/><path stroke="hsl(340, 100%, 50%)" d="M121.742 200.165a66.5 66.5 0 001.71.325"/><path stroke="hsl(341, 100%, 50%)" d="M120.607 199.924a66.5 66.5 0 001.704.354"/><path stroke="hsl(342, 100%, 50%)" d="M119.476 199.663a66.5 66.5 0 001.698.384"/><path stroke="hsl(343, 100%, 50%)" d="M118.35 199.382a66.5 66.5 0 001.69.414"/><path stroke="hsl(344, 100%, 50%)" d="M117.229 199.081a66.5 66.5 0 001.683.444"/><path stroke="hsl(345, 100%, 50%)" d="M116.113 198.762a66.5 66.5 0 001.676.472"/><path stroke="hsl(346, 100%, 50%)" d="M115.003 198.422a66.5 66.5 0 001.667.502"/><path stroke="hsl(347, 100%, 50%)" d="M113.9 198.064a66.5 66.5 0 001.657.53"/><path stroke="hsl(348, 100%, 50%)" d="M112.802 197.686a66.5 66.5 0 001.648.56"/><path stroke="hsl(349, 100%, 50%)" d="M111.711 197.289a66.5 66.5 0 001.639.588"/><path stroke="hsl(350, 100%, 50%)" d="M110.628 196.873a66.5 66.5 0 001.628.617"/><path stroke="hsl(351, 100%, 50%)" d="M109.552 196.438a66.5 66.5 0 001.617.645"/><path stroke="hsl(352, 100%, 50%)" d="M108.483 195.984a66.5 66.5 0 001.606.674"/><path stroke="hsl(353, 100%, 50%)" d="M107.423 195.512a66.5 66.5 0 001.593.702"/><path stroke="hsl(354, 100%, 50%)" d="M106.371 195.022a66.5 66.5 0 001.581.729"/><path stroke="hsl(355, 100%, 50%)" d="M105.328 194.513a66.5 66.5 0 001.568.756"/><path stroke="hsl(356, 100%, 50%)" d="M104.294 193.986a66.5 66.5 0 001.554.784"/><path stroke="hsl(357, 100%, 50%)" d="M103.269 193.441a66.5 66.5 0 001.54.81"/><path stroke="hsl(358, 100%, 50%)" d="M102.254 192.879a66.5 66.5 0 001.526.837"/><path stroke="hsl(359, 100%, 50%)" d="M101.249 192.298a66.5 66.5 0 001.511.864"/><path stroke="hsl(0, 100%, 50%)" d="M100.254 191.7a66.5 66.5 0 001.496.89"/><path stroke="hsl(1, 100%, 50%)" d="M99.27 191.086a66.5 66.5 0 001.48.916"/><path stroke="hsl(2, 100%, 50%)" d="M98.296 190.453a66.5 66.5 0 001.464.942"/><path stroke="hsl(3, 100%, 50%)" d="M97.334 189.804a66.5 66.5 0 001.448.968"/><path stroke="hsl(4, 100%, 50%)" d="M96.383 189.139a66.5 66.5 0 001.43.992"/><path stroke="hsl(5, 100%, 50%)" d="M95.444 188.456a66.5 66.5 0 001.413 1.018"/><path stroke="hsl(6, 100%, 50%)" d="M94.517 187.758a66.5 66.5 0 001.395 1.042"/><path stroke="hsl(7, 100%, 50%)" d="M93.603 187.043a66.5 66.5 0 001.376 1.066"/><path stroke="hsl(8, 100%, 50%)" d="M92.7 186.313a66.5 66.5 0 001.359 1.09"/><path stroke="hsl(9, 100%, 50%)" d="M91.812 185.567a66.5 66.5 0 001.338 1.113"/><path stroke="hsl(10, 100%, 50%)" d="M90.936 184.806a66.5 66.5 0 001.319 1.136"/><path stroke="hsl(11, 100%, 50%)" d="M90.073 184.029a66.5 66.5 0 001.3 1.16"/><path stroke="hsl(12, 100%, 50%)" d="M89.224 183.237a66.5 66.5 0 001.279 1.182"/><path stroke="hsl(13, 100%, 50%)" d="M88.39 182.431a66.5 66.5 0 001.257 1.204"/><path stroke="hsl(14, 100%, 50%)" d="M87.569 181.61a66.5 66.5 0 001.236 1.226"/><path stroke="hsl(15, 100%, 50%)" d="M86.763 180.776a66.5 66.5 0 001.214 1.247"/><path stroke="hsl(16, 100%, 50%)" d="M85.971 179.927a66.5 66.5 0 001.193 1.268"/><path stroke="hsl(17, 100%, 50%)" d="M85.194 179.064a66.5 66.5 0 001.171 1.289"/><path stroke="hsl(18, 100%, 50%)" d="M84.433 178.188a66.5 66.5 0 001.148 1.31"/><path stroke="hsl(19, 100%, 50%)" d="M83.687 177.3a66.5 66.5 0 001.125 1.328"/><path stroke="hsl(20, 100%, 50%)" d="M82.957 176.397a66.5 66.5 0 001.101 1.348"/><path stroke="hsl(21, 100%, 50%)" d="M82.242 175.483a66.5 66.5 0 001.078 1.367"/><path stroke="hsl(22, 100%, 50%)" d="M81.544 174.556a66.5 66.5 0 001.053 1.385"/><path stroke="hsl(23, 100%, 50%)" d="M80.861 173.617a66.5 66.5 0 001.03 1.404"/><path stroke="hsl(24, 100%, 50%)" d="M80.196 172.666a66.5 66.5 0 001.004 1.422"/><path stroke="hsl(25, 100%, 50%)" d="M79.547 171.704a66.5 66.5 0 00.98 1.439"/><path stroke="hsl(26, 100%, 50%)" d="M78.914 170.73a66.5 66.5 0 00.955 1.456"/><path stroke="hsl(27, 100%, 50%)" d="M78.3 169.746a66.5 66.5 0 00.928 1.472"/><path stroke="hsl(28, 100%, 50%)" d="M77.702 168.751a66.5 66.5 0 00.903 1.489"/><path stroke="hsl(29, 100%, 50%)" d="M77.121 167.746a66.5 66.5 0 00.877 1.504"/><path stroke="hsl(30, 100%, 50%)" d="M76.559 166.731a66.5 66.5 0 00.85 1.519"/><path stroke="hsl(31, 100%, 50%)" d="M76.014 165.706a66.5 66.5 0 00.824 1.534"/><path stroke="hsl(32, 100%, 50%)" d="M75.487 164.672a66.5 66.5 0 00.797 1.548"/><path stroke="hsl(33, 100%, 50%)" d="M74.978 163.629a66.5 66.5 0 00.77 1.561"/><path stroke="hsl(34, 100%, 50%)" d="M74.488 162.577a66.5 66.5 0 00.742 1.575"/><path stroke="hsl(35, 100%, 50%)" d="M74.016 161.517a66.5 66.5 0 00.715 1.587"/><path stroke="hsl(36, 100%, 50%)" d="M73.562 160.448a66.5 66.5 0 00.687 1.6"/><path stroke="hsl(37, 100%, 50%)" d="M73.127 159.372a66.5 66.5 0 00.66 1.612"/><path stroke="hsl(38, 100%, 50%)" d="M72.711 158.289a66.5 66.5 0 00.631 1.622"/><path stroke="hsl(39, 100%, 50%)" d="M72.314 157.198a66.5 66.5 0 00.603 1.633"/><path stroke="hsl(40, 100%, 50%)" d="M71.936 156.1a66.5 66.5 0 00.574 1.644"/><path stroke="hsl(41, 100%, 50%)" d="M71.578 154.997a66.5 66.5 0 00.545 1.653"/><path stroke="hsl(42, 100%, 50%)" d="M71.238 153.887a66.5 66.5 0 00.517 1.663"/><path stroke="hsl(43, 100%, 50%)" d="M70.919 152.771a66.5 66.5 0 00.487 1.672"/><path stroke="hsl(44, 100%, 50%)" d="M70.618 151.65a66.5 66.5 0 00.458 1.68"/><path stroke="hsl(45, 100%, 50%)" d="M70.337 150.524a66.5 66.5 0 00.429 1.687"/><path stroke="hsl(46, 100%, 50%)" d="M70.076 149.393a66.5 66.5 0 00.4 1.695"/><path stroke="hsl(47, 100%, 50%)" d="M69.835 148.258a66.5 66.5 0 00.37 1.701"/><path stroke="hsl(48, 100%, 50%)" d="M69.614 147.119a66.5 66.5 0 00.34 1.707"/><path stroke="hsl(49, 100%, 50%)" d="M69.412 145.976a66.5 66.5 0 00.31 1.713"/><path stroke="hsl(50, 100%, 50%)" d="M69.23 144.83a66.5 66.5 0 00.28 1.718"/><path stroke="hsl(51, 100%, 50%)" d="M69.069 143.68a66.5 66.5 0 00.25 1.723"/><path stroke="hsl(52, 100%, 50%)" d="M68.927 142.528a66.5 66.5 0 00.22 1.727"/><path stroke="hsl(53, 100%, 50%)" d="M68.806 141.374a66.5 66.5 0 00.19 1.73"/><path stroke="hsl(54, 100%, 50%)" d="M68.705 140.218a66.5 66.5 0 00.16 1.733"/><path stroke="hsl(55, 100%, 50%)" d="M68.624 139.06a66.5 66.5 0 00.13 1.736"/><path stroke="hsl(56, 100%, 50%)" d="M68.563 137.9a66.5 66.5 0 00.099 1.739"/><path stroke="hsl(57, 100%, 50%)" d="M68.523 136.74a66.5 66.5 0 00.068 1.74"/><path stroke="hsl(58, 100%, 50%)" d="M68.503 135.58a66.5 66.5 0 00.038 1.74"/><path stroke="hsl(59, 100%, 50%)" d="M68.503 134.42a66.5 66.5 0 00.007 1.74"/><path stroke="hsl(60, 100%, 50%)" d="M68.523 133.26A66.5 66.5 0 0068.5 135"/><path stroke="hsl(61, 100%, 50%)" d="M68.563 132.1a66.5 66.5 0 00-.053 1.74"/><path stroke="hsl(62, 100%, 50%)" d="M68.624 130.94a66.5 66.5 0 00-.083 1.74"/><path stroke="hsl(63, 100%, 50%)" d="M68.705 129.782a66.5 66.5 0 00-.114 1.738"/><path stroke="hsl(64, 100%, 50%)" d="M68.806 128.626a66.5 66.5 0 00-.144 1.735"/><path stroke="hsl(65, 100%, 50%)" d="M68.927 127.472a66.5 66.5 0 00-.174 1.732"/><path stroke="hsl(66, 100%, 50%)" d="M69.069 126.32a66.5 66.5 0 00-.205 1.729"/><path stroke="hsl(67, 100%, 50%)" d="M69.23 125.17a66.5 66.5 0 00-.234 1.726"/><path stroke="hsl(68, 100%, 50%)" d="M69.412 124.024a66.5 66.5 0 00-.265 1.721"/><path stroke="hsl(69, 100%, 50%)" d="M69.614 122.881a66.5 66.5 0 00-.295 1.716"/><path stroke="hsl(70, 100%, 50%)" d="M69.835 121.742a66.5 66.5 0 00-.325 1.71"/><path stroke="hsl(71, 100%, 50%)" d="M70.076 120.607a66.5 66.5 0 00-.354 1.704"/><path stroke="hsl(72, 100%, 50%)" d="M70.337 119.476a66.5 66.5 0 00-.384 1.698"/><path stroke="hsl(73, 100%, 50%)" d="M70.618 118.35a66.5 66.5 0 00-.414 1.69"/><path stroke="hsl(74, 100%, 50%)" d="M70.919 117.229a66.5 66.5 0 00-.444 1.683"/><path stroke="hsl(75, 100%, 50%)" d="M71.238 116.113a66.5 66.5 0 00-.472 1.676"/><path stroke="hsl(76, 100%, 50%)" d="M71.578 115.003a66.5 66.5 0 00-.502 1.667"/><path stroke="hsl(77, 100%, 50%)" d="M71.936 113.9a66.5 66.5 0 00-.53 1.657"/><path stroke="hsl(78, 100%, 50%)" d="M72.314 112.802a66.5 66.5 0 00-.56 1.648"/><path stroke="hsl(79, 100%, 50%)" d="M72.711 111.711a66.5 66.5 0 00-.588 1.639"/><path stroke="hsl(80, 100%, 50%)" d="M73.127 110.628a66.5 66.5 0 00-.617 1.628"/><path stroke="hsl(81, 100%, 50%)" d="M73.562 109.552a66.5 66.5 0 00-.645 1.617"/><path stroke="hsl(82, 100%, 50%)" d="M74.016 108.483a66.5 66.5 0 00-.674 1.606"/><path stroke="hsl(83, 100%, 50%)" d="M74.488 107.423a66.5 66.5 0 00-.702 1.593"/><path stroke="hsl(84, 100%, 50%)" d="M74.978 106.371a66.5 66.5 0 00-.729 1.581"/><path stroke="hsl(85, 100%, 50%)" d="M75.487 105.328a66.5 66.5 0 00-.756 1.568"/><path stroke="hsl(86, 100%, 50%)" d="M76.014 104.294a66.5 66.5 0 00-.784 1.554"/><path stroke="hsl(87, 100%, 50%)" d="M76.559 103.269a66.5 66.5 0 00-.81 1.54"/><path stroke="hsl(88, 100%, 50%)" d="M77.121 102.254a66.5 66.5 0 00-.837 1.526"/><path stroke="hsl(89, 100%, 50%)" d="M77.702 101.249a66.5 66.5 0 00-.864 1.511"/><path stroke="hsl(90, 100%, 50%)" d="M78.3 100.254a66.5 66.5 0 00-.89 1.496"/><path stroke="hsl(91, 100%, 50%)" d="M78.914 99.27a66.5 66.5 0 00-.916 1.48"/><path stroke="hsl(92, 100%, 50%)" d="M79.547 98.296a66.5 66.5 0 00-.942 1.464"/><path stroke="hsl(93, 100%, 50%)" d="M80.196 97.334a66.5 66.5 0 00-.968 1.448"/><path stroke="hsl(94, 100%, 50%)" d="M80.861 96.383a66.5 66.5 0 00-.992 1.43"/><path stroke="hsl(95, 100%, 50%)" d="M81.544 95.444a66.5 66.5 0 00-1.018 1.413"/><path stroke="hsl(96, 100%, 50%)" d="M82.242 94.517a66.5 66.5 0 00-1.042 1.395"/><path stroke="hsl(97, 100%, 50%)" d="M82.957 93.603a66.5 66.5 0 00-1.066 1.376"/><path stroke="hsl(98, 100%, 50%)" d="M83.687 92.7a66.5 66.5 0 00-1.09 1.359"/><path stroke="hsl(99, 100%, 50%)" d="M84.433 91.812a66.5 66.5 0 00-1.113 1.338"/><path stroke="hsl(100, 100%, 50%)" d="M85.194 90.936a66.5 66.5 0 00-1.136 1.319"/><path stroke="hsl(101, 100%, 50%)" d="M85.971 90.073a66.5 66.5 0 00-1.16 1.3"/><path stroke="hsl(102, 100%, 50%)" d="M86.763 89.224a66.5 66.5 0 00-1.182 1.279"/><path stroke="hsl(103, 100%, 50%)" d="M87.569 88.39a66.5 66.5 0 00-1.204 1.257"/><path stroke="hsl(104, 100%, 50%)" d="M88.39 87.569a66.5 66.5 0 00-1.226 1.236"/><path stroke="hsl(105, 100%, 50%)" d="M89.224 86.763a66.5 66.5 0 00-1.247 1.214"/><path stroke="hsl(106, 100%, 50%)" d="M90.073 85.971a66.5 66.5 0 00-1.268 1.193"/><path stroke="hsl(107, 100%, 50%)" d="M90.936 85.194a66.5 66.5 0 00-1.289 1.171"/><path stroke="hsl(108, 100%, 50%)" d="M91.812 84.433a66.5 66.5 0 00-1.31 1.148"/><path stroke="hsl(109, 100%, 50%)" d="M92.7 83.687a66.5 66.5 0 00-1.328 1.125"/><path stroke="hsl(110, 100%, 50%)" d="M93.603 82.957a66.5 66.5 0 00-1.348 1.101"/><path stroke="hsl(111, 100%, 50%)" d="M94.517 82.242a66.5 66.5 0 00-1.367 1.078"/><path stroke="hsl(112, 100%, 50%)" d="M95.444 81.544a66.5 66.5 0 00-1.385 1.053"/><path stroke="hsl(113, 100%, 50%)" d="M96.383 80.861a66.5 66.5 0 00-1.404 1.03"/><path stroke="hsl(114, 100%, 50%)" d="M97.334 80.196a66.5 66.5 0 00-1.422 1.004"/><path stroke="hsl(115, 100%, 50%)" d="M98.296 79.547a66.5 66.5 0 00-1.439.98"/><path stroke="hsl(116, 100%, 50%)" d="M99.27 78.914a66.5 66.5 0 00-1.456.955"/><path stroke="hsl(117, 100%, 50%)" d="M100.254 78.3a66.5 66.5 0 00-1.472.928"/><path stroke="hsl(118, 100%, 50%)" d="M101.249 77.702a66.5 66.5 0 00-1.489.903"/><path stroke="hsl(119, 100%, 50%)" d="M102.254 77.121a66.5 66.5 0 00-1.504.877"/><path stroke="hsl(120, 100%, 50%)" d="M103.269 76.559a66.5 66.5 0 00-1.519.85"/><path stroke="hsl(121, 100%, 50%)" d="M104.294 76.014a66.5 66.5 0 00-1.534.824"/><path stroke="hsl(122, 100%, 50%)" d="M105.328 75.487a66.5 66.5 0 00-1.548.797"/><path stroke="hsl(123, 100%, 50%)" d="M106.371 74.978a66.5 66.5 0 00-1.561.77"/><path stroke="hsl(124, 100%, 50%)" d="M107.423 74.488a66.5 66.5 0 00-1.575.742"/><path stroke="hsl(125, 100%, 50%)" d="M108.483 74.016a66.5 66.5 0 00-1.587.715"/><path stroke="hsl(126, 100%, 50%)" d="M109.552 73.562a66.5 66.5 0 00-1.6.687"/><path stroke="hsl(127, 100%, 50%)" d="M110.628 73.127a66.5 66.5 0 00-1.612.66"/><path stroke="hsl(128, 100%, 50%)" d="M111.711 72.711a66.5 66.5 0 00-1.622.631"/><path stroke="hsl(129, 100%, 50%)" d="M112.802 72.314a66.5 66.5 0 00-1.633.603"/><path stroke="hsl(130, 100%, 50%)" d="M113.9 71.936a66.5 66.5 0 00-1.644.574"/><path stroke="hsl(131, 100%, 50%)" d="M115.003 71.578a66.5 66.5 0 00-1.653.545"/><path stroke="hsl(132, 100%, 50%)" d="M116.113 71.238a66.5 66.5 0 00-1.663.517"/><path stroke="hsl(133, 100%, 50%)" d="M117.229 70.919a66.5 66.5 0 00-1.672.487"/><path stroke="hsl(134, 100%, 50%)" d="M118.35 70.618a66.5 66.5 0 00-1.68.458"/><path stroke="hsl(135, 100%, 50%)" d="M119.476 70.337a66.5 66.5 0 00-1.687.429"/><path stroke="hsl(136, 100%, 50%)" d="M120.607 70.076a66.5 66.5 0 00-1.695.4"/><path stroke="hsl(137, 100%, 50%)" d="M121.742 69.835a66.5 66.5 0 00-1.701.37"/><path stroke="hsl(138, 100%, 50%)" d="M122.881 69.614a66.5 66.5 0 00-1.707.34"/><path stroke="hsl(139, 100%, 50%)" d="M124.024 69.412a66.5 66.5 0 00-1.713.31"/><path stroke="hsl(140, 100%, 50%)" d="M125.17 69.23a66.5 66.5 0 00-1.718.28"/><path stroke="hsl(141, 100%, 50%)" d="M126.32 69.069a66.5 66.5 0 00-1.723.25"/><path stroke="hsl(142, 100%, 50%)" d="M127.472 68.927a66.5 66.5 0 00-1.727.22"/><path stroke="hsl(143, 100%, 50%)" d="M128.626 68.806a66.5 66.5 0 00-1.73.19"/><path stroke="hsl(144, 100%, 50%)" d="M129.782 68.705a66.5 66.5 0 00-1.733.16"/><path stroke="hsl(145, 100%, 50%)" d="M130.94 68.624a66.5 66.5 0 00-1.736.13"/><path stroke="hsl(146, 100%, 50%)" d="M132.1 68.563a66.5 66.5 0 00-1.739.099"/><path stroke="hsl(147, 100%, 50%)" d="M133.26 68.523a66.5 66.5 0 00-1.74.068"/><path stroke="hsl(148, 100%, 50%)" d="M134.42 68.503a66.5 66.5 0 00-1.74.038"/><path stroke="hsl(149, 100%, 50%)" d="M135.58 68.503a66.5 66.5 0 00-1.74.007"/><path stroke="hsl(150, 100%, 50%)" d="M136.74 68.523A66.5 66.5 0 00135 68.5"/><path stroke="hsl(151, 100%, 50%)" d="M137.9 68.563a66.5 66.5 0 00-1.74-.053"/><path stroke="hsl(152, 100%, 50%)" d="M139.06 68.624a66.5 66.5 0 00-1.74-.083"/><path stroke="hsl(153, 100%, 50%)" d="M140.218 68.705a66.5 66.5 0 00-1.738-.114"/><path stroke="hsl(154, 100%, 50%)" d="M141.374 68.806a66.5 66.5 0 00-1.735-.144"/><path stroke="hsl(155, 100%, 50%)" d="M142.528 68.927a66.5 66.5 0 00-1.732-.174"/><path stroke="hsl(156, 100%, 50%)" d="M143.68 69.069a66.5 66.5 0 00-1.729-.205"/><path stroke="hsl(157, 100%, 50%)" d="M144.83 69.23a66.5 66.5 0 00-1.726-.234"/><path stroke="hsl(158, 100%, 50%)" d="M145.976 69.412a66.5 66.5 0 00-1.721-.265"/><path stroke="hsl(159, 100%, 50%)" d="M147.119 69.614a66.5 66.5 0 00-1.716-.295"/><path stroke="hsl(160, 100%, 50%)" d="M148.258 69.835a66.5 66.5 0 00-1.71-.325"/><path stroke="hsl(161, 100%, 50%)" d="M149.393 70.076a66.5 66.5 0 00-1.704-.354"/><path stroke="hsl(162, 100%, 50%)" d="M150.524 70.337a66.5 66.5 0 00-1.698-.384"/><path stroke="hsl(163, 100%, 50%)" d="M151.65 70.618a66.5 66.5 0 00-1.69-.414"/><path stroke="hsl(164, 100%, 50%)" d="M152.771 70.919a66.5 66.5 0 00-1.683-.444"/><path stroke="hsl(165, 100%, 50%)" d="M153.887 71.238a66.5 66.5 0 00-1.676-.472"/><path stroke="hsl(166, 100%, 50%)" d="M154.997 71.578a66.5 66.5 0 00-1.667-.502"/><path stroke="hsl(167, 100%, 50%)" d="M156.1 71.936a66.5 66.5 0 00-1.657-.53"/><path stroke="hsl(168, 100%, 50%)" d="M157.198 72.314a66.5 66.5 0 00-1.648-.56"/><path stroke="hsl(169, 100%, 50%)" d="M158.289 72.711a66.5 66.5 0 00-1.639-.588"/><path stroke="hsl(170, 100%, 50%)" d="M159.372 73.127a66.5 66.5 0 00-1.628-.617"/><path stroke="hsl(171, 100%, 50%)" d="M160.448 73.562a66.5 66.5 0 00-1.617-.645"/><path stroke="hsl(172, 100%, 50%)" d="M161.517 74.016a66.5 66.5 0 00-1.606-.674"/><path stroke="hsl(173, 100%, 50%)" d="M162.577 74.488a66.5 66.5 0 00-1.593-.702"/><path stroke="hsl(174, 100%, 50%)" d="M163.629 74.978a66.5 66.5 0 00-1.581-.729"/><path stroke="hsl(175, 100%, 50%)" d="M164.672 75.487a66.5 66.5 0 00-1.568-.756"/><path stroke="hsl(176, 100%, 50%)" d="M165.706 76.014a66.5 66.5 0 00-1.554-.784"/><path stroke="hsl(177, 100%, 50%)" d="M166.731 76.559a66.5 66.5 0 00-1.54-.81"/><path stroke="hsl(178, 100%, 50%)" d="M167.746 77.121a66.5 66.5 0 00-1.526-.837"/><path stroke="hsl(179, 100%, 50%)" d="M168.751 77.702a66.5 66.5 0 00-1.511-.864"/><path stroke="hsl(180, 100%, 50%)" d="M169.746 78.3a66.5 66.5 0 00-1.496-.89"/><path stroke="hsl(181, 100%, 50%)" d="M170.73 78.914a66.5 66.5 0 00-1.48-.916"/><path stroke="hsl(182, 100%, 50%)" d="M171.704 79.547a66.5 66.5 0 00-1.464-.942"/><path stroke="hsl(183, 100%, 50%)" d="M172.666 80.196a66.5 66.5 0 00-1.448-.968"/><path stroke="hsl(184, 100%, 50%)" d="M173.617 80.861a66.5 66.5 0 00-1.43-.992"/><path stroke="hsl(185, 100%, 50%)" d="M174.556 81.544a66.5 66.5 0 00-1.413-1.018"/><path stroke="hsl(186, 100%, 50%)" d="M175.483 82.242a66.5 66.5 0 00-1.395-1.042"/><path stroke="hsl(187, 100%, 50%)" d="M176.397 82.957a66.5 66.5 0 00-1.376-1.066"/><path stroke="hsl(188, 100%, 50%)" d="M177.3 83.687a66.5 66.5 0 00-1.359-1.09"/><path stroke="hsl(189, 100%, 50%)" d="M178.188 84.433a66.5 66.5 0 00-1.338-1.113"/><path stroke="hsl(190, 100%, 50%)" d="M179.064 85.194a66.5 66.5 0 00-1.319-1.136"/><path stroke="hsl(191, 100%, 50%)" d="M179.927 85.971a66.5 66.5 0 00-1.3-1.16"/><path stroke="hsl(192, 100%, 50%)" d="M180.776 86.763a66.5 66.5 0 00-1.279-1.182"/><path stroke="hsl(193, 100%, 50%)" d="M181.61 87.569a66.5 66.5 0 00-1.257-1.204"/><path stroke="hsl(194, 100%, 50%)" d="M182.431 88.39a66.5 66.5 0 00-1.236-1.226"/><path stroke="hsl(195, 100%, 50%)" d="M183.237 89.224a66.5 66.5 0 00-1.214-1.247"/><path stroke="hsl(196, 100%, 50%)" d="M184.029 90.073a66.5 66.5 0 00-1.193-1.268"/><path stroke="hsl(197, 100%, 50%)" d="M184.806 90.936a66.5 66.5 0 00-1.171-1.289"/><path stroke="hsl(198, 100%, 50%)" d="M185.567 91.812a66.5 66.5 0 00-1.148-1.31"/><path stroke="hsl(199, 100%, 50%)" d="M186.313 92.7a66.5 66.5 0 00-1.125-1.328"/><path stroke="hsl(200, 100%, 50%)" d="M187.043 93.603a66.5 66.5 0 00-1.101-1.348"/><path stroke="hsl(201, 100%, 50%)" d="M187.758 94.517a66.5 66.5 0 00-1.078-1.367"/><path stroke="hsl(202, 100%, 50%)" d="M188.456 95.444a66.5 66.5 0 00-1.053-1.385"/><path stroke="hsl(203, 100%, 50%)" d="M189.139 96.383a66.5 66.5 0 00-1.03-1.404"/><path stroke="hsl(204, 100%, 50%)" d="M189.804 97.334a66.5 66.5 0 00-1.004-1.422"/><path stroke="hsl(205, 100%, 50%)" d="M190.453 98.296a66.5 66.5 0 00-.98-1.439"/><path stroke="hsl(206, 100%, 50%)" d="M191.086 99.27a66.5 66.5 0 00-.955-1.456"/><path stroke="hsl(207, 100%, 50%)" d="M191.7 100.254a66.5 66.5 0 00-.928-1.472"/><path stroke="hsl(208, 100%, 50%)" d="M192.298 101.249a66.5 66.5 0 00-.903-1.489"/><path stroke="hsl(209, 100%, 50%)" d="M192.879 102.254a66.5 66.5 0 00-.877-1.504"/><path stroke="hsl(210, 100%, 50%)" d="M193.441 103.269a66.5 66.5 0 00-.85-1.519"/><path stroke="hsl(211, 100%, 50%)" d="M193.986 104.294a66.5 66.5 0 00-.824-1.534"/><path stroke="hsl(212, 100%, 50%)" d="M194.513 105.328a66.5 66.5 0 00-.797-1.548"/><path stroke="hsl(213, 100%, 50%)" d="M195.022 106.371a66.5 66.5 0 00-.77-1.561"/><path stroke="hsl(214, 100%, 50%)" d="M195.512 107.423a66.5 66.5 0 00-.742-1.575"/><path stroke="hsl(215, 100%, 50%)" d="M195.984 108.483a66.5 66.5 0 00-.715-1.587"/><path stroke="hsl(216, 100%, 50%)" d="M196.438 109.552a66.5 66.5 0 00-.687-1.6"/><path stroke="hsl(217, 100%, 50%)" d="M196.873 110.628a66.5 66.5 0 00-.66-1.612"/><path stroke="hsl(218, 100%, 50%)" d="M197.289 111.711a66.5 66.5 0 00-.631-1.622"/><path stroke="hsl(219, 100%, 50%)" d="M197.686 112.802a66.5 66.5 0 00-.603-1.633"/><path stroke="hsl(220, 100%, 50%)" d="M198.064 113.9a66.5 66.5 0 00-.574-1.644"/><path stroke="hsl(221, 100%, 50%)" d="M198.422 115.003a66.5 66.5 0 00-.545-1.653"/><path stroke="hsl(222, 100%, 50%)" d="M198.762 116.113a66.5 66.5 0 00-.517-1.663"/><path stroke="hsl(223, 100%, 50%)" d="M199.081 117.229a66.5 66.5 0 00-.487-1.672"/><path stroke="hsl(224, 100%, 50%)" d="M199.382 118.35a66.5 66.5 0 00-.458-1.68"/><path stroke="hsl(225, 100%, 50%)" d="M199.663 119.476a66.5 66.5 0 00-.429-1.687"/><path stroke="hsl(226, 100%, 50%)" d="M199.924 120.607a66.5 66.5 0 00-.4-1.695"/><path stroke="hsl(227, 100%, 50%)" d="M200.165 121.742a66.5 66.5 0 00-.37-1.701"/><path stroke="hsl(228, 100%, 50%)" d="M200.386 122.881a66.5 66.5 0 00-.34-1.707"/><path stroke="hsl(229, 100%, 50%)" d="M200.588 124.024a66.5 66.5 0 00-.31-1.713"/><path stroke="hsl(230, 100%, 50%)" d="M200.77 125.17a66.5 66.5 0 00-.28-1.718"/><path stroke="hsl(231, 100%, 50%)" d="M200.931 126.32a66.5 66.5 0 00-.25-1.723"/><path stroke="hsl(232, 100%, 50%)" d="M201.073 127.472a66.5 66.5 0 00-.22-1.727"/><path stroke="hsl(233, 100%, 50%)" d="M201.194 128.626a66.5 66.5 0 00-.19-1.73"/><path stroke="hsl(234, 100%, 50%)" d="M201.295 129.782a66.5 66.5 0 00-.16-1.733"/><path stroke="hsl(235, 100%, 50%)" d="M201.376 130.94a66.5 66.5 0 00-.13-1.736"/><path stroke="hsl(236, 100%, 50%)" d="M201.437 132.1a66.5 66.5 0 00-.099-1.739"/><path stroke="hsl(237, 100%, 50%)" d="M201.477 133.26a66.5 66.5 0 00-.068-1.74"/><path stroke="hsl(238, 100%, 50%)" d="M201.497 134.42a66.5 66.5 0 00-.038-1.74"/><path stroke="hsl(239, 100%, 50%)" d="M201.497 135.58a66.5 66.5 0 00-.007-1.74"/></g><circle cx="135" cy="135" r="133" fill="url(#a)" class="IroWheelSaturation"/><circle cx="135" cy="135" r="133" fill="none" stroke="#fff" stroke-width="2" class="IroWheelBorder"/></svg>'; - - dialog.querySelector('.satus-scrollbar__content').appendChild(close); - dialog.querySelector('.satus-scrollbar__content').appendChild(component_canvas); - - document.body.appendChild(dialog); - }); - - component.appendChild(component_value); - - return component; -}; - - -/*-------------------------------------------------------------- -# DIALOG ---------------------------------------------------------------*/ - -satus.components.dialog = function(element) { - var component = document.createElement('div'), - component_scrim = document.createElement('div'), - component_surface = document.createElement('div'), - component_scrollbar = satus.components.scrollbar(component_surface), - options = element.options || {}; - - component_scrim.className = 'satus-dialog__scrim'; - component_surface.className = 'satus-dialog__surface'; - - for (var key in element) { - satus.render(element[key], component_scrollbar); - } - - function close() { - window.removeEventListener('keydown', keydown); - - component.classList.add('satus-dialog--closing'); - - if (typeof element.onclose === 'function') { - element.onclose(); - } - - setTimeout(function() { - component.remove(); - }, satus.getAnimationDuration(component_surface)); - } - - function keydown(event) { - if (event.keyCode === 27) { - event.preventDefault(); - close(); - } - - if (event.keyCode === 9) { - var elements = component_surface.querySelectorAll('button, input'), - focused = false; - - event.preventDefault(); - - for (var i = 0, l = elements.length; i < l; i++) { - if (elements[i] === document.activeElement && elements[i + 1]) { - elements[i + 1].focus(); - - focused = true; - - i = l; - } - } - - if (focused === false) { - elements[0].focus(); - } - } - } - - component_scrim.addEventListener('click', close); - window.addEventListener('keydown', keydown); - - component.appendChild(component_scrim); - component.appendChild(component_surface); - - // OPTIONS - - if (options.left) { - component_surface.style.left = options.left + 'px'; - } - - if (options.top) { - component_surface.style.top = options.top + 'px'; - } - - if (options.width) { - component_surface.style.width = options.width + 'px'; - } - - if (options.height) { - component_surface.style.height = options.height + 'px'; - } - - // END OPTIONS - - return component; -}; - - -/*-------------------------------------------------------------- -# FOLDER ---------------------------------------------------------------*/ - -satus.components.folder = function(object) { - var component = document.createElement('button'); - - component.object = object; - - component.classList.add('satus-button'); - - component.addEventListener('click', function() { - var parent = document.querySelector(component.object.parent) || document.querySelector('.satus-main'); - - if (!component.object.parent || !parent.classList.contains('satus-main')) { - while (!parent.classList.contains('satus-main')) { - parent = parent.parentNode; - } - } - - parent.open(this.object, object.onopen); - }); - - if (satus.isset(object.label)) { - var component_label = document.createElement('span'); - - component_label.className = 'satus-folder__label'; - component_label.innerText = satus.locale.getMessage(object.label); - - component.appendChild(component_label); - } - - return component; -}; - - -/*-------------------------------------------------------------- -# HEADER ---------------------------------------------------------------*/ - -satus.components.header = function(object) { - var component = document.createElement('header'); - - for (var key in object) { - satus.render(object[key], component); - } - - return component; -}; - - -/*-------------------------------------------------------------- -# LIST ---------------------------------------------------------------*/ - -satus.components.list = function(object) { - var ul = document.createElement('ul'); - - if (object.compact === true) { - ul.classList.add('satus-list'); - ul.classList.add('satus-list--compact'); - } - - for (var key in object) { - if (satus.isset(object[key].type)) { - var li = document.createElement('li'); - - if (object.sortable === true) { - function mousedown(event) { - if (event.button === 0) { - var self = this, - dragging = false, - clone = false, - current_index = Array.from(self.parentNode.children).indexOf(self), - bounding = this.getBoundingClientRect(), - first_x = event.clientX, - first_y = event.clientY, - offset_x = event.clientX - bounding.left, - offset_y = event.clientY - bounding.top; - - function mousemove(event) { - if (Math.abs(first_y - event.clientY) <= 5) { - return false; - } - - if (dragging === false) { - clone = self.cloneNode(true); - - satus.cloneNodeStyles(self, clone); - clone.style.position = 'fixed'; - clone.style.pointerEvents = 'none'; - clone.style.backgroundColor = '#fff'; - self.style.visibility = 'hidden'; - - document.body.appendChild(clone); - - dragging = true; - } - - var x = bounding.left, //event.clientX - offset_x - y = event.clientY - offset_y, - index = Math.floor(y / self.offsetHeight) - 1; - - clone.style.left = x + 'px'; - clone.style.top = y + 'px'; - - //return false; - - if (index !== current_index && self.parentNode.children[index]) { - var new_clone = self.cloneNode(true); - - if (index > 0) { - self.parentNode.insertBefore(new_clone, self.parentNode.children[index].nextSibling); - } else { - self.parentNode.insertBefore(new_clone, self.parentNode.children[index]); - } - - self.remove(); - - self = new_clone; - - self.addEventListener('mousedown', mousedown); - - if (typeof object.onchange === 'function') { - object.onchange(current_index, index); - } - - current_index = index; - } - } - - function mouseup(event) { - if (clone) { - clone.remove(); - self.style.visibility = ''; - } - - window.removeEventListener('mousemove', mousemove); - window.removeEventListener('mouseup', mouseup); - } - - window.addEventListener('mousemove', mousemove); - window.addEventListener('mouseup', mouseup); - } - } - - li.addEventListener('mousedown', mousedown); - } - - satus.render(object[key], li); - - ul.appendChild(li); - } - } - - return ul; -}; - - -/*-------------------------------------------------------------- -# MAIN ---------------------------------------------------------------*/ - -satus.components.main = function(object) { - var component = document.createElement('main'), - component_container = document.createElement('div'), - component_scrollbar = satus.components.scrollbar(component_container, object.scrollbar); - - component.history = [object]; - - component.back = function() { - var container = this.querySelector('.satus-main__container'), - component_container = document.createElement('div'), - component_scrollbar = satus.components.scrollbar(component_container); - - container.classList.add('satus-main__container--fade-out-right'); - component_container.className = 'satus-main__container satus-main__container--fade-in-left'; - - this.history.pop(); - - for (var key in this.history[this.history.length - 1]) { - satus.render(this.history[this.history.length - 1][key], component_scrollbar); - } - - this.appendChild(component_container); - - if (this.historyListener) { - this.historyListener(component_container); - } - - if (this.history[this.history.length - 1].onopen) { - component_scrollbar.onopen = this.history[this.history.length - 1].onopen; - - component_scrollbar.onopen(); - } - - setTimeout(function() { - container.remove(); - }, satus.getAnimationDuration(container)); - }; - - component.open = function(element, callback, animated) { - var container = this.querySelector('.satus-main__container'), - component_container = document.createElement('div'), - component_scrollbar = satus.components.scrollbar(component_container); - - if (animated !== false) { - container.classList.add('satus-main__container--fade-out-left'); - component_container.className = 'satus-main__container satus-main__container--fade-in-right'; - } else { - component_container.className = 'satus-main__container'; - } - - this.history.push(element); - - for (var key in this.history[this.history.length - 1]) { - satus.render(this.history[this.history.length - 1][key], component_scrollbar); - } - - this.appendChild(component_container); - - if (this.historyListener) { - this.historyListener(component_container); - } - - if (callback) { - component_scrollbar.onopen = callback; - - component_scrollbar.onopen(); - } - - setTimeout(function() { - container.remove(); - }, satus.getAnimationDuration(container)); - }; - - component_container.className = 'satus-main__container'; - - if (object.on && object.on.change) { - component.historyListener = object.on.change; - } - - if (component.historyListener) { - component.historyListener(component_container); - } - - for (var key in object) { - satus.render(object[key], component_scrollbar); - } - - component.appendChild(component_container); - - return component; -}; - - -/*-------------------------------------------------------------- -# SCROLL BAR ---------------------------------------------------------------*/ - -satus.components.scrollbar = function(parent, enabled) { - if (enabled === false) { - return parent; - } - - var component = document.createElement('div'), - component_wrapper = document.createElement('div'), - component_content = document.createElement('div'), - component_thumb = document.createElement('div'); - - component.className = 'satus-scrollbar'; - component_wrapper.className = 'satus-scrollbar__wrapper'; - component_content.className = 'satus-scrollbar__content'; - component_thumb.className = 'satus-scrollbar__thumb'; - - - // RESIZE - - function resize() { - component_content.style.width = component.offsetWidth + 'px'; - component_wrapper.style.height = component.offsetHeight + 'px'; - - if (component_wrapper.scrollHeight > component_wrapper.offsetHeight) { - component_thumb.style.height = component_wrapper.offsetHeight / component_wrapper.scrollHeight * component_wrapper.offsetHeight + 'px'; - } - } - - window.addEventListener('resize', resize); - - new MutationObserver(resize).observe(component_content, { - subtree: true, - childList: true - }); - - - // HOVER - - component.timeout = false; - - function active() { - if (component.timeout) { - clearTimeout(component.timeout); - - component.timeout = false; - } - - component.classList.add('active'); - - component.timeout = setTimeout(function() { - component.classList.remove('active'); - - component.timeout = false; - }, 1000); - } - - component.addEventListener('mousemove', active); - - - // SCROLL - - component_wrapper.addEventListener('scroll', function(event) { - active(); - - component_thumb.style.top = Math.floor(component_wrapper.scrollTop * (component_wrapper.offsetHeight - component_thumb.offsetHeight) / (component_wrapper.scrollHeight - component_wrapper.offsetHeight)) + 'px'; - }); - - component_thumb.addEventListener('mousedown', function(event) { - var offsetY = event.layerY; - - if (event.button !== 0) { - return false; - } - - function mousemove(event) { - var offset = 100 / ((component.offsetHeight - component_thumb.offsetHeight) / (event.clientY - offsetY - component.getBoundingClientRect().top)), - scroll = component_wrapper.scrollHeight - component.offsetHeight; - - component_wrapper.scrollTop = scroll / 100 * offset; - - event.preventDefault(); - - return false; - } - - function mouseup() { - window.removeEventListener('mouseup', mouseup); - window.removeEventListener('mousemove', mousemove); - } - - window.addEventListener('mouseup', mouseup); - window.addEventListener('mousemove', mousemove); - }); - - component_wrapper.appendChild(component_content); - component.appendChild(component_wrapper); - component.appendChild(component_thumb); - - parent.appendChild(component); - - return component_content; -}; - - -/*-------------------------------------------------------------- -# SECTION ---------------------------------------------------------------*/ - -satus.components.section = function(element) { - var component = document.createElement('section'); - - for (var key in element) { - satus.render(element[key], component); - } - - return component; -}; - - -/*-------------------------------------------------------------- -# SELECT ---------------------------------------------------------------*/ - -satus.components.select = function(element) { - var component = document.createElement('button'), - component_label = document.createElement('span'), - component_value = document.createElement('span'), - label = satus.locale.getMessage(element.label); - - component.classList.add('satus-button'); - - component_label.className = 'satus-select__label'; - component_label.innerText = label; - - component_value.className = 'satus-select__value'; - - if (element.storage_key) { - var value = satus.storage.get(element.storage_key); - - component.dataset.storageKey = element.storage_key; - - for (var i = 0, l = element.options.length; i < l; i++) { - if (value === element.options[i].value) { - value = element.options[i].label; - } - } - - component_value.innerText = satus.locale.getMessage(value || element.options[0].label); - } - - component.onclick = function() { - var position = this.getBoundingClientRect(), - dialog = { - type: 'dialog', - class: 'satus-dialog--select-component' - }; - - for (var key in element.options) { - dialog[key] = element.options[key]; - - dialog[key].type = 'button'; - dialog[key].dataset = {}; - dialog[key].dataset.key = element.options[key].label; - dialog[key].dataset.value = element.options[key].value; - dialog[key].onclick = function() { - component_value.innerText = satus.locale.getMessage(this.dataset.key); - - satus.storage.set(component.dataset.storageKey, this.dataset.value); - - var parent = this.parentNode; - - while (!parent.classList.contains('satus-dialog')) { - parent = parent.parentNode; - } - - parent.querySelector('.satus-dialog__scrim').click(); - }; - } - - satus.render(dialog); - }; - - component.appendChild(component_label); - component.appendChild(component_value); - - return component; -}; - - -/*--------------------------------------------------------------- -# SHORTCUT ----------------------------------------------------------------*/ - -satus.components.shortcut = function(element) { - var self = this, - value = (satus.storage.get(element.storage_key) ? JSON.parse(satus.storage.get(element.storage_key)) : false) || element.value || {}, - component = document.createElement('div'), - component_label = document.createElement('span'), - component_value = document.createElement('span'), - mousewheel_timeout = false, - mousewheel_only = false; - - component_label.className = 'satus-shortcut__label'; - component_value.className = 'satus-shortcut__value'; - - function update(canvas) { - let text_value = [], - keys_value = []; - - if (value.altKey === true) { - text_value.push('Alt'); - keys_value.push('
Alt
'); - } - - if (value.ctrlKey === true) { - text_value.push('Ctrl'); - keys_value.push('
Ctrl
'); - } - - if (value.shiftKey === true) { - text_value.push('Shift'); - keys_value.push('
Shift
'); - } - - if (value.key === ' ') { - text_value.push('Space bar'); - keys_value.push('
Space bar
'); - - } else if (typeof value.key === 'string' && ['Shift', 'Control', 'Alt'].indexOf(value.key) === -1) { - if (value.key === 'ArrowUp') { - text_value.push('↑'); - keys_value.push('
'); - } else if (value.key === 'ArrowRight') { - text_value.push('→'); - keys_value.push('
'); - } else if (value.key === 'ArrowDown') { - text_value.push('↓'); - keys_value.push('
'); - } else if (value.key === 'ArrowLeft') { - text_value.push('←'); - keys_value.push('
'); - } else { - let key = value.key.toUpperCase(); - - text_value.push(key); - keys_value.push('
' + key + '
'); - } - } - - if (value.wheel) { - keys_value.push('
'); - } - - component_value.innerText = text_value.join('+'); - - if (canvas) { - if (keys_value.length > 0) { - canvas.innerHTML = keys_value.join('
'); - } else { - canvas.innerText = satus.locale.getMessage('pressAnyKeyOrUseMouseWheel'); - } - } - } - - update(); - - component_value.dataset.value = component_value.innerText; - - component_label.innerText = satus.locale.getMessage(element.label); - - component.addEventListener('click', function() { - let component_dialog = document.createElement('div'), - component_dialog_label = document.createElement('span'), - component_scrim = document.createElement('div'), - component_surface = document.createElement('div'), - component_canvas = document.createElement('div'), - component_section = document.createElement('section'), - component_button_reset = document.createElement('div'), - component_button_cancel = document.createElement('div'), - component_button_save = document.createElement('div'); - - component_dialog.className = 'satus-dialog satus-dialog_open'; - component_dialog_label.className = 'satus-shortcut-dialog-label'; - component_scrim.className = 'satus-dialog__scrim'; - component_surface.className = 'satus-dialog__surface satus-dialog__surface_shortcut'; - component_canvas.className = 'satus-shortcut__canvas'; - component_section.className = 'satus-section satus-section--align-end satus-section_shortcut'; - component_button_reset.className = 'satus-button satus-button_shortcut'; - component_button_cancel.className = 'satus-button satus-button_shortcut'; - component_button_save.className = 'satus-button satus-button_shortcut'; - - component_dialog_label.innerText = component_label.innerText; - component_button_reset.innerText = satus.locale.getMessage('reset'); - component_button_cancel.innerText = satus.locale.getMessage('cancel'); - component_button_save.innerText = satus.locale.getMessage('save'); - - update(component_canvas); - - function keydown(event) { - event.preventDefault(); - event.stopPropagation(); - - mousewheel_only = false; - clearTimeout(mousewheel_timeout); - - value = { - key: event.key, - keyCode: event.keyCode, - shiftKey: event.shiftKey, - ctrlKey: event.ctrlKey, - altKey: event.altKey - }; - - update(component_canvas); - - return false; - } - - function mousewheel(event) { - event.stopPropagation(); - - if (mousewheel_only === true) { - delete value.shiftKey; - delete value.altKey; - delete value.ctrlKey; - delete value.keyCode; - delete value.key; - } - - clearTimeout(mousewheel_timeout); - - mousewheel_timeout = setTimeout(function() { - mousewheel_only = true; - }, 300); - - value.wheel = event.deltaY; - - update(component_canvas); - - return false; - } - - window.addEventListener('keydown', keydown); - window.addEventListener('mousewheel', mousewheel); - - function close(clear = true) { - window.removeEventListener('keydown', keydown); - window.removeEventListener('mousewheel', mousewheel); - - if (clear === true) { - component_value.innerText = component_value.dataset.value; - } - - component_dialog.classList.remove('satus-dialog_open'); - - setTimeout(function() { - component_dialog.remove(); - }, Number(document.defaultView.getComputedStyle(component_dialog, '').getPropertyValue('animation-duration').replace(/[^0-9.]/g, '') * 1000)); - } - - component_scrim.addEventListener('click', close); - component_button_reset.addEventListener('click', function() { - satus.storage.set(element.storage_key, null); - close(); - value = (satus.storage.get(element.storage_key) ? JSON.parse(satus.storage.get(element.storage_key)) : false) || element.value || {}; - update(); - }); - component_button_cancel.addEventListener('click', close); - component_button_save.addEventListener('click', function() { - satus.storage.set(element.storage_key, JSON.stringify(value)); - close(false); - }); - - component_section.appendChild(component_button_reset); - component_section.appendChild(component_button_cancel); - component_section.appendChild(component_button_save); - - component_surface.appendChild(component_dialog_label); - component_surface.appendChild(component_canvas); - component_surface.appendChild(component_section); - - component_dialog.appendChild(component_scrim); - component_dialog.appendChild(component_surface); - - document.body.appendChild(component_dialog); - }); - - component.appendChild(component_label); - component.appendChild(component_value); - - return component; -}; - - -/*-------------------------------------------------------------- -# SLIDER ---------------------------------------------------------------*/ - -satus.components.slider = function(element) { - var component = document.createElement('div'); - - // LABEL - if (satus.isset(element.label)) { - var component_label = document.createElement('span'); - - component_label.className = 'satus-slider__label'; - component_label.innerText = satus.locale.getMessage(element.label); - - component.appendChild(component_label); - } - - - // RANGE - var component_range = document.createElement('input'); - - component_range.type = 'range'; - component_range.className = 'satus-slider__range'; - component_range.min = element.min || 0; - component_range.max = element.max || 10; - component_range.step = element.step || 1; - - component_range.oninput = function() { - var track = this.parentNode.querySelector('.satus-slider__track'), - thumb = this.parentNode.querySelector('.satus-slider__thumb'), - min = Number(this.min) || 0, - max = Number(this.max) || 1, - step = Number(this.step) || 1, - value = Number(this.value) || 0, - offset = (value - min) / (max - min) * 100; - - track.style.width = 'calc(' + offset + '% - ' + Math.floor(offset * 12 / 100) + 'px)'; - - satus.storage.set(this.dataset.storageKey, Number(this.value)); - - component_thumb.dataset.value = this.value; - - if (component.onchange) { - component.onchange(Number(this.value)); - } - }; - - component.change = function(value) { - component_range.value = value; - - component_thumb.dataset.value = value; - - component_range.oninput(); - }; - - component.addEventListener('mousedown', function() { - function mousemove() { - component.classList.add('satus-slider--dragging'); - } - - function mouseup() { - component.classList.remove('satus-slider--dragging'); - - window.removeEventListener('mousemove', mousemove); - window.removeEventListener('mouseup', mouseup); - } - - window.addEventListener('mousemove', mousemove); - window.addEventListener('mouseup', mouseup); - }); - - if (element.onchange) { - component.onchange = element.onchange; - } - - component.appendChild(component_range); - - - // CONTAINER - var component_container = document.createElement('div'); - - component_container.className = 'satus-slider__container'; - - component.appendChild(component_container); - - - // TRACK - var component_track_container = document.createElement('div'), - component_track = document.createElement('div'); - - component_track_container.className = 'satus-slider__track-container'; - component_track.className = 'satus-slider__track'; - - component_track_container.appendChild(component_track); - component_container.appendChild(component_track_container); - - - // FOCUS RING - var component_ring = document.createElement('div'); - - component_ring.className = 'satus-slider__ring'; - - component_track.appendChild(component_ring); - - - // THUMB - var component_thumb = document.createElement('div'); - - component_thumb.className = 'satus-slider__thumb'; - - component_track.appendChild(component_thumb); - - if (element.storage_key) { - var value = satus.storage.get(element.storage_key) || element.value; - - component_range.dataset.storageKey = element.storage_key; - - if (value) { - component_range.value = value; - - if (!satus.isset(value)) { - value = element.value; - } - - var offset = (Number(component_range.value) - Number(component_range.min)) / (Number(component_range.max) - Number(component_range.min)) * 100; - - component_track.style.width = 'calc(' + offset + '% - ' + Math.floor(offset * 12 / 100) + 'px)'; - component_thumb.dataset.value = value; - } else { - component_range.value = 0; - component_thumb.dataset.value = 0; - } - } - - - return component; -}; - - -/*-------------------------------------------------------------- -# SWITCH ---------------------------------------------------------------*/ - -satus.components.switch = function(element) { - var component = document.createElement('div'), - value; - - // LABEL - if (satus.isset(element.label)) { - var component_label = document.createElement('span'); - - component_label.className = 'satus-switch__label'; - component_label.innerText = satus.locale.getMessage(element.label); - - component.appendChild(component_label); - } - - - // INPUT - var component_input = document.createElement('input'); - - component_input.type = 'checkbox'; - component_input.className = 'satus-switch__input'; - - if (element.storage_key) { - value = satus.storage.get(element.storage_key); - - component_input.dataset.storageKey = element.storage_key; - } - - if (!satus.isset(value)) { - value = element.value; - } - - if (value) { - component_input.checked = value; - } - - component_input.addEventListener('change', function() { - satus.storage.set(this.dataset.storageKey, this.checked); - }); - - component.appendChild(component_input); - - - // TRACK - var component_track = document.createElement('div'); - - component_track.className = 'satus-switch__track'; - - component.appendChild(component_track); - - - // MOUSE MOVE - component_track.addEventListener('mousedown', function(event) { - var prevent = false, - difference = 0; - - function click(event) { - event.preventDefault(); - event.stopPropagation(); - - component.removeEventListener('click', click); - - return false; - } - - function mousemove(event) { - var checkbox = component.querySelector('input'), - movement = event.movementX; - - if (movement * difference < 0) { - difference = 0; - } else { - difference += movement; - - if (prevent === false) { - prevent = true; - component.addEventListener('click', click); - } - } - - if (difference < -5) { - checkbox.checked = false; - } else if (difference > 5) { - checkbox.checked = true; - } - } - - function mouseup(event) { - window.removeEventListener('mousemove', mousemove); - window.removeEventListener('mouseup', mouseup); - } - - window.addEventListener('mousemove', mousemove); - window.addEventListener('mouseup', mouseup); - }); - - - // TOUCH MOVE - component_track.addEventListener('touchstart', function(event) { - var previous_x = 0, - difference = 0; - - function mousemove(event) { - var checkbox = component.querySelector('input'), - movement = event.touches[0].clientX - previous_x; - - previous_x = event.touches[0].clientX; - - if (movement * difference < 0) { - difference = 0; - } else { - difference += movement; - } - - if (difference < -5) { - checkbox.checked = false; - } else if (difference > 5) { - checkbox.checked = true; - } - } - - function mouseup(event) { - window.removeEventListener('touchmove', mousemove); - window.removeEventListener('touchend', mouseup); - } - - window.addEventListener('touchmove', mousemove); - window.addEventListener('touchend', mouseup); - }); - - - return component; -}; -satus.components.table = function(item) { - var component = document.createElement('div'), - component_head = document.createElement('div'), - component_body = document.createElement('div'), - component_scrollbar = satus.components.scrollbar(component_body, item.scrollbar), - table = document.createElement('div'); - - table.className = 'satus-table__container'; - component_head.className = 'satus-table__head'; - component_body.className = 'satus-table__body'; - - function update(data) { - var pages = Math.ceil(component.data.length / component.paging), - start = Math.max((component.pagingIndex - 1) * component.paging, 0), - end = component.pagingIndex * component.paging; - - if (end > data.length) { - end = data.length; - } else if (end === 0) { - end = component.paging; - } - - table.innerHTML = ''; - - if (data) { - for (var i = start, l = end; i < l; i++) { - if (data[i]) { - var tr = document.createElement('div'); - - tr.className = 'satus-table__row'; - - for (var j = 0, k = data[i].length; j < k; j++) { - var td = document.createElement('div'); - - - td.className = 'satus-table__cell'; - - if (data[i][j].html) { - td.innerHTML = data[i][j].html; - } else if (data[i][j].text) { - td.innerText = data[i][j].text; - } - - if (data[i][j].onrender) { - td.onrender = data[i][j].onrender; - - td.onrender(); - } - - tr.appendChild(td); - } - - table.appendChild(tr); - } - } - } - - component.pagingUpdate(); - } - - function sortArray(array, index, mode) { - if (mode === 'asc') { - if (typeof array[0][index].text === 'number') { - sorted = array.sort(function(a, b) { - return a[index].text - b[index].text; - }); - } else { - sorted = array.sort(function(a, b) { - return a[index].text.localeCompare(b[index].text); - }); - } - } else { - if (typeof array[0][index].text === 'number') { - sorted = array.sort(function(a, b) { - return b[index].text - a[index].text; - }); - } else { - sorted = array.sort(function(a, b) { - return b[index].text.localeCompare(a[index].text); - }); - } - } - - return array; - } - - function sort() { - var mode = this.dataset.sorting, - index = Array.prototype.indexOf.call(this.parentElement.children, this), - sorted; - - if (component.data[0][index] && component.data[0][index].hasOwnProperty('text')) { - if (mode === 'none') { - mode = 'asc'; - } else if (mode === 'asc') { - mode = 'desc'; - } else if (mode === 'desc') { - mode = 'asc'; - } - - if (this.parentNode.querySelector('div[data-sorting=asc], div[data-sorting=desc]')) { - this.parentNode.querySelector('div[data-sorting=asc], div[data-sorting=desc]').dataset.sorting = 'none'; - } - - this.dataset.sorting = mode; - - sorted = sortArray(component.data, index, mode); - - update(sorted); - } else { - this.dataset.sorting = false; - } - } - - function resize() {} - - for (var i = 0, l = item.columns.length; i < l; i++) { - var column = document.createElement('div'); - - column.dataset.sorting = 'none'; - column.addEventListener('click', sort); - column.innerHTML = '' + item.columns[i].title + ''; - - component_head.appendChild(column); - } - - component_scrollbar.appendChild(table); - - component.appendChild(component_head); - component.appendChild(component_body); - - component.data = item.data; - component.paging = item.paging; - component.pagingIndex = 0; - - component.update = function(data, index, mode) { - if (satus.isset(data)) { - this.data = data; - } - - if (this.querySelector('div[data-sorting=asc], div[data-sorting=desc]')) { - var mode = this.querySelector('div[data-sorting=asc], div[data-sorting=desc]').dataset.sorting, - index = Array.prototype.indexOf.call(this.querySelector('div[data-sorting=asc], div[data-sorting=desc]').parentElement.children, this.querySelector('div[data-sorting=asc], div[data-sorting=desc]')); - - update(sortArray(this.data, index, mode)); - } else { - for (var i = 0, l = item.columns.length; i < l; i++) { - if (item.columns[i].hasOwnProperty('sorting')) { - if (this.data[0][i].hasOwnProperty('text')) { - this.querySelectorAll('.satus-table__head > div')[i].dataset.sorting = item.columns[i].sorting; - } else { - this.querySelectorAll('.satus-table__head > div')[i].dataset.sorting = false; - } - - update(sortArray(this.data, i, item.columns[i].sorting)); - - i = l; - } - } - } - }; - - - // PAGING - - function pagingUpdate() { - if (typeof this.paging === 'number') { - var pages = Math.ceil(this.data.length / this.paging); - - this.querySelector('.satus-table__paging').innerHTML = ''; - - for (var i = 1; i <= pages; i++) { - var button = document.createElement('button'); - - if (i === (this.pagingIndex || 1)) { - button.className = 'active'; - } - - button.innerText = i; - button.parentComponent = this; - button.addEventListener('click', function() { - if (this.parentNode.querySelector('button.active')) { - this.parentNode.querySelector('button.active').classList.remove('active'); - } - - this.classList.add('active'); - - this.parentComponent.pagingIndex = Number(this.innerText); - this.parentComponent.update(this.parentComponent.data); - }); - - this.querySelector('.satus-table__paging').appendChild(button); - } - } - - resize(); - } - - component.pagingUpdate = pagingUpdate; - - component_paging = document.createElement('div'); - - component_paging.className = 'satus-table__paging'; - - component_scrollbar.appendChild(component_paging); - - // END PAGING - - if (item.data) { - component.update(item.data); - } - - return component; -}; - - -/*-------------------------------------------------------------- -# TEXT ---------------------------------------------------------------*/ - -satus.components.text = function(element) { - var component = document.createElement('span'); - - if (satus.isset(element.label)) { - var component_label = document.createElement('span'); - - component_label.className = 'satus-text__label'; - component_label.innerText = satus.locale.getMessage(element.label); - - component.appendChild(component_label); - } - - if (satus.isset(element.value)) { - var component_value = document.createElement('span'); - - component_value.className = 'satus-text__value'; - component_value.innerText = satus.locale.getMessage(element.value); - - component.appendChild(component_value); - } - - return component; -}; - - -/*-------------------------------------------------------------- -# TEXT FIELD ---------------------------------------------------------------*/ - -satus.components.textField = function(element) { - var component = element.rows > 1 ? document.createElement('textarea') : document.createElement('input'); - - component.type = 'text'; - - return component; -}; \ No newline at end of file