9 // THIS IS THE KIT KERNEL AND KIT WINDOW SYSTEM
10 // http://web.kitit.ml/
11 // https://github.com/mtsgi/kit
14 $( document ).ready( kit );
19 if( !localStorage.getItem( "kit-pid" ) ) processID = 0;
20 else processID = localStorage.getItem( "kit-pid" );
22 if( !localStorage.getItem( "kit-username" ) ) localStorage.setItem( "kit-username", "ユーザー" );
23 $( "#kit-header-username" ).text( localStorage.getItem( "kit-username" ) );
25 if( localStorage.getItem( "kit-lock" ) == null ) localStorage.setItem( "kit-lock", "false" );
27 if( System.bootopt.get("safe") ) $( "#kit-wallpaper" ).css( "background","#404040" );
28 else if( localStorage.getItem( "kit-wallpaper" ) ) $( "#kit-wallpaper" ).css( "background", localStorage.getItem( "kit-wallpaper" ) ).css( "background-size", "cover" ).css( "background-position", "center" );
30 if( !localStorage.getItem( "kit-default-browser" ) ) localStorage.setItem( "kit-default-browser", "browser" );
32 if( localStorage.getItem("kit-fusen") ){
33 this.list = JSON.parse(localStorage.getItem("kit-fusen"));
34 for( let i in this.list ){
35 KWS.fusen.add(this.list[i]);
39 if( localStorage.getItem("kit-darkmode") == "true" ){
41 $("#kit-darkmode").attr("href", "system/theme/kit-darkmode.css");
42 $(".winc-darkmode").addClass("kit-darkmode");
45 if( System.bootopt.get("safe") ){
46 $("#kit-theme-file").attr("href", "./system/theme/theme-light.css" );
49 if( !localStorage.getItem( "kit-theme" ) ) localStorage.setItem( "kit-theme", "theme-default.css" );
50 $("#kit-theme-file").attr("href", "./system/theme/" + localStorage.getItem("kit-theme") );
53 if( !localStorage.getItem( "kit-appdir" ) ) localStorage.setItem( "kit-appdir", "./app/" );
54 S.appdir = localStorage.getItem( "kit-appdir" );
56 if( localStorage.getItem( "kit-installed" ) ) System.installed = JSON.parse( localStorage.getItem( "kit-installed" ) );
58 if( localStorage["kit-userarea"] ) System.userarea = JSON.parse(localStorage["kit-userarea"]);
59 if( localStorage["kit-recycle"] ) System.recycle = JSON.parse(localStorage["kit-recycle"]);
61 System.moveDesktop( "1" );
64 if( System.bootopt.get("safe") ) clockmove = setInterval( System.clock, 1000 );
65 else clockmove = setInterval( System.clock, 10 );
67 Notification.push( "kitへようこそ", localStorage["kit-username"] + "さん、こんにちは。", "system" );
69 if( localStorage.getItem( "kit-startup" ) == undefined ) {
70 localStorage.setItem( "kit-startup", new Array( "welcome" ) );
72 System.startup = localStorage.getItem( "kit-startup" ).split( "," );
73 if( System.bootopt.get("safe") ){
74 Notification.push( "セーフブート", "現在、kitをセーフモードで起動しています。", "system" );
75 System.alert( "セーフブート", "現在、kitをセーフモードで起動しています。<br><a class='kit-hyperlink' onclick='System.reboot()'>通常モードで再起動</a>", "system" );
77 else for( let i of System.startup ) if( i != "" ) launch( i );
79 $("#kit-header-fullscreen").hide();
82 $( "#desktops" ).click( function() {
83 $( "#desktop-" + currentDesktop ).toggleClass( "selected-section" );
84 } ).mousedown( function() {
85 $( ".window" ).css( "opacity", "0.6" );
86 } ).mouseup( function() {
87 $( ".window" ).css( "opacity", "1.0" );
90 $( "#footer-tasks" ).click( function() {
91 if( $( "#kit-tasks" ).is( ":visible" ) ) {
92 $( "#kit-tasks" ).html( "" ).fadeOut( 300 );
95 $( "#task-ctx" ).fadeOut( 200 );
96 $( "#kit-tasks" ).html( $( "#tasks" ).html() ).fadeIn( 300 ).css( "z-index", "9997" );
100 $.getJSON("config/desktop.json", (data) => {
101 for( let i in data ){
102 $(".desktop-icons").append("<div class='desktop-icon' data-launch='" + i + "'><img src='" + data[i].icon + "'>" + data[i].name + "</div>");
104 $(".desktop-icon").on("click", function(){
105 launch( $(this).attr("data-launch") );
107 }).fail( function() {
108 Notification.push( "読み込みに失敗", "デスクトップ(config/desktop.json)の読み込みに失敗しました。", system );
111 $.getJSON("config/apps.json", System.initLauncher).fail( function() {
112 Notification.push( "ランチャー初期化失敗", "アプリケーション一覧(config/apps.json)の読み込みに失敗しました。", system );
114 $( "#kit-tasks" ).delegate( ".task", "click", function() {
115 System.close( this.id.slice( 1 ) );
119 $( "#footer-noti" ).click( function() {
120 $( "#last-notification" ).hide( "drop", {direction: "right"}, 300 );
121 if( $( "#notifications" ).is( ":visible" ) ) {
122 $( "#notifications" ).hide( "drop", {direction: "right"}, 300 );
125 $( "#notifications" ).show( "drop", {direction: "right"}, 300 );
128 $( "#last-notification-close" ).click( function() {
129 $( "#last-notification" ).hide( "drop", {direction: "right"}, 300 );
131 $("#notifications-dnp").prop("checked", false).on("change", ()=>{
132 if( $("#notifications-dnp").is(":checked") ){
133 Notification.goodnight = true;
135 else Notification.goodnight = false;
138 $( ".power-button" ).click( function() {
139 $( "#notifications" ).hide( "drop", {direction: "right"}, 300 );
140 $( "#last-notification" ).hide( "drop", {direction: "right"}, 300 );
141 $( "#kit-wallpaper" ).css( "filter", "blur(5px)" );
142 $( "footer, header, #desktop-" + currentDesktop ).hide();
143 $( "#kit-power" ).show();
145 $( "#kit-power-back" ).click( function() {
146 $( "section, header, footer, #kit-wallpaper, .dropdown" ).css( "filter", "none" );
147 $( "footer, header, #desktop-" + currentDesktop ).show();
148 $( "#kit-power" ).hide();
150 $( "#kit-power-shutdown" ).click( function() {
153 $( "#kit-power-reboot" ).click( function() {
156 $( "#kit-power-suspend" ).click( function() {
157 $( "section, header, footer, #kit-wallpaper" ).css( "filter", "none" );
158 $( "#kit-power" ).fadeOut( 300 );
159 System.alert("サスペンド機能", "サスペンド機能はこのバージョンのkitではサポートされていません。");
161 $( "#kit-power-lock" ).click( function() {
164 $( "#lock-password" ).keypress( function( e ) {
165 if( e.which == 13 ) $( "#lock-unl" ).click();
167 $( "#lock-unl" ).click( function() {
168 if( !localStorage.getItem( "kit-password" ) || $( "#lock-password" ).val() == localStorage.getItem( "kit-password" ) ) {
169 $( "header, footer" ).show();
170 $( "section, header, footer, #kit-wallpaper" ).css( "filter", "none" );
171 $( "#lock-password" ).val( "" );
172 System.moveDesktop(1);
174 else $( "#lock-password" ).effect( "bounce", {distance: 12, times: 4}, 500 );
175 } ).hover( function() {
176 $( "#lock-unl span" ).removeClass( "fa-lock" ).addClass( "fa-lock-open" );
178 $( "#lock-unl span" ).removeClass( "fa-lock-open" ).addClass( "fa-lock" );
181 $( "#launch" ).click( function() {
182 $( "#notifications" ).hide( "drop", {direction: "right"}, 300 );
183 if( $( "#launcher" ).is( ":visible" ) ) {
184 $( "#kit-wallpaper" ).css( "filter", "none" );
185 $( "#desktop-" + currentDesktop ).show();
186 $( "#launcher" ).hide();
189 $( "#kit-wallpaper" ).css( "filter", "blur(5px)" )
190 $( "section" ).hide();
191 $( "#launcher" ).show();
196 $( "#milp" ).val( "" ).on( "focus", function() {
197 $( "#kit-milp" ).show();
198 } ).on( "blur", function() {
199 $( "#kit-milp" ).fadeOut( 200 );
200 } ).on( 'keydown keyup keypress change', function() {
201 $( "#kit-milp-text" ).text( $( this ).val() );
202 } ).keypress( function( e ) {
203 if( e.which == 13 ) $( "#kit-milp-launch" ).click();
205 $( "#kit-milp-launch" ).click( function() {
206 if( $("#milp").val() == "kit" ){
207 System.alert("", "<div style='text-align:left;'> _ _ _ <br>| | _(_) |_ <br>| |/ / | __|<br>| 〈| | |_ <br>|_|\_ \ _\__|</div><hr>", S.version);
210 let _app = $( "#milp" ).val().split(",")[0];
213 if( $( "#milp" ).val().split(",")[1] ){
214 _args = JSON.parse( $( "#milp" ).val().split(",").slice(1).join() );
218 Notification.push("引数の解釈に失敗", error, "system");
220 launch( _app, _args );
222 $( "#kit-milp-search" ).click( function() {
223 launch( "browser", { "url" : "https://www.bing.com/search?q=" + $( "#milp" ).val() } );
225 $( "#kit-milp-wikipedia" ).click( function() {
226 launch( "browser", { "url" : "https://ja.wikipedia.org/wiki/" + $( "#milp" ).val() } );
230 $("#dropdown-sound-slider").slider({
231 min: 0, max: 100, step: 1, value: 100,
233 System.audio.level = ui.value;
234 $("#dropdown-sound-level").text(ui.value);
235 localStorage.setItem("kit-audio-level", ui.value);
236 for( let i in System.audio.list ){
237 System.audio.list[i].volume = System.audio.level / 100;
239 if( ui.value == 0 ) $("#kit-header-sound-icon").removeClass("fa-volume-up").addClass("fa-volume-mute");
240 else $("#kit-header-sound-icon").removeClass("fa-volume-mute").addClass("fa-volume-up");
243 if( localStorage["kit-audio-level"] ) System.audio.volume( localStorage["kit-audio-level"] );
245 $("#dropdown-sound-silent").prop("checked", false).on("change", ()=>{
246 if( $("#dropdown-sound-silent").is(":checked") ){
247 System.audio.silent = true;
248 $("#kit-header-sound-icon").removeClass("fa-volume-up").addClass("fa-volume-mute");
251 System.audio.silent = false;
252 $("#kit-header-sound-icon").removeClass("fa-volume-mute").addClass("fa-volume-up");
256 $("#kit-header-user").on("click", ()=>{
261 $(":root section:not(#desktop-l)").on("contextmenu", function() {
262 let _ptelem = $( document.elementFromPoint(S.mouseX, S.mouseY) );
263 S.selectedElement = _ptelem;
264 S.selectedText = window.getSelection();
265 $( "#kit-context-input" ).val( S.selectedText );
266 if( $( "#kit-context-input" ).val() == "" ) $("#kit-contextgroup-text").hide();
267 else $("#kit-contextgroup-text").show();
268 if( _ptelem[0].id == "desktop-" + currentDesktop ){
269 $("#kit-contextgroup-desktop").show();
270 $("#kit-contextgroup-elem").hide();
273 $("#kit-contextgroup-desktop").hide();
274 $("#kit-contextgroup-elem").show();
276 $( "#kit-context-elem" ).text( _ptelem.prop("tagName").toLowerCase() + "要素" );
277 $("#kit-contextgroup-custom").hide();
279 let _ctxid = _ptelem.attr("data-kit-contextid");
281 $("#kit-contextgroup-custom").show().html('<div id="kit-context-custom"></div>');
282 let _ctxname = KWS.context[_ctxid].name || _ctxid;
283 $("#kit-context-custom").text( _ctxname );
284 for( let i in KWS.context[_ctxid]){
285 if( i == "name" ) continue;
286 $("#kit-contextgroup-custom").append("<a id='kit-context-" + _ctxid + "-" + i + "'><span class='fa " + KWS.context[_ctxid][i].icon + "'></span> " + KWS.context[_ctxid][i].label +"</a>");
287 $("#kit-context-" + _ctxid + "-" + i).on("click", () => {
288 KWS.context[_ctxid][i].function();
289 $("#kit-context").fadeOut(300);
293 if( _ptelem[0].id ) $( "#kit-context-elem" ).append( "#" + _ptelem[0].id );
294 $( "#kit-context-size" ).text( _ptelem[0].clientWidth + "✕" + _ptelem[0].clientHeight );
295 $("#kit-context").toggle().css("left", S.mouseX).css("top", S.mouseY);
298 $("#kit-context-open").on("click", function(){
299 S.alert("要素", S.selectedElement.clone());
301 $("#kit-context-save").on("click", function(){
302 S.obj2img( S.selectedElement , true );
304 $( "#kit-context-search" ).on("click", function(){
305 $("#kit-context").fadeOut(300);
306 launch( "browser", { "url" : "https://www.bing.com/search?q=" + $( "#kit-context-input" ).val() } );
308 $( "#kit-context-input" ).keypress( function( e ) {
309 if( e.which == 13 ) $( "#kit-context-search" ).click();
311 $("#kit-context a").on("click", function(){
312 $("#kit-context").fadeOut(300);
314 $("#kit-context-vacuum").on("click", function(){
315 for( let i in process ){
316 KWS.vacuum( S.mouseX, S.mouseY );
319 $(".window").css("transition", "none");
322 $("#kit-context-fusen").on("click", function(){
327 $("section").on("click", function(){
328 $("#kit-context").fadeOut(300);
331 $( document ).delegate( "a", "click", function() {
333 launch( localStorage.getItem( "kit-default-browser" ), { "url" : this.href } );
336 } ).on("mousemove", function(event){
337 System.mouseX = event.clientX;
338 System.mouseY = event.clientY;
339 }).delegate( ".textbox", "keypress", function( e ) {
340 if( e.which == 13 && this.id ){
341 if( $("#" + this.id + " + .kit-button").length ){
342 Notification.push("debug", this.id, "system");
343 $("#" + this.id + " + .kit-button").click();
345 else if( $("#" + this.id + " + kit-button").length ){
346 Notification.push("debug", this.id, "system");
347 $("#" + this.id + " + kit-button").click();
352 window.onresize = () => {
353 System.display.width = window.innerWidth;
354 System.display.height = window.innerWidth;
356 if( KWS.fullscreen.pid ){
357 KWS.resize( KWS.fullscreen.pid, System.display.width, System.display.height - 30 );
361 if( localStorage.getItem( "kit-lock" ) == "true" ){
363 setTimeout(() => System.lock(), 100);
367 function launch( str, args, dir ) {
369 System.args[pid] = args;
370 System.launchpath[pid] = dir || System.appdir + str;
372 if( System.appCache[str] ) {
373 if( KWS.fullscreen.pid ) KWS.unmax(KWS.fullscreen.pid);
375 appData( System.appCache[str] );
379 $.getJSON( S.launchpath[pid] + "/define.json", appData ).fail( function() {
380 System.alert( "起動エラー", "アプリケーションの起動に失敗しました<br>アプリケーション" + str + "は存在しないかアクセス権がありません(pid:" + processID + ")。ヘルプは<a class='kit-hyperlink' href='https://kitdev.home.blog/'>こちら</a>" );
384 Notification.push( "System Error", error, "system" );
389 function appData( data ) {
391 process[String( pid )] = {
393 time: System.time.obj.toLocaleString(),
397 System.appCache[data.id] = data;
398 let _taskAppend = "<span id='t" + pid + "'>";
399 if( data.icon && data.icon != "none" ) _taskAppend += "<img src='" + S.launchpath[pid] + "/" + data.icon + "'>";
400 _taskAppend += "<span id='tname" + pid + "'>" + data.name + "<span></span>";
401 $( "#tasks" ).append( _taskAppend );
403 $( "#t" + pid ).addClass( "task" ).click( function() {
404 if( $(this).hasClass("t-active") || $(this).hasClass("task-min") ) KWS.min( pid );
406 $("#w"+pid).css("z-index", KWS.windowIndex + 1);
407 KWS.refreshWindowIndex();
410 $( "#t" + pid ).addClass( "task" ).on( "mouseenter", function() {
411 $( "#task-ctx-name" ).text( data.name );
412 if( data.icon && data.icon != "none" ) $( "#task-ctx-img" ).attr( "src", System.launchpath[pid] + "/" + data.icon );
413 else $( "#task-ctx-img" ).hide();
414 $( "#task-ctx-ver" ).text( data.version + "/pid:" + pid );
415 $( "#task-ctx-info" ).off().on( "click", function() { System.appInfo( pid )} );
416 $( "#task-ctx-sshot" ).off().on( "click", function() { S.screenshot(pid, true) } );
417 $( "#task-ctx-min" ).off().on( "click", function() { KWS.min( String(pid) ) } );
418 if( $(this).hasClass("t-active") ) $( "#task-ctx-front" ).hide();
419 else $( "#task-ctx-front" ).show();
420 $( "#task-ctx-front" ).off().on( "click", function() {
421 $("#w"+pid).css("z-index", KWS.windowIndex + 1);
422 KWS.refreshWindowIndex();
424 $( "#task-ctx-close" ).off().on( "click", () => { System.close( String(pid) ) } );
425 $( "#task-ctx-kill" ).off().on( "click", () => { System.kill( String(data.id) ) } );
426 const _ctxleft = $( "#t" + pid ).offset().left;
427 const _ctxtop = window.innerHeight - $( "#t" + pid ).offset().top;
428 if( _ctxleft != $( "#task-ctx" ).offset().left ) {
429 $( "#task-ctx" ).hide();
431 $( "#task-ctx" ).css( "left", _ctxleft ).css( "bottom", _ctxtop ).show();
433 $( "section, #kit-tasks" ).on( "mouseenter", function() {
434 $( "#task-ctx" ).fadeOut( 200 );
436 $( "#t" + pid ).hover( function() {
437 prevWindowIndex = $( "#w" + pid ).css( "z-index" );
438 $( "#w" + pid ).addClass( "win-highlight" );
440 $( "#w" + pid ).removeClass( "win-highlight" );
442 let _windowAppend = "<div id='w" + pid + "'><div id='wt" + pid + "' class='wt'><i class='wmzx'><span id='wm" + pid + "'></span>";
443 if( data.support && data.support.fullscreen == true ) _windowAppend += "<span id='wz" + pid + "'></span>";
444 _windowAppend += "<span id='wx" + pid + "'></span></i>";
445 if( data.icon && data.icon != "none" ) _windowAppend += "<img src='" + S.launchpath[pid] + "/" + data.icon + "'>";
446 _windowAppend += "<span id='wtname" + pid + "'>" + data.name + "</span></div><div class='winc winc-" + data.id + "' id='winc" + pid + "'></div></div>";
447 $( "#desktop-" + currentDesktop ).append( _windowAppend );
449 if( data.support && data.support.darkmode == true ) $("#winc"+pid).addClass("winc-darkmode");
450 if( KWS.darkmode ) $("#winc"+pid).addClass("kit-darkmode");
453 $("#winc"+pid).css("width", data.size.width).css("height", data.size.height);
456 let _minwidth = 200, _minheight = 40;
457 if( data.resize.minWidth ) _minwidth = data.resize.minWidth;
458 if( data.resize.minHeight ) _minheight = data.resize.minHeight;
459 $("#winc"+pid).windowResizable({
461 minHeight: _minheight
465 var windowPos = 50 + ( pid % 10 ) * 20;
466 //$( "#w" + pid ).addClass( "window" ).draggable( {cancel: ".winc", stack: ".window"} ).css( "left", windowPos + "px" ).css( "top", windowPos + "px" ).css( "z-index", $( ".window" ).length + 1 );
468 $( "#w"+pid ).addClass( "window" ).pep({
469 elementsWithInteraction: ".winc, .ui-resizable-handle",
470 useCSSTranslation: false,
471 disableSelect: false,
473 initiate: function(){
474 $(this.el).addClass("ui-draggable-dragging");
476 this.el.style.zIndex = KWS.windowIndex;
477 KWS.refreshWindowIndex();
480 this.el.style.transition = "none";
481 $(this.el).removeClass("ui-draggable-dragging");
483 }).on( "mousedown", function(){
484 $(".window").css( "transition", "none" );
485 $(this).css("z-index", KWS.windowIndex + 1);
486 KWS.refreshWindowIndex();
487 } ).css( "left", windowPos + "px" ).css( "top", windowPos + "px" ).css( "z-index", KWS.windowIndex );
488 KWS.refreshWindowIndex();
489 $( "#wm" + pid ).addClass( "wm fa fa-window-minimize" ).click( () => KWS.min( String(pid) ) );
490 $( "#wz" + pid ).addClass( "wz fas fa-square" ).click( () => KWS.max( String(pid) ) );
491 $( "#wx" + pid ).addClass( "wx fa fa-times" ).click( () => System.close( String(pid) ) );
492 $( "#winc" + pid ).resizable( {
494 } ).load( System.launchpath[pid] + "/" + data.view, (r, s, x) =>{
496 Notification.push("起動に失敗:" + x.status, x.statusText);
499 if( !data.script || data.script != "none" ) $.getScript( System.launchpath[pid] + "/" + data.script, () => App.kaf(pid) ).fail( () => App.kaf(pid) );
501 if( data.css != "none" && $("#kit-style-"+data.id).length == 0 ){
502 $( "head" ).append( '<link href="' + System.launchpath[pid] + '/' + data.css + '" rel="stylesheet" id="kit-style-' + data.id + '"></link>' );
503 //Notification.push("debug", "新規スタイルシートの読み込み", data.id);
506 localStorage.setItem( "kit-pid", processID );
511 function close( str ) {
516 function kill( str ) {
520 const System = new function() {
521 this.version = "0.2.0";
522 this.username = localStorage.getItem("kit-username");
523 this.appdir = localStorage.getItem("kit-appdir");
525 this.bootopt = new URLSearchParams(location.search);
531 "width": window.innerWidth,
532 "height": window.innerHeight
535 this.selectedElement = null;
536 this.selectedText = null;
538 this.dom = function(_pid, ..._elems) {
540 if( !_elems.length ) q = ",#winc" + _pid;
541 else for( let i of _elems ){
542 q += ",#winc" + _pid + " " + i;
544 return $( q.substring(1) );
547 this.userarea = new Object();
548 this.recycle = new Object();
554 this.launchpath = {};
556 this.support = $.support;
557 this.debugmode = false;
561 this.log = new Array();
564 this.setBattery = function(){
565 if( navigator.getBattery ) navigator.getBattery().then((e)=>{
566 let _lv = e.level * 100;
567 System.battery = _lv;
572 this.screenshot = function( _pid, _popup ){
573 let _elem = document.querySelector("body");
574 if( _pid ) _elem = document.querySelector("#w"+_pid);
575 html2canvas( _elem ).then(canvas => {
577 canvas.style.border = "1px solid #909090";
578 S.save( canvas.toDataURL("image/png"), "image" );
584 this.obj2img = function( _obj, _popup ){
586 html2canvas( _elem ).then(canvas => {
588 canvas.style.border = "1px solid #909090";
589 S.save( canvas.toDataURL("image/png"), "image" );
595 this.save = function(data, type){
596 launch("fivr", { "save" : data, "type" : type });
599 this.open = function(filename){
600 launch("fivr", { "open" : filename });
603 this.preventClose = function( _pid ){
604 if( !process[_pid] ) return false;
605 process[_pid].preventclose = true;
609 this.shutdown = function(_opt) {
610 $( "#last-notification-close" ).click();
611 $( "#kit-power-back" ).click();
612 for( let i in process ) {
613 if( process[i].preventclose == true ){
614 S.dialog( "シャットダウンの中断", "pid" + System.appCache[process[i].id].name + "がシャットダウンを妨げています。<br>強制終了してシャットダウンを続行する場合は[OK]を押下してください。", () => {
615 process[i].preventclose = false;
620 else System.close( i );
622 $( "section" ).hide();
623 $( "body" ).css( "background-color", "black" );
624 $( "header, footer" ).fadeOut( 300 );
625 $( "#kit-wallpaper" ).fadeOut( 1500 );
626 if( _opt == "reboot" ) location.href = "autorun.html";
629 this.reboot = function() {
630 System.shutdown("reboot");
633 this.lock = function(){
634 System.moveDesktop( "l" );
636 $( "#lock-user-icon" ).css( "background", localStorage.getItem( "kit-user-color" ) );
637 $( "section, header, footer" ).css( "filter", "none" );
638 $( "#kit-wallpaper" ).css( "filter", "blur(20px)" );
639 $( "header, footer, #kit-power" ).hide();
641 $( "#lock-username" ).text( localStorage.getItem( "kit-username" ) );
642 if( localStorage.getItem( "kit-password" ) ) $( "#lock-password" ).show();
643 else $( "#lock-password" ).hide();
646 this.alert = function( title, content, winname ) {
647 launch( "alert", [title, content, winname] );
650 this.dialog = function( title, content, func ){
658 this.appInfo = function( _pid ){
659 let _title = "", _content = "";
660 let ac = System.appCache[process[_pid].id];
661 let _lp = System.launchpath[_pid];
663 _title = ac.name + " " + ac.version;
664 if( ac.icon && ac.icon != "none" ) _content = "<img style='height: 96px' src='" + _lp + "/" + ac.icon + "'><br>";
666 if( typeof ac[i] != "object" ) _content += "<div><span style='font-weight: 100'>" + i + " </span>" + ac[i] + "</div>";
668 _content += "<br><span style='font-weight: 100'>起動パス " + _lp + "</span><br><br>"
670 else _title = "取得に失敗しました";
671 System.alert( _title, _content );
674 this.installed = new Array();
677 this.min = function( _str ) {
681 this.close = function( _str ) {
682 let _pid = String( _str );
683 $( "#w" + _pid ).remove();
684 $( "#t" + _pid ).remove();
685 $( "#task-ctx" ).hide();
686 delete process[_pid];
687 KWS.refreshWindowIndex();
690 this.kill = function( _str ){
691 for( let pid in process ) {
692 if( process[pid] && process[pid].id == _str ) System.close( pid );
696 this.vacuum = function( _left, _top ){
697 KWS.vacuum( _left, _top ); //非推奨です(削除予定)。
711 this.clock = function() {
714 let Year = DD.getFullYear();
715 S.time.day = DD.getDay();
717 let Month = ( "00" + Number(DD.getMonth()+1) ).slice( -2 );
719 let DateN = ( "00" + DD.getDate() ).slice( -2 );
721 let Hour = ( "00" + DD.getHours() ).slice( -2 );
723 let Min = ( "00" + DD.getMinutes() ).slice( -2 );
725 let Sec = ( "00" + DD.getSeconds() ).slice( -2 );
727 $( ".os-time" ).text( Hour + ":" + Min + ":" + Sec );
728 let MS = DD.getMilliseconds();
731 outer: { radius: .9, color: "transparent" },
732 inner: { radius: .85, color: "transparent" }
735 long: { from: .8, to: .7, width: 2, color: "#303030" },
736 short: { from: .8, to: .75, width: 1, color: "#a0a0a0" }
739 hour: { length: .4, width: 3, cap: "butt", color: "#303030", ratio: .2 },
740 minute: { length: .67, width: 2, cap: "butt", color: "#303030", ratio: .2 },
741 second: { length: .67, width: 1, cap: "butt", color: "dodgerblue", ratio: .2 }
743 let canvas = $(".dropdown-clock-canvas")[0];
744 canvas.width = "200", canvas.height = "200";
745 let context = canvas.getContext("2d");
746 let center = { x: Math.floor(canvas.width / 2), y: Math.floor(canvas.height / 2) };
747 let radius = Math.min(center.x, center.y), angle, len;
748 context.beginPath();context.fillStyle = circle.outer.color;
749 context.arc(center.x, center.y, radius * circle.outer.radius, 0, Math.PI * 2, false);
750 context.fill();context.beginPath();context.fillStyle = circle.inner.color;
751 context.arc(center.x, center.y, radius * circle.inner.radius, 0, Math.PI * 2, false);
753 for( let i=0; i<60; i++ ){
754 angle = Math.PI * i / 30;
756 let line = ( i%5 == 0 ) ? lines.long : lines.short;
757 context.lineWidth = line.width, context.strokeStyle = line.color;
758 context.moveTo(center.x + Math.sin(angle) * radius * line.from, center.y - Math.cos(angle) * radius * line.from)
759 context.lineTo(center.x + Math.sin(angle) * radius * line.to, center.y - Math.cos(angle) * radius * line.to);
762 angle = Math.PI * ( Number(Hour)+Number(Min)/60 ) / 6, len = radius * hands.hour.length;
763 context.beginPath(), context.lineWidth = hands.hour.width;
764 context.lineCap = hands.hour.cap, context.strokeStyle = hands.hour.color;
765 context.moveTo(center.x - Math.sin(angle) * len * hands.hour.ratio, center.y + Math.cos(angle) * len * hands.hour.ratio);
766 context.lineTo(center.x + Math.sin(angle) * len, center.y - Math.cos(angle) * len), context.stroke();
767 angle = Math.PI * ( Number(Min)+Number(Sec) / 60) / 30, len = radius * hands.minute.length;
768 context.beginPath(), context.lineWidth = hands.minute.width;
769 context.lineCap = hands.minute.cap, context.strokeStyle = hands.minute.color;
770 context.moveTo(center.x - Math.sin(angle) * len * hands.minute.ratio, center.y + Math.cos(angle) * len * hands.minute.ratio);
771 context.lineTo(center.x + Math.sin(angle) * len, center.y - Math.cos(angle) * len), context.stroke();
772 angle = Math.PI * Number(Sec) / 30, len = radius * hands.second.length;
773 context.beginPath(), context.lineWidth = hands.second.width;
774 context.lineCap = hands.second.cap, context.strokeStyle = hands.second.color;
775 context.moveTo(center.x - Math.sin(angle) * len * hands.second.ratio, center.y + Math.cos(angle) * len * hands.second.ratio);
776 context.lineTo(center.x + Math.sin(angle) * len, center.y - Math.cos(angle) * len), context.stroke();
779 this.changeWallpaper = function( str ) {
780 $( "#kit-wallpaper" ).css( "background", str ).css( "background-size", "cover" );
781 localStorage.setItem( "kit-wallpaper", str )
784 this.moveDesktop = function( str ) {
786 $( "section" ).hide();
787 $( "#desktop-" + str ).show();
788 $( "#desktops" ).html( "<span class='far fa-clone'></span>Desktop" + str );
789 currentDesktop = str;
792 this.avoidMultiple = function( _pid, _alert ) {
793 let _id = process[_pid].id;
795 for( let i in process ) {
796 if( process[i].id == _id ) _cnt += 1;
798 Notification.push( "debug", _cnt );
800 System.close( _pid );
802 System.alert( "多重起動", "アプリケーション" + _id + "が既に起動しています。このアプリケーションの多重起動は許可されていません。" );
808 this.resizable = function( _pid, _elem, _width, _height ){
810 if( _elem ) E = String( _elem );
811 if( !_width ) _width = null;
812 if( !_height ) _height = "100";
813 $("#w" + _pid).resizable({
814 alsoResize: "#w" + _pid + " " + E,
820 this.initLauncher = function(data){
821 $("#launcher-apps").html("");
822 for( let i in data ){
823 $("#launcher-apps").append("<div class='launcher-app' data-launch='" + i + "'><img src='" + data[i].icon + "'>" + data[i].name + "</div>");
825 if( !System.bootopt.get("safe") ){
826 for( let i of System.installed ){
827 $("#launcher-apps").append("<div class='launcher-app' data-define-path='" + i.path + "' data-define-id='" + i.id + "'><img src='" + i.icon + "'>" + i.name + "</div>");
830 $(".launcher-app").on("click", function(){
831 $("#launch").click();
832 if( $(this).attr("data-launch") ) launch( $(this).attr("data-launch") );
833 else if( $(this).attr("data-define-path") ){
834 launch( $(this).attr("data-define-id"), null, $(this).attr("data-define-path") );
839 this.clip = new function(){
841 this.history = new Array();
843 this.set = function( content ){
844 this.content = content;
845 this.history.push(content);
848 this.get = ()=>{ return this.content }
851 this.config = new function(){
852 this.apps = new Object();
855 this.audio = new function(){
856 this.level = localStorage["kit-audio-level"] || 100;
859 this.list = new Array();
861 this.volume = function( _level ){
862 $("#dropdown-sound-slider").slider("value", _level);
865 this.play = function( _audioid, _src ){
866 if( !System.audio.list[_audioid] ){
867 System.audio.list[_audioid] = new Audio(_src);
868 System.audio.list[_audioid].volume = System.audio.level / 100;
870 System.audio.list[_audioid].play();
873 this.get = function( _audioid ){
874 return System.audio.list[_audioid];
877 this.pause = function( _audioid ){
878 System.audio.list[_audioid].pause();
881 this.stop = function( _audioid ){
882 System.audio.list[_audioid].pause();
883 System.audio.list[_audioid] = null;
886 this.seek = function( _audioid, _time ){
887 System.audio.list[_audioid].fastSeek(_time);
890 this.mute = function( _audioid, _bool ){
891 System.audio.list[_audioid].muted = _bool;
896 const KWS = new function(){
897 this.version = "3.2.2";
900 this.darkmode = false;
902 this.changeWindowTitle = function( _pid, _str ){
903 $("#tname"+_pid).text( _str );
904 $("#wtname"+_pid).text( _str );
907 this.min = function( _str ) {
908 let _pid = String( _str );
909 if( $( "#w" + _pid ).is( ":visible" ) ) {
910 $( "#w" + _pid ).css("transition", "none").hide( "drop", {direction: "down"}, 300 );
911 $( "#task-ctx" ).effect( "bounce", {distance: 12, times: 1}, 400 );
912 $( "#t" + _pid ).addClass( "task-min" );
915 $( "#w" + _pid ).show( "drop", {direction: "down"}, 300 );
916 $( "#task-ctx" ).effect( "bounce", {distance: 12, times: 1}, 400 );
917 $( "#t" + _pid ).removeClass( "task-min" );
929 this.max = function( _pid ){
930 if( KWS.fullscreen.pid ){
931 Notification.push("最大化に失敗", "最大化しているウィンドウがあります。");
934 $( "#wt"+_pid ).addClass("wtmaximize");
939 .addClass("windowmaximize")
940 .css("z-index", KWS.windowIndex + 1);
941 KWS.refreshWindowIndex();
943 KWS.fullscreen.prevWidth = $("#winc"+_pid).outerWidth();
944 KWS.fullscreen.prevHeight = $("#winc"+_pid).outerHeight();
945 KWS.fullscreen.prevTop = $("#w"+_pid).offset().top;
946 KWS.fullscreen.prevLeft = $("#w"+_pid).offset().left;
948 KWS.resize( _pid, System.display.width, System.display.height - 30 );
950 $("#kit-header-fullscreen").show().on("click", () => {
953 KWS.fullscreen.pid = _pid;
956 this.unmax = function( _pid ){
957 if( _pid != KWS.fullscreen.pid ){
958 Notification.push("最大化解除に失敗", "対象がフルスクリーンウィンドウではありません。");
961 $( "#wt"+_pid ).removeClass("wtmaximize");
963 "top": KWS.fullscreen.prevTop,
964 "left": KWS.fullscreen.prevLeft
966 .removeClass("windowmaximize");
968 $("#kit-header-fullscreen").hide().off();
969 KWS.resize( _pid, KWS.fullscreen.prevWidth, KWS.fullscreen.prevHeight );
970 KWS.fullscreen.pid = null;
971 KWS.fullscreen.prevWidth = null;
972 KWS.fullscreen.prevHeight = null;
973 KWS.fullscreen.prevTop = null;
974 KWS.fullscreen.prevLeft = null;
977 this.vacuum = function( _left, _top ){
978 for( let i in process ){
979 $("#w"+i).css("transition", ".5s all ease").css("left", _left ).css("top", _top );
982 $(".window").css("transition", "none");
987 this.windowIndex = 1;
989 this.refreshWindowIndex = function(){
990 let num = $(".window").length;
991 let array = new Array();
992 let obj = new Object();
993 for( let i = 0; i < num; i++ ){
994 obj = { id: $(".window")[i].id, zindex: $(".window")[i].style.zIndex };
997 array.sort( (a,b) => {
998 return Number(a.zindex - b.zindex);
1000 for( let i in array ){
1001 document.getElementById(array[i].id).style.zIndex = i;
1003 $("#"+array[i].id).addClass("windowactive");
1004 $("#t"+String(array[i].id).substring(1)).addClass("t-active");
1005 KWS.active = String(array[i].id).substring(1);
1006 process[array[i].id.substring(1)].isactive = true;
1009 $("#"+array[i].id).removeClass("windowactive");
1010 $("#t"+String(array[i].id).substring(1)).removeClass("t-active");
1011 process[array[i].id.substring(1)].isactive = false;
1014 KWS.windowIndex = num;
1017 this.resize = function( _pid, _width, _height ){
1018 if( _width ) $("#winc"+_pid).css("width", _width)
1019 if( _height ) $("#winc"+_pid).css("height", _height);
1022 this.fusen = new function(){
1024 this.list = new Object();
1026 this.add = function(_text){
1027 KWS.fusen.list[KWS.fusen.fid] = String(_text);
1028 $("#desktop-"+currentDesktop).append("<div class='kit-fusen' id='kit-f"+KWS.fusen.fid+"'><i class='fa fa-quote-left'></i><textarea class='kit-fusen-textarea kit-selectable' data-fid='"+KWS.fusen.fid+"' data-kit-contextid='fusen'>"+_text+"</textarea></div>");
1029 $("#kit-f"+KWS.fusen.fid).css({
1030 "left": Number(KWS.fusen.fid)*40 + 20,
1031 "top": Number(KWS.fusen.fid)*10 + 100,
1033 elementsWithInteraction: ".kit-fusen-textarea",
1034 useCSSTranslation: false,
1035 disableSelect: false,
1037 initiate: function(){
1038 $(this.el).css("ui-opacity", "0.7");
1041 this.el.style.transition = "none";
1042 $(this.el).css("ui-opacity", "1.0");
1045 $(".kit-fusen-textarea").off().on("change",function(){
1046 Notification.push($(this).attr("data-fid"), $(this).val(), "debug");
1047 KWS.fusen.list[$(this).attr("data-fid")] = $(this).val();
1048 localStorage.setItem("kit-fusen", JSON.stringify( KWS.fusen.list ));
1050 localStorage.setItem("kit-fusen", JSON.stringify( KWS.fusen.list ));
1054 this.remove = function(_fid){
1055 delete KWS.fusen.list[_fid];
1056 localStorage.setItem("kit-fusen", JSON.stringify( KWS.fusen.list ));
1057 $("#kit-f"+_fid).remove();
1061 this.addCustomContext = function( _elem, _contextid, _obj ){
1062 KWS.context[_contextid] = _obj;
1070 "icon" : "fa-trash-alt",
1071 "function" : function(){
1072 KWS.fusen.remove( S.selectedElement.attr("data-fid") );
1078 "function" : function(){
1079 KWS.fusen.add( KWS.fusen.list[S.selectedElement.attr("data-fid")] );
1086 const Notification = new function() {
1088 this.list = new Object();
1090 this.goodnight = false;
1093 this.push = function( _title, _content, _app ) {
1094 if( !System.debugmode && ( _title == "debug" || _app == "debug" ) ){
1097 this.list[this.nid] = {
1099 "content" : _content,
1101 "time" : System.time.obj.toLocaleString()
1103 if( !this.goodnight ){
1104 if( this.sound ) System.audio.play( "n" + this.nid, this.sound );
1105 $( "#last-notification-title" ).text("").text( _title );
1106 $( "#last-notification-content" ).text("").text( _content );
1107 $( "#last-notification-app" ).text("").text( _app );
1108 $( "#last-notification" ).hide().show( "drop", {direction: "right"}, 300 );
1110 $( "#notifications" ).append( "<div class='notis' id='nt" + this.nid + "'><span class='notis_close' id='nc" + this.nid + "'></span><span><span class='fas fa-comment-alt'></span>" + _title + "</span>" + _content + "<div class='notis_time'>" + System.time.obj.toLocaleString() + "</div></div>" );
1111 $("#nc" + this.nid).on("click", function(){
1112 let _nid = this.id.slice(2);
1113 $("#nt" + _nid).fadeOut(300);
1116 $("#nt" + this.nid).on("click", function(){
1117 let _nid = this.id.slice(2);
1118 if( Notification.list[ _nid ].app != "system" ){
1119 launch(Notification.list[ _nid ].app);
1123 return (this.nid - 1);
1127 const App = new function() {
1128 this.e = new Object();
1130 this.event = ( _pid, _name, _event ) => {
1131 if( !App.e[_pid] ) App.e[_pid] = new Object();
1132 App.e[_pid][_name] = _event;
1135 this.kaf = ( _pid ) => {
1136 for( let i of S.dom(_pid, ".kaf", "kaf", "[kaf]") ){
1137 if( i.hasAttribute("kit-ref") ){
1138 $(i).on("click", () => App.load(_pid, i.getAttribute("kit-ref")) );
1140 if( i.hasAttribute("kit-e") ){
1141 let _eqs = i.getAttribute("kit-e").split(",");
1142 for( let k of _eqs ){
1143 let _eq = k.split(" ");
1144 $(i).on( _eq[1]||"click", App.e[_pid][_eq[0]] );
1147 if( i.hasAttribute("kit-src") ){
1148 $(i).attr("src", System.launchpath[_pid] +"/"+ i.getAttribute("kit-ref") )
1150 if( i.hasAttribute("kit-alert") ){
1151 $(i).on("click", ()=> System.alert( System.appCache[ process[_pid].id ].name, i.getAttribute("kit-alert") ) );
1153 if( i.hasAttribute("kit-launch") ){
1154 $(i).on("click", ()=> launch( i.getAttribute("kit-launch") ) );
1156 if( i.hasAttribute("kit-close") ){
1157 $(i).on("click", ()=> System.close( i.getAttribute("kit-close") || _pid ) );
1159 if( i.hasAttribute("kit-text") ){
1160 $(i).text( eval(i.getAttribute("kit-text")) );
1162 if( i.hasAttribute("kit-html") ){
1163 $(i).html( eval(i.getAttribute("kit-html")) );
1168 this.load = ( _pid, _path ) => {
1169 S.dom(_pid).load( System.launchpath[_pid] +"/"+ _path, () => {
1174 this.preventClose = ( _pid, _bool ) => {
1175 process[_pid].preventclose = _bool || true;
1179 var process = {}, processID = 0, pid, currentDesktop = 1, currentCTX = "", prevWindowIndex, S;